Re: [PATCH v1 4/8] gpio: acpi: Even more tighten up ACPI GPIO lookups

From: Andy Shevchenko
Date: Tue Mar 28 2017 - 12:33:39 EST


On Thu, 2017-03-23 at 13:12 -0700, Dmitry Torokhov wrote:
> On Thu, Mar 23, 2017 at 09:46:14PM +0200, Andy Shevchenko wrote:
> > The commit 10cf4899f8af ("gpiolib: tighten up ACPI legacy gpio
> > lookups")
> > prevents to getting same resource twice if the driver asks twice
> > using same
>
> s/same/different/
>
> > connection ID.

Oh, yeah, though it didn't fix a potential issue described below.

> > But the whole idea of fallback might bring some problems. Imagine
> > the case when
> > we have two versions of BIOS/hardware where in one _DSD is
> > introduced along
> > with GPIO resources, but the other one uses just plain GPIO resource
> > for
> > another purpose
> >
> > Case 1:
> >
> > ÂÂÂÂDevice (DEVX)
> > ÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂ...
> > ÂÂÂÂÂÂÂÂName (_CRS, ResourceTemplate ()
> > ÂÂÂÂÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂÂÂÂÂGpioIo (Exclusive, PullUp, 0, 0, IoRestrictionInputOnly,
> > ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ"\\_SB.GPO0", 0, ResourceConsumer) {15}
> > ÂÂÂÂÂÂÂÂ})
> > ÂÂÂÂÂÂÂÂName (_DSD, Package ()
> > ÂÂÂÂÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂÂÂÂÂToUUID("daffd814-6eba-4d8c-8a91-bc9bbf4aa301"),
> > ÂÂÂÂÂÂÂÂÂÂÂÂPackage ()
> > ÂÂÂÂÂÂÂÂÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂPackage () {"some-gpios", Package() {^DEVX, 0, 0, 0
> > }},
> > ÂÂÂÂÂÂÂÂÂÂÂÂ}
> > ÂÂÂÂÂÂÂÂ})
> > ÂÂÂÂ}
> >
> > Case 2:
> >
> > ÂÂÂÂDevice (DEVX)
> > ÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂ...
> > ÂÂÂÂÂÂÂÂName (_CRS, ResourceTemplate ()
> > ÂÂÂÂÂÂÂÂ{
> > ÂÂÂÂÂÂÂÂÂÂÂÂGpioIo (Exclusive, PullUp, 0, 0, IoRestrictionInputOnly,
> > ÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂÂ"\\_SB.GPO0", 0, ResourceConsumer) {27}
> > ÂÂÂÂÂÂÂÂ})
> > ÂÂÂÂ}
> >
> > To prevent the possible misconfiguration tighten up even more ACPI
> > GPIO lookups
> > for case without connection ID provided.

> I wonder if this will break Goodix. Irina, Bastien?

It would be helpful if anyone can test it.

Btw, which particular driver do you have in mind that might be broken
after such change? Ah, Goodix is a vendor of touchscreens, right?

I'm going through drivers which are using ACPI enumeration and
gpiod_get() API to create mapping tables. I didn't touch drivers/input/
folder yet.

So, potential problems might be there:

drivers/input/touchscreen/elants_i2c.c
drivers/input/touchscreen/goodix.c
drivers/input/touchscreen/melfas_mip4.c
drivers/input/touchscreen/raydium_i2c_ts.c
drivers/input/touchscreen/silead.c
drivers/input/touchscreen/surface3_spi.c

(except silead which Hans tested few times)

> > In the past the issue had been triggered by "use mctrl_gpio helpers"
> > series
> > [1,2].
> >
> > Besides above, removal of the main logic of
> > acpi_can_fallback_to_crs()
> > eliminates a potential memory leak when the same device has been
> > unbound and
> > bound again.
>
> Where? We'll reuse lookup table as ACPI device is still the same.

I used to have issues with unbind/bind cycle with pointer to struct
device * (IIRC platform device), but you probably right since pointer to
struct acpi_device is used here in your change.

I will remove this paragraph from commit message.

Thanks for review!

--
Andy Shevchenko <andriy.shevchenko@xxxxxxxxxxxxxxx>
Intel Finland Oy