[U-Boot] [PATCH 2/2] pinctrl: imx: Support i.MX7D

Peng Fan van.freenix at gmail.com
Tue Feb 2 10:00:24 CET 2016


Hi Simon,

On Mon, Feb 01, 2016 at 05:05:18PM -0700, Simon Glass wrote:
>Hi Peng,
>
>On 31 January 2016 at 22:38, Peng Fan <van.freenix at gmail.com> wrote:
>> Introudce i.MX7 pinctrl driver support.
>> For now only i.MX7D supported.
>> There are two iomux controllers in i.MX7D, iomuxc and iomuxc_lpsr.
>> To iomuxc_lpsr, ZERO_OFFSET_VALID is set, means offset of mux_reg
>> and conf_reg can begin at 0.
>>
>> Signed-off-by: Peng Fan <van.freenix at gmail.com>
>> Cc: Simon Glass <sjg at chromium.org>
>> Cc: Stefano Babic <sbabic at denx.de>
>> Cc: Fabio Estevam <fabio.estevam at nxp.com>
>> ---
>>  drivers/pinctrl/nxp/Kconfig        |  8 ++++++++
>>  drivers/pinctrl/nxp/Makefile       |  1 +
>>  drivers/pinctrl/nxp/pinctrl-imx7.c | 42 ++++++++++++++++++++++++++++++++++++++
>>  3 files changed, 51 insertions(+)
>>  create mode 100644 drivers/pinctrl/nxp/pinctrl-imx7.c
>
>Reviewed-by: Simon Glass <sjg at chromium.org>
>
>>
>> diff --git a/drivers/pinctrl/nxp/Kconfig b/drivers/pinctrl/nxp/Kconfig
>> index 2032588..a251d54 100644
>> --- a/drivers/pinctrl/nxp/Kconfig
>> +++ b/drivers/pinctrl/nxp/Kconfig
>> @@ -8,3 +8,11 @@ config PINCTRL_IMX6
>>         select PINCTRL_IMX
>>         help
>>           Say Y here to enable the imx6ul pinctrl driver
>> +
>> +config PINCTRL_IMX7
>> +       bool "IMX7 pinctrl driver"
>> +       depends on ARCH_MX7
>> +       select DEVRES
>> +       select PINCTRL_IMX
>> +       help
>> +         Say Y here to enable the imx6ul pinctrl driver
>
>Please add some help!

Will add more details in V2.

>
>> diff --git a/drivers/pinctrl/nxp/Makefile b/drivers/pinctrl/nxp/Makefile
>> index 7fd9850..0ee7f2f 100644
>> --- a/drivers/pinctrl/nxp/Makefile
>> +++ b/drivers/pinctrl/nxp/Makefile
>> @@ -1,2 +1,3 @@
>>  obj-$(CONFIG_PINCTRL_IMX)              += pinctrl-imx.o
>>  obj-$(CONFIG_PINCTRL_IMX6)             += pinctrl-imx6.o
>> +obj-$(CONFIG_PINCTRL_IMX7)             += pinctrl-imx7.o
>> diff --git a/drivers/pinctrl/nxp/pinctrl-imx7.c b/drivers/pinctrl/nxp/pinctrl-imx7.c
>> new file mode 100644
>> index 0000000..150ccf9
>> --- /dev/null
>> +++ b/drivers/pinctrl/nxp/pinctrl-imx7.c
>> @@ -0,0 +1,42 @@
>> +
>> +/*
>> + * Copyright (C) 2016 Peng Fan <van.freenix at gmail.com>
>> + *
>> + * SPDX-License-Identifier:    GPL-2.0+
>> + */
>> +
>> +#include <dm/device.h>
>> +#include <dm/pinctrl.h>
>> +
>> +#include "pinctrl-imx.h"
>> +
>> +static struct imx_pinctrl_soc_info imx7_pinctrl_soc_info;
>> +
>> +static struct imx_pinctrl_soc_info imx7_lpsr_pinctrl_soc_info = {
>> +       .flags = ZERO_OFFSET_VALID,
>> +};
>> +
>> +static int imx7_pinctrl_probe(struct udevice *dev)
>> +{
>> +       struct imx_pinctrl_soc_info *info =
>> +               (struct imx_pinctrl_soc_info *)dev_get_driver_data(dev);
>
>I think this should be platform data.

Yeah.

Thanks,
Peng.

>
>> +
>> +       return imx_pinctrl_probe(dev, info);
>> +}
>> +
>> +static const struct udevice_id imx7_pinctrl_match[] = {
>> +       { .compatible = "fsl,imx7d-iomuxc", .data = (ulong)&imx7_pinctrl_soc_info },
>> +       { .compatible = "fsl,imx7d-iomuxc-lpsr", .data = (ulong)&imx7_lpsr_pinctrl_soc_info },
>> +       { /* sentinel */ }
>> +};
>> +
>> +U_BOOT_DRIVER(imx7_pinctrl) = {
>> +       .name = "imx7-pinctrl",
>> +       .id = UCLASS_PINCTRL,
>> +       .of_match = of_match_ptr(imx7_pinctrl_match),
>> +       .probe = imx7_pinctrl_probe,
>> +       .remove = imx_pinctrl_remove,
>> +       .priv_auto_alloc_size = sizeof(struct imx_pinctrl_priv),
>> +       .ops = &imx_pinctrl_ops,
>> +       .flags = DM_FLAG_PRE_RELOC,
>> +};
>> --
>> 2.6.2
>>
>
>Regards,
>Simon


More information about the U-Boot mailing list