Re: [PATCH] gpio_free might sleep, arm architecture

From: David Brownell
Date: Mon Sep 15 2008 - 17:22:09 EST


On Monday 15 September 2008, Uwe Kleine-König wrote:
> According to the documentation gpio_free should only be called from task
> context only. To make this more explicit add a might sleep to all
> implementations.
>
> This patch changes the gpio_free implementations for the arm
> architecture. DaVinci is skipped on purpose to simplify the merge
> process for patches switching it over to use gpiolib as per request by
> David Brownell.
>
> Signed-off-by: Uwe Kleine-König <ukleinek@xxxxxxxxxxxxxxxxxxxxxxxxxx>

Acked-by: David Brownell <dbrownell@xxxxxxxxxxxxxxxxxxxxx>

Not dependent on anything else, FWIW (and Kevin already sent
the DaVinci patch for review) ... so IMO this is ready to
merge as soon as Russell agrees.

Consider this also an ack for the MIPS, Blackfin, and x86
arch-specific updates. (Which are likewise ripe for merge.)

(These patches are not a 2.6.27 priority, of course...)

> Cc: David Brownell <david-b@xxxxxxxxxxx>
> Cc: Andrew Victor <linux@xxxxxxxxxxxx>
> Cc: Haavard Skinnemoen <hskinnemoen@xxxxxxxxx>
> Cc: Sascha Hauer <kernel@xxxxxxxxxxxxxx>
> Cc: Guennadi Liakhovetski <g.liakhovetski@xxxxxxxxxxxxxx>
> Cc: Greg KH <greg@xxxxxxxxx>
> Cc: Kay Sievers <kay.sievers@xxxxxxxx>
> Cc: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>
> Cc: Russell King <rmk+kernel@xxxxxxxxxxxxxxxx>
> Cc: arm-linux-kernel@xxxxxxxxxxxxxxxx
> ---
> arch/arm/mach-at91/include/mach/gpio.h | 2 ++
> arch/arm/mach-imx/include/mach/gpio.h | 3 +++
> arch/arm/mach-ixp4xx/include/mach/gpio.h | 3 +++
> arch/arm/mach-ks8695/include/mach/gpio.h | 3 +++
> arch/arm/mach-ns9xxx/gpio.c | 2 ++
> arch/arm/mach-orion5x/gpio.c | 2 ++
> 6 files changed, 15 insertions(+), 0 deletions(-)
>
> diff --git a/arch/arm/mach-at91/include/mach/gpio.h b/arch/arm/mach-at91/include/mach/gpio.h
> index 76d76e2..bffa674 100644
> --- a/arch/arm/mach-at91/include/mach/gpio.h
> +++ b/arch/arm/mach-at91/include/mach/gpio.h
> @@ -13,6 +13,7 @@
> #ifndef __ASM_ARCH_AT91RM9200_GPIO_H
> #define __ASM_ARCH_AT91RM9200_GPIO_H
>
> +#include <linux/kernel.h>
> #include <asm/irq.h>
>
> #define PIN_BASE NR_AIC_IRQS
> @@ -220,6 +221,7 @@ static inline int gpio_request(unsigned gpio, const char *label)
>
> static inline void gpio_free(unsigned gpio)
> {
> + might_sleep();
> }
>
> extern int gpio_direction_input(unsigned gpio);
> diff --git a/arch/arm/mach-imx/include/mach/gpio.h b/arch/arm/mach-imx/include/mach/gpio.h
> index 6e3d795..502d5aa 100644
> --- a/arch/arm/mach-imx/include/mach/gpio.h
> +++ b/arch/arm/mach-imx/include/mach/gpio.h
> @@ -1,5 +1,6 @@
> #ifndef _IMX_GPIO_H
>
> +#include <linux/kernel.h>
> #include <mach/imx-regs.h>
>
> #define IMX_GPIO_ALLOC_MODE_NORMAL 0
> @@ -63,6 +64,8 @@ static inline int gpio_request(unsigned gpio, const char *label)
>
> static inline void gpio_free(unsigned gpio)
> {
> + might_sleep();
> +
> imx_gpio_free(gpio);
> }
>
> diff --git a/arch/arm/mach-ixp4xx/include/mach/gpio.h b/arch/arm/mach-ixp4xx/include/mach/gpio.h
> index 9fbde17..cd5aec2 100644
> --- a/arch/arm/mach-ixp4xx/include/mach/gpio.h
> +++ b/arch/arm/mach-ixp4xx/include/mach/gpio.h
> @@ -25,6 +25,7 @@
> #ifndef __ASM_ARCH_IXP4XX_GPIO_H
> #define __ASM_ARCH_IXP4XX_GPIO_H
>
> +#include <linux/kernel.h>
> #include <mach/hardware.h>
>
> static inline int gpio_request(unsigned gpio, const char *label)
> @@ -34,6 +35,8 @@ static inline int gpio_request(unsigned gpio, const char *label)
>
> static inline void gpio_free(unsigned gpio)
> {
> + might_sleep();
> +
> return;
> }
>
> diff --git a/arch/arm/mach-ks8695/include/mach/gpio.h b/arch/arm/mach-ks8695/include/mach/gpio.h
> index 73c8416..d4af5c3 100644
> --- a/arch/arm/mach-ks8695/include/mach/gpio.h
> +++ b/arch/arm/mach-ks8695/include/mach/gpio.h
> @@ -11,6 +11,8 @@
> #ifndef __ASM_ARCH_GPIO_H_
> #define __ASM_ARCH_GPIO_H_
>
> +#include <linux/kernel.h>
> +
> #define KS8695_GPIO_0 0
> #define KS8695_GPIO_1 1
> #define KS8695_GPIO_2 2
> @@ -74,6 +76,7 @@ static inline int gpio_request(unsigned int pin, const char *label)
>
> static inline void gpio_free(unsigned int pin)
> {
> + might_sleep();
> }
>
> #endif
> diff --git a/arch/arm/mach-ns9xxx/gpio.c b/arch/arm/mach-ns9xxx/gpio.c
> index 804c300..9e088c4 100644
> --- a/arch/arm/mach-ns9xxx/gpio.c
> +++ b/arch/arm/mach-ns9xxx/gpio.c
> @@ -12,6 +12,7 @@
> #include <linux/init.h>
> #include <linux/spinlock.h>
> #include <linux/module.h>
> +#include <linux/kernel.h>
>
> #include <mach/gpio.h>
> #include <mach/processor.h>
> @@ -63,6 +64,7 @@ EXPORT_SYMBOL(gpio_request);
>
> void gpio_free(unsigned gpio)
> {
> + might_sleep();
> clear_bit(gpio, gpiores);
> return;
> }
> diff --git a/arch/arm/mach-orion5x/gpio.c b/arch/arm/mach-orion5x/gpio.c
> index cd8a16f..3bdfd0a 100644
> --- a/arch/arm/mach-orion5x/gpio.c
> +++ b/arch/arm/mach-orion5x/gpio.c
> @@ -165,6 +165,8 @@ EXPORT_SYMBOL(gpio_request);
>
> void gpio_free(unsigned pin)
> {
> + might_sleep();
> +
> if (pin >= GPIO_MAX || !test_bit(pin, gpio_valid)) {
> pr_debug("%s: invalid GPIO %d\n", __func__, pin);
> return;
> --
> 1.5.6.5
>
>


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/