1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker * Copyright © 2016 Broadcom
3*d83cc019SAndroid Build Coastguard Worker * Copyright © 2019 Collabora, Ltd.
4*d83cc019SAndroid Build Coastguard Worker *
5*d83cc019SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
6*d83cc019SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
7*d83cc019SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
8*d83cc019SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9*d83cc019SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
10*d83cc019SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
11*d83cc019SAndroid Build Coastguard Worker *
12*d83cc019SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
13*d83cc019SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
14*d83cc019SAndroid Build Coastguard Worker * Software.
15*d83cc019SAndroid Build Coastguard Worker *
16*d83cc019SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17*d83cc019SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18*d83cc019SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19*d83cc019SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20*d83cc019SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21*d83cc019SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
22*d83cc019SAndroid Build Coastguard Worker * IN THE SOFTWARE.
23*d83cc019SAndroid Build Coastguard Worker */
24*d83cc019SAndroid Build Coastguard Worker
25*d83cc019SAndroid Build Coastguard Worker #include "igt.h"
26*d83cc019SAndroid Build Coastguard Worker #include "igt_panfrost.h"
27*d83cc019SAndroid Build Coastguard Worker #include "igt_syncobj.h"
28*d83cc019SAndroid Build Coastguard Worker #include <unistd.h>
29*d83cc019SAndroid Build Coastguard Worker #include <stdlib.h>
30*d83cc019SAndroid Build Coastguard Worker #include <stdio.h>
31*d83cc019SAndroid Build Coastguard Worker #include <string.h>
32*d83cc019SAndroid Build Coastguard Worker #include <fcntl.h>
33*d83cc019SAndroid Build Coastguard Worker #include <inttypes.h>
34*d83cc019SAndroid Build Coastguard Worker #include <errno.h>
35*d83cc019SAndroid Build Coastguard Worker #include <sys/stat.h>
36*d83cc019SAndroid Build Coastguard Worker #include <sys/ioctl.h>
37*d83cc019SAndroid Build Coastguard Worker #include "panfrost-job.h"
38*d83cc019SAndroid Build Coastguard Worker #include "panfrost_drm.h"
39*d83cc019SAndroid Build Coastguard Worker
40*d83cc019SAndroid Build Coastguard Worker #define WIDTH 1920
41*d83cc019SAndroid Build Coastguard Worker #define HEIGHT 1080
42*d83cc019SAndroid Build Coastguard Worker #define CLEAR_COLOR 0xff7f7f7f
43*d83cc019SAndroid Build Coastguard Worker
44*d83cc019SAndroid Build Coastguard Worker /* One tenth of a second */
45*d83cc019SAndroid Build Coastguard Worker #define SHORT_TIME_NSEC 100000000ull
46*d83cc019SAndroid Build Coastguard Worker
47*d83cc019SAndroid Build Coastguard Worker /* Add the time that the bad job takes to timeout (sched->timeout) and the time that a reset can take */
48*d83cc019SAndroid Build Coastguard Worker #define BAD_JOB_TIME_NSEC (SHORT_TIME_NSEC + 500000000ull + 100000000ull)
49*d83cc019SAndroid Build Coastguard Worker
50*d83cc019SAndroid Build Coastguard Worker #define NSECS_PER_SEC 1000000000ull
51*d83cc019SAndroid Build Coastguard Worker
52*d83cc019SAndroid Build Coastguard Worker static uint64_t
abs_timeout(uint64_t duration)53*d83cc019SAndroid Build Coastguard Worker abs_timeout(uint64_t duration)
54*d83cc019SAndroid Build Coastguard Worker {
55*d83cc019SAndroid Build Coastguard Worker struct timespec current;
56*d83cc019SAndroid Build Coastguard Worker clock_gettime(CLOCK_MONOTONIC, ¤t);
57*d83cc019SAndroid Build Coastguard Worker return (uint64_t)current.tv_sec * NSECS_PER_SEC + current.tv_nsec + duration;
58*d83cc019SAndroid Build Coastguard Worker }
59*d83cc019SAndroid Build Coastguard Worker
check_error(int fd,struct panfrost_submit * submit)60*d83cc019SAndroid Build Coastguard Worker static void check_error(int fd, struct panfrost_submit *submit)
61*d83cc019SAndroid Build Coastguard Worker {
62*d83cc019SAndroid Build Coastguard Worker struct mali_job_descriptor_header *header;
63*d83cc019SAndroid Build Coastguard Worker
64*d83cc019SAndroid Build Coastguard Worker header = submit->submit_bo->map;
65*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_u64(header->fault_pointer, 0);
66*d83cc019SAndroid Build Coastguard Worker }
67*d83cc019SAndroid Build Coastguard Worker
check_fb(int fd,struct panfrost_bo * bo)68*d83cc019SAndroid Build Coastguard Worker static void check_fb(int fd, struct panfrost_bo *bo)
69*d83cc019SAndroid Build Coastguard Worker {
70*d83cc019SAndroid Build Coastguard Worker int gpu_prod_id = igt_panfrost_get_param(fd, DRM_PANFROST_PARAM_GPU_PROD_ID);
71*d83cc019SAndroid Build Coastguard Worker __uint32_t *fbo;
72*d83cc019SAndroid Build Coastguard Worker int i;
73*d83cc019SAndroid Build Coastguard Worker
74*d83cc019SAndroid Build Coastguard Worker fbo = bo->map;
75*d83cc019SAndroid Build Coastguard Worker
76*d83cc019SAndroid Build Coastguard Worker if (gpu_prod_id >= 0x0750) {
77*d83cc019SAndroid Build Coastguard Worker for (i = 0; i < ALIGN(WIDTH, 16) * HEIGHT; i++)
78*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_u32(fbo[i], CLEAR_COLOR);
79*d83cc019SAndroid Build Coastguard Worker } else {
80*d83cc019SAndroid Build Coastguard Worker // Mask the alpha away because on <=T720 we don't know how to have it
81*d83cc019SAndroid Build Coastguard Worker for (i = 0; i < ALIGN(WIDTH, 16) * HEIGHT; i++)
82*d83cc019SAndroid Build Coastguard Worker igt_assert_eq_u32(fbo[i], CLEAR_COLOR & 0x00ffffff);
83*d83cc019SAndroid Build Coastguard Worker }
84*d83cc019SAndroid Build Coastguard Worker }
85*d83cc019SAndroid Build Coastguard Worker
86*d83cc019SAndroid Build Coastguard Worker igt_main
87*d83cc019SAndroid Build Coastguard Worker {
88*d83cc019SAndroid Build Coastguard Worker int fd;
89*d83cc019SAndroid Build Coastguard Worker
90*d83cc019SAndroid Build Coastguard Worker igt_fixture {
91*d83cc019SAndroid Build Coastguard Worker fd = drm_open_driver(DRIVER_PANFROST);
92*d83cc019SAndroid Build Coastguard Worker }
93*d83cc019SAndroid Build Coastguard Worker
94*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit") {
95*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
96*d83cc019SAndroid Build Coastguard Worker
97*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
98*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
99*d83cc019SAndroid Build Coastguard Worker
100*d83cc019SAndroid Build Coastguard Worker igt_panfrost_bo_mmap(fd, submit->fbo);
101*d83cc019SAndroid Build Coastguard Worker do_ioctl(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args);
102*d83cc019SAndroid Build Coastguard Worker igt_assert(syncobj_wait(fd, &submit->args->out_sync, 1,
103*d83cc019SAndroid Build Coastguard Worker abs_timeout(SHORT_TIME_NSEC), 0, NULL));
104*d83cc019SAndroid Build Coastguard Worker check_error(fd, submit);
105*d83cc019SAndroid Build Coastguard Worker check_fb(fd, submit->fbo);
106*d83cc019SAndroid Build Coastguard Worker igt_panfrost_free_job(fd, submit);
107*d83cc019SAndroid Build Coastguard Worker }
108*d83cc019SAndroid Build Coastguard Worker
109*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit-error-no-jc") {
110*d83cc019SAndroid Build Coastguard Worker struct drm_panfrost_submit submit = {.jc = 0,};
111*d83cc019SAndroid Build Coastguard Worker do_ioctl_err(fd, DRM_IOCTL_PANFROST_SUBMIT, &submit, EINVAL);
112*d83cc019SAndroid Build Coastguard Worker }
113*d83cc019SAndroid Build Coastguard Worker
114*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit-error-bad-in-syncs") {
115*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
116*d83cc019SAndroid Build Coastguard Worker
117*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
118*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
119*d83cc019SAndroid Build Coastguard Worker submit->args->in_syncs = 0ULL;
120*d83cc019SAndroid Build Coastguard Worker submit->args->in_sync_count = 1;
121*d83cc019SAndroid Build Coastguard Worker
122*d83cc019SAndroid Build Coastguard Worker do_ioctl_err(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args, EFAULT);
123*d83cc019SAndroid Build Coastguard Worker }
124*d83cc019SAndroid Build Coastguard Worker
125*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit-error-bad-bo-handles") {
126*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
127*d83cc019SAndroid Build Coastguard Worker
128*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
129*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
130*d83cc019SAndroid Build Coastguard Worker submit->args->bo_handles = 0ULL;
131*d83cc019SAndroid Build Coastguard Worker submit->args->bo_handle_count = 1;
132*d83cc019SAndroid Build Coastguard Worker
133*d83cc019SAndroid Build Coastguard Worker do_ioctl_err(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args, EFAULT);
134*d83cc019SAndroid Build Coastguard Worker }
135*d83cc019SAndroid Build Coastguard Worker
136*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit-error-bad-requirements") {
137*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
138*d83cc019SAndroid Build Coastguard Worker
139*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
140*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
141*d83cc019SAndroid Build Coastguard Worker submit->args->requirements = 2;
142*d83cc019SAndroid Build Coastguard Worker
143*d83cc019SAndroid Build Coastguard Worker do_ioctl_err(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args, EINVAL);
144*d83cc019SAndroid Build Coastguard Worker }
145*d83cc019SAndroid Build Coastguard Worker
146*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-submit-error-bad-out-sync") {
147*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
148*d83cc019SAndroid Build Coastguard Worker
149*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
150*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
151*d83cc019SAndroid Build Coastguard Worker submit->args->out_sync = -1;
152*d83cc019SAndroid Build Coastguard Worker
153*d83cc019SAndroid Build Coastguard Worker do_ioctl_err(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args, ENODEV);
154*d83cc019SAndroid Build Coastguard Worker }
155*d83cc019SAndroid Build Coastguard Worker
156*d83cc019SAndroid Build Coastguard Worker igt_subtest("pan-reset") {
157*d83cc019SAndroid Build Coastguard Worker struct panfrost_submit *submit;
158*d83cc019SAndroid Build Coastguard Worker
159*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, true, WIDTH, HEIGHT,
160*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
161*d83cc019SAndroid Build Coastguard Worker do_ioctl(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args);
162*d83cc019SAndroid Build Coastguard Worker /* Expect for this job to timeout */
163*d83cc019SAndroid Build Coastguard Worker igt_assert(!syncobj_wait(fd, &submit->args->out_sync, 1,
164*d83cc019SAndroid Build Coastguard Worker abs_timeout(SHORT_TIME_NSEC), 0, NULL));
165*d83cc019SAndroid Build Coastguard Worker igt_panfrost_free_job(fd, submit);
166*d83cc019SAndroid Build Coastguard Worker
167*d83cc019SAndroid Build Coastguard Worker submit = igt_panfrost_trivial_job(fd, false, WIDTH, HEIGHT,
168*d83cc019SAndroid Build Coastguard Worker CLEAR_COLOR);
169*d83cc019SAndroid Build Coastguard Worker igt_panfrost_bo_mmap(fd, submit->fbo);
170*d83cc019SAndroid Build Coastguard Worker do_ioctl(fd, DRM_IOCTL_PANFROST_SUBMIT, submit->args);
171*d83cc019SAndroid Build Coastguard Worker /* This one should work */
172*d83cc019SAndroid Build Coastguard Worker igt_assert(syncobj_wait(fd, &submit->args->out_sync, 1,
173*d83cc019SAndroid Build Coastguard Worker abs_timeout(BAD_JOB_TIME_NSEC), 0, NULL));
174*d83cc019SAndroid Build Coastguard Worker check_fb(fd, submit->fbo);
175*d83cc019SAndroid Build Coastguard Worker igt_panfrost_free_job(fd, submit);
176*d83cc019SAndroid Build Coastguard Worker }
177*d83cc019SAndroid Build Coastguard Worker
178*d83cc019SAndroid Build Coastguard Worker igt_fixture {
179*d83cc019SAndroid Build Coastguard Worker close(fd);
180*d83cc019SAndroid Build Coastguard Worker }
181*d83cc019SAndroid Build Coastguard Worker }
182