* [PATCH] pinctrl: sunxi: Honor GPIO output initial vaules @ 2014-01-14 14:50 Chen-Yu Tsai [not found] ` <000001cf1189$fc0f8120$f42e8360$@gmail.com> 0 siblings, 1 reply; 4+ messages in thread From: Chen-Yu Tsai @ 2014-01-14 14:50 UTC (permalink / raw) To: linux-arm-kernel Some GPIO users, such as fixed-regulator, request GPIO output with initial value of 1. This was ignored by sunxi driver. Signed-off-by: Chen-Yu Tsai <wens@csie.org> --- drivers/pinctrl/pinctrl-sunxi.c | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/drivers/pinctrl/pinctrl-sunxi.c b/drivers/pinctrl/pinctrl-sunxi.c index 119d2dd..fc72d10 100644 --- a/drivers/pinctrl/pinctrl-sunxi.c +++ b/drivers/pinctrl/pinctrl-sunxi.c @@ -469,12 +469,6 @@ static int sunxi_pinctrl_gpio_get(struct gpio_chip *chip, unsigned offset) return val; } -static int sunxi_pinctrl_gpio_direction_output(struct gpio_chip *chip, - unsigned offset, int value) -{ - return pinctrl_gpio_direction_output(chip->base + offset); -} - static void sunxi_pinctrl_gpio_set(struct gpio_chip *chip, unsigned offset, int value) { @@ -498,6 +492,17 @@ static void sunxi_pinctrl_gpio_set(struct gpio_chip *chip, spin_unlock_irqrestore(&pctl->lock, flags); } +static int sunxi_pinctrl_gpio_direction_output(struct gpio_chip *chip, + unsigned offset, int value) +{ + int ret = pinctrl_gpio_direction_output(chip->base + offset); + + if (ret == 0) + sunxi_pinctrl_gpio_set(chip, offset, value); + + return ret; +} + static int sunxi_pinctrl_gpio_of_xlate(struct gpio_chip *gc, const struct of_phandle_args *gpiospec, u32 *flags) -- 1.8.5.2 ^ permalink raw reply related [flat|nested] 4+ messages in thread
[parent not found: <000001cf1189$fc0f8120$f42e8360$@gmail.com>]
* [linux-sunxi] [PATCH] pinctrl: sunxi: Honor GPIO output initial vaules [not found] ` <000001cf1189$fc0f8120$f42e8360$@gmail.com> @ 2014-01-15 8:21 ` Chen-Yu Tsai 2014-01-15 10:02 ` Maxime Ripard 0 siblings, 1 reply; 4+ messages in thread From: Chen-Yu Tsai @ 2014-01-15 8:21 UTC (permalink / raw) To: linux-arm-kernel Hi, On Wed, Jan 15, 2014 at 8:37 AM, Ma Haijun <mahaijuns@gmail.com> wrote: > Hi, > > I think it is better to set the output value first to avoid glitch. If I understand the user manual correctly, setting the output value before changing the pin to output function first will have no effect. And it is not possible to set the function and the value at the same time, as they are in different registers. Cheers, ChenYu > Regards, > > Ma > >> -----Original Message----- >> From: linux-sunxi at googlegroups.com [mailto:linux-sunxi at googlegroups.com] >> On Behalf Of Chen-Yu Tsai >> Sent: Tuesday, January 14, 2014 10:50 PM >> To: Maxime Ripard >> Cc: Chen-Yu Tsai; linux-arm-kernel; linux-sunxi; Linus Walleij >> Subject: [linux-sunxi] [PATCH] pinctrl: sunxi: Honor GPIO output initial > vaules >> >> Some GPIO users, such as fixed-regulator, request GPIO output with initial >> value of 1. This was ignored by sunxi driver. >> >> Signed-off-by: Chen-Yu Tsai <wens@csie.org> >> --- >> drivers/pinctrl/pinctrl-sunxi.c | 17 +++++++++++------ >> 1 file changed, 11 insertions(+), 6 deletions(-) >> >> diff --git a/drivers/pinctrl/pinctrl-sunxi.c > b/drivers/pinctrl/pinctrl-sunxi.c index >> 119d2dd..fc72d10 100644 >> --- a/drivers/pinctrl/pinctrl-sunxi.c >> +++ b/drivers/pinctrl/pinctrl-sunxi.c >> @@ -469,12 +469,6 @@ static int sunxi_pinctrl_gpio_get(struct gpio_chip >> *chip, unsigned offset) >> return val; >> } >> >> -static int sunxi_pinctrl_gpio_direction_output(struct gpio_chip *chip, >> - unsigned offset, int value) >> -{ >> - return pinctrl_gpio_direction_output(chip->base + offset); >> -} >> - >> static void sunxi_pinctrl_gpio_set(struct gpio_chip *chip, >> unsigned offset, int value) >> { >> @@ -498,6 +492,17 @@ static void sunxi_pinctrl_gpio_set(struct gpio_chip >> *chip, >> spin_unlock_irqrestore(&pctl->lock, flags); } >> >> +static int sunxi_pinctrl_gpio_direction_output(struct gpio_chip *chip, >> + unsigned offset, int value) >> +{ >> + int ret = pinctrl_gpio_direction_output(chip->base + offset); >> + >> + if (ret == 0) >> + sunxi_pinctrl_gpio_set(chip, offset, value); >> + >> + return ret; >> +} >> + >> static int sunxi_pinctrl_gpio_of_xlate(struct gpio_chip *gc, >> const struct of_phandle_args *gpiospec, >> u32 *flags) >> -- >> 1.8.5.2 >> ^ permalink raw reply [flat|nested] 4+ messages in thread
* [linux-sunxi] [PATCH] pinctrl: sunxi: Honor GPIO output initial vaules 2014-01-15 8:21 ` [linux-sunxi] " Chen-Yu Tsai @ 2014-01-15 10:02 ` Maxime Ripard 2014-01-15 13:10 ` Chen-Yu Tsai 0 siblings, 1 reply; 4+ messages in thread From: Maxime Ripard @ 2014-01-15 10:02 UTC (permalink / raw) To: linux-arm-kernel Hi Chen-Yu, Nice catch :) On Wed, Jan 15, 2014 at 04:21:12PM +0800, Chen-Yu Tsai wrote: > Hi, > > On Wed, Jan 15, 2014 at 8:37 AM, Ma Haijun <mahaijuns@gmail.com> wrote: > > Hi, > > > > I think it is better to set the output value first to avoid glitch. > > If I understand the user manual correctly, setting the output value > before changing the pin to output function first will have no effect. I just tested it on my A31, and it is working as expected (the output value isn't output until the direction is changed). It would be great if you could test this as well on your device, and change it like suggested. Thanks! Maxime -- Maxime Ripard, Free Electrons Embedded Linux, Kernel and Android engineering http://free-electrons.com -------------- next part -------------- A non-text attachment was scrubbed... Name: signature.asc Type: application/pgp-signature Size: 836 bytes Desc: Digital signature URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20140115/b83fc452/attachment.sig> ^ permalink raw reply [flat|nested] 4+ messages in thread
* [linux-sunxi] [PATCH] pinctrl: sunxi: Honor GPIO output initial vaules 2014-01-15 10:02 ` Maxime Ripard @ 2014-01-15 13:10 ` Chen-Yu Tsai 0 siblings, 0 replies; 4+ messages in thread From: Chen-Yu Tsai @ 2014-01-15 13:10 UTC (permalink / raw) To: linux-arm-kernel Hi, On Wed, Jan 15, 2014 at 6:02 PM, Maxime Ripard <maxime.ripard@free-electrons.com> wrote: > Hi Chen-Yu, > > Nice catch :) > > On Wed, Jan 15, 2014 at 04:21:12PM +0800, Chen-Yu Tsai wrote: >> Hi, >> >> On Wed, Jan 15, 2014 at 8:37 AM, Ma Haijun <mahaijuns@gmail.com> wrote: >> > Hi, >> > >> > I think it is better to set the output value first to avoid glitch. >> >> If I understand the user manual correctly, setting the output value >> before changing the pin to output function first will have no effect. > > I just tested it on my A31, and it is working as expected (the output > value isn't output until the direction is changed). > > It would be great if you could test this as well on your device, and > change it like suggested. Tested on A20, works as you described. Output value is queued and changed when pin function is changed to output. I will rearrange the function calls and resend. Cheers ChenYu ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2014-01-15 13:10 UTC | newest] Thread overview: 4+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-01-14 14:50 [PATCH] pinctrl: sunxi: Honor GPIO output initial vaules Chen-Yu Tsai [not found] ` <000001cf1189$fc0f8120$f42e8360$@gmail.com> 2014-01-15 8:21 ` [linux-sunxi] " Chen-Yu Tsai 2014-01-15 10:02 ` Maxime Ripard 2014-01-15 13:10 ` Chen-Yu Tsai
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).