]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/panel: simple: Add missing panel_simple_unprepare() calls
authorJonathan Liu <net147@gmail.com>
Mon, 7 Aug 2017 11:55:45 +0000 (21:55 +1000)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 5 Dec 2017 10:20:47 +0000 (11:20 +0100)
commit f3621a8eb59a913612c8e6e37d81f16b649f8b6c upstream.

During panel removal or system shutdown panel_simple_disable() is called
which disables the panel backlight but the panel is still powered due to
missing calls to panel_simple_unprepare().

Fixes: d02fd93e2cd8 ("drm/panel: simple - Disable panel on shutdown")
Signed-off-by: Jonathan Liu <net147@gmail.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20170807115545.27747-1-net147@gmail.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/gpu/drm/panel/panel-simple.c

index 23de22f8c82078a11a4c9a7815c8aa099d74ddf9..7a4faf911ee87e863991a831854c5c06f8080996 100644 (file)
@@ -312,6 +312,7 @@ static int panel_simple_remove(struct device *dev)
        drm_panel_remove(&panel->base);
 
        panel_simple_disable(&panel->base);
+       panel_simple_unprepare(&panel->base);
 
        if (panel->ddc)
                put_device(&panel->ddc->dev);
@@ -327,6 +328,7 @@ static void panel_simple_shutdown(struct device *dev)
        struct panel_simple *panel = dev_get_drvdata(dev);
 
        panel_simple_disable(&panel->base);
+       panel_simple_unprepare(&panel->base);
 }
 
 static const struct drm_display_mode auo_b101aw03_mode = {