* Re: [PATCH 4.14 156/173] gpiolib: Respect error code of ->get_direction() [not found] ` <20180924113126.730832814@linuxfoundation.org> @ 2018-09-25 14:12 ` Jon Hunter 2018-09-25 14:42 ` Greg Kroah-Hartman 0 siblings, 1 reply; 2+ messages in thread From: Jon Hunter @ 2018-09-25 14:12 UTC (permalink / raw) To: Greg Kroah-Hartman, linux-kernel Cc: stable, Andy Shevchenko, Mika Westerberg, Linus Walleij, Sasha Levin, linux-tegra Hi Greg, On 24/09/18 12:53, Greg Kroah-Hartman wrote: > 4.14-stable review patch. If anyone has any objections, please let me know. > > ------------------ > > From: Andy Shevchenko <andriy.shevchenko@linux.intel.com> > > [ Upstream commit 36b312792b97933dc07abe074f50941199bd357c ] > > In case we try to lock GPIO pin as IRQ when something going wrong > we print a misleading message. > > Correct this by checking an error code from ->get_direction() in > gpiochip_lock_as_irq() and printing a corresponding message. > > Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> > Cc: Mika Westerberg <mika.westerberg@linux.intel.com> > Signed-off-by: Linus Walleij <linus.walleij@linaro.org> > Signed-off-by: Sasha Levin <alexander.levin@microsoft.com> > Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> > --- > drivers/gpio/gpiolib.c | 6 ++++++ > 1 file changed, 6 insertions(+) > > --- a/drivers/gpio/gpiolib.c > +++ b/drivers/gpio/gpiolib.c > @@ -2811,6 +2811,12 @@ int gpiochip_lock_as_irq(struct gpio_chi > if (!chip->can_sleep && chip->get_direction) { > int dir = chip->get_direction(chip, offset); > > + if (dir < 0) { > + chip_err(chip, "%s: cannot get GPIO direction\n", > + __func__); > + return dir; > + } > + > if (dir) > clear_bit(FLAG_IS_OUT, &desc->flags); > else This change is causing a boot regression on Tegra20 and Tegra30. After this change was merged in mainline there was a fix for Tegra [0] that was also needed. On Tegra the above change causes the allocation of GPIOs to fail and looks like this then exposes another bug somewhere else that finally leads to a system crash. If this is needed for stable, then we will need the fix for Tegra as well. Cheers Jon [0] https://lkml.org/lkml/2018/7/17/871 -- nvpublic ^ permalink raw reply [flat|nested] 2+ messages in thread
* Re: [PATCH 4.14 156/173] gpiolib: Respect error code of ->get_direction() 2018-09-25 14:12 ` [PATCH 4.14 156/173] gpiolib: Respect error code of ->get_direction() Jon Hunter @ 2018-09-25 14:42 ` Greg Kroah-Hartman 0 siblings, 0 replies; 2+ messages in thread From: Greg Kroah-Hartman @ 2018-09-25 14:42 UTC (permalink / raw) To: Jon Hunter Cc: linux-kernel, stable, Andy Shevchenko, Mika Westerberg, Linus Walleij, Sasha Levin, linux-tegra On Tue, Sep 25, 2018 at 03:12:13PM +0100, Jon Hunter wrote: > Hi Greg, > > On 24/09/18 12:53, Greg Kroah-Hartman wrote: > > 4.14-stable review patch. If anyone has any objections, please let me know. > > > > ------------------ > > > > From: Andy Shevchenko <andriy.shevchenko@linux.intel.com> > > > > [ Upstream commit 36b312792b97933dc07abe074f50941199bd357c ] > > > > In case we try to lock GPIO pin as IRQ when something going wrong > > we print a misleading message. > > > > Correct this by checking an error code from ->get_direction() in > > gpiochip_lock_as_irq() and printing a corresponding message. > > > > Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> > > Cc: Mika Westerberg <mika.westerberg@linux.intel.com> > > Signed-off-by: Linus Walleij <linus.walleij@linaro.org> > > Signed-off-by: Sasha Levin <alexander.levin@microsoft.com> > > Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> > > --- > > drivers/gpio/gpiolib.c | 6 ++++++ > > 1 file changed, 6 insertions(+) > > > > --- a/drivers/gpio/gpiolib.c > > +++ b/drivers/gpio/gpiolib.c > > @@ -2811,6 +2811,12 @@ int gpiochip_lock_as_irq(struct gpio_chi > > if (!chip->can_sleep && chip->get_direction) { > > int dir = chip->get_direction(chip, offset); > > > > + if (dir < 0) { > > + chip_err(chip, "%s: cannot get GPIO direction\n", > > + __func__); > > + return dir; > > + } > > + > > if (dir) > > clear_bit(FLAG_IS_OUT, &desc->flags); > > else > > This change is causing a boot regression on Tegra20 and Tegra30. After > this change was merged in mainline there was a fix for Tegra [0] that > was also needed. > > On Tegra the above change causes the allocation of GPIOs to fail and > looks like this then exposes another bug somewhere else that finally > leads to a system crash. > > If this is needed for stable, then we will need the fix for Tegra as well. Thanks, I've just dropped this from all of the queues, no need to cause more problems. greg k-h ^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2018-09-25 14:42 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20180924113114.334025954@linuxfoundation.org>
[not found] ` <20180924113126.730832814@linuxfoundation.org>
2018-09-25 14:12 ` [PATCH 4.14 156/173] gpiolib: Respect error code of ->get_direction() Jon Hunter
2018-09-25 14:42 ` Greg Kroah-Hartman
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).