From: Johan Hovold Date: Mon, 12 Jan 2015 16:12:29 +0000 (+0100) Subject: gpio: unregister gpiochip device before removing it X-Git-Tag: v3.16.35~2070 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=52812c8821ed62de51b31c21e38cce42855de723;p=thirdparty%2Fkernel%2Fstable.git gpio: unregister gpiochip device before removing it commit 01cca93a9491ed95992523ff7e79dd9bfcdea8e0 upstream. Unregister gpiochip device (used to export information through sysfs) before removing it internally. This way removal will reverse addition. Signed-off-by: Johan Hovold Signed-off-by: Linus Walleij [ luis: backported to 3.16: used Johan's backport to 3.14 ] Signed-off-by: Luis Henriques --- diff --git a/drivers/gpio/gpiolib.c b/drivers/gpio/gpiolib.c index d9b8844e27156..3f07d8aa848a8 100644 --- a/drivers/gpio/gpiolib.c +++ b/drivers/gpio/gpiolib.c @@ -1287,6 +1287,8 @@ int gpiochip_remove(struct gpio_chip *chip) int status = 0; unsigned id; + gpiochip_unexport(chip); + gpiochip_irqchip_remove(chip); acpi_gpiochip_remove(chip); @@ -1309,9 +1311,6 @@ int gpiochip_remove(struct gpio_chip *chip) spin_unlock_irqrestore(&gpio_lock, flags); - if (status == 0) - gpiochip_unexport(chip); - return status; } EXPORT_SYMBOL_GPL(gpiochip_remove);