xref: /aosp_15_r20/external/igt-gpu-tools/tests/vc4_tiling.c (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker  * Copyright © 2017 Broadcom
3*d83cc019SAndroid Build Coastguard Worker  *
4*d83cc019SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*d83cc019SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*d83cc019SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*d83cc019SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*d83cc019SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*d83cc019SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*d83cc019SAndroid Build Coastguard Worker  *
11*d83cc019SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*d83cc019SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*d83cc019SAndroid Build Coastguard Worker  * Software.
14*d83cc019SAndroid Build Coastguard Worker  *
15*d83cc019SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*d83cc019SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*d83cc019SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*d83cc019SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*d83cc019SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*d83cc019SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*d83cc019SAndroid Build Coastguard Worker  * IN THE SOFTWARE.
22*d83cc019SAndroid Build Coastguard Worker  */
23*d83cc019SAndroid Build Coastguard Worker 
24*d83cc019SAndroid Build Coastguard Worker #include "igt.h"
25*d83cc019SAndroid Build Coastguard Worker #include "igt_vc4.h"
26*d83cc019SAndroid Build Coastguard Worker #include <unistd.h>
27*d83cc019SAndroid Build Coastguard Worker #include <stdlib.h>
28*d83cc019SAndroid Build Coastguard Worker #include <stdio.h>
29*d83cc019SAndroid Build Coastguard Worker #include <string.h>
30*d83cc019SAndroid Build Coastguard Worker #include <fcntl.h>
31*d83cc019SAndroid Build Coastguard Worker #include <inttypes.h>
32*d83cc019SAndroid Build Coastguard Worker #include <errno.h>
33*d83cc019SAndroid Build Coastguard Worker #include <sys/stat.h>
34*d83cc019SAndroid Build Coastguard Worker #include <sys/ioctl.h>
35*d83cc019SAndroid Build Coastguard Worker #include <poll.h>
36*d83cc019SAndroid Build Coastguard Worker #include "vc4_drm.h"
37*d83cc019SAndroid Build Coastguard Worker 
38*d83cc019SAndroid Build Coastguard Worker igt_main
39*d83cc019SAndroid Build Coastguard Worker {
40*d83cc019SAndroid Build Coastguard Worker 	int fd;
41*d83cc019SAndroid Build Coastguard Worker 
42*d83cc019SAndroid Build Coastguard Worker 	igt_fixture
43*d83cc019SAndroid Build Coastguard Worker 		fd = drm_open_driver(DRIVER_VC4);
44*d83cc019SAndroid Build Coastguard Worker 
45*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("get-bad-handle") {
46*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_get_tiling get = {
47*d83cc019SAndroid Build Coastguard Worker 			.handle = 0xd0d0d0d0,
48*d83cc019SAndroid Build Coastguard Worker 		};
49*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_GET_TILING, &get, ENOENT);
50*d83cc019SAndroid Build Coastguard Worker 	}
51*d83cc019SAndroid Build Coastguard Worker 
52*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("set-bad-handle") {
53*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_set_tiling set = {
54*d83cc019SAndroid Build Coastguard Worker 			.handle = 0xd0d0d0d0,
55*d83cc019SAndroid Build Coastguard Worker 			.modifier = DRM_FORMAT_MOD_NONE,
56*d83cc019SAndroid Build Coastguard Worker 		};
57*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_SET_TILING, &set, ENOENT);
58*d83cc019SAndroid Build Coastguard Worker 	}
59*d83cc019SAndroid Build Coastguard Worker 
60*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("get-bad-flags") {
61*d83cc019SAndroid Build Coastguard Worker 		int bo = igt_vc4_create_bo(fd, 4096);
62*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_get_tiling get = {
63*d83cc019SAndroid Build Coastguard Worker 			.handle = bo,
64*d83cc019SAndroid Build Coastguard Worker 			.flags = 0xd0d0d0d0,
65*d83cc019SAndroid Build Coastguard Worker 		};
66*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_GET_TILING, &get, EINVAL);
67*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
68*d83cc019SAndroid Build Coastguard Worker 	}
69*d83cc019SAndroid Build Coastguard Worker 
70*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("set-bad-flags") {
71*d83cc019SAndroid Build Coastguard Worker 		int bo = igt_vc4_create_bo(fd, 4096);
72*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_set_tiling set = {
73*d83cc019SAndroid Build Coastguard Worker 			.handle = bo,
74*d83cc019SAndroid Build Coastguard Worker 			.flags = 0xd0d0d0d0,
75*d83cc019SAndroid Build Coastguard Worker 			.modifier = DRM_FORMAT_MOD_NONE,
76*d83cc019SAndroid Build Coastguard Worker 		};
77*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_SET_TILING, &set, EINVAL);
78*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
79*d83cc019SAndroid Build Coastguard Worker 	}
80*d83cc019SAndroid Build Coastguard Worker 
81*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("get-bad-modifier") {
82*d83cc019SAndroid Build Coastguard Worker 		int bo = igt_vc4_create_bo(fd, 4096);
83*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_get_tiling get = {
84*d83cc019SAndroid Build Coastguard Worker 			.handle = bo,
85*d83cc019SAndroid Build Coastguard Worker 			.modifier = 0xd0d0d0d0,
86*d83cc019SAndroid Build Coastguard Worker 		};
87*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_GET_TILING, &get, EINVAL);
88*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
89*d83cc019SAndroid Build Coastguard Worker 	}
90*d83cc019SAndroid Build Coastguard Worker 
91*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("set-bad-modifier") {
92*d83cc019SAndroid Build Coastguard Worker 		int bo = igt_vc4_create_bo(fd, 4096);
93*d83cc019SAndroid Build Coastguard Worker 		struct drm_vc4_set_tiling set = {
94*d83cc019SAndroid Build Coastguard Worker 			.handle = bo,
95*d83cc019SAndroid Build Coastguard Worker 			.modifier = 0xd0d0d0d0,
96*d83cc019SAndroid Build Coastguard Worker 		};
97*d83cc019SAndroid Build Coastguard Worker 		do_ioctl_err(fd, DRM_IOCTL_VC4_SET_TILING, &set, EINVAL);
98*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
99*d83cc019SAndroid Build Coastguard Worker 	}
100*d83cc019SAndroid Build Coastguard Worker 
101*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("set-get") {
102*d83cc019SAndroid Build Coastguard Worker 		int bo = igt_vc4_create_bo(fd, 4096);
103*d83cc019SAndroid Build Coastguard Worker 
104*d83cc019SAndroid Build Coastguard Worker 		/* Default is untiled. */
105*d83cc019SAndroid Build Coastguard Worker 		igt_assert(igt_vc4_get_tiling(fd, bo) == DRM_FORMAT_MOD_NONE);
106*d83cc019SAndroid Build Coastguard Worker 
107*d83cc019SAndroid Build Coastguard Worker 		/* Set to tiled and check. */
108*d83cc019SAndroid Build Coastguard Worker 		igt_vc4_set_tiling(fd, bo, DRM_FORMAT_MOD_BROADCOM_VC4_T_TILED);
109*d83cc019SAndroid Build Coastguard Worker 		igt_assert(igt_vc4_get_tiling(fd, bo) ==
110*d83cc019SAndroid Build Coastguard Worker 			   DRM_FORMAT_MOD_BROADCOM_VC4_T_TILED);
111*d83cc019SAndroid Build Coastguard Worker 
112*d83cc019SAndroid Build Coastguard Worker 		/* Set it back and check. */
113*d83cc019SAndroid Build Coastguard Worker 		igt_vc4_set_tiling(fd, bo, DRM_FORMAT_MOD_NONE);
114*d83cc019SAndroid Build Coastguard Worker 		igt_assert(igt_vc4_get_tiling(fd, bo) == DRM_FORMAT_MOD_NONE);
115*d83cc019SAndroid Build Coastguard Worker 
116*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
117*d83cc019SAndroid Build Coastguard Worker 	}
118*d83cc019SAndroid Build Coastguard Worker 
119*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("get-after-free") {
120*d83cc019SAndroid Build Coastguard Worker 		/* Some size that probably nobody else is using, to
121*d83cc019SAndroid Build Coastguard Worker 		 * encourage getting the same BO back from the cache.
122*d83cc019SAndroid Build Coastguard Worker 		 */
123*d83cc019SAndroid Build Coastguard Worker 		int size = 91 * 4096;
124*d83cc019SAndroid Build Coastguard Worker 		int bo;
125*d83cc019SAndroid Build Coastguard Worker 
126*d83cc019SAndroid Build Coastguard Worker 		bo = igt_vc4_create_bo(fd, size);
127*d83cc019SAndroid Build Coastguard Worker 		igt_vc4_set_tiling(fd, bo, DRM_FORMAT_MOD_BROADCOM_VC4_T_TILED);
128*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
129*d83cc019SAndroid Build Coastguard Worker 
130*d83cc019SAndroid Build Coastguard Worker 		bo = igt_vc4_create_bo(fd, size);
131*d83cc019SAndroid Build Coastguard Worker 		igt_assert(igt_vc4_get_tiling(fd, bo) == DRM_FORMAT_MOD_NONE);
132*d83cc019SAndroid Build Coastguard Worker 		gem_close(fd, bo);
133*d83cc019SAndroid Build Coastguard Worker 	}
134*d83cc019SAndroid Build Coastguard Worker 
135*d83cc019SAndroid Build Coastguard Worker 	igt_fixture
136*d83cc019SAndroid Build Coastguard Worker 		close(fd);
137*d83cc019SAndroid Build Coastguard Worker }
138