[PATCH] drm/rockchip: gem: Fix memory leak when drm object init failed

From: Karina Yankevich

Date: Wed Nov 05 2025 - 05:09:58 EST


If drm_gem_object_init() call in rockchip_gem_alloc_object() fails
then rk_obj isn't freed. Fix this by checking drm_gem_object_init()'s
result.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Fixes: 6fd0bfe2f7ea ("drm/rockchip: support prime import sg table")
Signed-off-by: Karina Yankevich <k.yankevich@xxxxxx>
Reviewed-by: Sergey Shtylyov <s.shtylyov@xxxxxx>
---
drivers/gpu/drm/rockchip/rockchip_drm_gem.c | 8 +++++++-
1 file changed, 7 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/rockchip/rockchip_drm_gem.c b/drivers/gpu/drm/rockchip/rockchip_drm_gem.c
index 6330b883efc3..ad888f9379db 100644
--- a/drivers/gpu/drm/rockchip/rockchip_drm_gem.c
+++ b/drivers/gpu/drm/rockchip/rockchip_drm_gem.c
@@ -284,6 +284,7 @@ static struct rockchip_gem_object *
{
struct rockchip_gem_object *rk_obj;
struct drm_gem_object *obj;
+ int ret;

size = round_up(size, PAGE_SIZE);

@@ -295,7 +296,12 @@ static struct rockchip_gem_object *

obj->funcs = &rockchip_gem_object_funcs;

- drm_gem_object_init(drm, obj, size);
+ ret = drm_gem_object_init(drm, obj, size);
+ if (ret) {
+ DRM_ERROR("failed to initialize gem object: %d\n", ret);
+ kfree(rk_obj);
+ return ERR_PTR(ret);
+ }

return rk_obj;
}
--
2.34.1