summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorshayderrr <darknessshayder@gmail.com>2026-05-17 20:04:56 +0300
committerThierry Reding <treding@nvidia.com>2026-05-28 18:19:28 +0300
commit71d25f668bc5c0f36ea843462e12307dea45aaa3 (patch)
tree38599a2884d4c3f55da62315c3c3626b3fa12932
parent05a07a31deda59b60483b5359b5c0ccb693d7311 (diff)
downloadlinux-71d25f668bc5c0f36ea843462e12307dea45aaa3.tar.xz
host1x: bus: Fix missing ops null check in error teardown
In host1x_device_init(), the error teardown paths do not check client->ops before dereferencing it, unlike the forward init paths which correctly guard with 'client->ops &&'. This can result in a NULL pointer dereference if client->ops is NULL. Fix by adding the missing client->ops check in both the teardown and teardown_late labels. Signed-off-by: shayderrr <darknessshayder@gmail.com> Signed-off-by: Thierry Reding <treding@nvidia.com> Link: https://patch.msgid.link/20260517170456.84927-1-darknessshayder@gmail.com
-rw-r--r--drivers/gpu/host1x/bus.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/gpu/host1x/bus.c b/drivers/gpu/host1x/bus.c
index 772e05a7b45b..70310d1e3162 100644
--- a/drivers/gpu/host1x/bus.c
+++ b/drivers/gpu/host1x/bus.c
@@ -221,7 +221,7 @@ int host1x_device_init(struct host1x_device *device)
teardown:
list_for_each_entry_continue_reverse(client, &device->clients, list)
- if (client->ops->exit)
+ if (client->ops && client->ops->exit)
client->ops->exit(client);
/* reset client to end of list for late teardown */
@@ -229,7 +229,7 @@ teardown:
teardown_late:
list_for_each_entry_continue_reverse(client, &device->clients, list)
- if (client->ops->late_exit)
+ if (client->ops && client->ops->late_exit)
client->ops->late_exit(client);
mutex_unlock(&device->clients_lock);