* [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
@ 2015-11-05 19:38 Dmitry Torokhov
2015-11-05 21:00 ` kbuild test robot
` (3 more replies)
0 siblings, 4 replies; 7+ messages in thread
From: Dmitry Torokhov @ 2015-11-05 19:38 UTC (permalink / raw)
To: Linus Walleij
Cc: Alexandre Courbot, Johan Hovold, Rafael J. Wysocki,
mika.westerberg, Tirdea, Irina, linux-gpio, linux-kernel
We should not fall back to the legacy unnamed gpio lookup style if the
driver requests gpios with different names, because we'll give out the same
gpio twice. Let's keep track of the names that were used for the device and
only do the fallback for the first name used.
Also disable fallback to _CRS gpios if ACPI device has DT-like
properties or driver-supplied gpio mappings.
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
---
This version incorporates changes suggested by Mika Westerberg in
response to the draft patch I posted in Goodix thread.
drivers/gpio/gpiolib.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 47 insertions(+)
diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
index a18f00f..9631ee8 100644
--- a/drivers/gpio/gpiolib.c
+++ b/drivers/gpio/gpiolib.c
@@ -1841,6 +1841,50 @@ static struct gpio_desc *of_find_gpio(struct device *dev, const char *con_id,
return desc;
}
+struct acpi_gpio_lookup {
+ struct list_head node;
+ struct acpi_device *adev;
+ const char *con_id;
+};
+
+static DEFINE_MUTEX(acpi_gpio_lookup_lock);
+static LIST_HEAD(acpi_gpio_lookup_list);
+
+static bool acpi_can_fallback_to_crs(struct acpi_device *adev,
+ const char *con_id)
+{
+ struct acpi_gpio_lookup *l, *lookup = NULL;
+
+ /* Never fallback if the device has properties */
+ if (adev->data.properties || adev->driver_gpios)
+ return false;
+
+ mutex_lock(&acpi_gpio_lookup_lock);
+
+ list_for_each_entry(l, &acpi_gpio_lookup_list, node) {
+ if (l->adev == adev) {
+ lookup = l;
+ break;
+ }
+ }
+
+ if (!lookup) {
+ lookup = kmalloc(sizeof(*lookup), GFP_KERNEL);
+ if (lookup) {
+ lookup->adev = adev;
+ lookup->con_id = con_id;
+ list_add_tail(&lookup->node, &acpi_gpio_lookup_list);
+ }
+ }
+
+ mutex_unlock(&acpi_gpio_lookup_lock);
+
+ return lookup &&
+ ((!lookup->con_id && !con_id) ||
+ (lookup->con_id && con_id &&
+ strcmp(lookup->con_id, con_id) == 0));
+}
+
static struct gpio_desc *acpi_find_gpio(struct device *dev, const char *con_id,
unsigned int idx,
enum gpio_lookup_flags *flags)
@@ -1868,6 +1912,9 @@ static struct gpio_desc *acpi_find_gpio(struct device *dev, const char *con_id,
/* Then from plain _CRS GPIOs */
if (IS_ERR(desc)) {
+ if (!acpi_can_fallback_to_crs(adev, con_id))
+ return ERR_PTR(-ENOENT);
+
desc = acpi_get_gpiod_by_index(adev, NULL, idx, &info);
if (IS_ERR(desc))
return desc;
--
2.6.0.rc2.230.g3dd15c0
--
Dmitry
^ permalink raw reply related [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-05 19:38 [PATCH] gpiolib: tighten up ACPI legacy gpio lookups Dmitry Torokhov
@ 2015-11-05 21:00 ` kbuild test robot
2015-11-05 21:02 ` kbuild test robot
` (2 subsequent siblings)
3 siblings, 0 replies; 7+ messages in thread
From: kbuild test robot @ 2015-11-05 21:00 UTC (permalink / raw)
To: Dmitry Torokhov
Cc: kbuild-all, Linus Walleij, Alexandre Courbot, Johan Hovold,
Rafael J. Wysocki, mika.westerberg, Tirdea, Irina, linux-gpio,
linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1444 bytes --]
Hi Dmitry,
[auto build test ERROR on: gpio/for-next]
[also build test ERROR on: v4.3 next-20151105]
url: https://github.com/0day-ci/linux/commits/Dmitry-Torokhov/gpiolib-tighten-up-ACPI-legacy-gpio-lookups/20151106-034359
base: https://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio.git for-next
config: mips-txx9 (attached as .config)
reproduce:
wget https://git.kernel.org/cgit/linux/kernel/git/wfg/lkp-tests.git/plain/sbin/make.cross -O ~/bin/make.cross
chmod +x ~/bin/make.cross
# save the attached .config to linux build tree
make.cross ARCH=mips
All errors (new ones prefixed by >>):
drivers/gpio/gpiolib.c: In function 'acpi_can_fallback_to_crs':
>> drivers/gpio/gpiolib.c:1859:10: error: dereferencing pointer to incomplete type 'struct acpi_device'
if (adev->data.properties || adev->driver_gpios)
^
vim +1859 drivers/gpio/gpiolib.c
1853 static bool acpi_can_fallback_to_crs(struct acpi_device *adev,
1854 const char *con_id)
1855 {
1856 struct acpi_gpio_lookup *l, *lookup = NULL;
1857
1858 /* Never fallback if the device has properties */
> 1859 if (adev->data.properties || adev->driver_gpios)
1860 return false;
1861
1862 mutex_lock(&acpi_gpio_lookup_lock);
---
0-DAY kernel test infrastructure Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all Intel Corporation
[-- Attachment #2: .config.gz --]
[-- Type: application/octet-stream, Size: 21272 bytes --]
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-05 19:38 [PATCH] gpiolib: tighten up ACPI legacy gpio lookups Dmitry Torokhov
2015-11-05 21:00 ` kbuild test robot
@ 2015-11-05 21:02 ` kbuild test robot
2015-11-06 8:08 ` Mika Westerberg
2015-11-17 10:57 ` Linus Walleij
3 siblings, 0 replies; 7+ messages in thread
From: kbuild test robot @ 2015-11-05 21:02 UTC (permalink / raw)
To: Dmitry Torokhov
Cc: kbuild-all, Linus Walleij, Alexandre Courbot, Johan Hovold,
Rafael J. Wysocki, mika.westerberg, Tirdea, Irina, linux-gpio,
linux-kernel
[-- Attachment #1: Type: text/plain, Size: 1457 bytes --]
Hi Dmitry,
[auto build test ERROR on: gpio/for-next]
[also build test ERROR on: v4.3 next-20151105]
url: https://github.com/0day-ci/linux/commits/Dmitry-Torokhov/gpiolib-tighten-up-ACPI-legacy-gpio-lookups/20151106-034359
base: https://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio.git for-next
config: cris-etrax-100lx_v2_defconfig (attached as .config)
reproduce:
wget https://git.kernel.org/cgit/linux/kernel/git/wfg/lkp-tests.git/plain/sbin/make.cross -O ~/bin/make.cross
chmod +x ~/bin/make.cross
# save the attached .config to linux build tree
make.cross ARCH=cris
All errors (new ones prefixed by >>):
drivers/gpio/gpiolib.c: In function 'acpi_can_fallback_to_crs':
>> drivers/gpio/gpiolib.c:1859:10: error: dereferencing pointer to incomplete type
drivers/gpio/gpiolib.c:1859:35: error: dereferencing pointer to incomplete type
vim +1859 drivers/gpio/gpiolib.c
1853 static bool acpi_can_fallback_to_crs(struct acpi_device *adev,
1854 const char *con_id)
1855 {
1856 struct acpi_gpio_lookup *l, *lookup = NULL;
1857
1858 /* Never fallback if the device has properties */
> 1859 if (adev->data.properties || adev->driver_gpios)
1860 return false;
1861
1862 mutex_lock(&acpi_gpio_lookup_lock);
---
0-DAY kernel test infrastructure Open Source Technology Center
https://lists.01.org/pipermail/kbuild-all Intel Corporation
[-- Attachment #2: .config.gz --]
[-- Type: application/octet-stream, Size: 7949 bytes --]
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-05 19:38 [PATCH] gpiolib: tighten up ACPI legacy gpio lookups Dmitry Torokhov
2015-11-05 21:00 ` kbuild test robot
2015-11-05 21:02 ` kbuild test robot
@ 2015-11-06 8:08 ` Mika Westerberg
2015-11-06 8:25 ` Dmitry Torokhov
2015-11-17 10:57 ` Linus Walleij
3 siblings, 1 reply; 7+ messages in thread
From: Mika Westerberg @ 2015-11-06 8:08 UTC (permalink / raw)
To: Dmitry Torokhov
Cc: Linus Walleij, Alexandre Courbot, Johan Hovold, Rafael J. Wysocki,
Tirdea, Irina, linux-gpio, linux-kernel
On Thu, Nov 05, 2015 at 11:38:38AM -0800, Dmitry Torokhov wrote:
> We should not fall back to the legacy unnamed gpio lookup style if the
> driver requests gpios with different names, because we'll give out the same
> gpio twice. Let's keep track of the names that were used for the device and
> only do the fallback for the first name used.
>
> Also disable fallback to _CRS gpios if ACPI device has DT-like
> properties or driver-supplied gpio mappings.
Thanks for taking care of this!
> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
> ---
>
> This version incorporates changes suggested by Mika Westerberg in
> response to the draft patch I posted in Goodix thread.
>
> drivers/gpio/gpiolib.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++
> 1 file changed, 47 insertions(+)
>
> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
> index a18f00f..9631ee8 100644
> --- a/drivers/gpio/gpiolib.c
> +++ b/drivers/gpio/gpiolib.c
> @@ -1841,6 +1841,50 @@ static struct gpio_desc *of_find_gpio(struct device *dev, const char *con_id,
> return desc;
> }
>
> +struct acpi_gpio_lookup {
> + struct list_head node;
> + struct acpi_device *adev;
> + const char *con_id;
> +};
> +
> +static DEFINE_MUTEX(acpi_gpio_lookup_lock);
> +static LIST_HEAD(acpi_gpio_lookup_list);
> +
> +static bool acpi_can_fallback_to_crs(struct acpi_device *adev,
> + const char *con_id)
> +{
> + struct acpi_gpio_lookup *l, *lookup = NULL;
> +
> + /* Never fallback if the device has properties */
> + if (adev->data.properties || adev->driver_gpios)
> + return false;
I missed the fact that struct acpi_device is declared in
<acpi/acpi_bus.h> so we can't use the two fields directly here when
!CONFIG_ACPI. Sorry about that.
Do you think we can just add
#ifdef CONFIG_ACPI
#endif
around the above check?
Alternatively we could add an inline function to drivers/gpio/gpiolib.h
like:
#ifdef CONFIG_ACPI
static inline bool acpi_gpio_has_properties(struct acpi_device *adev)
{
return adev->data.properties || adev->driver_gpios;
}
#else
static inline bool acpi_gpio_has_properties(struct acpi_device *adev)
{
return false;
}
#endif
> +
> + mutex_lock(&acpi_gpio_lookup_lock);
> +
> + list_for_each_entry(l, &acpi_gpio_lookup_list, node) {
> + if (l->adev == adev) {
> + lookup = l;
> + break;
> + }
> + }
> +
> + if (!lookup) {
> + lookup = kmalloc(sizeof(*lookup), GFP_KERNEL);
> + if (lookup) {
> + lookup->adev = adev;
> + lookup->con_id = con_id;
> + list_add_tail(&lookup->node, &acpi_gpio_lookup_list);
> + }
> + }
> +
> + mutex_unlock(&acpi_gpio_lookup_lock);
> +
> + return lookup &&
> + ((!lookup->con_id && !con_id) ||
> + (lookup->con_id && con_id &&
> + strcmp(lookup->con_id, con_id) == 0));
> +}
> +
> static struct gpio_desc *acpi_find_gpio(struct device *dev, const char *con_id,
> unsigned int idx,
> enum gpio_lookup_flags *flags)
> @@ -1868,6 +1912,9 @@ static struct gpio_desc *acpi_find_gpio(struct device *dev, const char *con_id,
>
> /* Then from plain _CRS GPIOs */
> if (IS_ERR(desc)) {
> + if (!acpi_can_fallback_to_crs(adev, con_id))
> + return ERR_PTR(-ENOENT);
> +
> desc = acpi_get_gpiod_by_index(adev, NULL, idx, &info);
> if (IS_ERR(desc))
> return desc;
> --
> 2.6.0.rc2.230.g3dd15c0
>
>
> --
> Dmitry
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-06 8:08 ` Mika Westerberg
@ 2015-11-06 8:25 ` Dmitry Torokhov
2015-11-06 8:31 ` Mika Westerberg
0 siblings, 1 reply; 7+ messages in thread
From: Dmitry Torokhov @ 2015-11-06 8:25 UTC (permalink / raw)
To: Mika Westerberg
Cc: Linus Walleij, Alexandre Courbot, Johan Hovold, Rafael J. Wysocki,
Tirdea, Irina, linux-gpio@vger.kernel.org, lkml
On Fri, Nov 6, 2015 at 12:08 AM, Mika Westerberg
<mika.westerberg@linux.intel.com> wrote:
> On Thu, Nov 05, 2015 at 11:38:38AM -0800, Dmitry Torokhov wrote:
>> We should not fall back to the legacy unnamed gpio lookup style if the
>> driver requests gpios with different names, because we'll give out the same
>> gpio twice. Let's keep track of the names that were used for the device and
>> only do the fallback for the first name used.
>>
>> Also disable fallback to _CRS gpios if ACPI device has DT-like
>> properties or driver-supplied gpio mappings.
>
> Thanks for taking care of this!
>
>> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
>> ---
>>
>> This version incorporates changes suggested by Mika Westerberg in
>> response to the draft patch I posted in Goodix thread.
>>
>> drivers/gpio/gpiolib.c | 47 +++++++++++++++++++++++++++++++++++++++++++++++
>> 1 file changed, 47 insertions(+)
>>
>> diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c
>> index a18f00f..9631ee8 100644
>> --- a/drivers/gpio/gpiolib.c
>> +++ b/drivers/gpio/gpiolib.c
>> @@ -1841,6 +1841,50 @@ static struct gpio_desc *of_find_gpio(struct device *dev, const char *con_id,
>> return desc;
>> }
>>
>> +struct acpi_gpio_lookup {
>> + struct list_head node;
>> + struct acpi_device *adev;
>> + const char *con_id;
>> +};
>> +
>> +static DEFINE_MUTEX(acpi_gpio_lookup_lock);
>> +static LIST_HEAD(acpi_gpio_lookup_list);
>> +
>> +static bool acpi_can_fallback_to_crs(struct acpi_device *adev,
>> + const char *con_id)
>> +{
>> + struct acpi_gpio_lookup *l, *lookup = NULL;
>> +
>> + /* Never fallback if the device has properties */
>> + if (adev->data.properties || adev->driver_gpios)
>> + return false;
>
> I missed the fact that struct acpi_device is declared in
> <acpi/acpi_bus.h> so we can't use the two fields directly here when
> !CONFIG_ACPI. Sorry about that.
>
> Do you think we can just add
>
> #ifdef CONFIG_ACPI
>
> #endif
>
> around the above check?
>
> Alternatively we could add an inline function to drivers/gpio/gpiolib.h
> like:
>
> #ifdef CONFIG_ACPI
> static inline bool acpi_gpio_has_properties(struct acpi_device *adev)
> {
> return adev->data.properties || adev->driver_gpios;
> }
> #else
> static inline bool acpi_gpio_has_properties(struct acpi_device *adev)
> {
> return false;
> }
> #endif
>
I wonder if I should move acpi_can_fallback_to_crs() into
gpiolib-acpi.c and provide a stub for it...
Thanks.
--
Dmitry
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-06 8:25 ` Dmitry Torokhov
@ 2015-11-06 8:31 ` Mika Westerberg
0 siblings, 0 replies; 7+ messages in thread
From: Mika Westerberg @ 2015-11-06 8:31 UTC (permalink / raw)
To: Dmitry Torokhov
Cc: Linus Walleij, Alexandre Courbot, Johan Hovold, Rafael J. Wysocki,
Tirdea, Irina, linux-gpio@vger.kernel.org, lkml
On Fri, Nov 06, 2015 at 12:25:34AM -0800, Dmitry Torokhov wrote:
> I wonder if I should move acpi_can_fallback_to_crs() into
> gpiolib-acpi.c and provide a stub for it...
That works too :-)
^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] gpiolib: tighten up ACPI legacy gpio lookups
2015-11-05 19:38 [PATCH] gpiolib: tighten up ACPI legacy gpio lookups Dmitry Torokhov
` (2 preceding siblings ...)
2015-11-06 8:08 ` Mika Westerberg
@ 2015-11-17 10:57 ` Linus Walleij
3 siblings, 0 replies; 7+ messages in thread
From: Linus Walleij @ 2015-11-17 10:57 UTC (permalink / raw)
To: Dmitry Torokhov
Cc: Alexandre Courbot, Johan Hovold, Rafael J. Wysocki,
Mika Westerberg, Tirdea, Irina, linux-gpio@vger.kernel.org,
linux-kernel@vger.kernel.org
On Thu, Nov 5, 2015 at 8:38 PM, Dmitry Torokhov
<dmitry.torokhov@gmail.com> wrote:
> We should not fall back to the legacy unnamed gpio lookup style if the
> driver requests gpios with different names, because we'll give out the same
> gpio twice. Let's keep track of the names that were used for the device and
> only do the fallback for the first name used.
>
> Also disable fallback to _CRS gpios if ACPI device has DT-like
> properties or driver-supplied gpio mappings.
>
> Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Looking for a newer version of this I think, also would like
Mika's and/or Rafael's ACKs.
Yours,
Linus Walleij
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2015-11-17 10:57 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-11-05 19:38 [PATCH] gpiolib: tighten up ACPI legacy gpio lookups Dmitry Torokhov
2015-11-05 21:00 ` kbuild test robot
2015-11-05 21:02 ` kbuild test robot
2015-11-06 8:08 ` Mika Westerberg
2015-11-06 8:25 ` Dmitry Torokhov
2015-11-06 8:31 ` Mika Westerberg
2015-11-17 10:57 ` Linus Walleij
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox