xref: /linux/drivers/gpu/drm/imagination/pvr_drv.c (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1 // SPDX-License-Identifier: GPL-2.0-only OR MIT
2 /* Copyright (c) 2023 Imagination Technologies Ltd. */
3 
4 #include "pvr_context.h"
5 #include "pvr_debugfs.h"
6 #include "pvr_device.h"
7 #include "pvr_drv.h"
8 #include "pvr_free_list.h"
9 #include "pvr_gem.h"
10 #include "pvr_hwrt.h"
11 #include "pvr_job.h"
12 #include "pvr_mmu.h"
13 #include "pvr_power.h"
14 #include "pvr_rogue_defs.h"
15 #include "pvr_rogue_fwif_client.h"
16 #include "pvr_rogue_fwif_shared.h"
17 #include "pvr_vm.h"
18 
19 #include <uapi/drm/pvr_drm.h>
20 
21 #include <drm/drm_device.h>
22 #include <drm/drm_drv.h>
23 #include <drm/drm_file.h>
24 #include <drm/drm_gem.h>
25 #include <drm/drm_ioctl.h>
26 
27 #include <linux/err.h>
28 #include <linux/export.h>
29 #include <linux/fs.h>
30 #include <linux/kernel.h>
31 #include <linux/mod_devicetable.h>
32 #include <linux/module.h>
33 #include <linux/moduleparam.h>
34 #include <linux/of_device.h>
35 #include <linux/of_platform.h>
36 #include <linux/platform_device.h>
37 #include <linux/pm_runtime.h>
38 #include <linux/xarray.h>
39 
40 /**
41  * DOC: PowerVR (Series 6 and later) and IMG Graphics Driver
42  *
43  * This driver supports the following PowerVR/IMG graphics cores from Imagination Technologies:
44  *
45  * * AXE-1-16M (found in Texas Instruments AM62)
46  */
47 
48 /**
49  * pvr_ioctl_create_bo() - IOCTL to create a GEM buffer object.
50  * @drm_dev: [IN] Target DRM device.
51  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
52  * &struct drm_pvr_ioctl_create_bo_args.
53  * @file: [IN] DRM file-private data.
54  *
55  * Called from userspace with %DRM_IOCTL_PVR_CREATE_BO.
56  *
57  * Return:
58  *  * 0 on success,
59  *  * -%EINVAL if the value of &drm_pvr_ioctl_create_bo_args.size is zero
60  *    or wider than &typedef size_t,
61  *  * -%EINVAL if any bits in &drm_pvr_ioctl_create_bo_args.flags that are
62  *    reserved or undefined are set,
63  *  * -%EINVAL if any padding fields in &drm_pvr_ioctl_create_bo_args are not
64  *    zero,
65  *  * Any error encountered while creating the object (see
66  *    pvr_gem_object_create()), or
67  *  * Any error encountered while transferring ownership of the object into a
68  *    userspace-accessible handle (see pvr_gem_object_into_handle()).
69  */
70 static int
71 pvr_ioctl_create_bo(struct drm_device *drm_dev, void *raw_args,
72 		    struct drm_file *file)
73 {
74 	struct drm_pvr_ioctl_create_bo_args *args = raw_args;
75 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
76 	struct pvr_file *pvr_file = to_pvr_file(file);
77 
78 	struct pvr_gem_object *pvr_obj;
79 	size_t sanitized_size;
80 
81 	int idx;
82 	int err;
83 
84 	if (!drm_dev_enter(drm_dev, &idx))
85 		return -EIO;
86 
87 	/* All padding fields must be zeroed. */
88 	if (args->_padding_c != 0) {
89 		err = -EINVAL;
90 		goto err_drm_dev_exit;
91 	}
92 
93 	/*
94 	 * On 64-bit platforms (our primary target), size_t is a u64. However,
95 	 * on other architectures we have to check for overflow when casting
96 	 * down to size_t from u64.
97 	 *
98 	 * We also disallow zero-sized allocations, and reserved (kernel-only)
99 	 * flags.
100 	 */
101 	if (args->size > SIZE_MAX || args->size == 0 || args->flags &
102 	    ~DRM_PVR_BO_FLAGS_MASK || args->size & (PVR_DEVICE_PAGE_SIZE - 1)) {
103 		err = -EINVAL;
104 		goto err_drm_dev_exit;
105 	}
106 
107 	sanitized_size = (size_t)args->size;
108 
109 	/*
110 	 * Create a buffer object and transfer ownership to a userspace-
111 	 * accessible handle.
112 	 */
113 	pvr_obj = pvr_gem_object_create(pvr_dev, sanitized_size, args->flags);
114 	if (IS_ERR(pvr_obj)) {
115 		err = PTR_ERR(pvr_obj);
116 		goto err_drm_dev_exit;
117 	}
118 
119 	/* This function will not modify &args->handle unless it succeeds. */
120 	err = pvr_gem_object_into_handle(pvr_obj, pvr_file, &args->handle);
121 	if (err)
122 		goto err_destroy_obj;
123 
124 	drm_dev_exit(idx);
125 
126 	return 0;
127 
128 err_destroy_obj:
129 	/*
130 	 * GEM objects are refcounted, so there is no explicit destructor
131 	 * function. Instead, we release the singular reference we currently
132 	 * hold on the object and let GEM take care of the rest.
133 	 */
134 	pvr_gem_object_put(pvr_obj);
135 
136 err_drm_dev_exit:
137 	drm_dev_exit(idx);
138 
139 	return err;
140 }
141 
142 /**
143  * pvr_ioctl_get_bo_mmap_offset() - IOCTL to generate a "fake" offset to be
144  * used when calling mmap() from userspace to map the given GEM buffer object
145  * @drm_dev: [IN] DRM device (unused).
146  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
147  *                     &struct drm_pvr_ioctl_get_bo_mmap_offset_args.
148  * @file: [IN] DRM file private data.
149  *
150  * Called from userspace with %DRM_IOCTL_PVR_GET_BO_MMAP_OFFSET.
151  *
152  * This IOCTL does *not* perform an mmap. See the docs on
153  * &struct drm_pvr_ioctl_get_bo_mmap_offset_args for details.
154  *
155  * Return:
156  *  * 0 on success,
157  *  * -%ENOENT if the handle does not reference a valid GEM buffer object,
158  *  * -%EINVAL if any padding fields in &struct
159  *    drm_pvr_ioctl_get_bo_mmap_offset_args are not zero, or
160  *  * Any error returned by drm_gem_create_mmap_offset().
161  */
162 static int
163 pvr_ioctl_get_bo_mmap_offset(struct drm_device *drm_dev, void *raw_args,
164 			     struct drm_file *file)
165 {
166 	struct drm_pvr_ioctl_get_bo_mmap_offset_args *args = raw_args;
167 	struct pvr_file *pvr_file = to_pvr_file(file);
168 	struct pvr_gem_object *pvr_obj;
169 	struct drm_gem_object *gem_obj;
170 	int idx;
171 	int ret;
172 
173 	if (!drm_dev_enter(drm_dev, &idx))
174 		return -EIO;
175 
176 	/* All padding fields must be zeroed. */
177 	if (args->_padding_4 != 0) {
178 		ret = -EINVAL;
179 		goto err_drm_dev_exit;
180 	}
181 
182 	/*
183 	 * Obtain a kernel reference to the buffer object. This reference is
184 	 * counted and must be manually dropped before returning. If a buffer
185 	 * object cannot be found for the specified handle, return -%ENOENT (No
186 	 * such file or directory).
187 	 */
188 	pvr_obj = pvr_gem_object_from_handle(pvr_file, args->handle);
189 	if (!pvr_obj) {
190 		ret = -ENOENT;
191 		goto err_drm_dev_exit;
192 	}
193 
194 	gem_obj = gem_from_pvr_gem(pvr_obj);
195 
196 	/*
197 	 * Allocate a fake offset which can be used in userspace calls to mmap
198 	 * on the DRM device file. If this fails, return the error code. This
199 	 * operation is idempotent.
200 	 */
201 	ret = drm_gem_create_mmap_offset(gem_obj);
202 	if (ret != 0) {
203 		/* Drop our reference to the buffer object. */
204 		drm_gem_object_put(gem_obj);
205 		goto err_drm_dev_exit;
206 	}
207 
208 	/*
209 	 * Read out the fake offset allocated by the earlier call to
210 	 * drm_gem_create_mmap_offset.
211 	 */
212 	args->offset = drm_vma_node_offset_addr(&gem_obj->vma_node);
213 
214 	/* Drop our reference to the buffer object. */
215 	pvr_gem_object_put(pvr_obj);
216 
217 err_drm_dev_exit:
218 	drm_dev_exit(idx);
219 
220 	return ret;
221 }
222 
223 static __always_inline u64
224 pvr_fw_version_packed(u32 major, u32 minor)
225 {
226 	return ((u64)major << 32) | minor;
227 }
228 
229 static u32
230 rogue_get_common_store_partition_space_size(struct pvr_device *pvr_dev)
231 {
232 	u32 max_partitions = 0;
233 	u32 tile_size_x = 0;
234 	u32 tile_size_y = 0;
235 
236 	PVR_FEATURE_VALUE(pvr_dev, tile_size_x, &tile_size_x);
237 	PVR_FEATURE_VALUE(pvr_dev, tile_size_y, &tile_size_y);
238 	PVR_FEATURE_VALUE(pvr_dev, max_partitions, &max_partitions);
239 
240 	if (tile_size_x == 16 && tile_size_y == 16) {
241 		u32 usc_min_output_registers_per_pix = 0;
242 
243 		PVR_FEATURE_VALUE(pvr_dev, usc_min_output_registers_per_pix,
244 				  &usc_min_output_registers_per_pix);
245 
246 		return tile_size_x * tile_size_y * max_partitions *
247 		       usc_min_output_registers_per_pix;
248 	}
249 
250 	return max_partitions * 1024;
251 }
252 
253 static u32
254 rogue_get_common_store_alloc_region_size(struct pvr_device *pvr_dev)
255 {
256 	u32 common_store_size_in_dwords = 512 * 4 * 4;
257 	u32 alloc_region_size;
258 
259 	PVR_FEATURE_VALUE(pvr_dev, common_store_size_in_dwords, &common_store_size_in_dwords);
260 
261 	alloc_region_size = common_store_size_in_dwords - (256U * 4U) -
262 			    rogue_get_common_store_partition_space_size(pvr_dev);
263 
264 	if (PVR_HAS_QUIRK(pvr_dev, 44079)) {
265 		u32 common_store_split_point = (768U * 4U * 4U);
266 
267 		return min(common_store_split_point - (256U * 4U), alloc_region_size);
268 	}
269 
270 	return alloc_region_size;
271 }
272 
273 static inline u32
274 rogue_get_num_phantoms(struct pvr_device *pvr_dev)
275 {
276 	u32 num_clusters = 1;
277 
278 	PVR_FEATURE_VALUE(pvr_dev, num_clusters, &num_clusters);
279 
280 	return ROGUE_REQ_NUM_PHANTOMS(num_clusters);
281 }
282 
283 static inline u32
284 rogue_get_max_coeffs(struct pvr_device *pvr_dev)
285 {
286 	u32 max_coeff_additional_portion = ROGUE_MAX_VERTEX_SHARED_REGISTERS;
287 	u32 pending_allocation_shared_regs = 2U * 1024U;
288 	u32 pending_allocation_coeff_regs = 0U;
289 	u32 num_phantoms = rogue_get_num_phantoms(pvr_dev);
290 	u32 tiles_in_flight = 0;
291 	u32 max_coeff_pixel_portion;
292 
293 	PVR_FEATURE_VALUE(pvr_dev, isp_max_tiles_in_flight, &tiles_in_flight);
294 	max_coeff_pixel_portion = DIV_ROUND_UP(tiles_in_flight, num_phantoms);
295 	max_coeff_pixel_portion *= ROGUE_MAX_PIXEL_SHARED_REGISTERS;
296 
297 	/*
298 	 * Compute tasks on cores with BRN48492 and without compute overlap may lock
299 	 * up without two additional lines of coeffs.
300 	 */
301 	if (PVR_HAS_QUIRK(pvr_dev, 48492) && !PVR_HAS_FEATURE(pvr_dev, compute_overlap))
302 		pending_allocation_coeff_regs = 2U * 1024U;
303 
304 	if (PVR_HAS_ENHANCEMENT(pvr_dev, 38748))
305 		pending_allocation_shared_regs = 0;
306 
307 	if (PVR_HAS_ENHANCEMENT(pvr_dev, 38020))
308 		max_coeff_additional_portion += ROGUE_MAX_COMPUTE_SHARED_REGISTERS;
309 
310 	return rogue_get_common_store_alloc_region_size(pvr_dev) + pending_allocation_coeff_regs -
311 		(max_coeff_pixel_portion + max_coeff_additional_portion +
312 		 pending_allocation_shared_regs);
313 }
314 
315 static inline u32
316 rogue_get_cdm_max_local_mem_size_regs(struct pvr_device *pvr_dev)
317 {
318 	u32 available_coeffs_in_dwords = rogue_get_max_coeffs(pvr_dev);
319 
320 	if (PVR_HAS_QUIRK(pvr_dev, 48492) && PVR_HAS_FEATURE(pvr_dev, roguexe) &&
321 	    !PVR_HAS_FEATURE(pvr_dev, compute_overlap)) {
322 		/* Driver must not use the 2 reserved lines. */
323 		available_coeffs_in_dwords -= ROGUE_CSRM_LINE_SIZE_IN_DWORDS * 2;
324 	}
325 
326 	/*
327 	 * The maximum amount of local memory available to a kernel is the minimum
328 	 * of the total number of coefficient registers available and the max common
329 	 * store allocation size which can be made by the CDM.
330 	 *
331 	 * If any coeff lines are reserved for tessellation or pixel then we need to
332 	 * subtract those too.
333 	 */
334 	return min(available_coeffs_in_dwords, (u32)ROGUE_MAX_PER_KERNEL_LOCAL_MEM_SIZE_REGS);
335 }
336 
337 /**
338  * pvr_dev_query_gpu_info_get()
339  * @pvr_dev: Device pointer.
340  * @args: [IN] Device query arguments containing a pointer to a userspace
341  *        struct drm_pvr_dev_query_gpu_info.
342  *
343  * If the query object pointer is NULL, the size field is updated with the
344  * expected size of the query object.
345  *
346  * Returns:
347  *  * 0 on success, or if size is requested using a NULL pointer, or
348  *  * -%E2BIG if the indicated length of the allocation is less than is
349  *    required to contain the copied data, or
350  *  * -%EFAULT if local memory could not be copied to userspace.
351  */
352 static int
353 pvr_dev_query_gpu_info_get(struct pvr_device *pvr_dev,
354 			   struct drm_pvr_ioctl_dev_query_args *args)
355 {
356 	struct drm_pvr_dev_query_gpu_info gpu_info = {0};
357 	int err;
358 
359 	if (!args->pointer) {
360 		args->size = sizeof(struct drm_pvr_dev_query_gpu_info);
361 		return 0;
362 	}
363 
364 	gpu_info.gpu_id =
365 		pvr_gpu_id_to_packed_bvnc(&pvr_dev->gpu_id);
366 	gpu_info.num_phantoms = rogue_get_num_phantoms(pvr_dev);
367 
368 	err = PVR_UOBJ_SET(args->pointer, args->size, gpu_info);
369 	if (err < 0)
370 		return err;
371 
372 	if (args->size > sizeof(gpu_info))
373 		args->size = sizeof(gpu_info);
374 	return 0;
375 }
376 
377 /**
378  * pvr_dev_query_runtime_info_get()
379  * @pvr_dev: Device pointer.
380  * @args: [IN] Device query arguments containing a pointer to a userspace
381  *        struct drm_pvr_dev_query_runtime_info.
382  *
383  * If the query object pointer is NULL, the size field is updated with the
384  * expected size of the query object.
385  *
386  * Returns:
387  *  * 0 on success, or if size is requested using a NULL pointer, or
388  *  * -%E2BIG if the indicated length of the allocation is less than is
389  *    required to contain the copied data, or
390  *  * -%EFAULT if local memory could not be copied to userspace.
391  */
392 static int
393 pvr_dev_query_runtime_info_get(struct pvr_device *pvr_dev,
394 			       struct drm_pvr_ioctl_dev_query_args *args)
395 {
396 	struct drm_pvr_dev_query_runtime_info runtime_info = {0};
397 	int err;
398 
399 	if (!args->pointer) {
400 		args->size = sizeof(struct drm_pvr_dev_query_runtime_info);
401 		return 0;
402 	}
403 
404 	runtime_info.free_list_min_pages =
405 		pvr_get_free_list_min_pages(pvr_dev);
406 	runtime_info.free_list_max_pages =
407 		ROGUE_PM_MAX_FREELIST_SIZE / ROGUE_PM_PAGE_SIZE;
408 	runtime_info.common_store_alloc_region_size =
409 		rogue_get_common_store_alloc_region_size(pvr_dev);
410 	runtime_info.common_store_partition_space_size =
411 		rogue_get_common_store_partition_space_size(pvr_dev);
412 	runtime_info.max_coeffs = rogue_get_max_coeffs(pvr_dev);
413 	runtime_info.cdm_max_local_mem_size_regs =
414 		rogue_get_cdm_max_local_mem_size_regs(pvr_dev);
415 
416 	err = PVR_UOBJ_SET(args->pointer, args->size, runtime_info);
417 	if (err < 0)
418 		return err;
419 
420 	if (args->size > sizeof(runtime_info))
421 		args->size = sizeof(runtime_info);
422 	return 0;
423 }
424 
425 /**
426  * pvr_dev_query_quirks_get() - Unpack array of quirks at the address given
427  * in a struct drm_pvr_dev_query_quirks, or gets the amount of space required
428  * for it.
429  * @pvr_dev: Device pointer.
430  * @args: [IN] Device query arguments containing a pointer to a userspace
431  *        struct drm_pvr_dev_query_query_quirks.
432  *
433  * If the query object pointer is NULL, the size field is updated with the
434  * expected size of the query object.
435  * If the userspace pointer in the query object is NULL, or the count is
436  * short, no data is copied.
437  * The count field will be updated to that copied, or if either pointer is
438  * NULL, that which would have been copied.
439  * The size field in the query object will be updated to the size copied.
440  *
441  * Returns:
442  *  * 0 on success, or if size/count is requested using a NULL pointer, or
443  *  * -%EINVAL if args contained non-zero reserved fields, or
444  *  * -%E2BIG if the indicated length of the allocation is less than is
445  *    required to contain the copied data, or
446  *  * -%EFAULT if local memory could not be copied to userspace.
447  */
448 static int
449 pvr_dev_query_quirks_get(struct pvr_device *pvr_dev,
450 			 struct drm_pvr_ioctl_dev_query_args *args)
451 {
452 	/*
453 	 * @FIXME - hardcoding of numbers here is intended as an
454 	 * intermediate step so the UAPI can be fixed, but requires a
455 	 * a refactor in the future to store them in a more appropriate
456 	 * location
457 	 */
458 	static const u32 umd_quirks_musthave[] = {
459 		47217,
460 		49927,
461 		62269,
462 	};
463 	static const u32 umd_quirks[] = {
464 		48545,
465 		51764,
466 	};
467 	struct drm_pvr_dev_query_quirks query;
468 	u32 out[ARRAY_SIZE(umd_quirks_musthave) + ARRAY_SIZE(umd_quirks)];
469 	size_t out_musthave_count = 0;
470 	size_t out_count = 0;
471 	int err;
472 
473 	if (!args->pointer) {
474 		args->size = sizeof(struct drm_pvr_dev_query_quirks);
475 		return 0;
476 	}
477 
478 	err = PVR_UOBJ_GET(query, args->size, args->pointer);
479 
480 	if (err < 0)
481 		return err;
482 	if (query._padding_c)
483 		return -EINVAL;
484 
485 	for (int i = 0; i < ARRAY_SIZE(umd_quirks_musthave); i++) {
486 		if (pvr_device_has_uapi_quirk(pvr_dev, umd_quirks_musthave[i])) {
487 			out[out_count++] = umd_quirks_musthave[i];
488 			out_musthave_count++;
489 		}
490 	}
491 
492 	for (int i = 0; i < ARRAY_SIZE(umd_quirks); i++) {
493 		if (pvr_device_has_uapi_quirk(pvr_dev, umd_quirks[i]))
494 			out[out_count++] = umd_quirks[i];
495 	}
496 
497 	if (!query.quirks)
498 		goto copy_out;
499 	if (query.count < out_count)
500 		return -E2BIG;
501 
502 	if (copy_to_user(u64_to_user_ptr(query.quirks), out,
503 			 out_count * sizeof(u32))) {
504 		return -EFAULT;
505 	}
506 
507 	query.musthave_count = out_musthave_count;
508 
509 copy_out:
510 	query.count = out_count;
511 	err = PVR_UOBJ_SET(args->pointer, args->size, query);
512 	if (err < 0)
513 		return err;
514 
515 	args->size = sizeof(query);
516 	return 0;
517 }
518 
519 /**
520  * pvr_dev_query_enhancements_get() - Unpack array of enhancements at the
521  * address given in a struct drm_pvr_dev_query_enhancements, or gets the amount
522  * of space required for it.
523  * @pvr_dev: Device pointer.
524  * @args: [IN] Device query arguments containing a pointer to a userspace
525  *        struct drm_pvr_dev_query_enhancements.
526  *
527  * If the query object pointer is NULL, the size field is updated with the
528  * expected size of the query object.
529  * If the userspace pointer in the query object is NULL, or the count is
530  * short, no data is copied.
531  * The count field will be updated to that copied, or if either pointer is
532  * NULL, that which would have been copied.
533  * The size field in the query object will be updated to the size copied.
534  *
535  * Returns:
536  *  * 0 on success, or if size/count is requested using a NULL pointer, or
537  *  * -%EINVAL if args contained non-zero reserved fields, or
538  *  * -%E2BIG if the indicated length of the allocation is less than is
539  *    required to contain the copied data, or
540  *  * -%EFAULT if local memory could not be copied to userspace.
541  */
542 static int
543 pvr_dev_query_enhancements_get(struct pvr_device *pvr_dev,
544 			       struct drm_pvr_ioctl_dev_query_args *args)
545 {
546 	/*
547 	 * @FIXME - hardcoding of numbers here is intended as an
548 	 * intermediate step so the UAPI can be fixed, but requires a
549 	 * a refactor in the future to store them in a more appropriate
550 	 * location
551 	 */
552 	const u32 umd_enhancements[] = {
553 		35421,
554 		42064,
555 	};
556 	struct drm_pvr_dev_query_enhancements query;
557 	u32 out[ARRAY_SIZE(umd_enhancements)];
558 	size_t out_idx = 0;
559 	int err;
560 
561 	if (!args->pointer) {
562 		args->size = sizeof(struct drm_pvr_dev_query_enhancements);
563 		return 0;
564 	}
565 
566 	err = PVR_UOBJ_GET(query, args->size, args->pointer);
567 
568 	if (err < 0)
569 		return err;
570 	if (query._padding_a)
571 		return -EINVAL;
572 	if (query._padding_c)
573 		return -EINVAL;
574 
575 	for (int i = 0; i < ARRAY_SIZE(umd_enhancements); i++) {
576 		if (pvr_device_has_uapi_enhancement(pvr_dev, umd_enhancements[i]))
577 			out[out_idx++] = umd_enhancements[i];
578 	}
579 
580 	if (!query.enhancements)
581 		goto copy_out;
582 	if (query.count < out_idx)
583 		return -E2BIG;
584 
585 	if (copy_to_user(u64_to_user_ptr(query.enhancements), out,
586 			 out_idx * sizeof(u32))) {
587 		return -EFAULT;
588 	}
589 
590 copy_out:
591 	query.count = out_idx;
592 	err = PVR_UOBJ_SET(args->pointer, args->size, query);
593 	if (err < 0)
594 		return err;
595 
596 	args->size = sizeof(query);
597 	return 0;
598 }
599 
600 /**
601  * pvr_ioctl_dev_query() - IOCTL to copy information about a device
602  * @drm_dev: [IN] DRM device.
603  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
604  *                     &struct drm_pvr_ioctl_dev_query_args.
605  * @file: [IN] DRM file private data.
606  *
607  * Called from userspace with %DRM_IOCTL_PVR_DEV_QUERY.
608  * If the given receiving struct pointer is NULL, or the indicated size is too
609  * small, the expected size of the struct type will be returned in the size
610  * argument field.
611  *
612  * Return:
613  *  * 0 on success or when fetching the size with args->pointer == NULL, or
614  *  * -%E2BIG if the indicated size of the receiving struct is less than is
615  *    required to contain the copied data, or
616  *  * -%EINVAL if the indicated struct type is unknown, or
617  *  * -%ENOMEM if local memory could not be allocated, or
618  *  * -%EFAULT if local memory could not be copied to userspace.
619  */
620 static int
621 pvr_ioctl_dev_query(struct drm_device *drm_dev, void *raw_args,
622 		    struct drm_file *file)
623 {
624 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
625 	struct drm_pvr_ioctl_dev_query_args *args = raw_args;
626 	int idx;
627 	int ret = -EINVAL;
628 
629 	if (!drm_dev_enter(drm_dev, &idx))
630 		return -EIO;
631 
632 	switch ((enum drm_pvr_dev_query)args->type) {
633 	case DRM_PVR_DEV_QUERY_GPU_INFO_GET:
634 		ret = pvr_dev_query_gpu_info_get(pvr_dev, args);
635 		break;
636 
637 	case DRM_PVR_DEV_QUERY_RUNTIME_INFO_GET:
638 		ret = pvr_dev_query_runtime_info_get(pvr_dev, args);
639 		break;
640 
641 	case DRM_PVR_DEV_QUERY_QUIRKS_GET:
642 		ret = pvr_dev_query_quirks_get(pvr_dev, args);
643 		break;
644 
645 	case DRM_PVR_DEV_QUERY_ENHANCEMENTS_GET:
646 		ret = pvr_dev_query_enhancements_get(pvr_dev, args);
647 		break;
648 
649 	case DRM_PVR_DEV_QUERY_HEAP_INFO_GET:
650 		ret = pvr_heap_info_get(pvr_dev, args);
651 		break;
652 
653 	case DRM_PVR_DEV_QUERY_STATIC_DATA_AREAS_GET:
654 		ret = pvr_static_data_areas_get(pvr_dev, args);
655 		break;
656 	}
657 
658 	drm_dev_exit(idx);
659 
660 	return ret;
661 }
662 
663 /**
664  * pvr_ioctl_create_context() - IOCTL to create a context
665  * @drm_dev: [IN] DRM device.
666  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
667  *                     &struct drm_pvr_ioctl_create_context_args.
668  * @file: [IN] DRM file private data.
669  *
670  * Called from userspace with %DRM_IOCTL_PVR_CREATE_CONTEXT.
671  *
672  * Return:
673  *  * 0 on success, or
674  *  * -%EINVAL if provided arguments are invalid, or
675  *  * -%EFAULT if arguments can't be copied from userspace, or
676  *  * Any error returned by pvr_create_render_context().
677  */
678 static int
679 pvr_ioctl_create_context(struct drm_device *drm_dev, void *raw_args,
680 			 struct drm_file *file)
681 {
682 	struct drm_pvr_ioctl_create_context_args *args = raw_args;
683 	struct pvr_file *pvr_file = file->driver_priv;
684 	int idx;
685 	int ret;
686 
687 	if (!drm_dev_enter(drm_dev, &idx))
688 		return -EIO;
689 
690 	ret = pvr_context_create(pvr_file, args);
691 
692 	drm_dev_exit(idx);
693 
694 	return ret;
695 }
696 
697 /**
698  * pvr_ioctl_destroy_context() - IOCTL to destroy a context
699  * @drm_dev: [IN] DRM device.
700  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
701  *                     &struct drm_pvr_ioctl_destroy_context_args.
702  * @file: [IN] DRM file private data.
703  *
704  * Called from userspace with %DRM_IOCTL_PVR_DESTROY_CONTEXT.
705  *
706  * Return:
707  *  * 0 on success, or
708  *  * -%EINVAL if context not in context list.
709  */
710 static int
711 pvr_ioctl_destroy_context(struct drm_device *drm_dev, void *raw_args,
712 			  struct drm_file *file)
713 {
714 	struct drm_pvr_ioctl_destroy_context_args *args = raw_args;
715 	struct pvr_file *pvr_file = file->driver_priv;
716 
717 	if (args->_padding_4)
718 		return -EINVAL;
719 
720 	return pvr_context_destroy(pvr_file, args->handle);
721 }
722 
723 /**
724  * pvr_ioctl_create_free_list() - IOCTL to create a free list
725  * @drm_dev: [IN] DRM device.
726  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
727  *                     &struct drm_pvr_ioctl_create_free_list_args.
728  * @file: [IN] DRM file private data.
729  *
730  * Called from userspace with %DRM_IOCTL_PVR_CREATE_FREE_LIST.
731  *
732  * Return:
733  *  * 0 on success, or
734  *  * Any error returned by pvr_free_list_create().
735  */
736 static int
737 pvr_ioctl_create_free_list(struct drm_device *drm_dev, void *raw_args,
738 			   struct drm_file *file)
739 {
740 	struct drm_pvr_ioctl_create_free_list_args *args = raw_args;
741 	struct pvr_file *pvr_file = to_pvr_file(file);
742 	struct pvr_free_list *free_list;
743 	int idx;
744 	int err;
745 
746 	if (!drm_dev_enter(drm_dev, &idx))
747 		return -EIO;
748 
749 	free_list = pvr_free_list_create(pvr_file, args);
750 	if (IS_ERR(free_list)) {
751 		err = PTR_ERR(free_list);
752 		goto err_drm_dev_exit;
753 	}
754 
755 	/* Allocate object handle for userspace. */
756 	err = xa_alloc(&pvr_file->free_list_handles,
757 		       &args->handle,
758 		       free_list,
759 		       xa_limit_32b,
760 		       GFP_KERNEL);
761 	if (err < 0)
762 		goto err_cleanup;
763 
764 	drm_dev_exit(idx);
765 
766 	return 0;
767 
768 err_cleanup:
769 	pvr_free_list_put(free_list);
770 
771 err_drm_dev_exit:
772 	drm_dev_exit(idx);
773 
774 	return err;
775 }
776 
777 /**
778  * pvr_ioctl_destroy_free_list() - IOCTL to destroy a free list
779  * @drm_dev: [IN] DRM device.
780  * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
781  *                 &struct drm_pvr_ioctl_destroy_free_list_args.
782  * @file: [IN] DRM file private data.
783  *
784  * Called from userspace with %DRM_IOCTL_PVR_DESTROY_FREE_LIST.
785  *
786  * Return:
787  *  * 0 on success, or
788  *  * -%EINVAL if free list not in object list.
789  */
790 static int
791 pvr_ioctl_destroy_free_list(struct drm_device *drm_dev, void *raw_args,
792 			    struct drm_file *file)
793 {
794 	struct drm_pvr_ioctl_destroy_free_list_args *args = raw_args;
795 	struct pvr_file *pvr_file = to_pvr_file(file);
796 	struct pvr_free_list *free_list;
797 
798 	if (args->_padding_4)
799 		return -EINVAL;
800 
801 	free_list = xa_erase(&pvr_file->free_list_handles, args->handle);
802 	if (!free_list)
803 		return -EINVAL;
804 
805 	pvr_free_list_put(free_list);
806 	return 0;
807 }
808 
809 /**
810  * pvr_ioctl_create_hwrt_dataset() - IOCTL to create a HWRT dataset
811  * @drm_dev: [IN] DRM device.
812  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
813  *                     &struct drm_pvr_ioctl_create_hwrt_dataset_args.
814  * @file: [IN] DRM file private data.
815  *
816  * Called from userspace with %DRM_IOCTL_PVR_CREATE_HWRT_DATASET.
817  *
818  * Return:
819  *  * 0 on success, or
820  *  * Any error returned by pvr_hwrt_dataset_create().
821  */
822 static int
823 pvr_ioctl_create_hwrt_dataset(struct drm_device *drm_dev, void *raw_args,
824 			      struct drm_file *file)
825 {
826 	struct drm_pvr_ioctl_create_hwrt_dataset_args *args = raw_args;
827 	struct pvr_file *pvr_file = to_pvr_file(file);
828 	struct pvr_hwrt_dataset *hwrt;
829 	int idx;
830 	int err;
831 
832 	if (!drm_dev_enter(drm_dev, &idx))
833 		return -EIO;
834 
835 	hwrt = pvr_hwrt_dataset_create(pvr_file, args);
836 	if (IS_ERR(hwrt)) {
837 		err = PTR_ERR(hwrt);
838 		goto err_drm_dev_exit;
839 	}
840 
841 	/* Allocate object handle for userspace. */
842 	err = xa_alloc(&pvr_file->hwrt_handles,
843 		       &args->handle,
844 		       hwrt,
845 		       xa_limit_32b,
846 		       GFP_KERNEL);
847 	if (err < 0)
848 		goto err_cleanup;
849 
850 	drm_dev_exit(idx);
851 
852 	return 0;
853 
854 err_cleanup:
855 	pvr_hwrt_dataset_put(hwrt);
856 
857 err_drm_dev_exit:
858 	drm_dev_exit(idx);
859 
860 	return err;
861 }
862 
863 /**
864  * pvr_ioctl_destroy_hwrt_dataset() - IOCTL to destroy a HWRT dataset
865  * @drm_dev: [IN] DRM device.
866  * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
867  *                 &struct drm_pvr_ioctl_destroy_hwrt_dataset_args.
868  * @file: [IN] DRM file private data.
869  *
870  * Called from userspace with %DRM_IOCTL_PVR_DESTROY_HWRT_DATASET.
871  *
872  * Return:
873  *  * 0 on success, or
874  *  * -%EINVAL if HWRT dataset not in object list.
875  */
876 static int
877 pvr_ioctl_destroy_hwrt_dataset(struct drm_device *drm_dev, void *raw_args,
878 			       struct drm_file *file)
879 {
880 	struct drm_pvr_ioctl_destroy_hwrt_dataset_args *args = raw_args;
881 	struct pvr_file *pvr_file = to_pvr_file(file);
882 	struct pvr_hwrt_dataset *hwrt;
883 
884 	if (args->_padding_4)
885 		return -EINVAL;
886 
887 	hwrt = xa_erase(&pvr_file->hwrt_handles, args->handle);
888 	if (!hwrt)
889 		return -EINVAL;
890 
891 	pvr_hwrt_dataset_put(hwrt);
892 	return 0;
893 }
894 
895 /**
896  * pvr_ioctl_create_vm_context() - IOCTL to create a VM context
897  * @drm_dev: [IN] DRM device.
898  * @raw_args: [IN/OUT] Arguments passed to this IOCTL. This must be of type
899  *                     &struct drm_pvr_ioctl_create_vm_context_args.
900  * @file: [IN] DRM file private data.
901  *
902  * Called from userspace with %DRM_IOCTL_PVR_CREATE_VM_CONTEXT.
903  *
904  * Return:
905  *  * 0 on success, or
906  *  * Any error returned by pvr_vm_create_context().
907  */
908 static int
909 pvr_ioctl_create_vm_context(struct drm_device *drm_dev, void *raw_args,
910 			    struct drm_file *file)
911 {
912 	struct drm_pvr_ioctl_create_vm_context_args *args = raw_args;
913 	struct pvr_file *pvr_file = to_pvr_file(file);
914 	struct pvr_vm_context *vm_ctx;
915 	int idx;
916 	int err;
917 
918 	if (!drm_dev_enter(drm_dev, &idx))
919 		return -EIO;
920 
921 	if (args->_padding_4) {
922 		err = -EINVAL;
923 		goto err_drm_dev_exit;
924 	}
925 
926 	vm_ctx = pvr_vm_create_context(pvr_file->pvr_dev, true);
927 	if (IS_ERR(vm_ctx)) {
928 		err = PTR_ERR(vm_ctx);
929 		goto err_drm_dev_exit;
930 	}
931 
932 	/* Allocate object handle for userspace. */
933 	err = xa_alloc(&pvr_file->vm_ctx_handles,
934 		       &args->handle,
935 		       vm_ctx,
936 		       xa_limit_32b,
937 		       GFP_KERNEL);
938 	if (err < 0)
939 		goto err_cleanup;
940 
941 	drm_dev_exit(idx);
942 
943 	return 0;
944 
945 err_cleanup:
946 	pvr_vm_context_put(vm_ctx);
947 
948 err_drm_dev_exit:
949 	drm_dev_exit(idx);
950 
951 	return err;
952 }
953 
954 /**
955  * pvr_ioctl_destroy_vm_context() - IOCTL to destroy a VM context
956 * @drm_dev: [IN] DRM device.
957 * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
958 *                 &struct drm_pvr_ioctl_destroy_vm_context_args.
959 * @file: [IN] DRM file private data.
960 *
961 * Called from userspace with %DRM_IOCTL_PVR_DESTROY_VM_CONTEXT.
962 *
963 * Return:
964 *  * 0 on success, or
965 *  * -%EINVAL if object not in object list.
966  */
967 static int
968 pvr_ioctl_destroy_vm_context(struct drm_device *drm_dev, void *raw_args,
969 			     struct drm_file *file)
970 {
971 	struct drm_pvr_ioctl_destroy_vm_context_args *args = raw_args;
972 	struct pvr_file *pvr_file = to_pvr_file(file);
973 	struct pvr_vm_context *vm_ctx;
974 
975 	if (args->_padding_4)
976 		return -EINVAL;
977 
978 	vm_ctx = xa_erase(&pvr_file->vm_ctx_handles, args->handle);
979 	if (!vm_ctx)
980 		return -EINVAL;
981 
982 	pvr_vm_context_put(vm_ctx);
983 	return 0;
984 }
985 
986 /**
987  * pvr_ioctl_vm_map() - IOCTL to map buffer to GPU address space.
988  * @drm_dev: [IN] DRM device.
989  * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
990  *                 &struct drm_pvr_ioctl_vm_map_args.
991  * @file: [IN] DRM file private data.
992  *
993  * Called from userspace with %DRM_IOCTL_PVR_VM_MAP.
994  *
995  * Return:
996  *  * 0 on success,
997  *  * -%EINVAL if &drm_pvr_ioctl_vm_op_map_args.flags is not zero,
998  *  * -%EINVAL if the bounds specified by &drm_pvr_ioctl_vm_op_map_args.offset
999  *    and &drm_pvr_ioctl_vm_op_map_args.size are not valid or do not fall
1000  *    within the buffer object specified by
1001  *    &drm_pvr_ioctl_vm_op_map_args.handle,
1002  *  * -%EINVAL if the bounds specified by
1003  *    &drm_pvr_ioctl_vm_op_map_args.device_addr and
1004  *    &drm_pvr_ioctl_vm_op_map_args.size do not form a valid device-virtual
1005  *    address range which falls entirely within a single heap, or
1006  *  * -%ENOENT if &drm_pvr_ioctl_vm_op_map_args.handle does not refer to a
1007  *    valid PowerVR buffer object.
1008  */
1009 static int
1010 pvr_ioctl_vm_map(struct drm_device *drm_dev, void *raw_args,
1011 		 struct drm_file *file)
1012 {
1013 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
1014 	struct drm_pvr_ioctl_vm_map_args *args = raw_args;
1015 	struct pvr_file *pvr_file = to_pvr_file(file);
1016 	struct pvr_vm_context *vm_ctx;
1017 
1018 	struct pvr_gem_object *pvr_obj;
1019 	size_t pvr_obj_size;
1020 
1021 	u64 offset_plus_size;
1022 	int idx;
1023 	int err;
1024 
1025 	if (!drm_dev_enter(drm_dev, &idx))
1026 		return -EIO;
1027 
1028 	/* Initial validation of args. */
1029 	if (args->_padding_14) {
1030 		err = -EINVAL;
1031 		goto err_drm_dev_exit;
1032 	}
1033 
1034 	if (args->flags != 0 ||
1035 	    check_add_overflow(args->offset, args->size, &offset_plus_size) ||
1036 	    !pvr_find_heap_containing(pvr_dev, args->device_addr, args->size)) {
1037 		err = -EINVAL;
1038 		goto err_drm_dev_exit;
1039 	}
1040 
1041 	vm_ctx = pvr_vm_context_lookup(pvr_file, args->vm_context_handle);
1042 	if (!vm_ctx) {
1043 		err = -EINVAL;
1044 		goto err_drm_dev_exit;
1045 	}
1046 
1047 	pvr_obj = pvr_gem_object_from_handle(pvr_file, args->handle);
1048 	if (!pvr_obj) {
1049 		err = -ENOENT;
1050 		goto err_put_vm_context;
1051 	}
1052 
1053 	pvr_obj_size = pvr_gem_object_size(pvr_obj);
1054 
1055 	/*
1056 	 * Validate offset and size args. The alignment of these will be
1057 	 * checked when mapping; for now just check that they're within valid
1058 	 * bounds
1059 	 */
1060 	if (args->offset >= pvr_obj_size || offset_plus_size > pvr_obj_size) {
1061 		err = -EINVAL;
1062 		goto err_put_pvr_object;
1063 	}
1064 
1065 	err = pvr_vm_map(vm_ctx, pvr_obj, args->offset,
1066 			 args->device_addr, args->size);
1067 	if (err)
1068 		goto err_put_pvr_object;
1069 
1070 	/*
1071 	 * In order to set up the mapping, we needed a reference to &pvr_obj.
1072 	 * However, pvr_vm_map() obtains and stores its own reference, so we
1073 	 * must release ours before returning.
1074 	 */
1075 
1076 err_put_pvr_object:
1077 	pvr_gem_object_put(pvr_obj);
1078 
1079 err_put_vm_context:
1080 	pvr_vm_context_put(vm_ctx);
1081 
1082 err_drm_dev_exit:
1083 	drm_dev_exit(idx);
1084 
1085 	return err;
1086 }
1087 
1088 /**
1089  * pvr_ioctl_vm_unmap() - IOCTL to unmap buffer from GPU address space.
1090  * @drm_dev: [IN] DRM device.
1091  * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
1092  *                 &struct drm_pvr_ioctl_vm_unmap_args.
1093  * @file: [IN] DRM file private data.
1094  *
1095  * Called from userspace with %DRM_IOCTL_PVR_VM_UNMAP.
1096  *
1097  * Return:
1098  *  * 0 on success,
1099  *  * -%EINVAL if &drm_pvr_ioctl_vm_op_unmap_args.device_addr is not a valid
1100  *    device page-aligned device-virtual address, or
1101  *  * -%ENOENT if there is currently no PowerVR buffer object mapped at
1102  *    &drm_pvr_ioctl_vm_op_unmap_args.device_addr.
1103  */
1104 static int
1105 pvr_ioctl_vm_unmap(struct drm_device *drm_dev, void *raw_args,
1106 		   struct drm_file *file)
1107 {
1108 	struct drm_pvr_ioctl_vm_unmap_args *args = raw_args;
1109 	struct pvr_file *pvr_file = to_pvr_file(file);
1110 	struct pvr_vm_context *vm_ctx;
1111 	int err;
1112 
1113 	/* Initial validation of args. */
1114 	if (args->_padding_4)
1115 		return -EINVAL;
1116 
1117 	vm_ctx = pvr_vm_context_lookup(pvr_file, args->vm_context_handle);
1118 	if (!vm_ctx)
1119 		return -EINVAL;
1120 
1121 	err = pvr_vm_unmap(vm_ctx, args->device_addr, args->size);
1122 
1123 	pvr_vm_context_put(vm_ctx);
1124 
1125 	return err;
1126 }
1127 
1128 /*
1129  * pvr_ioctl_submit_job() - IOCTL to submit a job to the GPU
1130  * @drm_dev: [IN] DRM device.
1131  * @raw_args: [IN] Arguments passed to this IOCTL. This must be of type
1132  *                 &struct drm_pvr_ioctl_submit_job_args.
1133  * @file: [IN] DRM file private data.
1134  *
1135  * Called from userspace with %DRM_IOCTL_PVR_SUBMIT_JOB.
1136  *
1137  * Return:
1138  *  * 0 on success, or
1139  *  * -%EINVAL if arguments are invalid.
1140  */
1141 static int
1142 pvr_ioctl_submit_jobs(struct drm_device *drm_dev, void *raw_args,
1143 		      struct drm_file *file)
1144 {
1145 	struct drm_pvr_ioctl_submit_jobs_args *args = raw_args;
1146 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
1147 	struct pvr_file *pvr_file = to_pvr_file(file);
1148 	int idx;
1149 	int err;
1150 
1151 	if (!drm_dev_enter(drm_dev, &idx))
1152 		return -EIO;
1153 
1154 	err = pvr_submit_jobs(pvr_dev, pvr_file, args);
1155 
1156 	drm_dev_exit(idx);
1157 
1158 	return err;
1159 }
1160 
1161 int
1162 pvr_get_uobj(u64 usr_ptr, u32 usr_stride, u32 min_stride, u32 obj_size, void *out)
1163 {
1164 	if (usr_stride < min_stride)
1165 		return -EINVAL;
1166 
1167 	return copy_struct_from_user(out, obj_size, u64_to_user_ptr(usr_ptr), usr_stride);
1168 }
1169 
1170 int
1171 pvr_set_uobj(u64 usr_ptr, u32 usr_stride, u32 min_stride, u32 obj_size, const void *in)
1172 {
1173 	if (usr_stride < min_stride)
1174 		return -EINVAL;
1175 
1176 	if (copy_to_user(u64_to_user_ptr(usr_ptr), in, min_t(u32, usr_stride, obj_size)))
1177 		return -EFAULT;
1178 
1179 	if (usr_stride > obj_size &&
1180 	    clear_user(u64_to_user_ptr(usr_ptr + obj_size), usr_stride - obj_size)) {
1181 		return -EFAULT;
1182 	}
1183 
1184 	return 0;
1185 }
1186 
1187 int
1188 pvr_get_uobj_array(const struct drm_pvr_obj_array *in, u32 min_stride, u32 obj_size, void **out)
1189 {
1190 	int ret = 0;
1191 	void *out_alloc;
1192 
1193 	if (in->stride < min_stride)
1194 		return -EINVAL;
1195 
1196 	if (!in->count)
1197 		return 0;
1198 
1199 	out_alloc = kvmalloc_array(in->count, obj_size, GFP_KERNEL);
1200 	if (!out_alloc)
1201 		return -ENOMEM;
1202 
1203 	if (obj_size == in->stride) {
1204 		if (copy_from_user(out_alloc, u64_to_user_ptr(in->array),
1205 				   (unsigned long)obj_size * in->count))
1206 			ret = -EFAULT;
1207 	} else {
1208 		void __user *in_ptr = u64_to_user_ptr(in->array);
1209 		void *out_ptr = out_alloc;
1210 
1211 		for (u32 i = 0; i < in->count; i++) {
1212 			ret = copy_struct_from_user(out_ptr, obj_size, in_ptr, in->stride);
1213 			if (ret)
1214 				break;
1215 
1216 			out_ptr += obj_size;
1217 			in_ptr += in->stride;
1218 		}
1219 	}
1220 
1221 	if (ret) {
1222 		kvfree(out_alloc);
1223 		return ret;
1224 	}
1225 
1226 	*out = out_alloc;
1227 	return 0;
1228 }
1229 
1230 int
1231 pvr_set_uobj_array(const struct drm_pvr_obj_array *out, u32 min_stride, u32 obj_size,
1232 		   const void *in)
1233 {
1234 	if (out->stride < min_stride)
1235 		return -EINVAL;
1236 
1237 	if (!out->count)
1238 		return 0;
1239 
1240 	if (obj_size == out->stride) {
1241 		if (copy_to_user(u64_to_user_ptr(out->array), in,
1242 				 (unsigned long)obj_size * out->count))
1243 			return -EFAULT;
1244 	} else {
1245 		u32 cpy_elem_size = min_t(u32, out->stride, obj_size);
1246 		void __user *out_ptr = u64_to_user_ptr(out->array);
1247 		const void *in_ptr = in;
1248 
1249 		for (u32 i = 0; i < out->count; i++) {
1250 			if (copy_to_user(out_ptr, in_ptr, cpy_elem_size))
1251 				return -EFAULT;
1252 
1253 			out_ptr += obj_size;
1254 			in_ptr += out->stride;
1255 		}
1256 
1257 		if (out->stride > obj_size &&
1258 		    clear_user(u64_to_user_ptr(out->array + obj_size),
1259 			       out->stride - obj_size)) {
1260 			return -EFAULT;
1261 		}
1262 	}
1263 
1264 	return 0;
1265 }
1266 
1267 #define DRM_PVR_IOCTL(_name, _func, _flags) \
1268 	DRM_IOCTL_DEF_DRV(PVR_##_name, pvr_ioctl_##_func, _flags)
1269 
1270 /* clang-format off */
1271 
1272 static const struct drm_ioctl_desc pvr_drm_driver_ioctls[] = {
1273 	DRM_PVR_IOCTL(DEV_QUERY, dev_query, DRM_RENDER_ALLOW),
1274 	DRM_PVR_IOCTL(CREATE_BO, create_bo, DRM_RENDER_ALLOW),
1275 	DRM_PVR_IOCTL(GET_BO_MMAP_OFFSET, get_bo_mmap_offset, DRM_RENDER_ALLOW),
1276 	DRM_PVR_IOCTL(CREATE_VM_CONTEXT, create_vm_context, DRM_RENDER_ALLOW),
1277 	DRM_PVR_IOCTL(DESTROY_VM_CONTEXT, destroy_vm_context, DRM_RENDER_ALLOW),
1278 	DRM_PVR_IOCTL(VM_MAP, vm_map, DRM_RENDER_ALLOW),
1279 	DRM_PVR_IOCTL(VM_UNMAP, vm_unmap, DRM_RENDER_ALLOW),
1280 	DRM_PVR_IOCTL(CREATE_CONTEXT, create_context, DRM_RENDER_ALLOW),
1281 	DRM_PVR_IOCTL(DESTROY_CONTEXT, destroy_context, DRM_RENDER_ALLOW),
1282 	DRM_PVR_IOCTL(CREATE_FREE_LIST, create_free_list, DRM_RENDER_ALLOW),
1283 	DRM_PVR_IOCTL(DESTROY_FREE_LIST, destroy_free_list, DRM_RENDER_ALLOW),
1284 	DRM_PVR_IOCTL(CREATE_HWRT_DATASET, create_hwrt_dataset, DRM_RENDER_ALLOW),
1285 	DRM_PVR_IOCTL(DESTROY_HWRT_DATASET, destroy_hwrt_dataset, DRM_RENDER_ALLOW),
1286 	DRM_PVR_IOCTL(SUBMIT_JOBS, submit_jobs, DRM_RENDER_ALLOW),
1287 };
1288 
1289 /* clang-format on */
1290 
1291 #undef DRM_PVR_IOCTL
1292 
1293 /**
1294  * pvr_drm_driver_open() - Driver callback when a new &struct drm_file is opened
1295  * @drm_dev: [IN] DRM device.
1296  * @file: [IN] DRM file private data.
1297  *
1298  * Allocates powervr-specific file private data (&struct pvr_file).
1299  *
1300  * Registered in &pvr_drm_driver.
1301  *
1302  * Return:
1303  *  * 0 on success,
1304  *  * -%ENOMEM if the allocation of a &struct ipvr_file fails, or
1305  *  * Any error returned by pvr_memory_context_init().
1306  */
1307 static int
1308 pvr_drm_driver_open(struct drm_device *drm_dev, struct drm_file *file)
1309 {
1310 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
1311 	struct pvr_file *pvr_file;
1312 
1313 	pvr_file = kzalloc(sizeof(*pvr_file), GFP_KERNEL);
1314 	if (!pvr_file)
1315 		return -ENOMEM;
1316 
1317 	/*
1318 	 * Store reference to base DRM file private data for use by
1319 	 * from_pvr_file.
1320 	 */
1321 	pvr_file->file = file;
1322 
1323 	/*
1324 	 * Store reference to powervr-specific outer device struct in file
1325 	 * private data for convenient access.
1326 	 */
1327 	pvr_file->pvr_dev = pvr_dev;
1328 
1329 	xa_init_flags(&pvr_file->ctx_handles, XA_FLAGS_ALLOC1);
1330 	xa_init_flags(&pvr_file->free_list_handles, XA_FLAGS_ALLOC1);
1331 	xa_init_flags(&pvr_file->hwrt_handles, XA_FLAGS_ALLOC1);
1332 	xa_init_flags(&pvr_file->vm_ctx_handles, XA_FLAGS_ALLOC1);
1333 
1334 	/*
1335 	 * Store reference to powervr-specific file private data in DRM file
1336 	 * private data.
1337 	 */
1338 	file->driver_priv = pvr_file;
1339 
1340 	return 0;
1341 }
1342 
1343 /**
1344  * pvr_drm_driver_postclose() - One of the driver callbacks when a &struct
1345  * drm_file is closed.
1346  * @drm_dev: [IN] DRM device (unused).
1347  * @file: [IN] DRM file private data.
1348  *
1349  * Frees powervr-specific file private data (&struct pvr_file).
1350  *
1351  * Registered in &pvr_drm_driver.
1352  */
1353 static void
1354 pvr_drm_driver_postclose(__always_unused struct drm_device *drm_dev,
1355 			 struct drm_file *file)
1356 {
1357 	struct pvr_file *pvr_file = to_pvr_file(file);
1358 
1359 	/* Kill remaining contexts. */
1360 	pvr_destroy_contexts_for_file(pvr_file);
1361 
1362 	/* Drop references on any remaining objects. */
1363 	pvr_destroy_free_lists_for_file(pvr_file);
1364 	pvr_destroy_hwrt_datasets_for_file(pvr_file);
1365 	pvr_destroy_vm_contexts_for_file(pvr_file);
1366 
1367 	kfree(pvr_file);
1368 	file->driver_priv = NULL;
1369 }
1370 
1371 DEFINE_DRM_GEM_FOPS(pvr_drm_driver_fops);
1372 
1373 static struct drm_driver pvr_drm_driver = {
1374 	.driver_features = DRIVER_GEM | DRIVER_GEM_GPUVA | DRIVER_RENDER |
1375 			   DRIVER_SYNCOBJ | DRIVER_SYNCOBJ_TIMELINE,
1376 	.open = pvr_drm_driver_open,
1377 	.postclose = pvr_drm_driver_postclose,
1378 	.ioctls = pvr_drm_driver_ioctls,
1379 	.num_ioctls = ARRAY_SIZE(pvr_drm_driver_ioctls),
1380 	.fops = &pvr_drm_driver_fops,
1381 #if defined(CONFIG_DEBUG_FS)
1382 	.debugfs_init = pvr_debugfs_init,
1383 #endif
1384 
1385 	.name = PVR_DRIVER_NAME,
1386 	.desc = PVR_DRIVER_DESC,
1387 	.date = PVR_DRIVER_DATE,
1388 	.major = PVR_DRIVER_MAJOR,
1389 	.minor = PVR_DRIVER_MINOR,
1390 	.patchlevel = PVR_DRIVER_PATCHLEVEL,
1391 
1392 	.gem_prime_import_sg_table = drm_gem_shmem_prime_import_sg_table,
1393 	.gem_create_object = pvr_gem_create_object,
1394 };
1395 
1396 static int
1397 pvr_probe(struct platform_device *plat_dev)
1398 {
1399 	struct pvr_device *pvr_dev;
1400 	struct drm_device *drm_dev;
1401 	int err;
1402 
1403 	pvr_dev = devm_drm_dev_alloc(&plat_dev->dev, &pvr_drm_driver,
1404 				     struct pvr_device, base);
1405 	if (IS_ERR(pvr_dev))
1406 		return PTR_ERR(pvr_dev);
1407 
1408 	drm_dev = &pvr_dev->base;
1409 
1410 	platform_set_drvdata(plat_dev, drm_dev);
1411 
1412 	init_rwsem(&pvr_dev->reset_sem);
1413 
1414 	pvr_context_device_init(pvr_dev);
1415 
1416 	err = pvr_queue_device_init(pvr_dev);
1417 	if (err)
1418 		goto err_context_fini;
1419 
1420 	devm_pm_runtime_enable(&plat_dev->dev);
1421 	pm_runtime_mark_last_busy(&plat_dev->dev);
1422 
1423 	pm_runtime_set_autosuspend_delay(&plat_dev->dev, 50);
1424 	pm_runtime_use_autosuspend(&plat_dev->dev);
1425 	pvr_watchdog_init(pvr_dev);
1426 
1427 	err = pvr_device_init(pvr_dev);
1428 	if (err)
1429 		goto err_watchdog_fini;
1430 
1431 	err = drm_dev_register(drm_dev, 0);
1432 	if (err)
1433 		goto err_device_fini;
1434 
1435 	xa_init_flags(&pvr_dev->free_list_ids, XA_FLAGS_ALLOC1);
1436 	xa_init_flags(&pvr_dev->job_ids, XA_FLAGS_ALLOC1);
1437 
1438 	return 0;
1439 
1440 err_device_fini:
1441 	pvr_device_fini(pvr_dev);
1442 
1443 err_watchdog_fini:
1444 	pvr_watchdog_fini(pvr_dev);
1445 
1446 	pvr_queue_device_fini(pvr_dev);
1447 
1448 err_context_fini:
1449 	pvr_context_device_fini(pvr_dev);
1450 
1451 	return err;
1452 }
1453 
1454 static int
1455 pvr_remove(struct platform_device *plat_dev)
1456 {
1457 	struct drm_device *drm_dev = platform_get_drvdata(plat_dev);
1458 	struct pvr_device *pvr_dev = to_pvr_device(drm_dev);
1459 
1460 	WARN_ON(!xa_empty(&pvr_dev->job_ids));
1461 	WARN_ON(!xa_empty(&pvr_dev->free_list_ids));
1462 
1463 	xa_destroy(&pvr_dev->job_ids);
1464 	xa_destroy(&pvr_dev->free_list_ids);
1465 
1466 	pm_runtime_suspend(drm_dev->dev);
1467 	pvr_device_fini(pvr_dev);
1468 	drm_dev_unplug(drm_dev);
1469 	pvr_watchdog_fini(pvr_dev);
1470 	pvr_queue_device_fini(pvr_dev);
1471 	pvr_context_device_fini(pvr_dev);
1472 
1473 	return 0;
1474 }
1475 
1476 static const struct of_device_id dt_match[] = {
1477 	{ .compatible = "img,img-axe", .data = NULL },
1478 	{}
1479 };
1480 MODULE_DEVICE_TABLE(of, dt_match);
1481 
1482 static const struct dev_pm_ops pvr_pm_ops = {
1483 	RUNTIME_PM_OPS(pvr_power_device_suspend, pvr_power_device_resume, pvr_power_device_idle)
1484 };
1485 
1486 static struct platform_driver pvr_driver = {
1487 	.probe = pvr_probe,
1488 	.remove = pvr_remove,
1489 	.driver = {
1490 		.name = PVR_DRIVER_NAME,
1491 		.pm = &pvr_pm_ops,
1492 		.of_match_table = dt_match,
1493 	},
1494 };
1495 module_platform_driver(pvr_driver);
1496 
1497 MODULE_AUTHOR("Imagination Technologies Ltd.");
1498 MODULE_DESCRIPTION(PVR_DRIVER_DESC);
1499 MODULE_LICENSE("Dual MIT/GPL");
1500 MODULE_IMPORT_NS(DMA_BUF);
1501 MODULE_FIRMWARE("powervr/rogue_33.15.11.3_v1.fw");
1502