drm/msm: fix NULL-deref on irq uninstall
In case of early initialisation errors and on platforms that do not use
the DPU controller, the deinitilisation code can be called with the kms
pointer set to NULL.
Fixes: f026e431cf
("drm/msm: Convert to Linux IRQ interfaces")
Cc: stable@vger.kernel.org # 5.14
Cc: Thomas Zimmermann <tzimmermann@suse.de>
Signed-off-by: Johan Hovold <johan+linaro@kernel.org>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Patchwork: https://patchwork.freedesktop.org/patch/525104/
Link: https://lore.kernel.org/r/20230306100722.28485-5-johan+linaro@kernel.org
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
This commit is contained in:
parent
a465353b92
commit
cd459c005d
@ -252,9 +252,11 @@ static int msm_drm_uninit(struct device *dev)
|
|||||||
drm_bridge_remove(priv->bridges[i]);
|
drm_bridge_remove(priv->bridges[i]);
|
||||||
priv->num_bridges = 0;
|
priv->num_bridges = 0;
|
||||||
|
|
||||||
pm_runtime_get_sync(dev);
|
if (kms) {
|
||||||
msm_irq_uninstall(ddev);
|
pm_runtime_get_sync(dev);
|
||||||
pm_runtime_put_sync(dev);
|
msm_irq_uninstall(ddev);
|
||||||
|
pm_runtime_put_sync(dev);
|
||||||
|
}
|
||||||
|
|
||||||
if (kms && kms->funcs)
|
if (kms && kms->funcs)
|
||||||
kms->funcs->destroy(kms);
|
kms->funcs->destroy(kms);
|
||||||
|
Loading…
Reference in New Issue
Block a user