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