xref: /aosp_15_r20/external/igt-gpu-tools/tests/kms_plane_alpha_blend.c (revision d83cc019efdc2edc6c4b16e9034a3ceb8d35d77c)
1*d83cc019SAndroid Build Coastguard Worker /*
2*d83cc019SAndroid Build Coastguard Worker  * Copyright © 2018 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  * Authors:
24*d83cc019SAndroid Build Coastguard Worker  *   Maarten Lankhorst <[email protected]>
25*d83cc019SAndroid Build Coastguard Worker  */
26*d83cc019SAndroid Build Coastguard Worker 
27*d83cc019SAndroid Build Coastguard Worker #include "igt.h"
28*d83cc019SAndroid Build Coastguard Worker 
29*d83cc019SAndroid Build Coastguard Worker IGT_TEST_DESCRIPTION("Test plane alpha and blending mode properties");
30*d83cc019SAndroid Build Coastguard Worker 
31*d83cc019SAndroid Build Coastguard Worker typedef struct {
32*d83cc019SAndroid Build Coastguard Worker 	int gfx_fd;
33*d83cc019SAndroid Build Coastguard Worker 	igt_display_t display;
34*d83cc019SAndroid Build Coastguard Worker 	struct igt_fb xrgb_fb, argb_fb_0, argb_fb_cov_0, argb_fb_7e, argb_fb_cov_7e, argb_fb_fc, argb_fb_cov_fc, argb_fb_100, black_fb, gray_fb;
35*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc;
36*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_t *pipe_crc;
37*d83cc019SAndroid Build Coastguard Worker } data_t;
38*d83cc019SAndroid Build Coastguard Worker 
__draw_gradient(struct igt_fb * fb,int w,int h,double a,cairo_t * cr)39*d83cc019SAndroid Build Coastguard Worker static void __draw_gradient(struct igt_fb *fb, int w, int h, double a, cairo_t *cr)
40*d83cc019SAndroid Build Coastguard Worker {
41*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_t *pat;
42*d83cc019SAndroid Build Coastguard Worker 
43*d83cc019SAndroid Build Coastguard Worker 	pat = cairo_pattern_create_linear(0, 0, w, h);
44*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_add_color_stop_rgba(pat, 0.00, 0.00, 0.00, 0.00, 1.);
45*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_add_color_stop_rgba(pat, 0.25, 1.00, 1.00, 0.00, 1.);
46*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_add_color_stop_rgba(pat, 0.50, 0.00, 1.00, 1.00, 1.);
47*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_add_color_stop_rgba(pat, 0.75, 1.00, 0.00, 1.00, 1.);
48*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_add_color_stop_rgba(pat, 1.00, 1.00, 1.00, 1.00, 1.);
49*d83cc019SAndroid Build Coastguard Worker 
50*d83cc019SAndroid Build Coastguard Worker 	cairo_rectangle(cr, 0, 0, w, h);
51*d83cc019SAndroid Build Coastguard Worker 	cairo_set_source(cr, pat);
52*d83cc019SAndroid Build Coastguard Worker 	cairo_set_operator(cr, CAIRO_OPERATOR_SOURCE);
53*d83cc019SAndroid Build Coastguard Worker 	cairo_paint_with_alpha(cr, a);
54*d83cc019SAndroid Build Coastguard Worker 	cairo_pattern_destroy(pat);
55*d83cc019SAndroid Build Coastguard Worker }
56*d83cc019SAndroid Build Coastguard Worker 
draw_gradient(struct igt_fb * fb,int w,int h,double a)57*d83cc019SAndroid Build Coastguard Worker static void draw_gradient(struct igt_fb *fb, int w, int h, double a)
58*d83cc019SAndroid Build Coastguard Worker {
59*d83cc019SAndroid Build Coastguard Worker 	cairo_t *cr = igt_get_cairo_ctx(fb->fd, fb);
60*d83cc019SAndroid Build Coastguard Worker 
61*d83cc019SAndroid Build Coastguard Worker 	__draw_gradient(fb, w, h, a, cr);
62*d83cc019SAndroid Build Coastguard Worker 
63*d83cc019SAndroid Build Coastguard Worker 	igt_put_cairo_ctx(fb->fd, fb, cr);
64*d83cc019SAndroid Build Coastguard Worker }
65*d83cc019SAndroid Build Coastguard Worker 
draw_gradient_coverage(struct igt_fb * fb,int w,int h,uint8_t a)66*d83cc019SAndroid Build Coastguard Worker static void draw_gradient_coverage(struct igt_fb *fb, int w, int h, uint8_t a)
67*d83cc019SAndroid Build Coastguard Worker {
68*d83cc019SAndroid Build Coastguard Worker 	cairo_t *cr = igt_get_cairo_ctx(fb->fd, fb);
69*d83cc019SAndroid Build Coastguard Worker 	uint8_t *data = cairo_image_surface_get_data(fb->cairo_surface);
70*d83cc019SAndroid Build Coastguard Worker 	uint32_t stride = fb->strides[0];
71*d83cc019SAndroid Build Coastguard Worker 	int i;
72*d83cc019SAndroid Build Coastguard Worker 
73*d83cc019SAndroid Build Coastguard Worker 	__draw_gradient(fb, w, h, 1., cr);
74*d83cc019SAndroid Build Coastguard Worker 
75*d83cc019SAndroid Build Coastguard Worker 	for (; h--; data += stride)
76*d83cc019SAndroid Build Coastguard Worker 		for (i = 0; i < w; i++)
77*d83cc019SAndroid Build Coastguard Worker 			data[i * 4 + 3] = a;
78*d83cc019SAndroid Build Coastguard Worker 
79*d83cc019SAndroid Build Coastguard Worker 	igt_put_cairo_ctx(fb->fd, fb, cr);
80*d83cc019SAndroid Build Coastguard Worker }
81*d83cc019SAndroid Build Coastguard Worker 
draw_squares(struct igt_fb * fb,int w,int h,double a)82*d83cc019SAndroid Build Coastguard Worker static void draw_squares(struct igt_fb *fb, int w, int h, double a)
83*d83cc019SAndroid Build Coastguard Worker {
84*d83cc019SAndroid Build Coastguard Worker 	cairo_t *cr = igt_get_cairo_ctx(fb->fd, fb);
85*d83cc019SAndroid Build Coastguard Worker 
86*d83cc019SAndroid Build Coastguard Worker 	cairo_set_operator(cr, CAIRO_OPERATOR_SOURCE);
87*d83cc019SAndroid Build Coastguard Worker 	igt_paint_color_alpha(cr, 0, 0,         w / 2, h / 2, 1., 0., 0., a);
88*d83cc019SAndroid Build Coastguard Worker 	igt_paint_color_alpha(cr, w / 2, 0,     w / 2, h / 2, 0., 1., 0., a);
89*d83cc019SAndroid Build Coastguard Worker 	igt_paint_color_alpha(cr, 0, h / 2,     w / 2, h / 2, 0., 0., 1., a);
90*d83cc019SAndroid Build Coastguard Worker 	igt_paint_color_alpha(cr, w / 2, h / 2, w / 4, h / 2, 1., 1., 1., a);
91*d83cc019SAndroid Build Coastguard Worker 	igt_paint_color_alpha(cr, 3 * w / 4, h / 2, w / 4, h / 2, 0., 0., 0., a);
92*d83cc019SAndroid Build Coastguard Worker 
93*d83cc019SAndroid Build Coastguard Worker 	igt_put_cairo_ctx(fb->fd, fb, cr);
94*d83cc019SAndroid Build Coastguard Worker }
95*d83cc019SAndroid Build Coastguard Worker 
draw_squares_coverage(struct igt_fb * fb,int w,int h,uint8_t as)96*d83cc019SAndroid Build Coastguard Worker static void draw_squares_coverage(struct igt_fb *fb, int w, int h, uint8_t as)
97*d83cc019SAndroid Build Coastguard Worker {
98*d83cc019SAndroid Build Coastguard Worker 	cairo_t *cr = igt_get_cairo_ctx(fb->fd, fb);
99*d83cc019SAndroid Build Coastguard Worker 	int i, j;
100*d83cc019SAndroid Build Coastguard Worker 	uint32_t *data = (void *)cairo_image_surface_get_data(fb->cairo_surface);
101*d83cc019SAndroid Build Coastguard Worker 	uint32_t stride = fb->strides[0] / 4;
102*d83cc019SAndroid Build Coastguard Worker 	uint32_t a = as << 24;
103*d83cc019SAndroid Build Coastguard Worker 
104*d83cc019SAndroid Build Coastguard Worker 	for (j = 0; j < h / 2; j++) {
105*d83cc019SAndroid Build Coastguard Worker 		for (i = 0; i < w / 2; i++)
106*d83cc019SAndroid Build Coastguard Worker 			data[j * stride + i] = a | 0xff0000;
107*d83cc019SAndroid Build Coastguard Worker 
108*d83cc019SAndroid Build Coastguard Worker 		for (; i < w; i++)
109*d83cc019SAndroid Build Coastguard Worker 			data[j * stride + i] = a | 0xff00;
110*d83cc019SAndroid Build Coastguard Worker 	}
111*d83cc019SAndroid Build Coastguard Worker 
112*d83cc019SAndroid Build Coastguard Worker 	for (j = h / 2; j < h; j++) {
113*d83cc019SAndroid Build Coastguard Worker 		for (i = 0; i < w / 2; i++)
114*d83cc019SAndroid Build Coastguard Worker 			data[j * stride + i] = a | 0xff;
115*d83cc019SAndroid Build Coastguard Worker 
116*d83cc019SAndroid Build Coastguard Worker 		for (; i < 3 * w / 4; i++)
117*d83cc019SAndroid Build Coastguard Worker 			data[j * stride + i] = a | 0xffffff;
118*d83cc019SAndroid Build Coastguard Worker 
119*d83cc019SAndroid Build Coastguard Worker 		for (; i < w; i++)
120*d83cc019SAndroid Build Coastguard Worker 			data[j * stride + i] = a;
121*d83cc019SAndroid Build Coastguard Worker 	}
122*d83cc019SAndroid Build Coastguard Worker 
123*d83cc019SAndroid Build Coastguard Worker 	igt_put_cairo_ctx(fb->fd, fb, cr);
124*d83cc019SAndroid Build Coastguard Worker }
125*d83cc019SAndroid Build Coastguard Worker 
reset_alpha(igt_display_t * display,enum pipe pipe)126*d83cc019SAndroid Build Coastguard Worker static void reset_alpha(igt_display_t *display, enum pipe pipe)
127*d83cc019SAndroid Build Coastguard Worker {
128*d83cc019SAndroid Build Coastguard Worker 	igt_plane_t *plane;
129*d83cc019SAndroid Build Coastguard Worker 
130*d83cc019SAndroid Build Coastguard Worker 	for_each_plane_on_pipe(display, pipe, plane) {
131*d83cc019SAndroid Build Coastguard Worker 		if (igt_plane_has_prop(plane, IGT_PLANE_ALPHA))
132*d83cc019SAndroid Build Coastguard Worker 			igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0xffff);
133*d83cc019SAndroid Build Coastguard Worker 
134*d83cc019SAndroid Build Coastguard Worker 		if (igt_plane_has_prop(plane, IGT_PLANE_PIXEL_BLEND_MODE))
135*d83cc019SAndroid Build Coastguard Worker 			igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "Pre-multiplied");
136*d83cc019SAndroid Build Coastguard Worker 	}
137*d83cc019SAndroid Build Coastguard Worker }
138*d83cc019SAndroid Build Coastguard Worker 
has_multiplied_alpha(data_t * data,igt_plane_t * plane)139*d83cc019SAndroid Build Coastguard Worker static bool has_multiplied_alpha(data_t *data, igt_plane_t *plane)
140*d83cc019SAndroid Build Coastguard Worker {
141*d83cc019SAndroid Build Coastguard Worker 	int ret;
142*d83cc019SAndroid Build Coastguard Worker 
143*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0x8080);
144*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_100);
145*d83cc019SAndroid Build Coastguard Worker 	ret = igt_display_try_commit_atomic(&data->display,
146*d83cc019SAndroid Build Coastguard Worker 		DRM_MODE_ATOMIC_TEST_ONLY | DRM_MODE_ATOMIC_ALLOW_MODESET, NULL);
147*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0xffff);
148*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, NULL);
149*d83cc019SAndroid Build Coastguard Worker 
150*d83cc019SAndroid Build Coastguard Worker 	return ret == 0;
151*d83cc019SAndroid Build Coastguard Worker }
152*d83cc019SAndroid Build Coastguard Worker 
prepare_crtc(data_t * data,igt_output_t * output,enum pipe pipe)153*d83cc019SAndroid Build Coastguard Worker static void prepare_crtc(data_t *data, igt_output_t *output, enum pipe pipe)
154*d83cc019SAndroid Build Coastguard Worker {
155*d83cc019SAndroid Build Coastguard Worker 	drmModeModeInfo *mode;
156*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
157*d83cc019SAndroid Build Coastguard Worker 	int w, h;
158*d83cc019SAndroid Build Coastguard Worker 	igt_plane_t *primary = igt_pipe_get_plane_type(&display->pipes[pipe], DRM_PLANE_TYPE_PRIMARY);
159*d83cc019SAndroid Build Coastguard Worker 
160*d83cc019SAndroid Build Coastguard Worker 	igt_display_reset(display);
161*d83cc019SAndroid Build Coastguard Worker 	igt_output_set_pipe(output, pipe);
162*d83cc019SAndroid Build Coastguard Worker 
163*d83cc019SAndroid Build Coastguard Worker 	/* create the pipe_crc object for this pipe */
164*d83cc019SAndroid Build Coastguard Worker 
165*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
166*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_free(data->pipe_crc);
167*d83cc019SAndroid Build Coastguard Worker 	data->pipe_crc = igt_pipe_crc_new(data->gfx_fd, pipe, INTEL_PIPE_CRC_SOURCE_AUTO);
168*d83cc019SAndroid Build Coastguard Worker #endif
169*d83cc019SAndroid Build Coastguard Worker 
170*d83cc019SAndroid Build Coastguard Worker 	mode = igt_output_get_mode(output);
171*d83cc019SAndroid Build Coastguard Worker 	w = mode->hdisplay;
172*d83cc019SAndroid Build Coastguard Worker 	h = mode->vdisplay;
173*d83cc019SAndroid Build Coastguard Worker 
174*d83cc019SAndroid Build Coastguard Worker 	/* recreate all fbs if incompatible */
175*d83cc019SAndroid Build Coastguard Worker 	if (data->xrgb_fb.width != w || data->xrgb_fb.height != h) {
176*d83cc019SAndroid Build Coastguard Worker 		cairo_t *cr;
177*d83cc019SAndroid Build Coastguard Worker 
178*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->xrgb_fb);
179*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_0);
180*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_cov_0);
181*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_7e);
182*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_fc);
183*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_cov_7e);
184*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_cov_fc);
185*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->argb_fb_100);
186*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->black_fb);
187*d83cc019SAndroid Build Coastguard Worker 		igt_remove_fb(data->gfx_fd, &data->gray_fb);
188*d83cc019SAndroid Build Coastguard Worker 
189*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
190*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_XRGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
191*d83cc019SAndroid Build Coastguard Worker 			      &data->xrgb_fb);
192*d83cc019SAndroid Build Coastguard Worker 		draw_gradient(&data->xrgb_fb, w, h, 1.);
193*d83cc019SAndroid Build Coastguard Worker 
194*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
195*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
196*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_cov_0);
197*d83cc019SAndroid Build Coastguard Worker 		draw_gradient_coverage(&data->argb_fb_cov_0, w, h, 0);
198*d83cc019SAndroid Build Coastguard Worker 
199*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
200*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
201*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_0);
202*d83cc019SAndroid Build Coastguard Worker 
203*d83cc019SAndroid Build Coastguard Worker 		cr = igt_get_cairo_ctx(data->gfx_fd, &data->argb_fb_0);
204*d83cc019SAndroid Build Coastguard Worker 		cairo_set_operator(cr, CAIRO_OPERATOR_SOURCE);
205*d83cc019SAndroid Build Coastguard Worker 		igt_paint_color_alpha(cr, 0, 0, w, h, 0., 0., 0., 0.0);
206*d83cc019SAndroid Build Coastguard Worker 		igt_put_cairo_ctx(data->gfx_fd, &data->argb_fb_0, cr);
207*d83cc019SAndroid Build Coastguard Worker 
208*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
209*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
210*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_7e);
211*d83cc019SAndroid Build Coastguard Worker 		draw_squares(&data->argb_fb_7e, w, h, 126. / 255.);
212*d83cc019SAndroid Build Coastguard Worker 
213*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
214*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
215*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_cov_7e);
216*d83cc019SAndroid Build Coastguard Worker 		draw_squares_coverage(&data->argb_fb_cov_7e, w, h, 0x7e);
217*d83cc019SAndroid Build Coastguard Worker 
218*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
219*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
220*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_fc);
221*d83cc019SAndroid Build Coastguard Worker 		draw_squares(&data->argb_fb_fc, w, h, 252. / 255.);
222*d83cc019SAndroid Build Coastguard Worker 
223*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
224*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
225*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_cov_fc);
226*d83cc019SAndroid Build Coastguard Worker 		draw_squares_coverage(&data->argb_fb_cov_fc, w, h, 0xfc);
227*d83cc019SAndroid Build Coastguard Worker 
228*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
229*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_ARGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
230*d83cc019SAndroid Build Coastguard Worker 			      &data->argb_fb_100);
231*d83cc019SAndroid Build Coastguard Worker 		draw_gradient(&data->argb_fb_100, w, h, 1.);
232*d83cc019SAndroid Build Coastguard Worker 
233*d83cc019SAndroid Build Coastguard Worker 		igt_create_fb(data->gfx_fd, w, h,
234*d83cc019SAndroid Build Coastguard Worker 			      DRM_FORMAT_XRGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
235*d83cc019SAndroid Build Coastguard Worker 			      &data->black_fb);
236*d83cc019SAndroid Build Coastguard Worker 
237*d83cc019SAndroid Build Coastguard Worker 		igt_create_color_fb(data->gfx_fd, w, h,
238*d83cc019SAndroid Build Coastguard Worker 				    DRM_FORMAT_XRGB8888, LOCAL_DRM_FORMAT_MOD_NONE,
239*d83cc019SAndroid Build Coastguard Worker 				    .5, .5, .5, &data->gray_fb);
240*d83cc019SAndroid Build Coastguard Worker 	}
241*d83cc019SAndroid Build Coastguard Worker 
242*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(primary, &data->black_fb);
243*d83cc019SAndroid Build Coastguard Worker 	/* reset alpha property to default */
244*d83cc019SAndroid Build Coastguard Worker 	reset_alpha(display, pipe);
245*d83cc019SAndroid Build Coastguard Worker }
246*d83cc019SAndroid Build Coastguard Worker 
basic_alpha(data_t * data,enum pipe pipe,igt_plane_t * plane)247*d83cc019SAndroid Build Coastguard Worker static void basic_alpha(data_t *data, enum pipe pipe, igt_plane_t *plane)
248*d83cc019SAndroid Build Coastguard Worker {
249*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
250*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
251*d83cc019SAndroid Build Coastguard Worker 	int i;
252*d83cc019SAndroid Build Coastguard Worker 
253*d83cc019SAndroid Build Coastguard Worker 	/* Testcase 1: alpha = 0.0, plane should be transparant. */
254*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
255*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
256*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_start(data->pipe_crc);
257*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_get_single(data->pipe_crc, &ref_crc);
258*d83cc019SAndroid Build Coastguard Worker #endif
259*d83cc019SAndroid Build Coastguard Worker 
260*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_0);
261*d83cc019SAndroid Build Coastguard Worker 
262*d83cc019SAndroid Build Coastguard Worker 	/* transparant fb should be transparant, no matter what.. */
263*d83cc019SAndroid Build Coastguard Worker 	for (i = 7; i < 256; i += 8) {
264*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, i | (i << 8));
265*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
266*d83cc019SAndroid Build Coastguard Worker 
267*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
268*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
269*d83cc019SAndroid Build Coastguard Worker 		igt_assert_crc_equal(&ref_crc, &crc);
270*d83cc019SAndroid Build Coastguard Worker #endif
271*d83cc019SAndroid Build Coastguard Worker 	}
272*d83cc019SAndroid Build Coastguard Worker 
273*d83cc019SAndroid Build Coastguard Worker 	/* And test alpha = 0, should give same CRC, but doesn't on some i915 platforms. */
274*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0);
275*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
276*d83cc019SAndroid Build Coastguard Worker 
277*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
278*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
279*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
280*d83cc019SAndroid Build Coastguard Worker 
281*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_stop(data->pipe_crc);
282*d83cc019SAndroid Build Coastguard Worker #endif
283*d83cc019SAndroid Build Coastguard Worker }
284*d83cc019SAndroid Build Coastguard Worker 
argb_opaque(data_t * data,enum pipe pipe,igt_plane_t * plane)285*d83cc019SAndroid Build Coastguard Worker static void argb_opaque(data_t *data, enum pipe pipe, igt_plane_t *plane)
286*d83cc019SAndroid Build Coastguard Worker {
287*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
288*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
289*d83cc019SAndroid Build Coastguard Worker 
290*d83cc019SAndroid Build Coastguard Worker 	/* alpha = 1.0, plane should be fully opaque, test with an opaque fb */
291*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->xrgb_fb);
292*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
293*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
294*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &ref_crc);
295*d83cc019SAndroid Build Coastguard Worker #endif
296*d83cc019SAndroid Build Coastguard Worker 
297*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_100);
298*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
299*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
300*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
301*d83cc019SAndroid Build Coastguard Worker 
302*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
303*d83cc019SAndroid Build Coastguard Worker #endif
304*d83cc019SAndroid Build Coastguard Worker }
305*d83cc019SAndroid Build Coastguard Worker 
argb_transparant(data_t * data,enum pipe pipe,igt_plane_t * plane)306*d83cc019SAndroid Build Coastguard Worker static void argb_transparant(data_t *data, enum pipe pipe, igt_plane_t *plane)
307*d83cc019SAndroid Build Coastguard Worker {
308*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
309*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
310*d83cc019SAndroid Build Coastguard Worker 
311*d83cc019SAndroid Build Coastguard Worker 	/* alpha = 1.0, plane should be fully opaque, test with a transparant fb */
312*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, NULL);
313*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
314*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
315*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &ref_crc);
316*d83cc019SAndroid Build Coastguard Worker #endif
317*d83cc019SAndroid Build Coastguard Worker 
318*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_0);
319*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
320*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
321*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
322*d83cc019SAndroid Build Coastguard Worker 
323*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
324*d83cc019SAndroid Build Coastguard Worker #endif
325*d83cc019SAndroid Build Coastguard Worker }
326*d83cc019SAndroid Build Coastguard Worker 
constant_alpha_min(data_t * data,enum pipe pipe,igt_plane_t * plane)327*d83cc019SAndroid Build Coastguard Worker static void constant_alpha_min(data_t *data, enum pipe pipe, igt_plane_t *plane)
328*d83cc019SAndroid Build Coastguard Worker {
329*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
330*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
331*d83cc019SAndroid Build Coastguard Worker 
332*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, NULL);
333*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
334*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
335*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &ref_crc);
336*d83cc019SAndroid Build Coastguard Worker #endif
337*d83cc019SAndroid Build Coastguard Worker 
338*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "None");
339*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0);
340*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_100);
341*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
342*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
343*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
344*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
345*d83cc019SAndroid Build Coastguard Worker #endif
346*d83cc019SAndroid Build Coastguard Worker 
347*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_0);
348*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
349*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
350*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
351*d83cc019SAndroid Build Coastguard Worker #endif
352*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
353*d83cc019SAndroid Build Coastguard Worker }
354*d83cc019SAndroid Build Coastguard Worker 
constant_alpha_mid(data_t * data,enum pipe pipe,igt_plane_t * plane)355*d83cc019SAndroid Build Coastguard Worker static void constant_alpha_mid(data_t *data, enum pipe pipe, igt_plane_t *plane)
356*d83cc019SAndroid Build Coastguard Worker {
357*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
358*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
359*d83cc019SAndroid Build Coastguard Worker 
360*d83cc019SAndroid Build Coastguard Worker 	if (plane->type != DRM_PLANE_TYPE_PRIMARY)
361*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(igt_pipe_get_plane_type(&display->pipes[pipe], DRM_PLANE_TYPE_PRIMARY), &data->gray_fb);
362*d83cc019SAndroid Build Coastguard Worker 
363*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "None");
364*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0x7fff);
365*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->xrgb_fb);
366*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
367*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
368*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &ref_crc);
369*d83cc019SAndroid Build Coastguard Worker #endif
370*d83cc019SAndroid Build Coastguard Worker 
371*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_cov_0);
372*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
373*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
374*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
375*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
376*d83cc019SAndroid Build Coastguard Worker #endif
377*d83cc019SAndroid Build Coastguard Worker 
378*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_100);
379*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
380*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
381*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
382*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
383*d83cc019SAndroid Build Coastguard Worker #endif
384*d83cc019SAndroid Build Coastguard Worker }
385*d83cc019SAndroid Build Coastguard Worker 
constant_alpha_max(data_t * data,enum pipe pipe,igt_plane_t * plane)386*d83cc019SAndroid Build Coastguard Worker static void constant_alpha_max(data_t *data, enum pipe pipe, igt_plane_t *plane)
387*d83cc019SAndroid Build Coastguard Worker {
388*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
389*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc, crc;
390*d83cc019SAndroid Build Coastguard Worker 
391*d83cc019SAndroid Build Coastguard Worker 	if (plane->type != DRM_PLANE_TYPE_PRIMARY)
392*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(igt_pipe_get_plane_type(&display->pipes[pipe], DRM_PLANE_TYPE_PRIMARY), &data->gray_fb);
393*d83cc019SAndroid Build Coastguard Worker 
394*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_100);
395*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
396*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
397*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &ref_crc);
398*d83cc019SAndroid Build Coastguard Worker #endif
399*d83cc019SAndroid Build Coastguard Worker 
400*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "None");
401*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
402*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
403*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
404*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
405*d83cc019SAndroid Build Coastguard Worker #endif
406*d83cc019SAndroid Build Coastguard Worker 
407*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_cov_0);
408*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
409*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
410*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
411*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
412*d83cc019SAndroid Build Coastguard Worker #endif
413*d83cc019SAndroid Build Coastguard Worker 
414*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->xrgb_fb);
415*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
416*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
417*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_collect_crc(data->pipe_crc, &crc);
418*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
419*d83cc019SAndroid Build Coastguard Worker #endif
420*d83cc019SAndroid Build Coastguard Worker 
421*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, NULL);
422*d83cc019SAndroid Build Coastguard Worker }
423*d83cc019SAndroid Build Coastguard Worker 
alpha_7efc(data_t * data,enum pipe pipe,igt_plane_t * plane)424*d83cc019SAndroid Build Coastguard Worker static void alpha_7efc(data_t *data, enum pipe pipe, igt_plane_t *plane)
425*d83cc019SAndroid Build Coastguard Worker {
426*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
427*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc = {}, crc = {};
428*d83cc019SAndroid Build Coastguard Worker 	int i;
429*d83cc019SAndroid Build Coastguard Worker 
430*d83cc019SAndroid Build Coastguard Worker 	if (plane->type != DRM_PLANE_TYPE_PRIMARY)
431*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(igt_pipe_get_plane_type(&display->pipes[pipe], DRM_PLANE_TYPE_PRIMARY), &data->gray_fb);
432*d83cc019SAndroid Build Coastguard Worker 
433*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
434*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
435*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_start(data->pipe_crc);
436*d83cc019SAndroid Build Coastguard Worker #endif
437*d83cc019SAndroid Build Coastguard Worker 
438*d83cc019SAndroid Build Coastguard Worker 	/* for coverage, plane alpha and fb alpha should be swappable, so swap fb and alpha */
439*d83cc019SAndroid Build Coastguard Worker 	for (i = 0; i < 256; i += 8) {
440*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, ((i/2) << 8) | (i/2));
441*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(plane, &data->argb_fb_fc);
442*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
443*d83cc019SAndroid Build Coastguard Worker 
444*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
445*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &ref_crc);
446*d83cc019SAndroid Build Coastguard Worker #endif
447*d83cc019SAndroid Build Coastguard Worker 
448*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, (i << 8) | i);
449*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(plane, &data->argb_fb_7e);
450*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
451*d83cc019SAndroid Build Coastguard Worker 
452*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
453*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
454*d83cc019SAndroid Build Coastguard Worker 		igt_assert_crc_equal(&ref_crc, &crc);
455*d83cc019SAndroid Build Coastguard Worker #endif
456*d83cc019SAndroid Build Coastguard Worker 	}
457*d83cc019SAndroid Build Coastguard Worker 
458*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
459*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_stop(data->pipe_crc);
460*d83cc019SAndroid Build Coastguard Worker #endif
461*d83cc019SAndroid Build Coastguard Worker }
462*d83cc019SAndroid Build Coastguard Worker 
coverage_7efc(data_t * data,enum pipe pipe,igt_plane_t * plane)463*d83cc019SAndroid Build Coastguard Worker static void coverage_7efc(data_t *data, enum pipe pipe, igt_plane_t *plane)
464*d83cc019SAndroid Build Coastguard Worker {
465*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
466*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc = {}, crc = {};
467*d83cc019SAndroid Build Coastguard Worker 	int i;
468*d83cc019SAndroid Build Coastguard Worker 
469*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "Coverage");
470*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
471*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
472*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_start(data->pipe_crc);
473*d83cc019SAndroid Build Coastguard Worker #endif
474*d83cc019SAndroid Build Coastguard Worker 
475*d83cc019SAndroid Build Coastguard Worker 	/* for coverage, plane alpha and fb alpha should be swappable, so swap fb and alpha */
476*d83cc019SAndroid Build Coastguard Worker 	for (i = 0; i < 256; i += 8) {
477*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, ((i/2) << 8) | (i/2));
478*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(plane, &data->argb_fb_cov_fc);
479*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
480*d83cc019SAndroid Build Coastguard Worker 
481*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
482*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &ref_crc);
483*d83cc019SAndroid Build Coastguard Worker #endif
484*d83cc019SAndroid Build Coastguard Worker 
485*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, (i << 8) | i);
486*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(plane, &data->argb_fb_cov_7e);
487*d83cc019SAndroid Build Coastguard Worker 		igt_display_commit2(display, COMMIT_ATOMIC);
488*d83cc019SAndroid Build Coastguard Worker 
489*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
490*d83cc019SAndroid Build Coastguard Worker 		igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
491*d83cc019SAndroid Build Coastguard Worker 		igt_assert_crc_equal(&ref_crc, &crc);
492*d83cc019SAndroid Build Coastguard Worker #endif
493*d83cc019SAndroid Build Coastguard Worker 	}
494*d83cc019SAndroid Build Coastguard Worker 
495*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
496*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_stop(data->pipe_crc);
497*d83cc019SAndroid Build Coastguard Worker #endif
498*d83cc019SAndroid Build Coastguard Worker }
499*d83cc019SAndroid Build Coastguard Worker 
coverage_premult_constant(data_t * data,enum pipe pipe,igt_plane_t * plane)500*d83cc019SAndroid Build Coastguard Worker static void coverage_premult_constant(data_t *data, enum pipe pipe, igt_plane_t *plane)
501*d83cc019SAndroid Build Coastguard Worker {
502*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
503*d83cc019SAndroid Build Coastguard Worker 	igt_crc_t ref_crc = {}, crc = {};
504*d83cc019SAndroid Build Coastguard Worker 
505*d83cc019SAndroid Build Coastguard Worker 	/* Set a background color on the primary fb for testing */
506*d83cc019SAndroid Build Coastguard Worker 	if (plane->type != DRM_PLANE_TYPE_PRIMARY)
507*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(igt_pipe_get_plane_type(&display->pipes[pipe], DRM_PLANE_TYPE_PRIMARY), &data->gray_fb);
508*d83cc019SAndroid Build Coastguard Worker 
509*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "Coverage");
510*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_cov_7e);
511*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
512*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
513*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_start(data->pipe_crc);
514*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_get_single(data->pipe_crc, &ref_crc);
515*d83cc019SAndroid Build Coastguard Worker #endif
516*d83cc019SAndroid Build Coastguard Worker 
517*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "Pre-multiplied");
518*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_7e);
519*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
520*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
521*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
522*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
523*d83cc019SAndroid Build Coastguard Worker #endif
524*d83cc019SAndroid Build Coastguard Worker 
525*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_enum(plane, IGT_PLANE_PIXEL_BLEND_MODE, "None");
526*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_prop_value(plane, IGT_PLANE_ALPHA, 0x7e7e);
527*d83cc019SAndroid Build Coastguard Worker 	igt_plane_set_fb(plane, &data->argb_fb_cov_7e);
528*d83cc019SAndroid Build Coastguard Worker 	igt_display_commit2(display, COMMIT_ATOMIC);
529*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
530*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_get_current(display->drm_fd, data->pipe_crc, &crc);
531*d83cc019SAndroid Build Coastguard Worker 	igt_assert_crc_equal(&ref_crc, &crc);
532*d83cc019SAndroid Build Coastguard Worker 
533*d83cc019SAndroid Build Coastguard Worker 	igt_pipe_crc_stop(data->pipe_crc);
534*d83cc019SAndroid Build Coastguard Worker #endif
535*d83cc019SAndroid Build Coastguard Worker }
536*d83cc019SAndroid Build Coastguard Worker 
run_test_on_pipe_planes(data_t * data,enum pipe pipe,bool blend,bool must_multiply,void (* test)(data_t *,enum pipe,igt_plane_t *))537*d83cc019SAndroid Build Coastguard Worker static void run_test_on_pipe_planes(data_t *data, enum pipe pipe, bool blend,
538*d83cc019SAndroid Build Coastguard Worker 				    bool must_multiply,
539*d83cc019SAndroid Build Coastguard Worker 				    void(*test)(data_t *, enum pipe, igt_plane_t *))
540*d83cc019SAndroid Build Coastguard Worker {
541*d83cc019SAndroid Build Coastguard Worker 	igt_display_t *display = &data->display;
542*d83cc019SAndroid Build Coastguard Worker 	igt_output_t *output = igt_get_single_output_for_pipe(display, pipe);
543*d83cc019SAndroid Build Coastguard Worker 	igt_plane_t *plane;
544*d83cc019SAndroid Build Coastguard Worker 	bool found = false;
545*d83cc019SAndroid Build Coastguard Worker 	bool multiply = false;
546*d83cc019SAndroid Build Coastguard Worker 
547*d83cc019SAndroid Build Coastguard Worker 	for_each_plane_on_pipe(display, pipe, plane) {
548*d83cc019SAndroid Build Coastguard Worker 		if (!igt_plane_has_prop(plane, IGT_PLANE_ALPHA))
549*d83cc019SAndroid Build Coastguard Worker 			continue;
550*d83cc019SAndroid Build Coastguard Worker 
551*d83cc019SAndroid Build Coastguard Worker 		if (blend && !igt_plane_has_prop(plane, IGT_PLANE_PIXEL_BLEND_MODE))
552*d83cc019SAndroid Build Coastguard Worker 			continue;
553*d83cc019SAndroid Build Coastguard Worker 
554*d83cc019SAndroid Build Coastguard Worker 		prepare_crtc(data, output, pipe);
555*d83cc019SAndroid Build Coastguard Worker 
556*d83cc019SAndroid Build Coastguard Worker 		/* reset plane alpha properties between each plane */
557*d83cc019SAndroid Build Coastguard Worker 		reset_alpha(display, pipe);
558*d83cc019SAndroid Build Coastguard Worker 
559*d83cc019SAndroid Build Coastguard Worker 		found = true;
560*d83cc019SAndroid Build Coastguard Worker 		if (must_multiply && !has_multiplied_alpha(data, plane))
561*d83cc019SAndroid Build Coastguard Worker 			continue;
562*d83cc019SAndroid Build Coastguard Worker 		multiply = true;
563*d83cc019SAndroid Build Coastguard Worker 
564*d83cc019SAndroid Build Coastguard Worker 		igt_info("Testing plane %u\n", plane->index);
565*d83cc019SAndroid Build Coastguard Worker 		test(data, pipe, plane);
566*d83cc019SAndroid Build Coastguard Worker 		igt_plane_set_fb(plane, NULL);
567*d83cc019SAndroid Build Coastguard Worker 	}
568*d83cc019SAndroid Build Coastguard Worker 
569*d83cc019SAndroid Build Coastguard Worker 	igt_require_f(found, "No planes with %s property found\n",
570*d83cc019SAndroid Build Coastguard Worker 		      blend ? "pixel blending mode" : "alpha");
571*d83cc019SAndroid Build Coastguard Worker 	igt_require_f(multiply, "Multiplied (plane x pixel) alpha not available\n");
572*d83cc019SAndroid Build Coastguard Worker }
573*d83cc019SAndroid Build Coastguard Worker 
run_subtests(data_t * data,enum pipe pipe)574*d83cc019SAndroid Build Coastguard Worker static void run_subtests(data_t *data, enum pipe pipe)
575*d83cc019SAndroid Build Coastguard Worker {
576*d83cc019SAndroid Build Coastguard Worker 	igt_fixture {
577*d83cc019SAndroid Build Coastguard Worker 		bool found = false;
578*d83cc019SAndroid Build Coastguard Worker 		igt_plane_t *plane;
579*d83cc019SAndroid Build Coastguard Worker 
580*d83cc019SAndroid Build Coastguard Worker 		igt_display_require_output_on_pipe(&data->display, pipe);
581*d83cc019SAndroid Build Coastguard Worker 		for_each_plane_on_pipe(&data->display, pipe, plane) {
582*d83cc019SAndroid Build Coastguard Worker 			if (!igt_plane_has_prop(plane, IGT_PLANE_ALPHA))
583*d83cc019SAndroid Build Coastguard Worker 				continue;
584*d83cc019SAndroid Build Coastguard Worker 
585*d83cc019SAndroid Build Coastguard Worker 			found = true;
586*d83cc019SAndroid Build Coastguard Worker 			break;
587*d83cc019SAndroid Build Coastguard Worker 		}
588*d83cc019SAndroid Build Coastguard Worker 
589*d83cc019SAndroid Build Coastguard Worker 		igt_require_f(found, "Found no plane on pipe %s with alpha blending supported\n",
590*d83cc019SAndroid Build Coastguard Worker 			      kmstest_pipe_name(pipe));
591*d83cc019SAndroid Build Coastguard Worker 	}
592*d83cc019SAndroid Build Coastguard Worker 
593*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-alpha-basic", kmstest_pipe_name(pipe))
594*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, false, true, basic_alpha);
595*d83cc019SAndroid Build Coastguard Worker 
596*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-alpha-7efc", kmstest_pipe_name(pipe))
597*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, false, true, alpha_7efc);
598*d83cc019SAndroid Build Coastguard Worker 
599*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-coverage-7efc", kmstest_pipe_name(pipe))
600*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, true, true, coverage_7efc);
601*d83cc019SAndroid Build Coastguard Worker 
602*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-coverage-vs-premult-vs-constant", kmstest_pipe_name(pipe))
603*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, true, false, coverage_premult_constant);
604*d83cc019SAndroid Build Coastguard Worker 
605*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-alpha-transparant-fb", kmstest_pipe_name(pipe))
606*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, false, false, argb_transparant);
607*d83cc019SAndroid Build Coastguard Worker 
608*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-alpha-opaque-fb", kmstest_pipe_name(pipe))
609*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, false, false, argb_opaque);
610*d83cc019SAndroid Build Coastguard Worker 
611*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-constant-alpha-min", kmstest_pipe_name(pipe))
612*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, true, false, constant_alpha_min);
613*d83cc019SAndroid Build Coastguard Worker 
614*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-constant-alpha-mid", kmstest_pipe_name(pipe))
615*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, true, false, constant_alpha_mid);
616*d83cc019SAndroid Build Coastguard Worker 
617*d83cc019SAndroid Build Coastguard Worker 	igt_subtest_f("pipe-%s-constant-alpha-max", kmstest_pipe_name(pipe))
618*d83cc019SAndroid Build Coastguard Worker 		run_test_on_pipe_planes(data, pipe, true, false, constant_alpha_max);
619*d83cc019SAndroid Build Coastguard Worker }
620*d83cc019SAndroid Build Coastguard Worker 
621*d83cc019SAndroid Build Coastguard Worker igt_main
622*d83cc019SAndroid Build Coastguard Worker {
623*d83cc019SAndroid Build Coastguard Worker 	data_t data = {};
624*d83cc019SAndroid Build Coastguard Worker 	enum pipe pipe;
625*d83cc019SAndroid Build Coastguard Worker 
626*d83cc019SAndroid Build Coastguard Worker 	igt_fixture {
627*d83cc019SAndroid Build Coastguard Worker 		data.gfx_fd = drm_open_driver(DRIVER_ANY);
628*d83cc019SAndroid Build Coastguard Worker #if defined (USE_CRC)
629*d83cc019SAndroid Build Coastguard Worker 		igt_require_pipe_crc(data.gfx_fd);
630*d83cc019SAndroid Build Coastguard Worker #endif
631*d83cc019SAndroid Build Coastguard Worker 		igt_display_require(&data.display, data.gfx_fd);
632*d83cc019SAndroid Build Coastguard Worker 		igt_require(data.display.is_atomic);
633*d83cc019SAndroid Build Coastguard Worker 	}
634*d83cc019SAndroid Build Coastguard Worker 
635*d83cc019SAndroid Build Coastguard Worker 	for_each_pipe_static(pipe)
636*d83cc019SAndroid Build Coastguard Worker 		igt_subtest_group
637*d83cc019SAndroid Build Coastguard Worker 			run_subtests(&data, pipe);
638*d83cc019SAndroid Build Coastguard Worker 
639*d83cc019SAndroid Build Coastguard Worker 	igt_fixture
640*d83cc019SAndroid Build Coastguard Worker 		igt_display_fini(&data.display);
641*d83cc019SAndroid Build Coastguard Worker }
642