[PATCH libdrm 2/2] tests/modeprint: Print details for IN_FORMATS blob

Wladimir J. van der Laan laanwj at gmail.com
Sun Nov 19 09:49:31 UTC 2017


Pretty-print formats and modifiers in IN_FORMATS blob.

Signed-off-by: Wladimir J. van der Laan <laanwj at gmail.com>
---
 tests/modeprint/modeprint.c | 23 +++++++++++++++++++++++
 1 file changed, 23 insertions(+)

diff --git a/tests/modeprint/modeprint.c b/tests/modeprint/modeprint.c
index 42c0a1b..ce84279 100644
--- a/tests/modeprint/modeprint.c
+++ b/tests/modeprint/modeprint.c
@@ -93,6 +93,28 @@ static int printMode(struct drm_mode_modeinfo *mode)
 	return 0;
 }
 
+static int printBlob(const char *name, void *data, uint32_t length)
+{
+	if (!strcmp(name, "IN_FORMATS")) {
+		struct drm_format_modifier_blob *m = data;
+		uint32_t *fmts = (uint32_t *)(((char *)data) + m->formats_offset);
+		struct drm_format_modifier *mod = (struct drm_format_modifier *)(((char *)data) + m->modifiers_offset);
+		int i,j,k;
+		printf("\tmodifiers    :\n");
+		for (j = 0; j < (int)m->count_modifiers; j++) {
+			printf("\t\t0x%016" PRIx64, mod[j].modifier);
+			for (i = 0; i < 64 && (i + mod[j].offset) < (int)m->count_formats; i++) {
+				if (mod[j].formats & (1<<i)) {
+					k = i + mod[j].offset;
+					printf(" %c%c%c%c", fmts[k] >> 24, fmts[k] >> 16, fmts[k] >> 8, fmts[k] >> 0);
+				}
+			}
+			printf("\n");
+		}
+	}
+	return 0;
+}
+
 static int printProperty(int fd, drmModePropertyPtr props, uint64_t value)
 {
 	const char *name = NULL;
@@ -120,6 +142,7 @@ static int printProperty(int fd, drmModePropertyPtr props, uint64_t value)
 		blob = drmModeGetPropertyBlob(fd, value);
 		if (blob) {
 			printf("blob is %d length, %08X\n", blob->length, *(uint32_t *)blob->data);
+			printBlob(props->name, blob->data, blob->length);
 			drmModeFreePropertyBlob(blob);
 		} else {
 			printf("error getting blob %" PRIu64 "\n", value);
-- 
2.7.4



More information about the dri-devel mailing list