1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * Copyright (C) 2016 Freescale Semiconductor, Inc.
4  *
5  * Peng Fan <peng.fan@nxp.com>
6  */
7 
8 #include <dm.h>
9 #include <dm/pinctrl.h>
10 
11 #include "pinctrl-imx.h"
12 
13 static struct imx_pinctrl_soc_info imx7ulp_pinctrl_soc_info0 = {
14 	.flags = ZERO_OFFSET_VALID | SHARE_MUX_CONF_REG | CFG_IBE_OBE,
15 };
16 
17 static struct imx_pinctrl_soc_info imx7ulp_pinctrl_soc_info1 = {
18 	.flags = ZERO_OFFSET_VALID | SHARE_MUX_CONF_REG | CFG_IBE_OBE,
19 };
20 
21 static const struct udevice_id imx7ulp_pinctrl_match[] = {
22 	{ .compatible = "fsl,imx7ulp-iomuxc-0", .data = (ulong)&imx7ulp_pinctrl_soc_info0 },
23 	{ .compatible = "fsl,imx7ulp-iomuxc-1", .data = (ulong)&imx7ulp_pinctrl_soc_info1 },
24 	{ /* sentinel */ }
25 };
26 
27 static const struct pinctrl_ops imx7ulp_pinctrl_ops = {
28 	.set_state = imx_pinctrl_set_state_mmio,
29 };
30 
31 U_BOOT_DRIVER(imx7ulp_pinctrl) = {
32 	.name = "imx7ulp-pinctrl",
33 	.id = UCLASS_PINCTRL,
34 	.of_match = of_match_ptr(imx7ulp_pinctrl_match),
35 	.probe = imx_pinctrl_probe_mmio,
36 	.remove = imx_pinctrl_remove_mmio,
37 	.priv_auto	= sizeof(struct imx_pinctrl_priv),
38 	.ops = &imx7ulp_pinctrl_ops,
39 	.flags = DM_FLAG_PRE_RELOC,
40 };
41