]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
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)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 Oct 2020 09:07:33 +0000 (10:07 +0100)
[ Upstream commit f7ec68b341dbd5da13d4c65ce444dcd605f1c42e ]

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
Signed-off-by: Sasha Levin <sashal@kernel.org>
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);