diff options
Diffstat (limited to 'drivers/char/drm/i915_ioc32.c')
-rw-r--r-- | drivers/char/drm/i915_ioc32.c | 64 |
1 files changed, 33 insertions, 31 deletions
diff --git a/drivers/char/drm/i915_ioc32.c b/drivers/char/drm/i915_ioc32.c index fe009e1b3a3f..2218a946ec87 100644 --- a/drivers/char/drm/i915_ioc32.c +++ b/drivers/char/drm/i915_ioc32.c | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * 32-bit ioctl compatibility routines for the i915 DRM. | 4 | * 32-bit ioctl compatibility routines for the i915 DRM. |
5 | * | 5 | * |
6 | * \author Alan Hourihane <alanh@fairlite.demon.co.uk> | 6 | * \author Alan Hourihane <alanh@fairlite.demon.co.uk> |
7 | * | 7 | * |
8 | * | 8 | * |
9 | * Copyright (C) Paul Mackerras 2005 | 9 | * Copyright (C) Paul Mackerras 2005 |
@@ -42,51 +42,55 @@ typedef struct _drm_i915_batchbuffer32 { | |||
42 | int DR1; /* hw flags for GFX_OP_DRAWRECT_INFO */ | 42 | int DR1; /* hw flags for GFX_OP_DRAWRECT_INFO */ |
43 | int DR4; /* window origin for GFX_OP_DRAWRECT_INFO */ | 43 | int DR4; /* window origin for GFX_OP_DRAWRECT_INFO */ |
44 | int num_cliprects; /* mulitpass with multiple cliprects? */ | 44 | int num_cliprects; /* mulitpass with multiple cliprects? */ |
45 | u32 cliprects; /* pointer to userspace cliprects */ | 45 | u32 cliprects; /* pointer to userspace cliprects */ |
46 | } drm_i915_batchbuffer32_t; | 46 | } drm_i915_batchbuffer32_t; |
47 | 47 | ||
48 | static int compat_i915_batchbuffer(struct file *file, unsigned int cmd, | 48 | static int compat_i915_batchbuffer(struct file *file, unsigned int cmd, |
49 | unsigned long arg) | 49 | unsigned long arg) |
50 | { | 50 | { |
51 | drm_i915_batchbuffer32_t batchbuffer32; | 51 | drm_i915_batchbuffer32_t batchbuffer32; |
52 | drm_i915_batchbuffer_t __user *batchbuffer; | 52 | drm_i915_batchbuffer_t __user *batchbuffer; |
53 | 53 | ||
54 | if (copy_from_user(&batchbuffer32, (void __user *)arg, sizeof(batchbuffer32))) | 54 | if (copy_from_user |
55 | (&batchbuffer32, (void __user *)arg, sizeof(batchbuffer32))) | ||
55 | return -EFAULT; | 56 | return -EFAULT; |
56 | 57 | ||
57 | batchbuffer = compat_alloc_user_space(sizeof(*batchbuffer)); | 58 | batchbuffer = compat_alloc_user_space(sizeof(*batchbuffer)); |
58 | if (!access_ok(VERIFY_WRITE, batchbuffer, sizeof(*batchbuffer)) | 59 | if (!access_ok(VERIFY_WRITE, batchbuffer, sizeof(*batchbuffer)) |
59 | || __put_user(batchbuffer32.start, &batchbuffer->start) | 60 | || __put_user(batchbuffer32.start, &batchbuffer->start) |
60 | || __put_user(batchbuffer32.used, &batchbuffer->used) | 61 | || __put_user(batchbuffer32.used, &batchbuffer->used) |
61 | || __put_user(batchbuffer32.DR1, &batchbuffer->DR1) | 62 | || __put_user(batchbuffer32.DR1, &batchbuffer->DR1) |
62 | || __put_user(batchbuffer32.DR4, &batchbuffer->DR4) | 63 | || __put_user(batchbuffer32.DR4, &batchbuffer->DR4) |
63 | || __put_user(batchbuffer32.num_cliprects, &batchbuffer->num_cliprects) | 64 | || __put_user(batchbuffer32.num_cliprects, |
65 | &batchbuffer->num_cliprects) | ||
64 | || __put_user((int __user *)(unsigned long)batchbuffer32.cliprects, | 66 | || __put_user((int __user *)(unsigned long)batchbuffer32.cliprects, |
65 | &batchbuffer->cliprects)) | 67 | &batchbuffer->cliprects)) |
66 | return -EFAULT; | 68 | return -EFAULT; |
67 | 69 | ||
68 | return drm_ioctl(file->f_dentry->d_inode, file, | 70 | return drm_ioctl(file->f_dentry->d_inode, file, |
69 | DRM_IOCTL_I915_BATCHBUFFER, (unsigned long) batchbuffer); | 71 | DRM_IOCTL_I915_BATCHBUFFER, |
72 | (unsigned long)batchbuffer); | ||
70 | } | 73 | } |
71 | 74 | ||
72 | typedef struct _drm_i915_cmdbuffer32 { | 75 | typedef struct _drm_i915_cmdbuffer32 { |
73 | u32 buf; /* pointer to userspace command buffer */ | 76 | u32 buf; /* pointer to userspace command buffer */ |
74 | int sz; /* nr bytes in buf */ | 77 | int sz; /* nr bytes in buf */ |
75 | int DR1; /* hw flags for GFX_OP_DRAWRECT_INFO */ | 78 | int DR1; /* hw flags for GFX_OP_DRAWRECT_INFO */ |
76 | int DR4; /* window origin for GFX_OP_DRAWRECT_INFO */ | 79 | int DR4; /* window origin for GFX_OP_DRAWRECT_INFO */ |
77 | int num_cliprects; /* mulitpass with multiple cliprects? */ | 80 | int num_cliprects; /* mulitpass with multiple cliprects? */ |
78 | u32 cliprects; /* pointer to userspace cliprects */ | 81 | u32 cliprects; /* pointer to userspace cliprects */ |
79 | } drm_i915_cmdbuffer32_t; | 82 | } drm_i915_cmdbuffer32_t; |
80 | 83 | ||
81 | static int compat_i915_cmdbuffer(struct file *file, unsigned int cmd, | 84 | static int compat_i915_cmdbuffer(struct file *file, unsigned int cmd, |
82 | unsigned long arg) | 85 | unsigned long arg) |
83 | { | 86 | { |
84 | drm_i915_cmdbuffer32_t cmdbuffer32; | 87 | drm_i915_cmdbuffer32_t cmdbuffer32; |
85 | drm_i915_cmdbuffer_t __user *cmdbuffer; | 88 | drm_i915_cmdbuffer_t __user *cmdbuffer; |
86 | 89 | ||
87 | if (copy_from_user(&cmdbuffer32, (void __user *)arg, sizeof(cmdbuffer32))) | 90 | if (copy_from_user |
91 | (&cmdbuffer32, (void __user *)arg, sizeof(cmdbuffer32))) | ||
88 | return -EFAULT; | 92 | return -EFAULT; |
89 | 93 | ||
90 | cmdbuffer = compat_alloc_user_space(sizeof(*cmdbuffer)); | 94 | cmdbuffer = compat_alloc_user_space(sizeof(*cmdbuffer)); |
91 | if (!access_ok(VERIFY_WRITE, cmdbuffer, sizeof(*cmdbuffer)) | 95 | if (!access_ok(VERIFY_WRITE, cmdbuffer, sizeof(*cmdbuffer)) |
92 | || __put_user((int __user *)(unsigned long)cmdbuffer32.buf, | 96 | || __put_user((int __user *)(unsigned long)cmdbuffer32.buf, |
@@ -98,9 +102,9 @@ static int compat_i915_cmdbuffer(struct file *file, unsigned int cmd, | |||
98 | || __put_user((int __user *)(unsigned long)cmdbuffer32.cliprects, | 102 | || __put_user((int __user *)(unsigned long)cmdbuffer32.cliprects, |
99 | &cmdbuffer->cliprects)) | 103 | &cmdbuffer->cliprects)) |
100 | return -EFAULT; | 104 | return -EFAULT; |
101 | 105 | ||
102 | return drm_ioctl(file->f_dentry->d_inode, file, | 106 | return drm_ioctl(file->f_dentry->d_inode, file, |
103 | DRM_IOCTL_I915_CMDBUFFER, (unsigned long) cmdbuffer); | 107 | DRM_IOCTL_I915_CMDBUFFER, (unsigned long)cmdbuffer); |
104 | } | 108 | } |
105 | 109 | ||
106 | typedef struct drm_i915_irq_emit32 { | 110 | typedef struct drm_i915_irq_emit32 { |
@@ -108,12 +112,12 @@ typedef struct drm_i915_irq_emit32 { | |||
108 | } drm_i915_irq_emit32_t; | 112 | } drm_i915_irq_emit32_t; |
109 | 113 | ||
110 | static int compat_i915_irq_emit(struct file *file, unsigned int cmd, | 114 | static int compat_i915_irq_emit(struct file *file, unsigned int cmd, |
111 | unsigned long arg) | 115 | unsigned long arg) |
112 | { | 116 | { |
113 | drm_i915_irq_emit32_t req32; | 117 | drm_i915_irq_emit32_t req32; |
114 | drm_i915_irq_emit_t __user *request; | 118 | drm_i915_irq_emit_t __user *request; |
115 | 119 | ||
116 | if (copy_from_user(&req32, (void __user *) arg, sizeof(req32))) | 120 | if (copy_from_user(&req32, (void __user *)arg, sizeof(req32))) |
117 | return -EFAULT; | 121 | return -EFAULT; |
118 | 122 | ||
119 | request = compat_alloc_user_space(sizeof(*request)); | 123 | request = compat_alloc_user_space(sizeof(*request)); |
@@ -123,7 +127,7 @@ static int compat_i915_irq_emit(struct file *file, unsigned int cmd, | |||
123 | return -EFAULT; | 127 | return -EFAULT; |
124 | 128 | ||
125 | return drm_ioctl(file->f_dentry->d_inode, file, | 129 | return drm_ioctl(file->f_dentry->d_inode, file, |
126 | DRM_IOCTL_I915_IRQ_EMIT, (unsigned long) request); | 130 | DRM_IOCTL_I915_IRQ_EMIT, (unsigned long)request); |
127 | } | 131 | } |
128 | typedef struct drm_i915_getparam32 { | 132 | typedef struct drm_i915_getparam32 { |
129 | int param; | 133 | int param; |
@@ -131,12 +135,12 @@ typedef struct drm_i915_getparam32 { | |||
131 | } drm_i915_getparam32_t; | 135 | } drm_i915_getparam32_t; |
132 | 136 | ||
133 | static int compat_i915_getparam(struct file *file, unsigned int cmd, | 137 | static int compat_i915_getparam(struct file *file, unsigned int cmd, |
134 | unsigned long arg) | 138 | unsigned long arg) |
135 | { | 139 | { |
136 | drm_i915_getparam32_t req32; | 140 | drm_i915_getparam32_t req32; |
137 | drm_i915_getparam_t __user *request; | 141 | drm_i915_getparam_t __user *request; |
138 | 142 | ||
139 | if (copy_from_user(&req32, (void __user *) arg, sizeof(req32))) | 143 | if (copy_from_user(&req32, (void __user *)arg, sizeof(req32))) |
140 | return -EFAULT; | 144 | return -EFAULT; |
141 | 145 | ||
142 | request = compat_alloc_user_space(sizeof(*request)); | 146 | request = compat_alloc_user_space(sizeof(*request)); |
@@ -147,7 +151,7 @@ static int compat_i915_getparam(struct file *file, unsigned int cmd, | |||
147 | return -EFAULT; | 151 | return -EFAULT; |
148 | 152 | ||
149 | return drm_ioctl(file->f_dentry->d_inode, file, | 153 | return drm_ioctl(file->f_dentry->d_inode, file, |
150 | DRM_IOCTL_I915_GETPARAM, (unsigned long) request); | 154 | DRM_IOCTL_I915_GETPARAM, (unsigned long)request); |
151 | } | 155 | } |
152 | 156 | ||
153 | typedef struct drm_i915_mem_alloc32 { | 157 | typedef struct drm_i915_mem_alloc32 { |
@@ -158,12 +162,12 @@ typedef struct drm_i915_mem_alloc32 { | |||
158 | } drm_i915_mem_alloc32_t; | 162 | } drm_i915_mem_alloc32_t; |
159 | 163 | ||
160 | static int compat_i915_alloc(struct file *file, unsigned int cmd, | 164 | static int compat_i915_alloc(struct file *file, unsigned int cmd, |
161 | unsigned long arg) | 165 | unsigned long arg) |
162 | { | 166 | { |
163 | drm_i915_mem_alloc32_t req32; | 167 | drm_i915_mem_alloc32_t req32; |
164 | drm_i915_mem_alloc_t __user *request; | 168 | drm_i915_mem_alloc_t __user *request; |
165 | 169 | ||
166 | if (copy_from_user(&req32, (void __user *) arg, sizeof(req32))) | 170 | if (copy_from_user(&req32, (void __user *)arg, sizeof(req32))) |
167 | return -EFAULT; | 171 | return -EFAULT; |
168 | 172 | ||
169 | request = compat_alloc_user_space(sizeof(*request)); | 173 | request = compat_alloc_user_space(sizeof(*request)); |
@@ -176,10 +180,9 @@ static int compat_i915_alloc(struct file *file, unsigned int cmd, | |||
176 | return -EFAULT; | 180 | return -EFAULT; |
177 | 181 | ||
178 | return drm_ioctl(file->f_dentry->d_inode, file, | 182 | return drm_ioctl(file->f_dentry->d_inode, file, |
179 | DRM_IOCTL_I915_ALLOC, (unsigned long) request); | 183 | DRM_IOCTL_I915_ALLOC, (unsigned long)request); |
180 | } | 184 | } |
181 | 185 | ||
182 | |||
183 | drm_ioctl_compat_t *i915_compat_ioctls[] = { | 186 | drm_ioctl_compat_t *i915_compat_ioctls[] = { |
184 | [DRM_I915_BATCHBUFFER] = compat_i915_batchbuffer, | 187 | [DRM_I915_BATCHBUFFER] = compat_i915_batchbuffer, |
185 | [DRM_I915_CMDBUFFER] = compat_i915_cmdbuffer, | 188 | [DRM_I915_CMDBUFFER] = compat_i915_cmdbuffer, |
@@ -197,8 +200,7 @@ drm_ioctl_compat_t *i915_compat_ioctls[] = { | |||
197 | * \param arg user argument. | 200 | * \param arg user argument. |
198 | * \return zero on success or negative number on failure. | 201 | * \return zero on success or negative number on failure. |
199 | */ | 202 | */ |
200 | long i915_compat_ioctl(struct file *filp, unsigned int cmd, | 203 | long i915_compat_ioctl(struct file *filp, unsigned int cmd, unsigned long arg) |
201 | unsigned long arg) | ||
202 | { | 204 | { |
203 | unsigned int nr = DRM_IOCTL_NR(cmd); | 205 | unsigned int nr = DRM_IOCTL_NR(cmd); |
204 | drm_ioctl_compat_t *fn = NULL; | 206 | drm_ioctl_compat_t *fn = NULL; |
@@ -206,13 +208,13 @@ long i915_compat_ioctl(struct file *filp, unsigned int cmd, | |||
206 | 208 | ||
207 | if (nr < DRM_COMMAND_BASE) | 209 | if (nr < DRM_COMMAND_BASE) |
208 | return drm_compat_ioctl(filp, cmd, arg); | 210 | return drm_compat_ioctl(filp, cmd, arg); |
209 | 211 | ||
210 | if (nr < DRM_COMMAND_BASE + DRM_ARRAY_SIZE(i915_compat_ioctls)) | 212 | if (nr < DRM_COMMAND_BASE + DRM_ARRAY_SIZE(i915_compat_ioctls)) |
211 | fn = i915_compat_ioctls[nr - DRM_COMMAND_BASE]; | 213 | fn = i915_compat_ioctls[nr - DRM_COMMAND_BASE]; |
212 | 214 | ||
213 | lock_kernel(); /* XXX for now */ | 215 | lock_kernel(); /* XXX for now */ |
214 | if (fn != NULL) | 216 | if (fn != NULL) |
215 | ret = (*fn)(filp, cmd, arg); | 217 | ret = (*fn) (filp, cmd, arg); |
216 | else | 218 | else |
217 | ret = drm_ioctl(filp->f_dentry->d_inode, filp, cmd, arg); | 219 | ret = drm_ioctl(filp->f_dentry->d_inode, filp, cmd, arg); |
218 | unlock_kernel(); | 220 | unlock_kernel(); |