summaryrefslogtreecommitdiff
path: root/drivers/gpu/drm/lima/lima_gp.c
diff options
context:
space:
mode:
authorErico Nunes <nunes.erico@gmail.com>2024-04-02 01:43:28 +0300
committerQiang Yu <yuq825@gmail.com>2024-04-15 04:06:18 +0300
commita6683c690bbfd1f371510cb051e8fa49507f3f5e (patch)
treeadb26c314c2aba49d0f1834f409bbd694ece475f /drivers/gpu/drm/lima/lima_gp.c
parenta421cc7a6a001b70415aa4f66024fa6178885a14 (diff)
downloadlinux-a6683c690bbfd1f371510cb051e8fa49507f3f5e.tar.xz
drm/lima: fix shared irq handling on driver remove
lima uses a shared interrupt, so the interrupt handlers must be prepared to be called at any time. At driver removal time, the clocks are disabled early and the interrupts stay registered until the very end of the remove process due to the devm usage. This is potentially a bug as the interrupts access device registers which assumes clocks are enabled. A crash can be triggered by removing the driver in a kernel with CONFIG_DEBUG_SHIRQ enabled. This patch frees the interrupts at each lima device finishing callback so that the handlers are already unregistered by the time we fully disable clocks. Signed-off-by: Erico Nunes <nunes.erico@gmail.com> Signed-off-by: Qiang Yu <yuq825@gmail.com> Link: https://patchwork.freedesktop.org/patch/msgid/20240401224329.1228468-2-nunes.erico@gmail.com
Diffstat (limited to 'drivers/gpu/drm/lima/lima_gp.c')
-rw-r--r--drivers/gpu/drm/lima/lima_gp.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/gpu/drm/lima/lima_gp.c b/drivers/gpu/drm/lima/lima_gp.c
index e15295071533..3282997a0358 100644
--- a/drivers/gpu/drm/lima/lima_gp.c
+++ b/drivers/gpu/drm/lima/lima_gp.c
@@ -345,7 +345,9 @@ int lima_gp_init(struct lima_ip *ip)
void lima_gp_fini(struct lima_ip *ip)
{
+ struct lima_device *dev = ip->dev;
+ devm_free_irq(dev->dev, ip->irq, ip);
}
int lima_gp_pipe_init(struct lima_device *dev)