Commit 6545135a authored by Gerd Hoffmann's avatar Gerd Hoffmann

drm/qxl: fix __user annotations

Drop them from u64 fields, tag local variables correctly instead.
While being at it switch the code to use u64_to_user_ptr().
Signed-off-by: default avatarGerd Hoffmann <kraxel@redhat.com>
Acked-by: default avatarDaniel Vetter <daniel@ffwll.ch>
Link: http://patchwork.freedesktop.org/patch/msgid/20170620113916.6967-2-kraxel@redhat.com
parent 8814b40b
...@@ -163,7 +163,7 @@ static int qxl_process_single_command(struct qxl_device *qdev, ...@@ -163,7 +163,7 @@ static int qxl_process_single_command(struct qxl_device *qdev,
return -EINVAL; return -EINVAL;
if (!access_ok(VERIFY_READ, if (!access_ok(VERIFY_READ,
(void *)(unsigned long)cmd->command, u64_to_user_ptr(cmd->command),
cmd->command_size)) cmd->command_size))
return -EFAULT; return -EFAULT;
...@@ -183,7 +183,9 @@ static int qxl_process_single_command(struct qxl_device *qdev, ...@@ -183,7 +183,9 @@ static int qxl_process_single_command(struct qxl_device *qdev,
/* TODO copy slow path code from i915 */ /* TODO copy slow path code from i915 */
fb_cmd = qxl_bo_kmap_atomic_page(qdev, cmd_bo, (release->release_offset & PAGE_SIZE)); fb_cmd = qxl_bo_kmap_atomic_page(qdev, cmd_bo, (release->release_offset & PAGE_SIZE));
unwritten = __copy_from_user_inatomic_nocache(fb_cmd + sizeof(union qxl_release_info) + (release->release_offset & ~PAGE_SIZE), (void *)(unsigned long)cmd->command, cmd->command_size); unwritten = __copy_from_user_inatomic_nocache
(fb_cmd + sizeof(union qxl_release_info) + (release->release_offset & ~PAGE_SIZE),
u64_to_user_ptr(cmd->command), cmd->command_size);
{ {
struct qxl_drawable *draw = fb_cmd; struct qxl_drawable *draw = fb_cmd;
...@@ -201,10 +203,9 @@ static int qxl_process_single_command(struct qxl_device *qdev, ...@@ -201,10 +203,9 @@ static int qxl_process_single_command(struct qxl_device *qdev,
num_relocs = 0; num_relocs = 0;
for (i = 0; i < cmd->relocs_num; ++i) { for (i = 0; i < cmd->relocs_num; ++i) {
struct drm_qxl_reloc reloc; struct drm_qxl_reloc reloc;
struct drm_qxl_reloc __user *u = u64_to_user_ptr(cmd->relocs);
if (copy_from_user(&reloc, if (copy_from_user(&reloc, u + i, sizeof(reloc))) {
&((struct drm_qxl_reloc *)(uintptr_t)cmd->relocs)[i],
sizeof(reloc))) {
ret = -EFAULT; ret = -EFAULT;
goto out_free_bos; goto out_free_bos;
} }
...@@ -282,10 +283,10 @@ static int qxl_execbuffer_ioctl(struct drm_device *dev, void *data, ...@@ -282,10 +283,10 @@ static int qxl_execbuffer_ioctl(struct drm_device *dev, void *data,
for (cmd_num = 0; cmd_num < execbuffer->commands_num; ++cmd_num) { for (cmd_num = 0; cmd_num < execbuffer->commands_num; ++cmd_num) {
struct drm_qxl_command *commands = struct drm_qxl_command __user *commands =
(struct drm_qxl_command *)(uintptr_t)execbuffer->commands; u64_to_user_ptr(execbuffer->commands);
if (copy_from_user(&user_cmd, &commands[cmd_num], if (copy_from_user(&user_cmd, commands + cmd_num,
sizeof(user_cmd))) sizeof(user_cmd)))
return -EFAULT; return -EFAULT;
......
...@@ -80,8 +80,8 @@ struct drm_qxl_reloc { ...@@ -80,8 +80,8 @@ struct drm_qxl_reloc {
}; };
struct drm_qxl_command { struct drm_qxl_command {
__u64 __user command; /* void* */ __u64 command; /* void* */
__u64 __user relocs; /* struct drm_qxl_reloc* */ __u64 relocs; /* struct drm_qxl_reloc* */
__u32 type; __u32 type;
__u32 command_size; __u32 command_size;
__u32 relocs_num; __u32 relocs_num;
...@@ -91,7 +91,7 @@ struct drm_qxl_command { ...@@ -91,7 +91,7 @@ struct drm_qxl_command {
struct drm_qxl_execbuffer { struct drm_qxl_execbuffer {
__u32 flags; /* for future use */ __u32 flags; /* for future use */
__u32 commands_num; __u32 commands_num;
__u64 __user commands; /* struct drm_qxl_command* */ __u64 commands; /* struct drm_qxl_command* */
}; };
struct drm_qxl_update_area { struct drm_qxl_update_area {
......
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