summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMaxime Ripard <maxime@cerno.tech>2022-03-08 14:23:39 +0100
committerMaxime Ripard <maxime@cerno.tech>2022-06-28 15:56:16 +0200
commit85f4c1005150683397fd2775885067ce3515fe06 (patch)
tree70c5644bdae3fd879897126d3fd919685a2952ca
parent9e9469cee564428d21ac2a72e81e4244ebca4d53 (diff)
lib/igt_fb: Ignore the X component when computing CRC
The igt_fb_get_fnv1a_crc() function will compute a FNV-1a hash over the content of the framebuffer. The sole user of this function is the writeback test suite, which will use it to compare an XRGB8888 buffer used in input to an XRGB8888 buffer filled by the writeback connector. However, that function uses each bytes of each buffers to compute the hash, and therefore the writeback code assumes that the hardware will preserve the content of the X component through the writeback pipeline, which isn't true for all hardware. VC4 doesn't for example. Since that function is only ever used for XRGB8888 buffers, let's just set the most significant to 0 (which is the X padding) for each pixel when computing the hash, and thus ignore whatever the hardware will return here. Acked-by: Pekka Paalanen <pekka.paalanen@collabora.com> Signed-off-by: Maxime Ripard <maxime@cerno.tech>
-rw-r--r--lib/igt_fb.c20
1 files changed, 16 insertions, 4 deletions
diff --git a/lib/igt_fb.c b/lib/igt_fb.c
index 1b9131f2..780283a0 100644
--- a/lib/igt_fb.c
+++ b/lib/igt_fb.c
@@ -4437,15 +4437,19 @@ int igt_fb_get_fnv1a_crc(struct igt_fb *fb, igt_crc_t *crc)
{
const uint32_t FNV1a_OFFSET_BIAS = 2166136261;
const uint32_t FNV1a_PRIME = 16777619;
+ uint32_t *line = NULL;
uint32_t hash;
void *map;
- char *ptr, *line = NULL;
+ char *ptr;
int x, y, cpp = igt_drm_format_to_bpp(fb->drm_format) / 8;
uint32_t stride = calc_plane_stride(fb, 0);
if (fb->num_planes != 1)
return -EINVAL;
+ if (fb->drm_format != DRM_FORMAT_XRGB8888)
+ return -EINVAL;
+
ptr = igt_fb_map_buffer(fb->fd, fb);
igt_assert(ptr);
map = ptr;
@@ -4467,9 +4471,17 @@ int igt_fb_get_fnv1a_crc(struct igt_fb *fb, igt_crc_t *crc)
igt_memcpy_from_wc(line, ptr, fb->width * cpp);
- for (x = 0; x < fb->width * cpp; x++) {
- hash ^= line[x];
- hash *= FNV1a_PRIME;
+ for (x = 0; x < fb->width; x++) {
+ unsigned int i;
+ uint32_t pixel = le32_to_cpu(line[x]);
+ pixel &= 0x00ffffff;
+
+ for (i = 0; i < sizeof(pixel); i++) {
+ uint8_t component = (pixel >> (i * 8)) & 0xff;
+
+ hash ^= component;
+ hash *= FNV1a_PRIME;
+ }
}
}