Commit 00f17e45 authored by Rob Clark's avatar Rob Clark Committed by Tomi Valkeinen

OMAPDSS: fix potential NULL pointer ref in OCP_ERR handling path

The dispc's error handler tries to disable all outputs when OCP_ERR
happens. However, the code doesn't check if there actually is a display
on each particular output, nor if there's a driver for the display. This
may lead to NULL pointer reference.
Signed-off-by: default avatarRob Clark <rob@ti.com>
[tomi.valkeinen@ti.com: added patch description]
Signed-off-by: default avatarTomi Valkeinen <tomi.valkeinen@ti.com>
parent f806f9b6
...@@ -3201,7 +3201,8 @@ static void dispc_error_worker(struct work_struct *work) ...@@ -3201,7 +3201,8 @@ static void dispc_error_worker(struct work_struct *work)
for (i = 0; i < omap_dss_get_num_overlay_managers(); ++i) { for (i = 0; i < omap_dss_get_num_overlay_managers(); ++i) {
struct omap_overlay_manager *mgr; struct omap_overlay_manager *mgr;
mgr = omap_dss_get_overlay_manager(i); mgr = omap_dss_get_overlay_manager(i);
mgr->device->driver->disable(mgr->device); if (mgr->device && mgr->device->driver)
mgr->device->driver->disable(mgr->device);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment