]> git.baikalelectronics.ru Git - kernel.git/commit
gpio: sysfs: fix memory leaks and device hotplug
authorJohan Hovold <johan@kernel.org>
Tue, 21 Apr 2015 15:42:09 +0000 (17:42 +0200)
committerLinus Walleij <linus.walleij@linaro.org>
Wed, 29 Apr 2015 21:42:47 +0000 (23:42 +0200)
commit09f149ae568045cc05a73dd25340f55f51e82f07
tree65869fcdd9ea80b6275e282f017a5d018c659cd2
parent670e4a7516c2314326233004f4d3b16e2f5a7e8f
gpio: sysfs: fix memory leaks and device hotplug

Unregister GPIOs requested through sysfs at chip remove to avoid leaking
the associated memory and sysfs entries.

The stale sysfs entries prevented the gpio numbers from being exported
when the gpio range was later reused (e.g. at device reconnect).

This also fixes the related module-reference leak.

Note that kernfs makes sure that any on-going sysfs operations finish
before the class devices are unregistered and that further accesses
fail.

The chip exported flag is used to prevent gpiod exports during removal.
This also makes it harder to trigger, but does not fix, the related race
between gpiochip_remove and export_store, which is really a race with
gpiod_request that needs to be addressed separately.

Also note that this would prevent the crashes (e.g. NULL-dereferences)
at reconnect that affects pre-3.18 kernels, as well as use-after-free on
operations on open attribute files on pre-3.14 kernels (prior to
kernfs).

Fixes: 601455711103 ("gpio: sysfs interface")
Cc: stable <stable@vger.kernel.org> # v2.6.27: dbb6588d62b7
Signed-off-by: Johan Hovold <johan@kernel.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpiolib-sysfs.c