xref: /aosp_15_r20/external/igt-gpu-tools/tests/kms_atomic_interruptible.c (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker  * Copyright © 2017 Intel Corporation
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 <signal.h>
25*d83cc019SAndroid Build Coastguard Worker 
26*d83cc019SAndroid Build Coastguard Worker #include "igt.h"
27*d83cc019SAndroid Build Coastguard Worker #include "drmtest.h"
28*d83cc019SAndroid Build Coastguard Worker #include "sw_sync.h"
29*d83cc019SAndroid Build Coastguard Worker 
30*d83cc019SAndroid Build Coastguard Worker IGT_TEST_DESCRIPTION("Tests that interrupt various atomic ioctls.");
31*d83cc019SAndroid Build Coastguard Worker 
32*d83cc019SAndroid Build Coastguard Worker enum plane_test_type
33*d83cc019SAndroid Build Coastguard Worker {
34*d83cc019SAndroid Build Coastguard Worker 	test_legacy_modeset,
35*d83cc019SAndroid Build Coastguard Worker 	test_atomic_modeset,
36*d83cc019SAndroid Build Coastguard Worker 	test_legacy_dpms,
37*d83cc019SAndroid Build Coastguard Worker 	test_setplane,
38*d83cc019SAndroid Build Coastguard Worker 	test_setcursor,
39*d83cc019SAndroid Build Coastguard Worker 	test_pageflip
40*d83cc019SAndroid Build Coastguard Worker };
41*d83cc019SAndroid Build Coastguard Worker 
block_plane(igt_display_t * display,igt_output_t * output,enum plane_test_type test_type,igt_plane_t * plane)42*d83cc019SAndroid Build Coastguard Worker static int block_plane(igt_display_t *display, igt_output_t *output, enum plane_test_type test_type, igt_plane_t *plane)
43*d83cc019SAndroid Build Coastguard Worker {
44*d83cc019SAndroid Build Coastguard Worker 	int timeline = sw_sync_timeline_create();
45*d83cc019SAndroid Build Coastguard Worker 
46*d83cc019SAndroid Build Coastguard Worker 	igt_fork(child, 1) {
47*d83cc019SAndroid Build Coastguard Worker 		/* Ignore the signal helper, we need to block indefinitely on the fence. */
48*d83cc019SAndroid Build Coastguard Worker 		signal(SIGCONT, SIG_IGN);
49*d83cc019SAndroid Build Coastguard Worker 
50*d83cc019SAndroid Build Coastguard Worker 		if (test_type == test_legacy_modeset || test_type == test_atomic_modeset) {
51*d83cc019SAndroid Build Coastguard Worker 			igt_output_set_pipe(output, PIPE_NONE);
52*d83cc019SAndroid Build Coastguard Worker 			igt_plane_set_fb(plane, NULL);
53*d83cc019SAndroid Build Coastguard Worker 		}
54*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fence_fd(plane, sw_sync_timeline_create_fence(timeline, 1));
55*d83cc019SAndroid Build Coastguard Worker 
56*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
57*d83cc019SAndroid Build Coastguard Worker 	}
58*d83cc019SAndroid Build Coastguard Worker 
59*d83cc019SAndroid Build Coastguard Worker 	return timeline;
60*d83cc019SAndroid Build Coastguard Worker }
61*d83cc019SAndroid Build Coastguard Worker 
unblock(int block)62*d83cc019SAndroid Build Coastguard Worker static void unblock(int block)
63*d83cc019SAndroid Build Coastguard Worker {
64*d83cc019SAndroid Build Coastguard Worker 	sw_sync_timeline_inc(block, 1);
65*d83cc019SAndroid Build Coastguard Worker 	close(block);
66*d83cc019SAndroid Build Coastguard Worker }
67*d83cc019SAndroid Build Coastguard Worker 
ev_page_flip(int fd,unsigned seq,unsigned tv_sec,unsigned tv_usec,void * user_data)68*d83cc019SAndroid Build Coastguard Worker static void ev_page_flip(int fd, unsigned seq, unsigned tv_sec, unsigned tv_usec, void *user_data)
69*d83cc019SAndroid Build Coastguard Worker {
70*d83cc019SAndroid Build Coastguard Worker 	igt_debug("Retrieved vblank seq: %u on unk\n", seq);
71*d83cc019SAndroid Build Coastguard Worker }
72*d83cc019SAndroid Build Coastguard Worker 
73*d83cc019SAndroid Build Coastguard Worker static drmEventContext drm_events = {
74*d83cc019SAndroid Build Coastguard Worker 	.version = 2,
75*d83cc019SAndroid Build Coastguard Worker 	.page_flip_handler = ev_page_flip
76*d83cc019SAndroid Build Coastguard Worker };
77*d83cc019SAndroid Build Coastguard Worker 
run_plane_test(igt_display_t * display,enum pipe pipe,igt_output_t * output,enum plane_test_type test_type,unsigned plane_type)78*d83cc019SAndroid Build Coastguard Worker static void run_plane_test(igt_display_t *display, enum pipe pipe, igt_output_t *output,
79*d83cc019SAndroid Build Coastguard Worker 			   enum plane_test_type test_type, unsigned plane_type)
80*d83cc019SAndroid Build Coastguard Worker {
81*d83cc019SAndroid Build Coastguard Worker 	drmModeModeInfo *mode;
82*d83cc019SAndroid Build Coastguard Worker 	igt_fb_t fb, fb2;
83*d83cc019SAndroid Build Coastguard Worker 	igt_plane_t *primary, *plane;
84*d83cc019SAndroid Build Coastguard Worker 	int block;
85*d83cc019SAndroid Build Coastguard Worker 
86*d83cc019SAndroid Build Coastguard Worker 	/*
87*d83cc019SAndroid Build Coastguard Worker 	 * Make sure we start with everything disabled to force a real modeset.
88*d83cc019SAndroid Build Coastguard Worker 	 * igt_display_require only sets sw state, and assumes the first test
89*d83cc019SAndroid Build Coastguard Worker 	 * doesn't care about hw state.
90*d83cc019SAndroid Build Coastguard Worker 	 */
91*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
92*d83cc019SAndroid Build Coastguard Worker 
93*d83cc019SAndroid Build Coastguard Worker 	igt_output_set_pipe(output, pipe);
94*d83cc019SAndroid Build Coastguard Worker 
95*d83cc019SAndroid Build Coastguard Worker 	primary = igt_output_get_plane_type(output, DRM_PLANE_TYPE_PRIMARY);
96*d83cc019SAndroid Build Coastguard Worker 	plane = igt_output_get_plane_type(output, plane_type);
97*d83cc019SAndroid Build Coastguard Worker 	mode = igt_output_get_mode(output);
98*d83cc019SAndroid Build Coastguard Worker 
99*d83cc019SAndroid Build Coastguard Worker 	igt_create_fb(display->drm_fd, mode->hdisplay, mode->vdisplay,
100*d83cc019SAndroid Build Coastguard Worker 		      DRM_FORMAT_XRGB8888, LOCAL_DRM_FORMAT_MOD_NONE, &fb);
101*d83cc019SAndroid Build Coastguard Worker 
102*d83cc019SAndroid Build Coastguard Worker 	switch (plane_type) {
103*d83cc019SAndroid Build Coastguard Worker 	case DRM_PLANE_TYPE_PRIMARY:
104*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(display->drm_fd, mode->hdisplay, mode->vdisplay,
105*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_XRGB8888, LOCAL_DRM_FORMAT_MOD_NONE, &fb2);
106*d83cc019SAndroid Build Coastguard Worker 		break;
107*d83cc019SAndroid Build Coastguard Worker 	case DRM_PLANE_TYPE_CURSOR:
108*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(display->drm_fd, 64, 64,
109*d83cc019SAndroid Build Coastguard Worker 		      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE, &fb2);
110*d83cc019SAndroid Build Coastguard Worker 		break;
111*d83cc019SAndroid Build Coastguard Worker 	}
112*d83cc019SAndroid Build Coastguard Worker 
113*d83cc019SAndroid Build Coastguard Worker 	if (test_type != test_legacy_modeset && test_type != test_atomic_modeset) {
114*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(primary, &fb);
115*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
116*d83cc019SAndroid Build Coastguard Worker 	}
117*d83cc019SAndroid Build Coastguard Worker 
118*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &fb2);
119*d83cc019SAndroid Build Coastguard Worker 
120*d83cc019SAndroid Build Coastguard Worker 	block = block_plane(display, output, test_type, plane);
121*d83cc019SAndroid Build Coastguard Worker 
122*d83cc019SAndroid Build Coastguard Worker 	/* wait for the block to complete in block_plane */
123*d83cc019SAndroid Build Coastguard Worker 	sleep(1);
124*d83cc019SAndroid Build Coastguard Worker 
125*d83cc019SAndroid Build Coastguard Worker 	igt_fork(child, 1) {
126*d83cc019SAndroid Build Coastguard Worker 		signal(SIGCONT, SIG_IGN);
127*d83cc019SAndroid Build Coastguard Worker 
128*d83cc019SAndroid Build Coastguard Worker 		 /* unblock after 5 seconds to allow the ioctl to complete,
129*d83cc019SAndroid Build Coastguard Worker 		  * instead of failing with -EINTR.
130*d83cc019SAndroid Build Coastguard Worker 		  */
131*d83cc019SAndroid Build Coastguard Worker 		igt_assert(sleep(5) == 0);
132*d83cc019SAndroid Build Coastguard Worker 
133*d83cc019SAndroid Build Coastguard Worker 		unblock(block);
134*d83cc019SAndroid Build Coastguard Worker 	}
135*d83cc019SAndroid Build Coastguard Worker 
136*d83cc019SAndroid Build Coastguard Worker 	/* run the test */
137*d83cc019SAndroid Build Coastguard Worker 	igt_while_interruptible(true) {
138*d83cc019SAndroid Build Coastguard Worker 		switch (test_type) {
139*d83cc019SAndroid Build Coastguard Worker 			case test_legacy_modeset: {
140*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_crtc crtc = {
141*d83cc019SAndroid Build Coastguard Worker 					.set_connectors_ptr = (uint64_t)(uintptr_t)&output->id,
142*d83cc019SAndroid Build Coastguard Worker 					.count_connectors = 1,
143*d83cc019SAndroid Build Coastguard Worker 					.crtc_id = primary->pipe->crtc_id,
144*d83cc019SAndroid Build Coastguard Worker 					.fb_id = fb2.fb_id,
145*d83cc019SAndroid Build Coastguard Worker 					.mode_valid = 1,
146*d83cc019SAndroid Build Coastguard Worker 					.mode = *(struct drm_mode_modeinfo*)mode,
147*d83cc019SAndroid Build Coastguard Worker 				};
148*d83cc019SAndroid Build Coastguard Worker 
149*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_SETCRTC, &crtc);
150*d83cc019SAndroid Build Coastguard Worker 				break;
151*d83cc019SAndroid Build Coastguard Worker 			}
152*d83cc019SAndroid Build Coastguard Worker 			case test_atomic_modeset: {
153*d83cc019SAndroid Build Coastguard Worker 				uint32_t objs[3] = {
154*d83cc019SAndroid Build Coastguard Worker 					plane->pipe->crtc_id,
155*d83cc019SAndroid Build Coastguard Worker 					output->id,
156*d83cc019SAndroid Build Coastguard Worker 					plane->drm_plane->plane_id
157*d83cc019SAndroid Build Coastguard Worker 				};
158*d83cc019SAndroid Build Coastguard Worker 				uint32_t count_props[3] = { 2, 1, 6 };
159*d83cc019SAndroid Build Coastguard Worker 				uint32_t props[] = {
160*d83cc019SAndroid Build Coastguard Worker 					/* crtc: 2 props */
161*d83cc019SAndroid Build Coastguard Worker 					plane->pipe->props[IGT_CRTC_MODE_ID],
162*d83cc019SAndroid Build Coastguard Worker 					plane->pipe->props[IGT_CRTC_ACTIVE],
163*d83cc019SAndroid Build Coastguard Worker 					/* connector: 1 prop */
164*d83cc019SAndroid Build Coastguard Worker 					output->props[IGT_CONNECTOR_CRTC_ID],
165*d83cc019SAndroid Build Coastguard Worker 					/* plane: remainder props */
166*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_CRTC_ID],
167*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_FB_ID],
168*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_SRC_W],
169*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_SRC_H],
170*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_CRTC_W],
171*d83cc019SAndroid Build Coastguard Worker 					plane->props[IGT_PLANE_CRTC_H]
172*d83cc019SAndroid Build Coastguard Worker 				};
173*d83cc019SAndroid Build Coastguard Worker 				uint64_t prop_vals[] = {
174*d83cc019SAndroid Build Coastguard Worker 					/* crtc */
175*d83cc019SAndroid Build Coastguard Worker 					0, /* mode_id, filled in below */
176*d83cc019SAndroid Build Coastguard Worker 					true,
177*d83cc019SAndroid Build Coastguard Worker 					/* connector */
178*d83cc019SAndroid Build Coastguard Worker 					plane->pipe->crtc_id,
179*d83cc019SAndroid Build Coastguard Worker 					/* plane */
180*d83cc019SAndroid Build Coastguard Worker 					plane->pipe->crtc_id,
181*d83cc019SAndroid Build Coastguard Worker 					fb2.fb_id,
182*d83cc019SAndroid Build Coastguard Worker 					IGT_FIXED(fb2.width, 0),
183*d83cc019SAndroid Build Coastguard Worker 					IGT_FIXED(fb2.height, 0),
184*d83cc019SAndroid Build Coastguard Worker 					fb2.width,
185*d83cc019SAndroid Build Coastguard Worker 					fb2.height
186*d83cc019SAndroid Build Coastguard Worker 				};
187*d83cc019SAndroid Build Coastguard Worker 				uint32_t mode_blob;
188*d83cc019SAndroid Build Coastguard Worker 
189*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_atomic atm = {
190*d83cc019SAndroid Build Coastguard Worker 					.flags = DRM_MODE_ATOMIC_ALLOW_MODESET,
191*d83cc019SAndroid Build Coastguard Worker 					.count_objs = 3, /* crtc, connector, plane */
192*d83cc019SAndroid Build Coastguard Worker 					.objs_ptr = (uint64_t)(uintptr_t)&objs,
193*d83cc019SAndroid Build Coastguard Worker 					.count_props_ptr = (uint64_t)(uintptr_t)&count_props,
194*d83cc019SAndroid Build Coastguard Worker 					.props_ptr = (uint64_t)(uintptr_t)&props,
195*d83cc019SAndroid Build Coastguard Worker 					.prop_values_ptr = (uint64_t)(uintptr_t)&prop_vals,
196*d83cc019SAndroid Build Coastguard Worker 				};
197*d83cc019SAndroid Build Coastguard Worker 
198*d83cc019SAndroid Build Coastguard Worker 				do_or_die(drmModeCreatePropertyBlob(display->drm_fd, mode, sizeof(*mode), &mode_blob));
199*d83cc019SAndroid Build Coastguard Worker 				prop_vals[0] = mode_blob;
200*d83cc019SAndroid Build Coastguard Worker 
201*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_ATOMIC, &atm);
202*d83cc019SAndroid Build Coastguard Worker 
203*d83cc019SAndroid Build Coastguard Worker 				do_or_die(drmModeDestroyPropertyBlob(display->drm_fd, mode_blob));
204*d83cc019SAndroid Build Coastguard Worker 				break;
205*d83cc019SAndroid Build Coastguard Worker 			}
206*d83cc019SAndroid Build Coastguard Worker 			case test_legacy_dpms: {
207*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_connector_set_property prop = {
208*d83cc019SAndroid Build Coastguard Worker 					.value = DRM_MODE_DPMS_OFF,
209*d83cc019SAndroid Build Coastguard Worker 					.prop_id = output->props[IGT_CONNECTOR_DPMS],
210*d83cc019SAndroid Build Coastguard Worker 					.connector_id = output->id,
211*d83cc019SAndroid Build Coastguard Worker 				};
212*d83cc019SAndroid Build Coastguard Worker 
213*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_SETPROPERTY, &prop);
214*d83cc019SAndroid Build Coastguard Worker 				break;
215*d83cc019SAndroid Build Coastguard Worker 			}
216*d83cc019SAndroid Build Coastguard Worker 			case test_setcursor: {
217*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_cursor cur = {
218*d83cc019SAndroid Build Coastguard Worker 					.flags = DRM_MODE_CURSOR_BO,
219*d83cc019SAndroid Build Coastguard Worker 					.crtc_id = plane->pipe->crtc_id,
220*d83cc019SAndroid Build Coastguard Worker 					.width = fb2.width,
221*d83cc019SAndroid Build Coastguard Worker 					.height = fb2.height,
222*d83cc019SAndroid Build Coastguard Worker 					.handle = fb2.gem_handle,
223*d83cc019SAndroid Build Coastguard Worker 				};
224*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_CURSOR, &cur);
225*d83cc019SAndroid Build Coastguard Worker 				break;
226*d83cc019SAndroid Build Coastguard Worker 			}
227*d83cc019SAndroid Build Coastguard Worker 			case test_setplane: {
228*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_set_plane setplane = {
229*d83cc019SAndroid Build Coastguard Worker 					.plane_id = plane->drm_plane->plane_id,
230*d83cc019SAndroid Build Coastguard Worker 					.crtc_id = plane->pipe->crtc_id,
231*d83cc019SAndroid Build Coastguard Worker 					.fb_id = fb2.fb_id,
232*d83cc019SAndroid Build Coastguard Worker 					.crtc_w = fb2.width,
233*d83cc019SAndroid Build Coastguard Worker 					.crtc_h = fb2.height,
234*d83cc019SAndroid Build Coastguard Worker 					.src_w = IGT_FIXED(fb2.width, 0),
235*d83cc019SAndroid Build Coastguard Worker 					.src_h = IGT_FIXED(fb2.height, 0),
236*d83cc019SAndroid Build Coastguard Worker 				};
237*d83cc019SAndroid Build Coastguard Worker 
238*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_SETPLANE, &setplane);
239*d83cc019SAndroid Build Coastguard Worker 				break;
240*d83cc019SAndroid Build Coastguard Worker 			}
241*d83cc019SAndroid Build Coastguard Worker 			case test_pageflip: {
242*d83cc019SAndroid Build Coastguard Worker 				struct drm_mode_crtc_page_flip pageflip = {
243*d83cc019SAndroid Build Coastguard Worker 					.crtc_id = plane->pipe->crtc_id,
244*d83cc019SAndroid Build Coastguard Worker 					.fb_id = fb2.fb_id,
245*d83cc019SAndroid Build Coastguard Worker 					.flags = DRM_MODE_PAGE_FLIP_EVENT,
246*d83cc019SAndroid Build Coastguard Worker 				};
247*d83cc019SAndroid Build Coastguard Worker 
248*d83cc019SAndroid Build Coastguard Worker 				do_ioctl(display->drm_fd, DRM_IOCTL_MODE_PAGE_FLIP, &pageflip);
249*d83cc019SAndroid Build Coastguard Worker 
250*d83cc019SAndroid Build Coastguard Worker 				drmHandleEvent(display->drm_fd, &drm_events);
251*d83cc019SAndroid Build Coastguard Worker 				break;
252*d83cc019SAndroid Build Coastguard Worker 			}
253*d83cc019SAndroid Build Coastguard Worker 		}
254*d83cc019SAndroid Build Coastguard Worker 	}
255*d83cc019SAndroid Build Coastguard Worker 
256*d83cc019SAndroid Build Coastguard Worker 	igt_waitchildren();
257*d83cc019SAndroid Build Coastguard Worker 
258*d83cc019SAndroid Build Coastguard Worker 	/* The mode is unset by the forked helper, force a refresh here */
259*d83cc019SAndroid Build Coastguard Worker 	if (test_type == test_legacy_modeset || test_type == test_atomic_modeset)
260*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_refresh(display, pipe, true);
261*d83cc019SAndroid Build Coastguard Worker 
262*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, NULL);
263*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(primary, NULL);
264*d83cc019SAndroid Build Coastguard Worker 	igt_output_set_pipe(output, PIPE_NONE);
265*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
266*d83cc019SAndroid Build Coastguard Worker 	igt_remove_fb(display->drm_fd, &fb);
267*d83cc019SAndroid Build Coastguard Worker }
268*d83cc019SAndroid Build Coastguard Worker 
269*d83cc019SAndroid Build Coastguard Worker igt_main
270*d83cc019SAndroid Build Coastguard Worker {
271*d83cc019SAndroid Build Coastguard Worker 	igt_display_t display;
272*d83cc019SAndroid Build Coastguard Worker 	igt_output_t *output;
273*d83cc019SAndroid Build Coastguard Worker 	enum pipe pipe;
274*d83cc019SAndroid Build Coastguard Worker 
275*d83cc019SAndroid Build Coastguard Worker 	igt_skip_on_simulation();
276*d83cc019SAndroid Build Coastguard Worker 
277*d83cc019SAndroid Build Coastguard Worker 	igt_fixture {
278*d83cc019SAndroid Build Coastguard Worker 		display.drm_fd = drm_open_driver_master(DRIVER_ANY);
279*d83cc019SAndroid Build Coastguard Worker 
280*d83cc019SAndroid Build Coastguard Worker 		kmstest_set_vt_graphics_mode();
281*d83cc019SAndroid Build Coastguard Worker 
282*d83cc019SAndroid Build Coastguard Worker 		igt_display_require(&display, display.drm_fd);
283*d83cc019SAndroid Build Coastguard Worker 		igt_require(display.is_atomic);
284*d83cc019SAndroid Build Coastguard Worker 		igt_display_require_output(&display);
285*d83cc019SAndroid Build Coastguard Worker 
286*d83cc019SAndroid Build Coastguard Worker 		igt_require_sw_sync();
287*d83cc019SAndroid Build Coastguard Worker 	}
288*d83cc019SAndroid Build Coastguard Worker 
289*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("legacy-setmode")
290*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
291*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_legacy_modeset, DRM_PLANE_TYPE_PRIMARY);
292*d83cc019SAndroid Build Coastguard Worker 			break;
293*d83cc019SAndroid Build Coastguard Worker 		}
294*d83cc019SAndroid Build Coastguard Worker 
295*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("atomic-setmode")
296*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
297*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_atomic_modeset, DRM_PLANE_TYPE_PRIMARY);
298*d83cc019SAndroid Build Coastguard Worker 			break;
299*d83cc019SAndroid Build Coastguard Worker 		}
300*d83cc019SAndroid Build Coastguard Worker 
301*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("legacy-dpms")
302*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
303*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_legacy_dpms, DRM_PLANE_TYPE_PRIMARY);
304*d83cc019SAndroid Build Coastguard Worker 			break;
305*d83cc019SAndroid Build Coastguard Worker 		}
306*d83cc019SAndroid Build Coastguard Worker 
307*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("legacy-pageflip")
308*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
309*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_pageflip, DRM_PLANE_TYPE_PRIMARY);
310*d83cc019SAndroid Build Coastguard Worker 			break;
311*d83cc019SAndroid Build Coastguard Worker 		}
312*d83cc019SAndroid Build Coastguard Worker 
313*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("legacy-cursor")
314*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
315*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_setcursor, DRM_PLANE_TYPE_CURSOR);
316*d83cc019SAndroid Build Coastguard Worker 			break;
317*d83cc019SAndroid Build Coastguard Worker 		}
318*d83cc019SAndroid Build Coastguard Worker 
319*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("universal-setplane-primary")
320*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
321*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_setplane, DRM_PLANE_TYPE_PRIMARY);
322*d83cc019SAndroid Build Coastguard Worker 			break;
323*d83cc019SAndroid Build Coastguard Worker 		}
324*d83cc019SAndroid Build Coastguard Worker 
325*d83cc019SAndroid Build Coastguard Worker 	igt_subtest("universal-setplane-cursor")
326*d83cc019SAndroid Build Coastguard Worker 		for_each_pipe_with_valid_output(&display, pipe, output) {
327*d83cc019SAndroid Build Coastguard Worker 			run_plane_test(&display, pipe, output, test_setplane, DRM_PLANE_TYPE_CURSOR);
328*d83cc019SAndroid Build Coastguard Worker 			break;
329*d83cc019SAndroid Build Coastguard Worker 		}
330*d83cc019SAndroid Build Coastguard Worker 
331*d83cc019SAndroid Build Coastguard Worker 	/* TODO: legacy gamma_set/get, object set/getprop, getcrtc, getconnector */
332*d83cc019SAndroid Build Coastguard Worker 	igt_fixture {
333*d83cc019SAndroid Build Coastguard Worker 		igt_display_fini(&display);
334*d83cc019SAndroid Build Coastguard Worker 	}
335*d83cc019SAndroid Build Coastguard Worker }
336