On Thu, Nov 28, 2013 at 1:47 AM, Rhyland Klein <rklein@xxxxxxxxxx> wrote: > On 11/26/2013 5:05 AM, Mika Westerberg wrote: >> From: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> >> >> This makes it possible to request the gpio descriptors in >> rfkill_gpio driver regardless of the platform. >> >> Signed-off-by: Heikki Krogerus <heikki.krogerus@xxxxxxxxxxxxxxx> >> Signed-off-by: Mika Westerberg <mika.westerberg@xxxxxxxxxxxxxxx> >> Tested-by: Stephen Warren <swarren@xxxxxxxxxx> >> --- >> arch/arm/mach-tegra/board-paz00.c | 7 +++++++ >> 1 file changed, 7 insertions(+) >> >> diff --git a/arch/arm/mach-tegra/board-paz00.c b/arch/arm/mach-tegra/board-paz00.c >> index 06f024070dab..a309795da665 100644 >> --- a/arch/arm/mach-tegra/board-paz00.c >> +++ b/arch/arm/mach-tegra/board-paz00.c >> @@ -18,6 +18,7 @@ >> */ >> >> #include <linux/platform_device.h> >> +#include <linux/gpio/driver.h> >> #include <linux/rfkill-gpio.h> >> #include "board.h" >> >> @@ -36,7 +37,13 @@ static struct platform_device wifi_rfkill_device = { >> }, >> }; >> >> +static struct gpiod_lookup wifi_gpio_lookup[] = { >> + GPIO_LOOKUP_IDX("tegra-gpio", 25, "rfkill_gpio", NULL, 0, 0), >> + GPIO_LOOKUP_IDX("tegra-gpio", 85, "rfkill_gpio", NULL, 1, 0), >> +}; > > I wouldn't think this table would match for the gpios as the driver > currently is. From what I see, the driver calls into gpiod_get_index, > which will try 1 of 3 ways of getting the gpios: > > of-enabled: of_find_gpio > - which I believe wouldn't work for paz00, since rfkill > doesn't support dt? > acpi: acpi_find_gpio > - I assume this does work, but I didn't dive into it > gpiod lookup table: gpiod_find > - I think this is the path we expect to be taken, given the addition of > the lookup table here, but I don't think it would actually match. > Looking at the code for gpiod_find, it seems like it would try to match > the con_id, but would fail. Patch 2/6 is passing the reset_name and > shutdown_name for the con_ids, which isn't what is registered in this > table. > > Shouldn't it look more like this? > > +static struct gpiod_lookup wifi_gpio_lookup[] = { > + GPIO_LOOKUP_IDX("tegra-gpio", 25, "rfkill_gpio_reset", NULL, 0, 0), > + GPIO_LOOKUP_IDX("tegra-gpio", 85, "rfkill_gpio_shutdown", NULL, 1, 0), > +}; The original GPIO lookup table specifies the device name ("rfkill_gpio"), no con_id, and an index. gpiod_find() will ensure that the device names match, skip the con_id (as it is null in the table), and again require that the indexes are the same. So provided the instanciated device's dev_name() is "rfkill_gpio" (which it seems to be according to the driver - not sure if it could become "rfkill_gpio.0"), then I'd say the GPIOs will match. The con_id passed to gpiod_get() will only be used as a label for debugfs. I am not sure where the "rfkill_gpio_reset" you mention comes from? One could wonder why the names of the GPIO are not hardcoded in the driver instead of being defined as platform data, but that point could be improved in a future patch. It is true however that the platform GPIO lookup mechanism is confusing at best, on top of being inefficient (one big linked list). I have a patch in the pipe that should improve both points by making GPIO lookup tables defined per-device - don't hesitate to merge this series first if it works though. Alex. -- To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html