• Johan Hovold's avatar
    gpio: sysfs: fix memory leaks and device hotplug · 5e3a0d7c
    Johan Hovold authored
    commit 483d8211 upstream.
    
    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: d8f388d8 ("gpio: sysfs interface")
    Signed-off-by: default avatarJohan Hovold <johan@kernel.org>
    Signed-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
    [bwh: Backported to 3.2:
     - Adjust filename, context
     - Move up initialisation of 'desc' in gpio_export()
     - Use global 'gpio_desc' array and gpio_free() function in
       gpiochip_unexport()]
    Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
    5e3a0d7c
gpiolib.c 43.1 KB