]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/bridge/panel: Fix runtime warning on panel bridge release
authorAdam Miotk <adam.miotk@arm.com>
Mon, 10 Jun 2024 10:27:39 +0000 (11:27 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 5 Jul 2024 07:08:17 +0000 (09:08 +0200)
[ Upstream commit ce62600c4dbee8d43b02277669dd91785a9b81d9 ]

Device managed panel bridge wrappers are created by calling to
drm_panel_bridge_add_typed() and registering a release handler for
clean-up when the device gets unbound.

Since the memory for this bridge is also managed and linked to the panel
device, the release function should not try to free that memory.
Moreover, the call to devm_kfree() inside drm_panel_bridge_remove() will
fail in this case and emit a warning because the panel bridge resource
is no longer on the device resources list (it has been removed from
there before the call to release handlers).

Fixes: 67022227ffb1 ("drm/bridge: Add a devm_ allocator for panel bridge.")
Signed-off-by: Adam Miotk <adam.miotk@arm.com>
Signed-off-by: Maxime Ripard <mripard@kernel.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20240610102739.139852-1-adam.miotk@arm.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/gpu/drm/bridge/panel.c

index b12ae3a4c5f11b243e8440f1ffd6e6ed0c1f0633..695dba0f018f8d8ae96ff6899ab2551a38e4b8d2 100644 (file)
@@ -203,9 +203,12 @@ EXPORT_SYMBOL(drm_panel_bridge_remove);
 
 static void devm_drm_panel_bridge_release(struct device *dev, void *res)
 {
-       struct drm_bridge **bridge = res;
+       struct drm_bridge *bridge = *(struct drm_bridge **)res;
 
-       drm_panel_bridge_remove(*bridge);
+       if (!bridge)
+               return;
+
+       drm_bridge_remove(bridge);
 }
 
 /**