Re: [PATCH V4 5/7] pinctrl: imx: remove gpio_request_enable and gpio_disable_free

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On 2017-06-21 04:59, Dong Aisheng wrote:
> gpio_request_enable/disable_free actually are not quite necessary as
> standard IMX pinctrl binding already sets GPIO mux from device tree,
> e.g. VF610_PAD_PTB20__GPIO_42 or MX7D_PAD_SD2_CD_B__GPIO5_IO9
> No need to do it again in gpio_request_enable.
> 
> And according to Stefan:
> "For all GPIO I checked in upstream device trees we assign a pinctrl
> to the same node, so in all cases gpio_request_enable/disable is really
> unnecessary."
> 
> So it should be safe to simply remove it.

Thanks looks good.

I would add a comment that this changes semantics for Vybrid, e.g.

"The two functions have been introduced for Vybrid (through
SHARE_MUX_CONF_REG) and mux pins as GPIOs automatically when a GPIO gets
requested. The automatic mux is optional by the pinmux/gpio subsystem
semantics, and other NXP devices do not use it, instead an explicit
pinctrl node is added in the device tree to mux GPIOs where required.
Hence this change aligns Vybrid to other NXP (i.MX) devices.

Note that all upstream device tree assign proper pinctrl properties
where GPIOs are used so no change is necessary for device trees."

Otherwise:
Acked-by: Stefan Agner <stefan@xxxxxxxx>

--
Stefan

> 
> Cc: Stefan Agner <stefan@xxxxxxxx>
> Cc: Linus Walleij <linus.walleij@xxxxxxxxxx>
> Cc: Alexandre Courbot <gnurou@xxxxxxxxx>
> Cc: Shawn Guo <shawnguo@xxxxxxxxxx>
> Cc: Fugang Duan <fugang.duan@xxxxxxx>
> Cc: Bai Ping <ping.bai@xxxxxxx>
> Signed-off-by: Dong Aisheng <aisheng.dong@xxxxxxx>
> 
> ---
> ChangeLog:
>  * New patch.
>    Instead of fixing gpio_request_enable/disable, we decided to remove it
>    after dicussion with Stefan (see blow).
>    https://www.spinics.net/lists/arm-kernel/msg583154.html
> ---
>  drivers/pinctrl/freescale/pinctrl-imx.c | 69 ---------------------------------
>  1 file changed, 69 deletions(-)
> 
> diff --git a/drivers/pinctrl/freescale/pinctrl-imx.c
> b/drivers/pinctrl/freescale/pinctrl-imx.c
> index fc1ba3c..505fe79 100644
> --- a/drivers/pinctrl/freescale/pinctrl-imx.c
> +++ b/drivers/pinctrl/freescale/pinctrl-imx.c
> @@ -255,73 +255,6 @@ static int imx_pmx_set(struct pinctrl_dev
> *pctldev, unsigned selector,
>  	return 0;
>  }
>  
> -static int imx_pmx_gpio_request_enable(struct pinctrl_dev *pctldev,
> -			struct pinctrl_gpio_range *range, unsigned offset)
> -{
> -	struct imx_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
> -	struct imx_pinctrl_soc_info *info = ipctl->info;
> -	const struct imx_pin_reg *pin_reg;
> -	struct group_desc *grp;
> -	struct imx_pin *imx_pin;
> -	unsigned int pin, group;
> -	u32 reg;
> -
> -	/* Currently implementation only for shared mux/conf register */
> -	if (!(info->flags & SHARE_MUX_CONF_REG))
> -		return 0;
> -
> -	pin_reg = &info->pin_regs[offset];
> -	if (pin_reg->mux_reg == -1)
> -		return -EINVAL;
> -
> -	/* Find the pinctrl config with GPIO mux mode for the requested pin */
> -	for (group = 0; group < pctldev->num_groups; group++) {
> -		grp = pinctrl_generic_get_group(pctldev, group);
> -		if (!grp)
> -			continue;
> -		for (pin = 0; pin < grp->num_pins; pin++) {
> -			imx_pin = &((struct imx_pin *)(grp->data))[pin];
> -			if (imx_pin->pin == offset && !imx_pin->mux_mode)
> -				goto mux_pin;
> -		}
> -	}
> -
> -	return -EINVAL;
> -
> -mux_pin:
> -	reg = readl(ipctl->base + pin_reg->mux_reg);
> -	reg &= ~info->mux_mask;
> -	reg |= imx_pin->config;
> -	writel(reg, ipctl->base + pin_reg->mux_reg);
> -
> -	return 0;
> -}
> -
> -static void imx_pmx_gpio_disable_free(struct pinctrl_dev *pctldev,
> -			struct pinctrl_gpio_range *range, unsigned offset)
> -{
> -	struct imx_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
> -	struct imx_pinctrl_soc_info *info = ipctl->info;
> -	const struct imx_pin_reg *pin_reg;
> -	u32 reg;
> -
> -	/*
> -	 * Only Vybrid has the input/output buffer enable flags (IBE/OBE)
> -	 * They are part of the shared mux/conf register.
> -	 */
> -	if (!(info->flags & SHARE_MUX_CONF_REG))
> -		return;
> -
> -	pin_reg = &info->pin_regs[offset];
> -	if (pin_reg->mux_reg == -1)
> -		return;
> -
> -	/* Clear IBE/OBE/PUE to disable the pin (Hi-Z) */
> -	reg = readl(ipctl->base + pin_reg->mux_reg);
> -	reg &= ~0x7;
> -	writel(reg, ipctl->base + pin_reg->mux_reg);
> -}
> -
>  static int imx_pmx_gpio_set_direction(struct pinctrl_dev *pctldev,
>  	   struct pinctrl_gpio_range *range, unsigned offset, bool input)
>  {
> @@ -357,8 +290,6 @@ static const struct pinmux_ops imx_pmx_ops = {
>  	.get_function_name = pinmux_generic_get_function_name,
>  	.get_function_groups = pinmux_generic_get_function_groups,
>  	.set_mux = imx_pmx_set,
> -	.gpio_request_enable = imx_pmx_gpio_request_enable,
> -	.gpio_disable_free = imx_pmx_gpio_disable_free,
>  	.gpio_set_direction = imx_pmx_gpio_set_direction,
>  };
--
To unsubscribe from this list: send the line "unsubscribe linux-gpio" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux SPI]     [Linux Kernel]     [Linux ARM (vger)]     [Linux ARM MSM]     [Linux Omap]     [Linux Arm]     [Linux Tegra]     [Fedora ARM]     [Linux for Samsung SOC]     [eCos]     [Linux Fastboot]     [Gcc Help]     [Git]     [DCCP]     [IETF Announce]     [Security]     [Linux MIPS]     [Yosemite Campsites]

  Powered by Linux