]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
udmabuf: fix a buf size overflow issue during udmabuf creation
authorXiaogang Chen <xiaogang.chen@amd.com>
Fri, 21 Mar 2025 16:41:26 +0000 (11:41 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 2 May 2025 05:44:36 +0000 (07:44 +0200)
[ Upstream commit 021ba7f1babd029e714d13a6bf2571b08af96d0f ]

by casting size_limit_mb to u64  when calculate pglimit.

Signed-off-by: Xiaogang Chen<Xiaogang.Chen@amd.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20250321164126.329638-1-xiaogang.chen@amd.com
Signed-off-by: Christian König <christian.koenig@amd.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/dma-buf/udmabuf.c

index a8094d57d2d067efd479a5f0b53fae30d268f6bf..84f7611c765b9f86efbefd95b2402cb0bad9f5e7 100644 (file)
@@ -186,7 +186,7 @@ static long udmabuf_create(struct miscdevice *device,
        if (!ubuf)
                return -ENOMEM;
 
-       pglimit = (size_limit_mb * 1024 * 1024) >> PAGE_SHIFT;
+       pglimit = ((u64)size_limit_mb * 1024 * 1024) >> PAGE_SHIFT;
        for (i = 0; i < head->count; i++) {
                if (!IS_ALIGNED(list[i].offset, PAGE_SIZE))
                        goto err;