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