14aa9d4d0SPeng Fan /* 24aa9d4d0SPeng Fan * Copyright (C) 2016 Freescale Semiconductor, Inc. 34aa9d4d0SPeng Fan * 44aa9d4d0SPeng Fan * Peng Fan <peng.fan@nxp.com> 54aa9d4d0SPeng Fan * 64aa9d4d0SPeng Fan * SPDX-License-Identifier: GPL-2.0+ 74aa9d4d0SPeng Fan */ 84aa9d4d0SPeng Fan 9*4af0d7e8SSimon Glass #include <common.h> 109d922450SSimon Glass #include <dm.h> 114aa9d4d0SPeng Fan #include <dm/pinctrl.h> 124aa9d4d0SPeng Fan 134aa9d4d0SPeng Fan #include "pinctrl-imx.h" 144aa9d4d0SPeng Fan 154aa9d4d0SPeng Fan static struct imx_pinctrl_soc_info imx7ulp_pinctrl_soc_info = { 164aa9d4d0SPeng Fan .flags = ZERO_OFFSET_VALID | SHARE_MUX_CONF_REG | CONFIG_IBE_OBE, 174aa9d4d0SPeng Fan }; 184aa9d4d0SPeng Fan 194aa9d4d0SPeng Fan static int imx7ulp_pinctrl_probe(struct udevice *dev) 204aa9d4d0SPeng Fan { 214aa9d4d0SPeng Fan struct imx_pinctrl_soc_info *info = 224aa9d4d0SPeng Fan (struct imx_pinctrl_soc_info *)dev_get_driver_data(dev); 234aa9d4d0SPeng Fan 244aa9d4d0SPeng Fan return imx_pinctrl_probe(dev, info); 254aa9d4d0SPeng Fan } 264aa9d4d0SPeng Fan 274aa9d4d0SPeng Fan static const struct udevice_id imx7ulp_pinctrl_match[] = { 284aa9d4d0SPeng Fan { .compatible = "fsl,imx7ulp-iomuxc-0", .data = (ulong)&imx7ulp_pinctrl_soc_info }, 294aa9d4d0SPeng Fan { .compatible = "fsl,imx7ulp-iomuxc-1", .data = (ulong)&imx7ulp_pinctrl_soc_info }, 304aa9d4d0SPeng Fan { /* sentinel */ } 314aa9d4d0SPeng Fan }; 324aa9d4d0SPeng Fan 334aa9d4d0SPeng Fan U_BOOT_DRIVER(imx7ulp_pinctrl) = { 344aa9d4d0SPeng Fan .name = "imx7ulp-pinctrl", 354aa9d4d0SPeng Fan .id = UCLASS_PINCTRL, 364aa9d4d0SPeng Fan .of_match = of_match_ptr(imx7ulp_pinctrl_match), 374aa9d4d0SPeng Fan .probe = imx7ulp_pinctrl_probe, 384aa9d4d0SPeng Fan .remove = imx_pinctrl_remove, 394aa9d4d0SPeng Fan .priv_auto_alloc_size = sizeof(struct imx_pinctrl_priv), 404aa9d4d0SPeng Fan .ops = &imx_pinctrl_ops, 414aa9d4d0SPeng Fan .flags = DM_FLAG_PRE_RELOC, 424aa9d4d0SPeng Fan }; 43