Commit d016da58 authored by Dan Carpenter's avatar Dan Carpenter Committed by Dave Airlie

drm: use memdup_user() as a cleanup

drivers/gpu/drm/r128/r128_state.c:1014:10-17: WARNING opportunity for memdup_user
/c/kernel-tests/src/cocci/drivers/gpu/drm/r128/r128_state.c:1029:9-16: WARNING opportunity for memdup_user
/c/kernel-tests/src/cocci/drivers/gpu/drm/r128/r128_state.c:904:10-17: WARNING opportunity for memdup_user
/c/kernel-tests/src/cocci/drivers/gpu/drm/r128/r128_state.c:914:9-16: WARNING opportunity for memdup_user

 Use memdup_user rather than duplicating its implementation
 This is a little bit restricted to reduce false positives

Generated by: coccinelle/api/memdup_user.cocci

CC: Daniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: default avatarDan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent 99c09e74
...@@ -901,25 +901,16 @@ static int r128_cce_dispatch_write_span(struct drm_device *dev, ...@@ -901,25 +901,16 @@ static int r128_cce_dispatch_write_span(struct drm_device *dev,
return -EFAULT; return -EFAULT;
buffer_size = depth->n * sizeof(u32); buffer_size = depth->n * sizeof(u32);
buffer = kmalloc(buffer_size, GFP_KERNEL); buffer = memdup_user(depth->buffer, buffer_size);
if (buffer == NULL) if (IS_ERR(buffer))
return -ENOMEM; return PTR_ERR(buffer);
if (copy_from_user(buffer, depth->buffer, buffer_size)) {
kfree(buffer);
return -EFAULT;
}
mask_size = depth->n * sizeof(u8); mask_size = depth->n * sizeof(u8);
if (depth->mask) { if (depth->mask) {
mask = kmalloc(mask_size, GFP_KERNEL); mask = memdup_user(depth->mask, mask_size);
if (mask == NULL) { if (IS_ERR(mask)) {
kfree(buffer); kfree(buffer);
return -ENOMEM; return PTR_ERR(mask);
}
if (copy_from_user(mask, depth->mask, mask_size)) {
kfree(buffer);
kfree(mask);
return -EFAULT;
} }
for (i = 0; i < count; i++, x++) { for (i = 0; i < count; i++, x++) {
...@@ -1011,34 +1002,21 @@ static int r128_cce_dispatch_write_pixels(struct drm_device *dev, ...@@ -1011,34 +1002,21 @@ static int r128_cce_dispatch_write_pixels(struct drm_device *dev,
} }
buffer_size = depth->n * sizeof(u32); buffer_size = depth->n * sizeof(u32);
buffer = kmalloc(buffer_size, GFP_KERNEL); buffer = memdup_user(depth->buffer, buffer_size);
if (buffer == NULL) { if (IS_ERR(buffer)) {
kfree(x);
kfree(y);
return -ENOMEM;
}
if (copy_from_user(buffer, depth->buffer, buffer_size)) {
kfree(x); kfree(x);
kfree(y); kfree(y);
kfree(buffer); return PTR_ERR(buffer);
return -EFAULT;
} }
if (depth->mask) { if (depth->mask) {
mask_size = depth->n * sizeof(u8); mask_size = depth->n * sizeof(u8);
mask = kmalloc(mask_size, GFP_KERNEL); mask = memdup_user(depth->mask, mask_size);
if (mask == NULL) { if (IS_ERR(mask)) {
kfree(x);
kfree(y);
kfree(buffer);
return -ENOMEM;
}
if (copy_from_user(mask, depth->mask, mask_size)) {
kfree(x); kfree(x);
kfree(y); kfree(y);
kfree(buffer); kfree(buffer);
kfree(mask); return PTR_ERR(mask);
return -EFAULT;
} }
for (i = 0; i < count; i++) { for (i = 0; i < count; i++) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment