args->n_devices is a u32 that comes from the user.  The multiplication
could overflow on 32 bit systems possibly leading to privilege
escalation.

Fixes: 5ec7e02854b3 ("drm/amdkfd: Add ioctls for GPUVM memory management")
Signed-off-by: Dan Carpenter dan.carpen...@oracle.com>

diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c 
b/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
index cd679cf1fd30..ce36e556da38 100644
--- a/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
+++ b/drivers/gpu/drm/amd/amdkfd/kfd_chardev.c
@@ -1295,8 +1295,8 @@ static int kfd_ioctl_map_memory_to_gpu(struct file *filep,
                return -EINVAL;
        }
 
-       devices_arr = kmalloc(args->n_devices * sizeof(*devices_arr),
-                             GFP_KERNEL);
+       devices_arr = kmalloc_array(args->n_devices, sizeof(*devices_arr),
+                                   GFP_KERNEL);
        if (!devices_arr)
                return -ENOMEM;
 
@@ -1404,8 +1404,8 @@ static int kfd_ioctl_unmap_memory_from_gpu(struct file 
*filep,
                return -EINVAL;
        }
 
-       devices_arr = kmalloc(args->n_devices * sizeof(*devices_arr),
-                             GFP_KERNEL);
+       devices_arr = kmalloc_array(args->n_devices, sizeof(*devices_arr),
+                                   GFP_KERNEL);
        if (!devices_arr)
                return -ENOMEM;
 
_______________________________________________
dri-devel mailing list
dri-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/dri-devel

Reply via email to