2 * Copyright © 2020 Google LLC
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the "Software"),
6 * to deal in the Software without restriction, including without limitation
7 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8 * and/or sell copies of the Software, and to permit persons to whom the
9 * Software is furnished to do so, subject to the following conditions:
11 * The above copyright notice and this permission notice (including the next
12 * paragraph) shall be included in all copies or substantial portions of the
15 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
24 #include "freedreno_layout.h"
25 #include "adreno_common.xml.h"
31 enum pipe_format format
;
33 int array_size
; /* Size for array textures, or 0 otherwise. */
36 /* Partially filled layout of input parameters and expected results. */
37 struct fdl_layout layout
;
40 static const struct testcase testcases
[] = {
41 /* A straightforward first testcase, linear, with an obvious format. */
43 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
45 .width0
= 32, .height0
= 32,
47 { .offset
= 0, .pitch
= 256 },
48 { .offset
= 8192, .pitch
= 256 },
49 { .offset
= 12288, .pitch
= 256 },
50 { .offset
= 14336, .pitch
= 256 },
51 { .offset
= 15360, .pitch
= 256 },
52 { .offset
= 15872, .pitch
= 256 },
57 /* A tiled/ubwc layout from the blob driver, at a size where the a630 blob
58 * driver does something interesting for linear.
61 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
65 .width0
= 1024, .height0
= 1,
67 { .offset
= 0, .pitch
= 4096 },
68 { .offset
= 65536, .pitch
= 2048 },
69 { .offset
= 98304, .pitch
= 1024 },
70 { .offset
= 114688, .pitch
= 512 },
71 { .offset
= 122880, .pitch
= 256 },
72 { .offset
= 126976, .pitch
= 256 },
73 { .offset
= 131072, .pitch
= 256 },
74 { .offset
= 135168, .pitch
= 256 },
75 { .offset
= 139264, .pitch
= 256 },
76 { .offset
= 143360, .pitch
= 256 },
77 { .offset
= 147456, .pitch
= 256 },
80 { .offset
= 0, .pitch
= 64 },
81 { .offset
= 4096, .pitch
= 64 },
82 { .offset
= 8192, .pitch
= 64 },
83 { .offset
= 12288, .pitch
= 64 },
84 { .offset
= 16384, .pitch
= 64 },
85 { .offset
= 20480, .pitch
= 64 },
86 { .offset
= 24576, .pitch
= 64 },
87 { .offset
= 28672, .pitch
= 64 },
88 { .offset
= 32768, .pitch
= 64 },
89 { .offset
= 36864, .pitch
= 64 },
90 { .offset
= 40960, .pitch
= 64 },
95 /* An interesting layout from the blob driver on a630, showing that
96 * per-level pitch must be derived from level 0's pitch, not width0. We
97 * don't do this level 0 pitch disalignment (we pick 4096), so disabled
102 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
104 .width0
= 1024, .height0
= 1,
106 { .offset
= 0, .pitch
= 5120 },
107 { .offset
= 5120, .pitch
= 2560 },
108 { .offset
= 7680, .pitch
= 1280 },
109 { .offset
= 8960, .pitch
= 768 },
110 { .offset
= 9728, .pitch
= 512 },
111 { .offset
= 10240, .pitch
= 256 },
112 { .offset
= 10496, .pitch
= 256 },
113 { .offset
= 10752, .pitch
= 256 },
114 { .offset
= 11008, .pitch
= 256 },
115 { .offset
= 11264, .pitch
= 256 },
116 { .offset
= 11520, .pitch
= 256 },
122 /* A layout that we failed on (129 wide has a surprise level 1 pitch
123 * increase), and the sizes bracketing it.
126 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
128 .width0
= 128, .height0
= 1,
130 { .offset
= 0, .pitch
= 512 },
131 { .offset
= 512, .pitch
= 256 },
132 { .offset
= 768, .pitch
= 256 },
133 { .offset
= 1024, .pitch
= 256 },
134 { .offset
= 1280, .pitch
= 256 },
135 { .offset
= 1536, .pitch
= 256 },
136 { .offset
= 1792, .pitch
= 256 },
137 { .offset
= 2048, .pitch
= 256 },
142 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
144 .width0
= 129, .height0
= 1,
146 { .offset
= 0, .pitch
= 768 },
147 { .offset
= 768, .pitch
= 512 },
148 { .offset
= 1280, .pitch
= 256 },
149 { .offset
= 1536, .pitch
= 256 },
150 { .offset
= 1792, .pitch
= 256 },
151 { .offset
= 2048, .pitch
= 256 },
152 { .offset
= 2304, .pitch
= 256 },
153 { .offset
= 2560, .pitch
= 256 },
158 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
160 .width0
= 130, .height0
= 1,
162 { .offset
= 0, .pitch
= 768 },
163 { .offset
= 768, .pitch
= 512 },
164 { .offset
= 1280, .pitch
= 256 },
165 { .offset
= 1536, .pitch
= 256 },
166 { .offset
= 1792, .pitch
= 256 },
167 { .offset
= 2048, .pitch
= 256 },
168 { .offset
= 2304, .pitch
= 256 },
169 { .offset
= 2560, .pitch
= 256 },
174 /* The 129 failure seems to be across formats, let's test some cpps */
176 .format
= PIPE_FORMAT_R8_UNORM
,
178 .width0
= 129, .height0
= 1,
180 { .offset
= 0, .pitch
= 192 },
181 { .offset
= 192, .pitch
= 128 },
182 { .offset
= 320, .pitch
= 64 },
183 { .offset
= 384, .pitch
= 64 },
184 { .offset
= 448, .pitch
= 64 },
185 { .offset
= 512, .pitch
= 64 },
186 { .offset
= 576, .pitch
= 64 },
187 { .offset
= 640, .pitch
= 64 },
192 .format
= PIPE_FORMAT_R16_UINT
,
194 .width0
= 129, .height0
= 1,
196 { .offset
= 0, .pitch
= 384 },
197 { .offset
= 384, .pitch
= 256 },
198 { .offset
= 640, .pitch
= 128 },
199 { .offset
= 768, .pitch
= 128 },
200 { .offset
= 896, .pitch
= 128 },
201 { .offset
= 1024, .pitch
= 128 },
202 { .offset
= 1152, .pitch
= 128 },
203 { .offset
= 1280, .pitch
= 128 },
208 .format
= PIPE_FORMAT_R32G32B32A32_FLOAT
,
210 .width0
= 129, .height0
= 1,
212 { .offset
= 0, .pitch
= 3072 },
213 { .offset
= 3072, .pitch
= 2048 },
214 { .offset
= 5120, .pitch
= 1024 },
215 { .offset
= 6144, .pitch
= 1024 },
216 { .offset
= 7168, .pitch
= 1024 },
217 { .offset
= 8192, .pitch
= 1024 },
218 { .offset
= 9216, .pitch
= 1024 },
219 { .offset
= 10240, .pitch
= 1024 },
224 /* The 129 failure replicated at every +256 pixels wide. Pick one of
225 * them, and this time increase the height as a new variable as well.
228 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
230 .width0
= 385, .height0
= 128,
232 { .offset
= 0, .pitch
= 1792 },
233 { .offset
= 229376, .pitch
= 1024 },
234 { .offset
= 294912, .pitch
= 512 },
235 { .offset
= 311296, .pitch
= 256 },
236 { .offset
= 315392, .pitch
= 256 },
237 { .offset
= 317440, .pitch
= 256 },
238 { .offset
= 318464, .pitch
= 256 },
239 { .offset
= 318976, .pitch
= 256 },
240 { .offset
= 319232, .pitch
= 256 },
245 /* At 257-259 (and replicated every +256 pixels) we had another failure. */
247 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
249 .width0
= 257, .height0
= 1,
251 { .offset
= 0, .pitch
= 1280 },
252 { .offset
= 1280, .pitch
= 768 },
253 { .offset
= 2048, .pitch
= 512 },
254 { .offset
= 2560, .pitch
= 256 },
255 { .offset
= 2816, .pitch
= 256 },
256 { .offset
= 3072, .pitch
= 256 },
257 { .offset
= 3328, .pitch
= 256 },
258 { .offset
= 3584, .pitch
= 256 },
259 { .offset
= 3840, .pitch
= 256 },
264 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
266 .width0
= 258, .height0
= 1,
268 { .offset
= 0, .pitch
= 1280 },
269 { .offset
= 1280, .pitch
= 768 },
270 { .offset
= 2048, .pitch
= 512 },
271 { .offset
= 2560, .pitch
= 256 },
272 { .offset
= 2816, .pitch
= 256 },
273 { .offset
= 3072, .pitch
= 256 },
274 { .offset
= 3328, .pitch
= 256 },
275 { .offset
= 3584, .pitch
= 256 },
276 { .offset
= 3840, .pitch
= 256 },
281 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
283 .width0
= 259, .height0
= 1,
285 { .offset
= 0, .pitch
= 1280 },
286 { .offset
= 1280, .pitch
= 768 },
287 { .offset
= 2048, .pitch
= 512 },
288 { .offset
= 2560, .pitch
= 256 },
289 { .offset
= 2816, .pitch
= 256 },
290 { .offset
= 3072, .pitch
= 256 },
291 { .offset
= 3328, .pitch
= 256 },
292 { .offset
= 3584, .pitch
= 256 },
293 { .offset
= 3840, .pitch
= 256 },
298 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
300 .width0
= 260, .height0
= 1,
302 { .offset
= 0, .pitch
= 1280 },
303 { .offset
= 1280, .pitch
= 768 },
304 { .offset
= 2048, .pitch
= 512 },
305 { .offset
= 2560, .pitch
= 256 },
306 { .offset
= 2816, .pitch
= 256 },
307 { .offset
= 3072, .pitch
= 256 },
308 { .offset
= 3328, .pitch
= 256 },
309 { .offset
= 3584, .pitch
= 256 },
310 { .offset
= 3840, .pitch
= 256 },
315 /* And, again for the 257-9 failure, test a replica with a larger size*/
317 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
319 .width0
= 513, .height0
= 32,
321 { .offset
= 0, .pitch
= 2304 },
322 { .offset
= 73728, .pitch
= 1280 },
323 { .offset
= 94208, .pitch
= 768 },
324 { .offset
= 100352, .pitch
= 512 },
325 { .offset
= 102400, .pitch
= 256 },
326 { .offset
= 102912, .pitch
= 256 },
327 { .offset
= 103168, .pitch
= 256 },
328 { .offset
= 103424, .pitch
= 256 },
329 { .offset
= 103680, .pitch
= 256 },
330 { .offset
= 103936, .pitch
= 256 },
335 /* Oh, look. The 513-517 failure extends up to 518 at the next texture
339 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
341 .width0
= 518, .height0
= 1,
343 { .offset
= 0, .pitch
= 2304 },
344 { .offset
= 2304, .pitch
= 1280 },
345 { .offset
= 3584, .pitch
= 768 },
346 { .offset
= 4352, .pitch
= 512 },
347 { .offset
= 4864, .pitch
= 256 },
348 { .offset
= 5120, .pitch
= 256 },
349 { .offset
= 5376, .pitch
= 256 },
350 { .offset
= 5632, .pitch
= 256 },
351 { .offset
= 5888, .pitch
= 256 },
352 { .offset
= 6144, .pitch
= 256 },
357 /* Tiled mode testing of the unusual 1/2-bytes-per-pixel pitch alignment */
359 .format
= PIPE_FORMAT_R8_UNORM
,
361 .tile_mode
= TILE6_3
,
362 .width0
= 129, .height0
= 1,
364 { .offset
= 0, .pitch
= 256 },
365 { .offset
= 8192, .pitch
= 128 },
366 { .offset
= 12288, .pitch
= 128 },
367 { .offset
= 16384, .pitch
= 128 },
368 { .offset
= 20480, .pitch
= 64 },
369 { .offset
= 20544, .pitch
= 64 },
370 { .offset
= 20608, .pitch
= 64 },
371 { .offset
= 20672, .pitch
= 64 },
376 /* Single-level RGBA8888 UBWC following UBWC alignment rules laid out in
377 * msm_media_info.h to verify that we don't break buffer sharing.
380 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
382 .tile_mode
= TILE6_3
,
384 .width0
= 16384, .height0
= 129,
386 { .offset
= 1024 * 48, .pitch
= 16384 * 4 },
389 { .offset
= 0, .pitch
= 1024 },
394 /* UBWC: Pitch comes from POT-aligned level 0. */
395 /* Pitch fixed in this commit, but offsets broken. Will be fixed in
399 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
401 .tile_mode
= TILE6_3
,
403 .width0
= 2049, .height0
= 128,
405 { .offset
= 0, .pitch
= 8448 },
406 { .offset
= 1081344, .pitch
= 4352 },
407 { .offset
= 1359872, .pitch
= 2304 },
408 { .offset
= 1433600, .pitch
= 1280 },
409 { .offset
= 1454080, .pitch
= 768 },
410 { .offset
= 1466368, .pitch
= 512 },
411 { .offset
= 1474560, .pitch
= 256 },
412 { .offset
= 1478656, .pitch
= 256 },
413 { .offset
= 1482752, .pitch
= 256 },
414 { .offset
= 1486848, .pitch
= 256 },
415 { .offset
= 1490944, .pitch
= 256 },
416 { .offset
= 1495040, .pitch
= 256 },
419 { .offset
= 0, .pitch
= 256 },
420 { .offset
= 16384, .pitch
= 128 },
421 { .offset
= 24576, .pitch
= 64 },
422 { .offset
= 28672, .pitch
= 64 },
423 { .offset
= 32768, .pitch
= 64 },
424 { .offset
= 36864, .pitch
= 64 },
425 { .offset
= 40960, .pitch
= 64 },
426 { .offset
= 45056, .pitch
= 64 },
427 { .offset
= 49152, .pitch
= 64 },
428 { .offset
= 53248, .pitch
= 64 },
429 { .offset
= 57344, .pitch
= 64 },
430 { .offset
= 61440, .pitch
= 64 },
434 /* UBWC: Height comes from POT-aligned level 0. */
436 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
438 .tile_mode
= TILE6_3
,
440 .width0
= 1024, .height0
= 1025,
442 { .offset
= 0, .pitch
= 4096 },
443 { .offset
= 4259840, .pitch
= 2048 },
444 { .offset
= 5308416, .pitch
= 1024 },
445 { .offset
= 5570560, .pitch
= 512 },
446 { .offset
= 5636096, .pitch
= 256 },
447 { .offset
= 5652480, .pitch
= 256 },
448 { .offset
= 5660672, .pitch
= 256 },
449 { .offset
= 5664768, .pitch
= 256 },
450 { .offset
= 5668864, .pitch
= 256 },
451 { .offset
= 5672960, .pitch
= 256 },
452 { .offset
= 5677056, .pitch
= 256 },
455 { .offset
= 0, .pitch
= 64 },
456 { .offset
= 32768, .pitch
= 64 },
457 { .offset
= 49152, .pitch
= 64 },
458 { .offset
= 57344, .pitch
= 64 },
459 { .offset
= 61440, .pitch
= 64 },
460 { .offset
= 65536, .pitch
= 64 },
461 { .offset
= 69632, .pitch
= 64 },
462 { .offset
= 73728, .pitch
= 64 },
463 { .offset
= 77824, .pitch
= 64 },
464 { .offset
= 81920, .pitch
= 64 },
465 { .offset
= 86016, .pitch
= 64 },
470 /* UBWC: Get at minimum height of a level across cpps */
472 .format
= PIPE_FORMAT_R16_UINT
,
474 .tile_mode
= TILE6_3
,
476 .width0
= 16384, .height0
= 1,
478 { .offset
= 0, .pitch
= 32768 },
479 { .offset
= 524288, .pitch
= 16384 },
480 { .offset
= 786432, .pitch
= 8192 },
481 { .offset
= 917504, .pitch
= 4096 },
482 { .offset
= 983040, .pitch
= 2048 },
483 { .offset
= 1015808, .pitch
= 1024 },
484 { .offset
= 1032192, .pitch
= 512 },
485 { .offset
= 1040384, .pitch
= 256 },
486 { .offset
= 1044480, .pitch
= 256 },
487 { .offset
= 1048576, .pitch
= 256 },
488 { .offset
= 1052672, .pitch
= 256 },
489 { .offset
= 1056768, .pitch
= 256 },
490 { .offset
= 1060864, .pitch
= 256 },
491 { .offset
= 1064960, .pitch
= 256 },
492 { .offset
= 1069056, .pitch
= 256 },
495 { .offset
= 0, .pitch
= 1024 },
496 { .offset
= 65536, .pitch
= 512 },
497 { .offset
= 98304, .pitch
= 256 },
498 { .offset
= 114688, .pitch
= 128 },
499 { .offset
= 122880, .pitch
= 64 },
500 { .offset
= 126976, .pitch
= 64 },
501 { .offset
= 131072, .pitch
= 64 },
502 { .offset
= 135168, .pitch
= 64 },
503 { .offset
= 139264, .pitch
= 64 },
504 { .offset
= 143360, .pitch
= 64 },
505 { .offset
= 147456, .pitch
= 64 },
506 { .offset
= 151552, .pitch
= 64 },
507 { .offset
= 155648, .pitch
= 64 },
508 { .offset
= 159744, .pitch
= 64 },
509 { .offset
= 163840, .pitch
= 64 },
514 .format
= PIPE_FORMAT_R8G8B8A8_UNORM
,
516 .tile_mode
= TILE6_3
,
518 .width0
= 16384, .height0
= 1,
520 { .offset
= 0, .pitch
= 65536 },
521 { .offset
= 1048576, .pitch
= 32768 },
522 { .offset
= 1572864, .pitch
= 16384 },
523 { .offset
= 1835008, .pitch
= 8192 },
524 { .offset
= 1966080, .pitch
= 4096 },
525 { .offset
= 2031616, .pitch
= 2048 },
526 { .offset
= 2064384, .pitch
= 1024 },
527 { .offset
= 2080768, .pitch
= 512 },
528 { .offset
= 2088960, .pitch
= 256 },
529 { .offset
= 2093056, .pitch
= 256 },
530 { .offset
= 2097152, .pitch
= 256 },
531 { .offset
= 2101248, .pitch
= 256 },
532 { .offset
= 2105344, .pitch
= 256 },
533 { .offset
= 2109440, .pitch
= 256 },
534 { .offset
= 2113536, .pitch
= 256 },
537 { .offset
= 0, .pitch
= 1024 },
538 { .offset
= 65536, .pitch
= 512 },
539 { .offset
= 98304, .pitch
= 256 },
540 { .offset
= 114688, .pitch
= 128 },
541 { .offset
= 122880, .pitch
= 64 },
542 { .offset
= 126976, .pitch
= 64 },
543 { .offset
= 131072, .pitch
= 64 },
544 { .offset
= 135168, .pitch
= 64 },
545 { .offset
= 139264, .pitch
= 64 },
546 { .offset
= 143360, .pitch
= 64 },
547 { .offset
= 147456, .pitch
= 64 },
548 { .offset
= 151552, .pitch
= 64 },
549 { .offset
= 155648, .pitch
= 64 },
550 { .offset
= 159744, .pitch
= 64 },
551 { .offset
= 163840, .pitch
= 64 },
556 .format
= PIPE_FORMAT_R32G32B32A32_FLOAT
,
558 .tile_mode
= TILE6_3
,
560 .width0
= 16384, .height0
= 1,
562 { .offset
= 0, .pitch
= 262144 },
563 { .offset
= 4194304, .pitch
= 131072 },
564 { .offset
= 6291456, .pitch
= 65536 },
565 { .offset
= 7340032, .pitch
= 32768 },
566 { .offset
= 7864320, .pitch
= 16384 },
567 { .offset
= 8126464, .pitch
= 8192 },
568 { .offset
= 8257536, .pitch
= 4096 },
569 { .offset
= 8323072, .pitch
= 2048 },
570 { .offset
= 8355840, .pitch
= 1024 },
571 { .offset
= 8372224, .pitch
= 1024 },
572 { .offset
= 8388608, .pitch
= 1024 },
573 { .offset
= 8404992, .pitch
= 1024 },
574 { .offset
= 8421376, .pitch
= 1024 },
575 { .offset
= 8437760, .pitch
= 1024 },
576 { .offset
= 8454144, .pitch
= 1024 },
579 { .offset
= 0, .pitch
= 4096 },
580 { .offset
= 262144, .pitch
= 2048 },
581 { .offset
= 393216, .pitch
= 1024 },
582 { .offset
= 458752, .pitch
= 512 },
583 { .offset
= 491520, .pitch
= 256 },
584 { .offset
= 507904, .pitch
= 128 },
585 { .offset
= 516096, .pitch
= 64 },
586 { .offset
= 520192, .pitch
= 64 },
587 { .offset
= 524288, .pitch
= 64 },
588 { .offset
= 528384, .pitch
= 64 },
589 { .offset
= 532480, .pitch
= 64 },
590 { .offset
= 536576, .pitch
= 64 },
591 { .offset
= 540672, .pitch
= 64 },
592 { .offset
= 544768, .pitch
= 64 },
593 { .offset
= 548864, .pitch
= 64 },
599 static bool test_layout(const struct testcase
*testcase
)
601 struct fdl_layout layout
= {
602 .ubwc
= testcase
->layout
.ubwc
,
603 .tile_mode
= testcase
->layout
.tile_mode
,
607 int max_size
= MAX2(testcase
->layout
.width0
, testcase
->layout
.height0
);
609 while (max_size
> 1 && testcase
->layout
.slices
[mip_levels
].pitch
) {
611 max_size
= u_minify(max_size
, 1);
616 MAX2(testcase
->layout
.nr_samples
, 1),
617 testcase
->layout
.width0
,
618 MAX2(testcase
->layout
.height0
, 1),
619 MAX2(testcase
->layout
.depth0
, 1),
621 MAX2(testcase
->array_size
, 1),
624 /* fdl lays out UBWC data before the color data, while all we have
625 * recorded in this testcase are the color offsets (other than the UBWC
626 * buffer sharing test). Shift the fdl layout down so we can compare
629 if (layout
.ubwc
&& !testcase
->layout
.slices
[0].offset
) {
630 for (int l
= 1; l
< mip_levels
; l
++)
631 layout
.slices
[l
].offset
-= layout
.slices
[0].offset
;
632 layout
.slices
[0].offset
= 0;
635 for (int l
= 0; l
< mip_levels
; l
++) {
636 if (layout
.slices
[l
].offset
!= testcase
->layout
.slices
[l
].offset
) {
637 fprintf(stderr
, "%s %dx%dx%d@%dx lvl%d: offset 0x%x != 0x%x\n",
638 util_format_short_name(testcase
->format
),
639 layout
.width0
, layout
.height0
, layout
.depth0
,
640 layout
.nr_samples
, l
,
641 layout
.slices
[l
].offset
,
642 testcase
->layout
.slices
[l
].offset
);
645 if (layout
.slices
[l
].pitch
!= testcase
->layout
.slices
[l
].pitch
) {
646 fprintf(stderr
, "%s %dx%dx%d@%dx lvl%d: pitch %d != %d\n",
647 util_format_short_name(testcase
->format
),
648 layout
.width0
, layout
.height0
, layout
.depth0
,
649 layout
.nr_samples
, l
,
650 layout
.slices
[l
].pitch
,
651 testcase
->layout
.slices
[l
].pitch
);
655 if (layout
.ubwc_slices
[l
].offset
!= testcase
->layout
.ubwc_slices
[l
].offset
) {
656 fprintf(stderr
, "%s %dx%dx%d@%dx lvl%d: UBWC offset 0x%x != 0x%x\n",
657 util_format_short_name(testcase
->format
),
658 layout
.width0
, layout
.height0
, layout
.depth0
,
659 layout
.nr_samples
, l
,
660 layout
.ubwc_slices
[l
].offset
,
661 testcase
->layout
.ubwc_slices
[l
].offset
);
664 if (layout
.ubwc_slices
[l
].pitch
!= testcase
->layout
.ubwc_slices
[l
].pitch
) {
665 fprintf(stderr
, "%s %dx%dx%d@%dx lvl%d: UBWC pitch %d != %d\n",
666 util_format_short_name(testcase
->format
),
667 layout
.width0
, layout
.height0
, layout
.depth0
,
668 layout
.nr_samples
, l
,
669 layout
.ubwc_slices
[l
].pitch
,
670 testcase
->layout
.ubwc_slices
[l
].pitch
);
676 fprintf(stderr
, "\n");
682 main(int argc
, char **argv
)
686 for (int i
= 0; i
< ARRAY_SIZE(testcases
); i
++) {
687 if (!test_layout(&testcases
[i
]))