drm/crc-debugfs: Fix memleak in crc_control_write
authorDinghao Liu <dinghao.liu@zju.edu.cn>
Wed, 19 Aug 2020 08:22:28 +0000 (16:22 +0800)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Tue, 1 Sep 2020 07:45:44 +0000 (09:45 +0200)
When verify_crc_source() fails, source needs to be freed.
However, current code is returning directly and ends up
leaking memory.

Fixes: d5cc15a0c66e ("drm: crc: Introduce verify_crc_source callback")
Signed-off-by: Dinghao Liu <dinghao.liu@zju.edu.cn>
Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
[danvet: change Fixes: tag per Laurent's review]
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20200819082228.26847-1-dinghao.liu@zju.edu.cn
drivers/gpu/drm/drm_debugfs_crc.c

index 5d67a41f7c3a8f208e2aee802c8bffa16e13cac6..3dd70d813f69427323b658d311e76b6a0edd6bf5 100644 (file)
@@ -144,8 +144,10 @@ static ssize_t crc_control_write(struct file *file, const char __user *ubuf,
                source[len - 1] = '\0';
 
        ret = crtc->funcs->verify_crc_source(crtc, source, &values_cnt);
-       if (ret)
+       if (ret) {
+               kfree(source);
                return ret;
+       }
 
        spin_lock_irq(&crc->lock);