Intel-XE Archive on lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2 0/5]  Crescent Island PMT support
@ 2026-01-30 13:36 Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 1/5] pmt: Add register access callbacks Michael J. Ruhl
                   ` (6 more replies)
  0 siblings, 7 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

The Crescent Island (CRI) GPU supports PMT from the via Xe driver
registration.

The CRI PMT MMIO mapping is shared for each PMT feature and it is
necessary to set an index register value to access the correct memory
space.

The PMT driver has a callback infrastructure to access data areas with
driver specific access. It is does not support the PMT control access.

CRI discovery/control spaces are part of the access window so a driver
callback is necessary to allow for the correct window to be exposed.

Add control path callback support to the PMT driver.

Add CRI PMT discovery information.

Update the Xe driver to support the CRI PMT access.

The crashlog access needs to be done with power enabled (telem is only
available when the device is powered).

Determine which access is requested, and do the appropriate power
request.

v2:
 - clean up commit messages (reflow and content)
 - remove debug usage of __func__
 - addressed kernel-doc issue
 - clean up some added lines 

Michael J. Ruhl (5):
  pmt: Add register access callbacks
  drm/xe/vsec: Use correct pm state get
  drm/xe/vsec: Support Crescent Island PMT
  drm/xe/vsec: Crescent Island PMT decode
  drm/xe/vsec: Crescent Island PMT callbacks

 drivers/gpu/drm/xe/regs/xe_pmt.h          |   5 +
 drivers/gpu/drm/xe/xe_vsec.c              | 255 +++++++++++++++++++---
 drivers/platform/x86/intel/pmt/crashlog.c |  39 +++-
 include/linux/intel_vsec.h                |  26 ++-
 4 files changed, 289 insertions(+), 36 deletions(-)

-- 
2.52.0


^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH v2 1/5] pmt: Add register access callbacks
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
@ 2026-01-30 13:36 ` Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 2/5] drm/xe/vsec: Use correct pm state get Michael J. Ruhl
                   ` (5 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

Some HW does not have direct MMIO access to PMT control and data
features.

Augment the current callback infrastructure (data access) to allow
a registered driver to customize read/write access to the control
paths for PMT usage.

Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
---
 drivers/platform/x86/intel/pmt/crashlog.c | 39 +++++++++++++++++++++--
 include/linux/intel_vsec.h                | 26 +++++++++++----
 2 files changed, 55 insertions(+), 10 deletions(-)

diff --git a/drivers/platform/x86/intel/pmt/crashlog.c b/drivers/platform/x86/intel/pmt/crashlog.c
index b0393c9c5b4b..e4778068b068 100644
--- a/drivers/platform/x86/intel/pmt/crashlog.c
+++ b/drivers/platform/x86/intel/pmt/crashlog.c
@@ -129,7 +129,19 @@ static void pmt_crashlog_rmw(struct crashlog_entry *crashlog, u32 bit, bool set)
 {
 	const struct crashlog_control *control = &crashlog->info->control;
 	struct intel_pmt_entry *entry = &crashlog->entry;
-	u32 reg = readl(entry->disc_table + control->offset);
+	u32 guid = entry->header.guid;
+	u32 reg;
+	int err;
+
+	if (entry->cb->read_reg) {
+		err = entry->cb->read_reg(entry->pcidev, guid, &reg, control->offset);
+		if (err) {
+			pr_err("failed to read reg: %d\n", err);
+			return;
+		}
+	} else {
+		reg = readl(entry->disc_table + control->offset);
+	}
 
 	reg &= ~control->trigger_mask;
 
@@ -138,14 +150,35 @@ static void pmt_crashlog_rmw(struct crashlog_entry *crashlog, u32 bit, bool set)
 	else
 		reg &= ~bit;
 
-	writel(reg, entry->disc_table + control->offset);
+	if (entry->cb->write_reg) {
+		err = entry->cb->write_reg(entry->pcidev, guid, reg, control->offset);
+		if (err) {
+			pr_err("failed to write reg: %d\n", err);
+			return;
+		}
+	} else {
+		writel(reg, entry->disc_table + control->offset);
+	}
 }
 
 /* Read the status register and see if the specified @bit is set */
 static bool pmt_crashlog_rc(struct crashlog_entry *crashlog, u32 bit)
 {
 	const struct crashlog_status *status = &crashlog->info->status;
-	u32 reg = readl(crashlog->entry.disc_table + status->offset);
+	struct intel_pmt_entry *entry = &crashlog->entry;
+	u32 guid = entry->header.guid;
+	u32 reg;
+	int err;
+
+	if (entry->cb->read_reg) {
+		err = entry->cb->read_reg(entry->pcidev, guid, &reg, status->offset);
+		if (err) {
+			pr_err("failed to read reg: %d\n", err);
+			return false;
+		}
+	} else {
+		reg = readl(crashlog->entry.disc_table + status->offset);
+	}
 
 	return !!(reg & bit);
 }
diff --git a/include/linux/intel_vsec.h b/include/linux/intel_vsec.h
index 1a0f357c2427..c9b7aa860d0b 100644
--- a/include/linux/intel_vsec.h
+++ b/include/linux/intel_vsec.h
@@ -80,16 +80,28 @@ enum intel_vsec_quirks {
 
 /**
  * struct pmt_callbacks - Callback infrastructure for PMT devices
- * @read_telem: when specified, called by client driver to access PMT
- * data (instead of direct copy).
- * * pdev:  PCI device reference for the callback's use
- * * guid:  ID of data to acccss
- * * data:  buffer for the data to be copied
- * * off:   offset into the requested buffer
- * * count: size of buffer
+ * @read_telem: when specified, called by client driver to access PMT data (instead
+ * of direct copy).
+ * @pdev:  PCI device reference for the callback's use
+ * @guid:  ID of data to access
+ * @data:  buffer for the data to be copied
+ * @off:   offset into the requested buffer
+ * @count: size of buffer
+ * @read_reg: when specified called by client driver to read PMT state
+ * @pdev: PCI device reference for the callback's use
+ * @guid: ID of data to access
+ * @data: buffer for the register data to be read
+ * @offset: offset of control register to access
+ * @write_reg: when specified called by client driver to write PMT state
+ * @pdev: PCI device reference for the callback's use
+ * @guid: ID of data to access
+ * @data: buffer data to be written to the register
+ * @offset: offset of control register to access
  */
 struct pmt_callbacks {
 	int (*read_telem)(struct pci_dev *pdev, u32 guid, u64 *data, loff_t off, u32 count);
+	int (*read_reg)(struct pci_dev *pdev, u32 guid, u32 *data, u32 offset);
+	int (*write_reg)(struct pci_dev *pdev, u32 guid, u32 data, u32 offset);
 };
 
 struct vsec_feature_dependency {
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 2/5] drm/xe/vsec: Use correct pm state get
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 1/5] pmt: Add register access callbacks Michael J. Ruhl
@ 2026-01-30 13:36 ` Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 3/5] drm/xe/vsec: Support Crescent Island PMT Michael J. Ruhl
                   ` (4 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

Crashlog needs to be collected at all times. The current pm check
assumes telemetry only.

Update read path to enable device for crashlog instances.

Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
---
 drivers/gpu/drm/xe/xe_vsec.c | 16 +++++++++++++---
 1 file changed, 13 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/xe/xe_vsec.c b/drivers/gpu/drm/xe/xe_vsec.c
index 4ebb4dbe1c9b..44607f1eaa88 100644
--- a/drivers/gpu/drm/xe/xe_vsec.c
+++ b/drivers/gpu/drm/xe/xe_vsec.c
@@ -145,6 +145,7 @@ int xe_pmt_telem_read(struct pci_dev *pdev, u32 guid, u64 *data, loff_t user_off
 {
 	struct xe_device *xe = pdev_to_xe_device(pdev);
 	void __iomem *telem_addr = xe->mmio.regs + BMG_TELEMETRY_OFFSET;
+	u32 cap_type = FIELD_GET(GUID_CAP_TYPE, guid);
 	u32 mem_region;
 	u32 offset;
 	int ret;
@@ -160,9 +161,18 @@ int xe_pmt_telem_read(struct pci_dev *pdev, u32 guid, u64 *data, loff_t user_off
 	if (!xe->soc_remapper.set_telem_region)
 		return -ENODEV;
 
-	/* indicate that we are not at an appropriate power level */
-	if (!xe_pm_runtime_get_if_active(xe))
-		return -ENODATA;
+	/* make sure that we are not at an inappropriate power level */
+	switch (cap_type) {
+	case CRASHLOG:
+		xe_pm_runtime_get(xe);
+		break;
+	case TELEMETRY:
+		if (!xe_pm_runtime_get_if_active(xe))
+			return -ENODATA;
+		break;
+	case WATCHER:
+		return -EINVAL;
+	}
 
 	/* set SoC re-mapper index register based on GUID memory region */
 	xe->soc_remapper.set_telem_region(xe, mem_region);
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 3/5] drm/xe/vsec: Support Crescent Island PMT
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 1/5] pmt: Add register access callbacks Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 2/5] drm/xe/vsec: Use correct pm state get Michael J. Ruhl
@ 2026-01-30 13:36 ` Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 4/5] drm/xe/vsec: Crescent Island PMT decode Michael J. Ruhl
                   ` (3 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

Crescent Island (CRI) supports PMT telemetry and crashlog.

Add Crescent Island (CRI) discovery structure (DVSEC) information to
allow for Xe registration.

Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
---
 drivers/gpu/drm/xe/regs/xe_pmt.h |  5 ++++
 drivers/gpu/drm/xe/xe_vsec.c     | 43 ++++++++++++++++++++++++++++++--
 2 files changed, 46 insertions(+), 2 deletions(-)

diff --git a/drivers/gpu/drm/xe/regs/xe_pmt.h b/drivers/gpu/drm/xe/regs/xe_pmt.h
index 240d57993ea6..874f44b79780 100644
--- a/drivers/gpu/drm/xe/regs/xe_pmt.h
+++ b/drivers/gpu/drm/xe/regs/xe_pmt.h
@@ -18,6 +18,11 @@
 #define BMG_TELEMETRY_BASE_OFFSET	0xE0000
 #define BMG_TELEMETRY_OFFSET		(SOC_BASE + BMG_TELEMETRY_BASE_OFFSET)
 
+#define CRI_TELEMETRY_BASE_OFFSET	0xE0000
+/* for CRI discovery and telemetry are in an indexed window */
+#define CRI_DISCOVERY_OFFSET		(SOC_BASE + CRI_TELEMETRY_BASE_OFFSET)
+#define CRI_TELEMETRY_OFFSET		(SOC_BASE + CRI_TELEMETRY_BASE_OFFSET)
+
 #define BMG_MODS_RESIDENCY_OFFSET		(0x4D0)
 #define BMG_G2_RESIDENCY_OFFSET		(0x530)
 #define BMG_G6_RESIDENCY_OFFSET		(0x538)
diff --git a/drivers/gpu/drm/xe/xe_vsec.c b/drivers/gpu/drm/xe/xe_vsec.c
index 44607f1eaa88..254f7ebca6eb 100644
--- a/drivers/gpu/drm/xe/xe_vsec.c
+++ b/drivers/gpu/drm/xe/xe_vsec.c
@@ -19,8 +19,16 @@
 
 #include "regs/xe_pmt.h"
 
-/* PMT GUID value for BMG devices.  NOTE: this is NOT a PCI id */
+/* PMT GUID value for BMG and CRI devices.  NOTE: this is NOT a PCI id */
 #define BMG_DEVICE_ID 0xE2F8
+#define CRI_DEVICE_ID 0xE2F9
+
+/*
+ * sizeof(Crashlog Type1 Version2) = 0x18 (24) bytes
+ * For BMG and CRI crashlogs are consecutive and start at 0x60.
+ */
+#define PUNIT_DISC_OFFSET 0x60
+#define OOBMSM_DISC_OFFSET (PUNIT_DISC_OFFSET + 0x18)
 
 static struct intel_vsec_header bmg_telemetry = {
 	.rev = 1,
@@ -39,7 +47,7 @@ static struct intel_vsec_header bmg_crashlog = {
 	.num_entries = 2,
 	.entry_size = 6,
 	.tbir = 0,
-	.offset = BMG_DISCOVERY_OFFSET + 0x60,
+	.offset = BMG_DISCOVERY_OFFSET + PUNIT_DISC_OFFSET,
 };
 
 static struct intel_vsec_header *bmg_capabilities[] = {
@@ -48,9 +56,36 @@ static struct intel_vsec_header *bmg_capabilities[] = {
 	NULL
 };
 
+static struct intel_vsec_header cri_telemetry = {
+	.rev = 1,
+	.length = 0x10,
+	.id = VSEC_ID_TELEMETRY,
+	.num_entries = 3,
+	.entry_size = 4,
+	.tbir = 0,
+	.offset = CRI_DISCOVERY_OFFSET,
+};
+
+static struct intel_vsec_header cri_crashlog = {
+	.rev = 1,
+	.length = 0x10,
+	.id = VSEC_ID_CRASHLOG,
+	.num_entries = 2,
+	.entry_size = 6,
+	.tbir = 0,
+	.offset = CRI_DISCOVERY_OFFSET + PUNIT_DISC_OFFSET,
+};
+
+static struct intel_vsec_header *cri_capabilities[] = {
+	&cri_telemetry,
+	&cri_crashlog,
+	NULL
+};
+
 enum xe_vsec {
 	XE_VSEC_UNKNOWN = 0,
 	XE_VSEC_BMG,
+	XE_VSEC_CRI,
 };
 
 static struct intel_vsec_platform_info xe_vsec_info[] = {
@@ -58,6 +93,10 @@ static struct intel_vsec_platform_info xe_vsec_info[] = {
 		.caps = VSEC_CAP_TELEMETRY | VSEC_CAP_CRASHLOG,
 		.headers = bmg_capabilities,
 	},
+	[XE_VSEC_CRI] = {
+		.caps = VSEC_CAP_TELEMETRY | VSEC_CAP_CRASHLOG,
+		.headers = cri_capabilities,
+	},
 	{ }
 };
 
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 4/5] drm/xe/vsec: Crescent Island PMT decode
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
                   ` (2 preceding siblings ...)
  2026-01-30 13:36 ` [PATCH v2 3/5] drm/xe/vsec: Support Crescent Island PMT Michael J. Ruhl
@ 2026-01-30 13:36 ` Michael J. Ruhl
  2026-01-30 13:36 ` [PATCH v2 5/5] drm/xe/vsec: Crescent Island PMT callbacks Michael J. Ruhl
                   ` (2 subsequent siblings)
  6 siblings, 0 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

Crescent Island (CRI) has different index and offset values for
accessing the PMT data area.

Update the decode path to support the CRI device.

Update the data read callback so to support the CRI usage.

Define several magic numbers.

Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
---
 drivers/gpu/drm/xe/xe_vsec.c | 113 +++++++++++++++++++++++++++++------
 1 file changed, 95 insertions(+), 18 deletions(-)

diff --git a/drivers/gpu/drm/xe/xe_vsec.c b/drivers/gpu/drm/xe/xe_vsec.c
index 254f7ebca6eb..c43b0d554ead 100644
--- a/drivers/gpu/drm/xe/xe_vsec.c
+++ b/drivers/gpu/drm/xe/xe_vsec.c
@@ -116,10 +116,27 @@ static struct intel_vsec_platform_info xe_vsec_info[] = {
 #define GUID_CAP_TYPE		GENMASK(29, 28)
 #define GUID_RECORD_ID		GENMASK(31, 30)
 
-#define PUNIT_TELEMETRY_OFFSET		0x0200
-#define PUNIT_WATCHER_OFFSET		0x14A0
-#define OOBMSM_0_WATCHER_OFFSET		0x18D8
-#define OOBMSM_1_TELEMETRY_OFFSET	0x1000
+#define BMG_IDX_TELEM_PUNIT		0x00
+#define BMG_IDX_TELEM_OOBMSM		0x01
+#define BMG_IDX_CRASHLOG_PUNIT		0x02
+#define BMG_IDX_CRASHLOG_OOBMSM		0x04
+
+#define BMG_PUNIT_TELEMETRY_OFFSET	0x0200
+#define BMG_PUNIT_WATCHER_OFFSET	0x14A0
+#define BMG_OOBMSM_0_WATCHER_OFFSET	0x18D8
+#define BMG_OOBMSM_1_TELEMETRY_OFFSET	0x1000
+
+#define CRI_IDX_TELEM_DISCOVERY		0x00
+#define CRI_IDX_TELEM_PUNIT		0x01
+#define CRI_IDX_TELEM_OOBMSM		0x02
+#define CRI_IDX_CRASHLOG_PUNIT		0x03
+#define CRI_IDX_CRASHLOG_OOBMSM		0x04
+
+#define CRI_PUNIT_TELEMETRY_OFFSET	0x0200
+#define CRI_PUNIT_WATCHER_OFFSET	0x00A0
+#define CRI_OOBMSM_0_WATCHER_OFFSET	0x04F8
+#define CRI_OOBMSM_1_TELEMETRY_OFFSET	0x1800
+#define CRI_PUNIT_CRASHLOG_OFFSET	0x0660
 
 enum record_id {
 	PUNIT,
@@ -133,44 +150,81 @@ enum capability {
 	WATCHER,
 };
 
-static int xe_guid_decode(u32 guid, int *index, u32 *offset)
+static int bmg_guid_decode(u32 guid, int *index, u32 *offset)
 {
 	u32 record_id = FIELD_GET(GUID_RECORD_ID, guid);
 	u32 cap_type  = FIELD_GET(GUID_CAP_TYPE, guid);
-	u32 device_id = FIELD_GET(GUID_DEVICE_ID, guid);
 
-	if (device_id != BMG_DEVICE_ID)
-		return -ENODEV;
+	*offset = 0;
 
-	if (cap_type > WATCHER)
+	if (cap_type == CRASHLOG) {
+		*index = record_id == PUNIT ? BMG_IDX_CRASHLOG_PUNIT : BMG_IDX_CRASHLOG_OOBMSM;
+		return 0;
+	}
+
+	switch (record_id) {
+	case PUNIT:
+		*index = BMG_IDX_TELEM_PUNIT;
+		if (cap_type == TELEMETRY)
+			*offset = BMG_PUNIT_TELEMETRY_OFFSET;
+		else
+			*offset = BMG_PUNIT_WATCHER_OFFSET;
+		break;
+
+	case OOBMSM_0:
+		*index = BMG_IDX_TELEM_OOBMSM;
+		if (cap_type == WATCHER)
+			*offset = BMG_OOBMSM_0_WATCHER_OFFSET;
+		break;
+
+	case OOBMSM_1:
+		*index = BMG_IDX_TELEM_OOBMSM;
+		if (cap_type == TELEMETRY)
+			*offset = BMG_OOBMSM_1_TELEMETRY_OFFSET;
+		break;
+	default:
 		return -EINVAL;
+	}
+
+	return 0;
+}
+
+static int cri_guid_decode(u32 guid, int *index, u32 *offset)
+{
+	u32 record_id = FIELD_GET(GUID_RECORD_ID, guid);
+	u32 cap_type  = FIELD_GET(GUID_CAP_TYPE, guid);
 
 	*offset = 0;
 
 	if (cap_type == CRASHLOG) {
-		*index = record_id == PUNIT ? 2 : 4;
+		if (record_id == PUNIT) {
+			*index = CRI_IDX_CRASHLOG_PUNIT;
+			*offset = CRI_PUNIT_CRASHLOG_OFFSET;
+		} else {
+			*index = CRI_IDX_CRASHLOG_OOBMSM;
+		}
 		return 0;
 	}
 
 	switch (record_id) {
 	case PUNIT:
-		*index = 0;
+		*index = CRI_IDX_TELEM_PUNIT;
 		if (cap_type == TELEMETRY)
-			*offset = PUNIT_TELEMETRY_OFFSET;
+			*offset = CRI_PUNIT_TELEMETRY_OFFSET;
 		else
-			*offset = PUNIT_WATCHER_OFFSET;
+			*offset = CRI_PUNIT_WATCHER_OFFSET;
 		break;
 
 	case OOBMSM_0:
-		*index = 1;
+		*index = CRI_IDX_TELEM_OOBMSM;
 		if (cap_type == WATCHER)
-			*offset = OOBMSM_0_WATCHER_OFFSET;
+			*offset = CRI_OOBMSM_0_WATCHER_OFFSET;
 		break;
 
 	case OOBMSM_1:
-		*index = 1;
+		*index = CRI_IDX_TELEM_OOBMSM;
 		if (cap_type == TELEMETRY)
-			*offset = OOBMSM_1_TELEMETRY_OFFSET;
+			*offset = CRI_OOBMSM_1_TELEMETRY_OFFSET;
 		break;
 	default:
 		return -EINVAL;
@@ -179,12 +233,30 @@ static int xe_guid_decode(u32 guid, int *index, u32 *offset)
 	return 0;
 }
 
+static int xe_guid_decode(u32 guid, int *index, u32 *offset)
+{
+	u32 cap_type  = FIELD_GET(GUID_CAP_TYPE, guid);
+	u32 device_id = FIELD_GET(GUID_DEVICE_ID, guid);
+
+	if (cap_type > WATCHER)
+		return -EINVAL;
+
+	if (device_id == BMG_DEVICE_ID)
+		return bmg_guid_decode(guid, index, offset);
+
+	if (device_id == CRI_DEVICE_ID)
+		return cri_guid_decode(guid, index, offset);
+
+	return -ENODEV;
+}
+
 int xe_pmt_telem_read(struct pci_dev *pdev, u32 guid, u64 *data, loff_t user_offset,
 		      u32 count)
 {
 	struct xe_device *xe = pdev_to_xe_device(pdev);
-	void __iomem *telem_addr = xe->mmio.regs + BMG_TELEMETRY_OFFSET;
 	u32 cap_type = FIELD_GET(GUID_CAP_TYPE, guid);
+	u32 device_id = FIELD_GET(GUID_DEVICE_ID, guid);
+	void __iomem *telem_addr = xe->mmio.regs;
 	u32 mem_region;
 	u32 offset;
 	int ret;
@@ -193,6 +265,11 @@ int xe_pmt_telem_read(struct pci_dev *pdev, u32 guid, u64 *data, loff_t user_off
 	if (ret)
 		return ret;
 
+	if (device_id == BMG_DEVICE_ID)
+		telem_addr += BMG_TELEMETRY_OFFSET;
+	else
+		telem_addr += CRI_TELEMETRY_OFFSET;
+
 	telem_addr += offset + user_offset;
 
 	guard(mutex)(&xe->pmt.lock);
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* [PATCH v2 5/5] drm/xe/vsec: Crescent Island PMT callbacks
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
                   ` (3 preceding siblings ...)
  2026-01-30 13:36 ` [PATCH v2 4/5] drm/xe/vsec: Crescent Island PMT decode Michael J. Ruhl
@ 2026-01-30 13:36 ` Michael J. Ruhl
  2026-01-30 13:48 ` ✓ CI.KUnit: success for Crescent Island PMT support (rev2) Patchwork
  2026-01-30 14:24 ` ✓ Xe.CI.BAT: " Patchwork
  6 siblings, 0 replies; 8+ messages in thread
From: Michael J. Ruhl @ 2026-01-30 13:36 UTC (permalink / raw)
  To: platform-driver-x86, intel-xe, hansg, ilpo.jarvinen,
	matthew.brost, rodrigo.vivi, thomas.hellstrom, airlied, simona,
	david.e.box
  Cc: Michael J. Ruhl

CRI PMT support requires callbacks to access the discovery status
and control areas.  Access is a common MMIO area that requires an
index to be set before access is allowed.

Introduce the necessary callbacks to get the status and control
information for CRI PMT usage.

Add the glue logic to register the CRI PMT functionality.

Signed-off-by: Michael J. Ruhl <michael.j.ruhl@intel.com>
---
 drivers/gpu/drm/xe/xe_vsec.c | 83 ++++++++++++++++++++++++++++++++++--
 1 file changed, 80 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/xe/xe_vsec.c b/drivers/gpu/drm/xe/xe_vsec.c
index c43b0d554ead..f55d9a292818 100644
--- a/drivers/gpu/drm/xe/xe_vsec.c
+++ b/drivers/gpu/drm/xe/xe_vsec.c
@@ -299,17 +299,88 @@ int xe_pmt_telem_read(struct pci_dev *pdev, u32 guid, u64 *data, loff_t user_off
 	return count;
 }
 
-static struct pmt_callbacks xe_pmt_cb = {
+/**
+ * xe_pmt_read_reg() - read a crashlog register
+ * @pdev: the pcie device that register the callback
+ * @guid: PMT guid of the crashlog instance
+ * @reg: data read from the PMT data structure
+ * @offset: which data to read from the PMT data structure
+ *
+ * Read the requested PMT register based on the pcie device and guid.  The
+ * supported struct is the Crashlog Type1 Version2.
+ *
+ * Currently this is for CRI only.
+ */
+static int xe_pmt_read_reg(struct pci_dev *pdev, u32 guid, u32 *reg, u32 offset)
+{
+	struct xe_device *xe = pdev_to_xe_device(pdev);
+	void __iomem *disc_addr = xe->mmio.regs;
+	u32 inst;
+
+	if (FIELD_GET(GUID_DEVICE_ID, guid) != CRI_DEVICE_ID ||
+	    FIELD_GET(GUID_CAP_TYPE, guid) != CRASHLOG)
+		return -EINVAL;
+
+	inst = FIELD_GET(GUID_RECORD_ID, guid) == PUNIT ? PUNIT_DISC_OFFSET : OOBMSM_DISC_OFFSET;
+	disc_addr += CRI_DISCOVERY_OFFSET + inst + offset;
+
+	guard(mutex)(&xe->pmt.lock);
+
+	xe_pm_runtime_get(xe);
+
+	xe->soc_remapper.set_telem_region(xe, CRI_IDX_TELEM_DISCOVERY);
+
+	memcpy_fromio(reg, disc_addr, sizeof(*reg));
+
+	xe_pm_runtime_put(xe);
+
+	return 0;
+}
+
+static int xe_pmt_write_reg(struct pci_dev *pdev, u32 guid, u32 reg, u32 offset)
+{
+	struct xe_device *xe = pdev_to_xe_device(pdev);
+	void __iomem *disc_addr = xe->mmio.regs;
+	u32 inst;
+
+	if (FIELD_GET(GUID_DEVICE_ID, guid) != CRI_DEVICE_ID ||
+	    FIELD_GET(GUID_CAP_TYPE, guid) != CRASHLOG)
+		return -EINVAL;
+
+	inst = FIELD_GET(GUID_RECORD_ID, guid) == PUNIT ? PUNIT_DISC_OFFSET : OOBMSM_DISC_OFFSET;
+	disc_addr += CRI_DISCOVERY_OFFSET + inst + offset;
+
+	guard(mutex)(&xe->pmt.lock);
+
+	xe_pm_runtime_get(xe);
+
+	xe->soc_remapper.set_telem_region(xe, CRI_IDX_TELEM_DISCOVERY);
+
+	memcpy_toio(disc_addr, &reg, sizeof(reg));
+
+	xe_pm_runtime_put(xe);
+
+	return 0;
+}
+
+static struct pmt_callbacks xe_bmg_pmt_cb = {
+	.read_telem = xe_pmt_telem_read,
+};
+
+static struct pmt_callbacks xe_cri_pmt_cb = {
 	.read_telem = xe_pmt_telem_read,
+	.read_reg = xe_pmt_read_reg,
+	.write_reg = xe_pmt_write_reg,
 };
 
 static const int vsec_platforms[] = {
 	[XE_BATTLEMAGE] = XE_VSEC_BMG,
+	[XE_CRESCENTISLAND] = XE_VSEC_CRI,
 };
 
 static enum xe_vsec get_platform_info(struct xe_device *xe)
 {
-	if (xe->info.platform > XE_BATTLEMAGE)
+	if (xe->info.platform > XE_CRESCENTISLAND)
 		return XE_VSEC_UNKNOWN;
 
 	return vsec_platforms[xe->info.platform];
@@ -337,8 +408,14 @@ void xe_vsec_init(struct xe_device *xe)
 
 	switch (platform) {
 	case XE_VSEC_BMG:
-		info->priv_data = &xe_pmt_cb;
+		info->priv_data = &xe_bmg_pmt_cb;
 		break;
+
+	case XE_VSEC_CRI:
+		info->priv_data = &xe_cri_pmt_cb;
+		xe->soc_remapper.set_telem_region(xe, CRI_IDX_TELEM_DISCOVERY);
+		break;
+
 	default:
 		break;
 	}
-- 
2.52.0


^ permalink raw reply related	[flat|nested] 8+ messages in thread

* ✓ CI.KUnit: success for Crescent Island PMT support (rev2)
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
                   ` (4 preceding siblings ...)
  2026-01-30 13:36 ` [PATCH v2 5/5] drm/xe/vsec: Crescent Island PMT callbacks Michael J. Ruhl
@ 2026-01-30 13:48 ` Patchwork
  2026-01-30 14:24 ` ✓ Xe.CI.BAT: " Patchwork
  6 siblings, 0 replies; 8+ messages in thread
From: Patchwork @ 2026-01-30 13:48 UTC (permalink / raw)
  To: Michael J. Ruhl; +Cc: intel-xe

== Series Details ==

Series: Crescent Island PMT support (rev2)
URL   : https://patchwork.freedesktop.org/series/160717/
State : success

== Summary ==

+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[13:46:23] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[13:46:27] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=25
[13:47:07] Starting KUnit Kernel (1/1)...
[13:47:07] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[13:47:07] ================== guc_buf (11 subtests) ===================
[13:47:07] [PASSED] test_smallest
[13:47:07] [PASSED] test_largest
[13:47:07] [PASSED] test_granular
[13:47:07] [PASSED] test_unique
[13:47:07] [PASSED] test_overlap
[13:47:07] [PASSED] test_reusable
[13:47:07] [PASSED] test_too_big
[13:47:07] [PASSED] test_flush
[13:47:07] [PASSED] test_lookup
[13:47:07] [PASSED] test_data
[13:47:07] [PASSED] test_class
[13:47:07] ===================== [PASSED] guc_buf =====================
[13:47:07] =================== guc_dbm (7 subtests) ===================
[13:47:07] [PASSED] test_empty
[13:47:07] [PASSED] test_default
[13:47:07] ======================== test_size  ========================
[13:47:07] [PASSED] 4
[13:47:07] [PASSED] 8
[13:47:07] [PASSED] 32
[13:47:07] [PASSED] 256
[13:47:07] ==================== [PASSED] test_size ====================
[13:47:07] ======================= test_reuse  ========================
[13:47:07] [PASSED] 4
[13:47:07] [PASSED] 8
[13:47:07] [PASSED] 32
[13:47:07] [PASSED] 256
[13:47:07] =================== [PASSED] test_reuse ====================
[13:47:07] =================== test_range_overlap  ====================
[13:47:07] [PASSED] 4
[13:47:07] [PASSED] 8
[13:47:07] [PASSED] 32
[13:47:07] [PASSED] 256
[13:47:07] =============== [PASSED] test_range_overlap ================
[13:47:07] =================== test_range_compact  ====================
[13:47:07] [PASSED] 4
[13:47:07] [PASSED] 8
[13:47:07] [PASSED] 32
[13:47:07] [PASSED] 256
[13:47:07] =============== [PASSED] test_range_compact ================
[13:47:07] ==================== test_range_spare  =====================
[13:47:07] [PASSED] 4
[13:47:07] [PASSED] 8
[13:47:07] [PASSED] 32
[13:47:07] [PASSED] 256
[13:47:07] ================ [PASSED] test_range_spare =================
[13:47:07] ===================== [PASSED] guc_dbm =====================
[13:47:07] =================== guc_idm (6 subtests) ===================
[13:47:07] [PASSED] bad_init
[13:47:07] [PASSED] no_init
[13:47:07] [PASSED] init_fini
[13:47:07] [PASSED] check_used
[13:47:07] [PASSED] check_quota
[13:47:07] [PASSED] check_all
[13:47:07] ===================== [PASSED] guc_idm =====================
[13:47:07] ================== no_relay (3 subtests) ===================
[13:47:07] [PASSED] xe_drops_guc2pf_if_not_ready
[13:47:07] [PASSED] xe_drops_guc2vf_if_not_ready
[13:47:07] [PASSED] xe_rejects_send_if_not_ready
[13:47:07] ==================== [PASSED] no_relay =====================
[13:47:07] ================== pf_relay (14 subtests) ==================
[13:47:07] [PASSED] pf_rejects_guc2pf_too_short
[13:47:07] [PASSED] pf_rejects_guc2pf_too_long
[13:47:07] [PASSED] pf_rejects_guc2pf_no_payload
[13:47:07] [PASSED] pf_fails_no_payload
[13:47:07] [PASSED] pf_fails_bad_origin
[13:47:07] [PASSED] pf_fails_bad_type
[13:47:07] [PASSED] pf_txn_reports_error
[13:47:07] [PASSED] pf_txn_sends_pf2guc
[13:47:07] [PASSED] pf_sends_pf2guc
[13:47:07] [SKIPPED] pf_loopback_nop
[13:47:07] [SKIPPED] pf_loopback_echo
[13:47:07] [SKIPPED] pf_loopback_fail
[13:47:07] [SKIPPED] pf_loopback_busy
[13:47:07] [SKIPPED] pf_loopback_retry
[13:47:07] ==================== [PASSED] pf_relay =====================
[13:47:07] ================== vf_relay (3 subtests) ===================
[13:47:07] [PASSED] vf_rejects_guc2vf_too_short
[13:47:07] [PASSED] vf_rejects_guc2vf_too_long
[13:47:07] [PASSED] vf_rejects_guc2vf_no_payload
[13:47:07] ==================== [PASSED] vf_relay =====================
[13:47:07] ================ pf_gt_config (6 subtests) =================
[13:47:07] [PASSED] fair_contexts_1vf
[13:47:07] [PASSED] fair_doorbells_1vf
[13:47:07] [PASSED] fair_ggtt_1vf
[13:47:07] ====================== fair_contexts  ======================
[13:47:07] [PASSED] 1 VF
[13:47:07] [PASSED] 2 VFs
[13:47:07] [PASSED] 3 VFs
[13:47:07] [PASSED] 4 VFs
[13:47:07] [PASSED] 5 VFs
[13:47:07] [PASSED] 6 VFs
[13:47:07] [PASSED] 7 VFs
[13:47:07] [PASSED] 8 VFs
[13:47:07] [PASSED] 9 VFs
[13:47:07] [PASSED] 10 VFs
[13:47:07] [PASSED] 11 VFs
[13:47:07] [PASSED] 12 VFs
[13:47:07] [PASSED] 13 VFs
[13:47:07] [PASSED] 14 VFs
[13:47:07] [PASSED] 15 VFs
[13:47:07] [PASSED] 16 VFs
[13:47:07] [PASSED] 17 VFs
[13:47:07] [PASSED] 18 VFs
[13:47:07] [PASSED] 19 VFs
[13:47:07] [PASSED] 20 VFs
[13:47:07] [PASSED] 21 VFs
[13:47:07] [PASSED] 22 VFs
[13:47:07] [PASSED] 23 VFs
[13:47:07] [PASSED] 24 VFs
[13:47:07] [PASSED] 25 VFs
[13:47:07] [PASSED] 26 VFs
[13:47:07] [PASSED] 27 VFs
[13:47:07] [PASSED] 28 VFs
[13:47:07] [PASSED] 29 VFs
[13:47:07] [PASSED] 30 VFs
[13:47:07] [PASSED] 31 VFs
[13:47:07] [PASSED] 32 VFs
[13:47:07] [PASSED] 33 VFs
[13:47:07] [PASSED] 34 VFs
[13:47:07] [PASSED] 35 VFs
[13:47:07] [PASSED] 36 VFs
[13:47:07] [PASSED] 37 VFs
[13:47:07] [PASSED] 38 VFs
[13:47:07] [PASSED] 39 VFs
[13:47:07] [PASSED] 40 VFs
[13:47:07] [PASSED] 41 VFs
[13:47:07] [PASSED] 42 VFs
[13:47:07] [PASSED] 43 VFs
[13:47:07] [PASSED] 44 VFs
[13:47:07] [PASSED] 45 VFs
[13:47:07] [PASSED] 46 VFs
[13:47:07] [PASSED] 47 VFs
[13:47:07] [PASSED] 48 VFs
[13:47:07] [PASSED] 49 VFs
[13:47:07] [PASSED] 50 VFs
[13:47:07] [PASSED] 51 VFs
[13:47:07] [PASSED] 52 VFs
[13:47:07] [PASSED] 53 VFs
[13:47:07] [PASSED] 54 VFs
[13:47:07] [PASSED] 55 VFs
[13:47:07] [PASSED] 56 VFs
[13:47:07] [PASSED] 57 VFs
[13:47:07] [PASSED] 58 VFs
[13:47:07] [PASSED] 59 VFs
[13:47:07] [PASSED] 60 VFs
[13:47:07] [PASSED] 61 VFs
[13:47:07] [PASSED] 62 VFs
[13:47:07] [PASSED] 63 VFs
[13:47:07] ================== [PASSED] fair_contexts ==================
[13:47:07] ===================== fair_doorbells  ======================
[13:47:07] [PASSED] 1 VF
[13:47:07] [PASSED] 2 VFs
[13:47:07] [PASSED] 3 VFs
[13:47:07] [PASSED] 4 VFs
[13:47:07] [PASSED] 5 VFs
[13:47:07] [PASSED] 6 VFs
[13:47:07] [PASSED] 7 VFs
[13:47:07] [PASSED] 8 VFs
[13:47:07] [PASSED] 9 VFs
[13:47:07] [PASSED] 10 VFs
[13:47:07] [PASSED] 11 VFs
[13:47:07] [PASSED] 12 VFs
[13:47:07] [PASSED] 13 VFs
[13:47:07] [PASSED] 14 VFs
[13:47:07] [PASSED] 15 VFs
[13:47:07] [PASSED] 16 VFs
[13:47:07] [PASSED] 17 VFs
[13:47:07] [PASSED] 18 VFs
[13:47:07] [PASSED] 19 VFs
[13:47:07] [PASSED] 20 VFs
[13:47:07] [PASSED] 21 VFs
[13:47:07] [PASSED] 22 VFs
[13:47:07] [PASSED] 23 VFs
[13:47:07] [PASSED] 24 VFs
[13:47:07] [PASSED] 25 VFs
[13:47:07] [PASSED] 26 VFs
[13:47:07] [PASSED] 27 VFs
[13:47:07] [PASSED] 28 VFs
[13:47:07] [PASSED] 29 VFs
[13:47:07] [PASSED] 30 VFs
[13:47:07] [PASSED] 31 VFs
[13:47:07] [PASSED] 32 VFs
[13:47:07] [PASSED] 33 VFs
[13:47:07] [PASSED] 34 VFs
[13:47:07] [PASSED] 35 VFs
[13:47:07] [PASSED] 36 VFs
[13:47:07] [PASSED] 37 VFs
[13:47:07] [PASSED] 38 VFs
[13:47:07] [PASSED] 39 VFs
[13:47:07] [PASSED] 40 VFs
[13:47:07] [PASSED] 41 VFs
[13:47:07] [PASSED] 42 VFs
[13:47:07] [PASSED] 43 VFs
[13:47:07] [PASSED] 44 VFs
[13:47:07] [PASSED] 45 VFs
[13:47:07] [PASSED] 46 VFs
[13:47:07] [PASSED] 47 VFs
[13:47:07] [PASSED] 48 VFs
[13:47:07] [PASSED] 49 VFs
[13:47:07] [PASSED] 50 VFs
[13:47:07] [PASSED] 51 VFs
[13:47:07] [PASSED] 52 VFs
[13:47:07] [PASSED] 53 VFs
[13:47:07] [PASSED] 54 VFs
[13:47:07] [PASSED] 55 VFs
[13:47:07] [PASSED] 56 VFs
[13:47:07] [PASSED] 57 VFs
[13:47:07] [PASSED] 58 VFs
[13:47:07] [PASSED] 59 VFs
[13:47:07] [PASSED] 60 VFs
[13:47:07] [PASSED] 61 VFs
[13:47:07] [PASSED] 62 VFs
[13:47:07] [PASSED] 63 VFs
[13:47:07] ================= [PASSED] fair_doorbells ==================
[13:47:07] ======================== fair_ggtt  ========================
[13:47:07] [PASSED] 1 VF
[13:47:07] [PASSED] 2 VFs
[13:47:07] [PASSED] 3 VFs
[13:47:07] [PASSED] 4 VFs
[13:47:07] [PASSED] 5 VFs
[13:47:07] [PASSED] 6 VFs
[13:47:07] [PASSED] 7 VFs
[13:47:07] [PASSED] 8 VFs
[13:47:07] [PASSED] 9 VFs
[13:47:07] [PASSED] 10 VFs
[13:47:07] [PASSED] 11 VFs
[13:47:07] [PASSED] 12 VFs
[13:47:07] [PASSED] 13 VFs
[13:47:07] [PASSED] 14 VFs
[13:47:07] [PASSED] 15 VFs
[13:47:07] [PASSED] 16 VFs
[13:47:07] [PASSED] 17 VFs
[13:47:07] [PASSED] 18 VFs
[13:47:07] [PASSED] 19 VFs
[13:47:07] [PASSED] 20 VFs
[13:47:07] [PASSED] 21 VFs
[13:47:07] [PASSED] 22 VFs
[13:47:07] [PASSED] 23 VFs
[13:47:07] [PASSED] 24 VFs
[13:47:07] [PASSED] 25 VFs
[13:47:07] [PASSED] 26 VFs
[13:47:07] [PASSED] 27 VFs
[13:47:07] [PASSED] 28 VFs
[13:47:07] [PASSED] 29 VFs
[13:47:07] [PASSED] 30 VFs
[13:47:07] [PASSED] 31 VFs
[13:47:07] [PASSED] 32 VFs
[13:47:07] [PASSED] 33 VFs
[13:47:07] [PASSED] 34 VFs
[13:47:07] [PASSED] 35 VFs
[13:47:07] [PASSED] 36 VFs
[13:47:07] [PASSED] 37 VFs
[13:47:07] [PASSED] 38 VFs
[13:47:07] [PASSED] 39 VFs
[13:47:07] [PASSED] 40 VFs
[13:47:07] [PASSED] 41 VFs
[13:47:07] [PASSED] 42 VFs
[13:47:07] [PASSED] 43 VFs
[13:47:07] [PASSED] 44 VFs
[13:47:07] [PASSED] 45 VFs
[13:47:07] [PASSED] 46 VFs
[13:47:07] [PASSED] 47 VFs
[13:47:07] [PASSED] 48 VFs
[13:47:07] [PASSED] 49 VFs
[13:47:07] [PASSED] 50 VFs
[13:47:07] [PASSED] 51 VFs
[13:47:07] [PASSED] 52 VFs
[13:47:07] [PASSED] 53 VFs
[13:47:07] [PASSED] 54 VFs
[13:47:07] [PASSED] 55 VFs
[13:47:07] [PASSED] 56 VFs
[13:47:07] [PASSED] 57 VFs
[13:47:07] [PASSED] 58 VFs
[13:47:07] [PASSED] 59 VFs
[13:47:07] [PASSED] 60 VFs
[13:47:07] [PASSED] 61 VFs
[13:47:07] [PASSED] 62 VFs
[13:47:07] [PASSED] 63 VFs
[13:47:07] ==================== [PASSED] fair_ggtt ====================
[13:47:07] ================== [PASSED] pf_gt_config ===================
[13:47:07] ===================== lmtt (1 subtest) =====================
[13:47:07] ======================== test_ops  =========================
[13:47:07] [PASSED] 2-level
[13:47:07] [PASSED] multi-level
[13:47:07] ==================== [PASSED] test_ops =====================
[13:47:07] ====================== [PASSED] lmtt =======================
[13:47:07] ================= pf_service (11 subtests) =================
[13:47:07] [PASSED] pf_negotiate_any
[13:47:07] [PASSED] pf_negotiate_base_match
[13:47:07] [PASSED] pf_negotiate_base_newer
[13:47:07] [PASSED] pf_negotiate_base_next
[13:47:07] [SKIPPED] pf_negotiate_base_older
[13:47:07] [PASSED] pf_negotiate_base_prev
[13:47:07] [PASSED] pf_negotiate_latest_match
[13:47:07] [PASSED] pf_negotiate_latest_newer
[13:47:07] [PASSED] pf_negotiate_latest_next
[13:47:07] [SKIPPED] pf_negotiate_latest_older
[13:47:07] [SKIPPED] pf_negotiate_latest_prev
[13:47:07] =================== [PASSED] pf_service ====================
[13:47:07] ================= xe_guc_g2g (2 subtests) ==================
[13:47:07] ============== xe_live_guc_g2g_kunit_default  ==============
[13:47:07] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[13:47:07] ============== xe_live_guc_g2g_kunit_allmem  ===============
[13:47:07] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[13:47:07] =================== [SKIPPED] xe_guc_g2g ===================
[13:47:07] =================== xe_mocs (2 subtests) ===================
[13:47:07] ================ xe_live_mocs_kernel_kunit  ================
[13:47:07] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[13:47:07] ================ xe_live_mocs_reset_kunit  =================
[13:47:07] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[13:47:07] ==================== [SKIPPED] xe_mocs =====================
[13:47:07] ================= xe_migrate (2 subtests) ==================
[13:47:07] ================= xe_migrate_sanity_kunit  =================
[13:47:07] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[13:47:07] ================== xe_validate_ccs_kunit  ==================
[13:47:07] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[13:47:07] =================== [SKIPPED] xe_migrate ===================
[13:47:07] ================== xe_dma_buf (1 subtest) ==================
[13:47:07] ==================== xe_dma_buf_kunit  =====================
[13:47:07] ================ [SKIPPED] xe_dma_buf_kunit ================
[13:47:07] =================== [SKIPPED] xe_dma_buf ===================
[13:47:07] ================= xe_bo_shrink (1 subtest) =================
[13:47:07] =================== xe_bo_shrink_kunit  ====================
[13:47:07] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[13:47:07] ================== [SKIPPED] xe_bo_shrink ==================
[13:47:07] ==================== xe_bo (2 subtests) ====================
[13:47:07] ================== xe_ccs_migrate_kunit  ===================
[13:47:07] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[13:47:07] ==================== xe_bo_evict_kunit  ====================
[13:47:07] =============== [SKIPPED] xe_bo_evict_kunit ================
[13:47:07] ===================== [SKIPPED] xe_bo ======================
[13:47:07] ==================== args (13 subtests) ====================
[13:47:07] [PASSED] count_args_test
[13:47:07] [PASSED] call_args_example
[13:47:07] [PASSED] call_args_test
[13:47:07] [PASSED] drop_first_arg_example
[13:47:07] [PASSED] drop_first_arg_test
[13:47:07] [PASSED] first_arg_example
[13:47:07] [PASSED] first_arg_test
[13:47:07] [PASSED] last_arg_example
[13:47:07] [PASSED] last_arg_test
[13:47:07] [PASSED] pick_arg_example
[13:47:07] [PASSED] if_args_example
[13:47:07] [PASSED] if_args_test
[13:47:07] [PASSED] sep_comma_example
[13:47:07] ====================== [PASSED] args =======================
[13:47:07] =================== xe_pci (3 subtests) ====================
[13:47:07] ==================== check_graphics_ip  ====================
[13:47:07] [PASSED] 12.00 Xe_LP
[13:47:07] [PASSED] 12.10 Xe_LP+
[13:47:07] [PASSED] 12.55 Xe_HPG
[13:47:07] [PASSED] 12.60 Xe_HPC
[13:47:07] [PASSED] 12.70 Xe_LPG
[13:47:07] [PASSED] 12.71 Xe_LPG
[13:47:07] [PASSED] 12.74 Xe_LPG+
[13:47:07] [PASSED] 20.01 Xe2_HPG
[13:47:07] [PASSED] 20.02 Xe2_HPG
[13:47:07] [PASSED] 20.04 Xe2_LPG
[13:47:07] [PASSED] 30.00 Xe3_LPG
[13:47:07] [PASSED] 30.01 Xe3_LPG
[13:47:07] [PASSED] 30.03 Xe3_LPG
[13:47:07] [PASSED] 30.04 Xe3_LPG
[13:47:07] [PASSED] 30.05 Xe3_LPG
[13:47:07] [PASSED] 35.11 Xe3p_XPC
[13:47:07] ================ [PASSED] check_graphics_ip ================
[13:47:07] ===================== check_media_ip  ======================
[13:47:07] [PASSED] 12.00 Xe_M
[13:47:07] [PASSED] 12.55 Xe_HPM
[13:47:07] [PASSED] 13.00 Xe_LPM+
[13:47:07] [PASSED] 13.01 Xe2_HPM
[13:47:07] [PASSED] 20.00 Xe2_LPM
[13:47:07] [PASSED] 30.00 Xe3_LPM
[13:47:07] [PASSED] 30.02 Xe3_LPM
[13:47:07] [PASSED] 35.00 Xe3p_LPM
[13:47:07] [PASSED] 35.03 Xe3p_HPM
[13:47:07] ================= [PASSED] check_media_ip ==================
[13:47:07] =================== check_platform_desc  ===================
[13:47:07] [PASSED] 0x9A60 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A68 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A70 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A40 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A49 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A59 (TIGERLAKE)
[13:47:07] [PASSED] 0x9A78 (TIGERLAKE)
[13:47:07] [PASSED] 0x9AC0 (TIGERLAKE)
[13:47:07] [PASSED] 0x9AC9 (TIGERLAKE)
[13:47:07] [PASSED] 0x9AD9 (TIGERLAKE)
[13:47:07] [PASSED] 0x9AF8 (TIGERLAKE)
[13:47:07] [PASSED] 0x4C80 (ROCKETLAKE)
[13:47:07] [PASSED] 0x4C8A (ROCKETLAKE)
[13:47:07] [PASSED] 0x4C8B (ROCKETLAKE)
[13:47:07] [PASSED] 0x4C8C (ROCKETLAKE)
[13:47:07] [PASSED] 0x4C90 (ROCKETLAKE)
[13:47:07] [PASSED] 0x4C9A (ROCKETLAKE)
[13:47:07] [PASSED] 0x4680 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4682 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4688 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x468A (ALDERLAKE_S)
[13:47:07] [PASSED] 0x468B (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4690 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4692 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4693 (ALDERLAKE_S)
[13:47:07] [PASSED] 0x46A0 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46A1 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46A2 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46A3 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46A6 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46A8 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46AA (ALDERLAKE_P)
[13:47:07] [PASSED] 0x462A (ALDERLAKE_P)
[13:47:07] [PASSED] 0x4626 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x4628 (ALDERLAKE_P)
stty: 'standard input': Inappropriate ioctl for device
[13:47:07] [PASSED] 0x46B0 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46B1 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46B2 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46B3 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46C0 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46C1 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46C2 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46C3 (ALDERLAKE_P)
[13:47:07] [PASSED] 0x46D0 (ALDERLAKE_N)
[13:47:07] [PASSED] 0x46D1 (ALDERLAKE_N)
[13:47:07] [PASSED] 0x46D2 (ALDERLAKE_N)
[13:47:07] [PASSED] 0x46D3 (ALDERLAKE_N)
[13:47:07] [PASSED] 0x46D4 (ALDERLAKE_N)
[13:47:07] [PASSED] 0xA721 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7A1 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7A9 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7AC (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7AD (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA720 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7A0 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7A8 (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7AA (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA7AB (ALDERLAKE_P)
[13:47:07] [PASSED] 0xA780 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA781 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA782 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA783 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA788 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA789 (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA78A (ALDERLAKE_S)
[13:47:07] [PASSED] 0xA78B (ALDERLAKE_S)
[13:47:07] [PASSED] 0x4905 (DG1)
[13:47:07] [PASSED] 0x4906 (DG1)
[13:47:07] [PASSED] 0x4907 (DG1)
[13:47:07] [PASSED] 0x4908 (DG1)
[13:47:07] [PASSED] 0x4909 (DG1)
[13:47:07] [PASSED] 0x56C0 (DG2)
[13:47:07] [PASSED] 0x56C2 (DG2)
[13:47:07] [PASSED] 0x56C1 (DG2)
[13:47:07] [PASSED] 0x7D51 (METEORLAKE)
[13:47:07] [PASSED] 0x7DD1 (METEORLAKE)
[13:47:07] [PASSED] 0x7D41 (METEORLAKE)
[13:47:07] [PASSED] 0x7D67 (METEORLAKE)
[13:47:07] [PASSED] 0xB640 (METEORLAKE)
[13:47:07] [PASSED] 0x56A0 (DG2)
[13:47:07] [PASSED] 0x56A1 (DG2)
[13:47:07] [PASSED] 0x56A2 (DG2)
[13:47:07] [PASSED] 0x56BE (DG2)
[13:47:07] [PASSED] 0x56BF (DG2)
[13:47:07] [PASSED] 0x5690 (DG2)
[13:47:07] [PASSED] 0x5691 (DG2)
[13:47:07] [PASSED] 0x5692 (DG2)
[13:47:07] [PASSED] 0x56A5 (DG2)
[13:47:07] [PASSED] 0x56A6 (DG2)
[13:47:07] [PASSED] 0x56B0 (DG2)
[13:47:07] [PASSED] 0x56B1 (DG2)
[13:47:07] [PASSED] 0x56BA (DG2)
[13:47:07] [PASSED] 0x56BB (DG2)
[13:47:07] [PASSED] 0x56BC (DG2)
[13:47:07] [PASSED] 0x56BD (DG2)
[13:47:07] [PASSED] 0x5693 (DG2)
[13:47:07] [PASSED] 0x5694 (DG2)
[13:47:07] [PASSED] 0x5695 (DG2)
[13:47:07] [PASSED] 0x56A3 (DG2)
[13:47:07] [PASSED] 0x56A4 (DG2)
[13:47:07] [PASSED] 0x56B2 (DG2)
[13:47:07] [PASSED] 0x56B3 (DG2)
[13:47:07] [PASSED] 0x5696 (DG2)
[13:47:07] [PASSED] 0x5697 (DG2)
[13:47:07] [PASSED] 0xB69 (PVC)
[13:47:07] [PASSED] 0xB6E (PVC)
[13:47:07] [PASSED] 0xBD4 (PVC)
[13:47:07] [PASSED] 0xBD5 (PVC)
[13:47:07] [PASSED] 0xBD6 (PVC)
[13:47:07] [PASSED] 0xBD7 (PVC)
[13:47:07] [PASSED] 0xBD8 (PVC)
[13:47:07] [PASSED] 0xBD9 (PVC)
[13:47:07] [PASSED] 0xBDA (PVC)
[13:47:07] [PASSED] 0xBDB (PVC)
[13:47:07] [PASSED] 0xBE0 (PVC)
[13:47:07] [PASSED] 0xBE1 (PVC)
[13:47:07] [PASSED] 0xBE5 (PVC)
[13:47:07] [PASSED] 0x7D40 (METEORLAKE)
[13:47:07] [PASSED] 0x7D45 (METEORLAKE)
[13:47:07] [PASSED] 0x7D55 (METEORLAKE)
[13:47:07] [PASSED] 0x7D60 (METEORLAKE)
[13:47:07] [PASSED] 0x7DD5 (METEORLAKE)
[13:47:07] [PASSED] 0x6420 (LUNARLAKE)
[13:47:07] [PASSED] 0x64A0 (LUNARLAKE)
[13:47:07] [PASSED] 0x64B0 (LUNARLAKE)
[13:47:07] [PASSED] 0xE202 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE209 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE20B (BATTLEMAGE)
[13:47:07] [PASSED] 0xE20C (BATTLEMAGE)
[13:47:07] [PASSED] 0xE20D (BATTLEMAGE)
[13:47:07] [PASSED] 0xE210 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE211 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE212 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE216 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE220 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE221 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE222 (BATTLEMAGE)
[13:47:07] [PASSED] 0xE223 (BATTLEMAGE)
[13:47:07] [PASSED] 0xB080 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB081 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB082 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB083 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB084 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB085 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB086 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB087 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB08F (PANTHERLAKE)
[13:47:07] [PASSED] 0xB090 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB0A0 (PANTHERLAKE)
[13:47:07] [PASSED] 0xB0B0 (PANTHERLAKE)
[13:47:07] [PASSED] 0xFD80 (PANTHERLAKE)
[13:47:07] [PASSED] 0xFD81 (PANTHERLAKE)
[13:47:07] [PASSED] 0xD740 (NOVALAKE_S)
[13:47:07] [PASSED] 0xD741 (NOVALAKE_S)
[13:47:07] [PASSED] 0xD742 (NOVALAKE_S)
[13:47:07] [PASSED] 0xD743 (NOVALAKE_S)
[13:47:07] [PASSED] 0xD744 (NOVALAKE_S)
[13:47:07] [PASSED] 0xD745 (NOVALAKE_S)
[13:47:07] [PASSED] 0x674C (CRESCENTISLAND)
[13:47:07] =============== [PASSED] check_platform_desc ===============
[13:47:07] ===================== [PASSED] xe_pci ======================
[13:47:07] =================== xe_rtp (2 subtests) ====================
[13:47:07] =============== xe_rtp_process_to_sr_tests  ================
[13:47:07] [PASSED] coalesce-same-reg
[13:47:07] [PASSED] no-match-no-add
[13:47:07] [PASSED] match-or
[13:47:07] [PASSED] match-or-xfail
[13:47:07] [PASSED] no-match-no-add-multiple-rules
[13:47:07] [PASSED] two-regs-two-entries
[13:47:07] [PASSED] clr-one-set-other
[13:47:07] [PASSED] set-field
[13:47:07] [PASSED] conflict-duplicate
[13:47:07] [PASSED] conflict-not-disjoint
[13:47:07] [PASSED] conflict-reg-type
[13:47:07] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[13:47:07] ================== xe_rtp_process_tests  ===================
[13:47:07] [PASSED] active1
[13:47:07] [PASSED] active2
[13:47:07] [PASSED] active-inactive
[13:47:07] [PASSED] inactive-active
[13:47:07] [PASSED] inactive-1st_or_active-inactive
[13:47:07] [PASSED] inactive-2nd_or_active-inactive
[13:47:07] [PASSED] inactive-last_or_active-inactive
[13:47:07] [PASSED] inactive-no_or_active-inactive
[13:47:07] ============== [PASSED] xe_rtp_process_tests ===============
[13:47:07] ===================== [PASSED] xe_rtp ======================
[13:47:07] ==================== xe_wa (1 subtest) =====================
[13:47:07] ======================== xe_wa_gt  =========================
[13:47:07] [PASSED] TIGERLAKE B0
[13:47:07] [PASSED] DG1 A0
[13:47:07] [PASSED] DG1 B0
[13:47:07] [PASSED] ALDERLAKE_S A0
[13:47:07] [PASSED] ALDERLAKE_S B0
[13:47:07] [PASSED] ALDERLAKE_S C0
[13:47:07] [PASSED] ALDERLAKE_S D0
[13:47:07] [PASSED] ALDERLAKE_P A0
[13:47:07] [PASSED] ALDERLAKE_P B0
[13:47:07] [PASSED] ALDERLAKE_P C0
[13:47:07] [PASSED] ALDERLAKE_S RPLS D0
[13:47:07] [PASSED] ALDERLAKE_P RPLU E0
[13:47:07] [PASSED] DG2 G10 C0
[13:47:07] [PASSED] DG2 G11 B1
[13:47:07] [PASSED] DG2 G12 A1
[13:47:07] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[13:47:07] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[13:47:07] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[13:47:07] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[13:47:07] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[13:47:07] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[13:47:07] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[13:47:07] ==================== [PASSED] xe_wa_gt =====================
[13:47:07] ====================== [PASSED] xe_wa ======================
[13:47:07] ============================================================
[13:47:07] Testing complete. Ran 512 tests: passed: 494, skipped: 18
[13:47:07] Elapsed time: 43.893s total, 4.317s configuring, 39.059s building, 0.487s running

+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[13:47:07] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[13:47:09] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=25
[13:47:39] Starting KUnit Kernel (1/1)...
[13:47:39] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[13:47:39] ============ drm_test_pick_cmdline (2 subtests) ============
[13:47:39] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[13:47:39] =============== drm_test_pick_cmdline_named  ===============
[13:47:39] [PASSED] NTSC
[13:47:39] [PASSED] NTSC-J
[13:47:39] [PASSED] PAL
[13:47:39] [PASSED] PAL-M
[13:47:39] =========== [PASSED] drm_test_pick_cmdline_named ===========
[13:47:39] ============== [PASSED] drm_test_pick_cmdline ==============
[13:47:39] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[13:47:39] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[13:47:39] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[13:47:39] =========== drm_validate_clone_mode (2 subtests) ===========
[13:47:39] ============== drm_test_check_in_clone_mode  ===============
[13:47:39] [PASSED] in_clone_mode
[13:47:39] [PASSED] not_in_clone_mode
[13:47:39] ========== [PASSED] drm_test_check_in_clone_mode ===========
[13:47:39] =============== drm_test_check_valid_clones  ===============
[13:47:39] [PASSED] not_in_clone_mode
[13:47:39] [PASSED] valid_clone
[13:47:39] [PASSED] invalid_clone
[13:47:39] =========== [PASSED] drm_test_check_valid_clones ===========
[13:47:39] ============= [PASSED] drm_validate_clone_mode =============
[13:47:39] ============= drm_validate_modeset (1 subtest) =============
[13:47:39] [PASSED] drm_test_check_connector_changed_modeset
[13:47:39] ============== [PASSED] drm_validate_modeset ===============
[13:47:39] ====== drm_test_bridge_get_current_state (2 subtests) ======
[13:47:39] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[13:47:39] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[13:47:39] ======== [PASSED] drm_test_bridge_get_current_state ========
[13:47:39] ====== drm_test_bridge_helper_reset_crtc (3 subtests) ======
[13:47:39] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[13:47:39] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[13:47:39] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[13:47:39] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[13:47:39] ============== drm_bridge_alloc (2 subtests) ===============
[13:47:39] [PASSED] drm_test_drm_bridge_alloc_basic
[13:47:39] [PASSED] drm_test_drm_bridge_alloc_get_put
[13:47:39] ================ [PASSED] drm_bridge_alloc =================
[13:47:39] ================== drm_buddy (9 subtests) ==================
[13:47:39] [PASSED] drm_test_buddy_alloc_limit
[13:47:39] [PASSED] drm_test_buddy_alloc_optimistic
[13:47:39] [PASSED] drm_test_buddy_alloc_pessimistic
[13:47:39] [PASSED] drm_test_buddy_alloc_pathological
[13:47:39] [PASSED] drm_test_buddy_alloc_contiguous
[13:47:39] [PASSED] drm_test_buddy_alloc_clear
[13:47:40] [PASSED] drm_test_buddy_alloc_range_bias
[13:47:40] [PASSED] drm_test_buddy_fragmentation_performance
[13:47:40] [PASSED] drm_test_buddy_alloc_exceeds_max_order
[13:47:40] ==================== [PASSED] drm_buddy ====================
[13:47:40] ============= drm_cmdline_parser (40 subtests) =============
[13:47:40] [PASSED] drm_test_cmdline_force_d_only
[13:47:40] [PASSED] drm_test_cmdline_force_D_only_dvi
[13:47:40] [PASSED] drm_test_cmdline_force_D_only_hdmi
[13:47:40] [PASSED] drm_test_cmdline_force_D_only_not_digital
[13:47:40] [PASSED] drm_test_cmdline_force_e_only
[13:47:40] [PASSED] drm_test_cmdline_res
[13:47:40] [PASSED] drm_test_cmdline_res_vesa
[13:47:40] [PASSED] drm_test_cmdline_res_vesa_rblank
[13:47:40] [PASSED] drm_test_cmdline_res_rblank
[13:47:40] [PASSED] drm_test_cmdline_res_bpp
[13:47:40] [PASSED] drm_test_cmdline_res_refresh
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[13:47:40] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[13:47:40] [PASSED] drm_test_cmdline_res_margins_force_on
[13:47:40] [PASSED] drm_test_cmdline_res_vesa_margins
[13:47:40] [PASSED] drm_test_cmdline_name
[13:47:40] [PASSED] drm_test_cmdline_name_bpp
[13:47:40] [PASSED] drm_test_cmdline_name_option
[13:47:40] [PASSED] drm_test_cmdline_name_bpp_option
[13:47:40] [PASSED] drm_test_cmdline_rotate_0
[13:47:40] [PASSED] drm_test_cmdline_rotate_90
[13:47:40] [PASSED] drm_test_cmdline_rotate_180
[13:47:40] [PASSED] drm_test_cmdline_rotate_270
[13:47:40] [PASSED] drm_test_cmdline_hmirror
[13:47:40] [PASSED] drm_test_cmdline_vmirror
[13:47:40] [PASSED] drm_test_cmdline_margin_options
[13:47:40] [PASSED] drm_test_cmdline_multiple_options
[13:47:40] [PASSED] drm_test_cmdline_bpp_extra_and_option
[13:47:40] [PASSED] drm_test_cmdline_extra_and_option
[13:47:40] [PASSED] drm_test_cmdline_freestanding_options
[13:47:40] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[13:47:40] [PASSED] drm_test_cmdline_panel_orientation
[13:47:40] ================ drm_test_cmdline_invalid  =================
[13:47:40] [PASSED] margin_only
[13:47:40] [PASSED] interlace_only
[13:47:40] [PASSED] res_missing_x
[13:47:40] [PASSED] res_missing_y
[13:47:40] [PASSED] res_bad_y
[13:47:40] [PASSED] res_missing_y_bpp
[13:47:40] [PASSED] res_bad_bpp
[13:47:40] [PASSED] res_bad_refresh
[13:47:40] [PASSED] res_bpp_refresh_force_on_off
[13:47:40] [PASSED] res_invalid_mode
[13:47:40] [PASSED] res_bpp_wrong_place_mode
[13:47:40] [PASSED] name_bpp_refresh
[13:47:40] [PASSED] name_refresh
[13:47:40] [PASSED] name_refresh_wrong_mode
[13:47:40] [PASSED] name_refresh_invalid_mode
[13:47:40] [PASSED] rotate_multiple
[13:47:40] [PASSED] rotate_invalid_val
[13:47:40] [PASSED] rotate_truncated
[13:47:40] [PASSED] invalid_option
[13:47:40] [PASSED] invalid_tv_option
[13:47:40] [PASSED] truncated_tv_option
[13:47:40] ============ [PASSED] drm_test_cmdline_invalid =============
[13:47:40] =============== drm_test_cmdline_tv_options  ===============
[13:47:40] [PASSED] NTSC
[13:47:40] [PASSED] NTSC_443
[13:47:40] [PASSED] NTSC_J
[13:47:40] [PASSED] PAL
[13:47:40] [PASSED] PAL_M
[13:47:40] [PASSED] PAL_N
[13:47:40] [PASSED] SECAM
[13:47:40] [PASSED] MONO_525
[13:47:40] [PASSED] MONO_625
[13:47:40] =========== [PASSED] drm_test_cmdline_tv_options ===========
[13:47:40] =============== [PASSED] drm_cmdline_parser ================
[13:47:40] ========== drmm_connector_hdmi_init (20 subtests) ==========
[13:47:40] [PASSED] drm_test_connector_hdmi_init_valid
[13:47:40] [PASSED] drm_test_connector_hdmi_init_bpc_8
[13:47:40] [PASSED] drm_test_connector_hdmi_init_bpc_10
[13:47:40] [PASSED] drm_test_connector_hdmi_init_bpc_12
[13:47:40] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[13:47:40] [PASSED] drm_test_connector_hdmi_init_bpc_null
[13:47:40] [PASSED] drm_test_connector_hdmi_init_formats_empty
[13:47:40] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[13:47:40] === drm_test_connector_hdmi_init_formats_yuv420_allowed  ===
[13:47:40] [PASSED] supported_formats=0x9 yuv420_allowed=1
[13:47:40] [PASSED] supported_formats=0x9 yuv420_allowed=0
[13:47:40] [PASSED] supported_formats=0x3 yuv420_allowed=1
[13:47:40] [PASSED] supported_formats=0x3 yuv420_allowed=0
[13:47:40] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[13:47:40] [PASSED] drm_test_connector_hdmi_init_null_ddc
[13:47:40] [PASSED] drm_test_connector_hdmi_init_null_product
[13:47:40] [PASSED] drm_test_connector_hdmi_init_null_vendor
[13:47:40] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[13:47:40] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[13:47:40] [PASSED] drm_test_connector_hdmi_init_product_valid
[13:47:40] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[13:47:40] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[13:47:40] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[13:47:40] ========= drm_test_connector_hdmi_init_type_valid  =========
[13:47:40] [PASSED] HDMI-A
[13:47:40] [PASSED] HDMI-B
[13:47:40] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[13:47:40] ======== drm_test_connector_hdmi_init_type_invalid  ========
[13:47:40] [PASSED] Unknown
[13:47:40] [PASSED] VGA
[13:47:40] [PASSED] DVI-I
[13:47:40] [PASSED] DVI-D
[13:47:40] [PASSED] DVI-A
[13:47:40] [PASSED] Composite
[13:47:40] [PASSED] SVIDEO
[13:47:40] [PASSED] LVDS
[13:47:40] [PASSED] Component
[13:47:40] [PASSED] DIN
[13:47:40] [PASSED] DP
[13:47:40] [PASSED] TV
[13:47:40] [PASSED] eDP
[13:47:40] [PASSED] Virtual
[13:47:40] [PASSED] DSI
[13:47:40] [PASSED] DPI
[13:47:40] [PASSED] Writeback
[13:47:40] [PASSED] SPI
[13:47:40] [PASSED] USB
[13:47:40] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[13:47:40] ============ [PASSED] drmm_connector_hdmi_init =============
[13:47:40] ============= drmm_connector_init (3 subtests) =============
[13:47:40] [PASSED] drm_test_drmm_connector_init
[13:47:40] [PASSED] drm_test_drmm_connector_init_null_ddc
[13:47:40] ========= drm_test_drmm_connector_init_type_valid  =========
[13:47:40] [PASSED] Unknown
[13:47:40] [PASSED] VGA
[13:47:40] [PASSED] DVI-I
[13:47:40] [PASSED] DVI-D
[13:47:40] [PASSED] DVI-A
[13:47:40] [PASSED] Composite
[13:47:40] [PASSED] SVIDEO
[13:47:40] [PASSED] LVDS
[13:47:40] [PASSED] Component
[13:47:40] [PASSED] DIN
[13:47:40] [PASSED] DP
[13:47:40] [PASSED] HDMI-A
[13:47:40] [PASSED] HDMI-B
[13:47:40] [PASSED] TV
[13:47:40] [PASSED] eDP
[13:47:40] [PASSED] Virtual
[13:47:40] [PASSED] DSI
[13:47:40] [PASSED] DPI
[13:47:40] [PASSED] Writeback
[13:47:40] [PASSED] SPI
[13:47:40] [PASSED] USB
[13:47:40] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[13:47:40] =============== [PASSED] drmm_connector_init ===============
[13:47:40] ========= drm_connector_dynamic_init (6 subtests) ==========
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_init
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_init_properties
[13:47:40] ===== drm_test_drm_connector_dynamic_init_type_valid  ======
[13:47:40] [PASSED] Unknown
[13:47:40] [PASSED] VGA
[13:47:40] [PASSED] DVI-I
[13:47:40] [PASSED] DVI-D
[13:47:40] [PASSED] DVI-A
[13:47:40] [PASSED] Composite
[13:47:40] [PASSED] SVIDEO
[13:47:40] [PASSED] LVDS
[13:47:40] [PASSED] Component
[13:47:40] [PASSED] DIN
[13:47:40] [PASSED] DP
[13:47:40] [PASSED] HDMI-A
[13:47:40] [PASSED] HDMI-B
[13:47:40] [PASSED] TV
[13:47:40] [PASSED] eDP
[13:47:40] [PASSED] Virtual
[13:47:40] [PASSED] DSI
[13:47:40] [PASSED] DPI
[13:47:40] [PASSED] Writeback
[13:47:40] [PASSED] SPI
[13:47:40] [PASSED] USB
[13:47:40] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[13:47:40] ======== drm_test_drm_connector_dynamic_init_name  =========
[13:47:40] [PASSED] Unknown
[13:47:40] [PASSED] VGA
[13:47:40] [PASSED] DVI-I
[13:47:40] [PASSED] DVI-D
[13:47:40] [PASSED] DVI-A
[13:47:40] [PASSED] Composite
[13:47:40] [PASSED] SVIDEO
[13:47:40] [PASSED] LVDS
[13:47:40] [PASSED] Component
[13:47:40] [PASSED] DIN
[13:47:40] [PASSED] DP
[13:47:40] [PASSED] HDMI-A
[13:47:40] [PASSED] HDMI-B
[13:47:40] [PASSED] TV
[13:47:40] [PASSED] eDP
[13:47:40] [PASSED] Virtual
[13:47:40] [PASSED] DSI
[13:47:40] [PASSED] DPI
[13:47:40] [PASSED] Writeback
[13:47:40] [PASSED] SPI
[13:47:40] [PASSED] USB
[13:47:40] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[13:47:40] =========== [PASSED] drm_connector_dynamic_init ============
[13:47:40] ==== drm_connector_dynamic_register_early (4 subtests) =====
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[13:47:40] ====== [PASSED] drm_connector_dynamic_register_early =======
[13:47:40] ======= drm_connector_dynamic_register (7 subtests) ========
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[13:47:40] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[13:47:40] ========= [PASSED] drm_connector_dynamic_register ==========
[13:47:40] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[13:47:40] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[13:47:40] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[13:47:40] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[13:47:40] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[13:47:40] ========== drm_test_get_tv_mode_from_name_valid  ===========
[13:47:40] [PASSED] NTSC
[13:47:40] [PASSED] NTSC-443
[13:47:40] [PASSED] NTSC-J
[13:47:40] [PASSED] PAL
[13:47:40] [PASSED] PAL-M
[13:47:40] [PASSED] PAL-N
[13:47:40] [PASSED] SECAM
[13:47:40] [PASSED] Mono
[13:47:40] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[13:47:40] [PASSED] drm_test_get_tv_mode_from_name_truncated
[13:47:40] ============ [PASSED] drm_get_tv_mode_from_name ============
[13:47:40] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[13:47:40] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[13:47:40] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid  =
[13:47:40] [PASSED] VIC 96
[13:47:40] [PASSED] VIC 97
[13:47:40] [PASSED] VIC 101
[13:47:40] [PASSED] VIC 102
[13:47:40] [PASSED] VIC 106
[13:47:40] [PASSED] VIC 107
[13:47:40] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[13:47:40] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[13:47:40] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[13:47:40] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[13:47:40] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[13:47:40] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[13:47:40] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[13:47:40] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[13:47:40] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name  ====
[13:47:40] [PASSED] Automatic
[13:47:40] [PASSED] Full
[13:47:40] [PASSED] Limited 16:235
[13:47:40] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[13:47:40] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[13:47:40] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[13:47:40] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[13:47:40] === drm_test_drm_hdmi_connector_get_output_format_name  ====
[13:47:40] [PASSED] RGB
[13:47:40] [PASSED] YUV 4:2:0
[13:47:40] [PASSED] YUV 4:2:2
[13:47:40] [PASSED] YUV 4:4:4
[13:47:40] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[13:47:40] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[13:47:40] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[13:47:40] ============= drm_damage_helper (21 subtests) ==============
[13:47:40] [PASSED] drm_test_damage_iter_no_damage
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_src_moved
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_not_visible
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[13:47:40] [PASSED] drm_test_damage_iter_no_damage_no_fb
[13:47:40] [PASSED] drm_test_damage_iter_simple_damage
[13:47:40] [PASSED] drm_test_damage_iter_single_damage
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_outside_src
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_src_moved
[13:47:40] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[13:47:40] [PASSED] drm_test_damage_iter_damage
[13:47:40] [PASSED] drm_test_damage_iter_damage_one_intersect
[13:47:40] [PASSED] drm_test_damage_iter_damage_one_outside
[13:47:40] [PASSED] drm_test_damage_iter_damage_src_moved
[13:47:40] [PASSED] drm_test_damage_iter_damage_not_visible
[13:47:40] ================ [PASSED] drm_damage_helper ================
[13:47:40] ============== drm_dp_mst_helper (3 subtests) ==============
[13:47:40] ============== drm_test_dp_mst_calc_pbn_mode  ==============
[13:47:40] [PASSED] Clock 154000 BPP 30 DSC disabled
[13:47:40] [PASSED] Clock 234000 BPP 30 DSC disabled
[13:47:40] [PASSED] Clock 297000 BPP 24 DSC disabled
[13:47:40] [PASSED] Clock 332880 BPP 24 DSC enabled
[13:47:40] [PASSED] Clock 324540 BPP 24 DSC enabled
[13:47:40] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[13:47:40] ============== drm_test_dp_mst_calc_pbn_div  ===============
[13:47:40] [PASSED] Link rate 2000000 lane count 4
[13:47:40] [PASSED] Link rate 2000000 lane count 2
[13:47:40] [PASSED] Link rate 2000000 lane count 1
[13:47:40] [PASSED] Link rate 1350000 lane count 4
[13:47:40] [PASSED] Link rate 1350000 lane count 2
[13:47:40] [PASSED] Link rate 1350000 lane count 1
[13:47:40] [PASSED] Link rate 1000000 lane count 4
[13:47:40] [PASSED] Link rate 1000000 lane count 2
[13:47:40] [PASSED] Link rate 1000000 lane count 1
[13:47:40] [PASSED] Link rate 810000 lane count 4
[13:47:40] [PASSED] Link rate 810000 lane count 2
[13:47:40] [PASSED] Link rate 810000 lane count 1
[13:47:40] [PASSED] Link rate 540000 lane count 4
[13:47:40] [PASSED] Link rate 540000 lane count 2
[13:47:40] [PASSED] Link rate 540000 lane count 1
[13:47:40] [PASSED] Link rate 270000 lane count 4
[13:47:40] [PASSED] Link rate 270000 lane count 2
[13:47:40] [PASSED] Link rate 270000 lane count 1
[13:47:40] [PASSED] Link rate 162000 lane count 4
[13:47:40] [PASSED] Link rate 162000 lane count 2
[13:47:40] [PASSED] Link rate 162000 lane count 1
[13:47:40] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[13:47:40] ========= drm_test_dp_mst_sideband_msg_req_decode  =========
[13:47:40] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[13:47:40] [PASSED] DP_POWER_UP_PHY with port number
[13:47:40] [PASSED] DP_POWER_DOWN_PHY with port number
[13:47:40] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[13:47:40] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[13:47:40] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[13:47:40] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[13:47:40] [PASSED] DP_QUERY_PAYLOAD with port number
[13:47:40] [PASSED] DP_QUERY_PAYLOAD with VCPI
[13:47:40] [PASSED] DP_REMOTE_DPCD_READ with port number
[13:47:40] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[13:47:40] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[13:47:40] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[13:47:40] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[13:47:40] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[13:47:40] [PASSED] DP_REMOTE_I2C_READ with port number
[13:47:40] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[13:47:40] [PASSED] DP_REMOTE_I2C_READ with transactions array
[13:47:40] [PASSED] DP_REMOTE_I2C_WRITE with port number
[13:47:40] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[13:47:40] [PASSED] DP_REMOTE_I2C_WRITE with data array
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[13:47:40] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[13:47:40] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[13:47:40] ================ [PASSED] drm_dp_mst_helper ================
[13:47:40] ================== drm_exec (7 subtests) ===================
[13:47:40] [PASSED] sanitycheck
[13:47:40] [PASSED] test_lock
[13:47:40] [PASSED] test_lock_unlock
[13:47:40] [PASSED] test_duplicates
[13:47:40] [PASSED] test_prepare
[13:47:40] [PASSED] test_prepare_array
[13:47:40] [PASSED] test_multiple_loops
[13:47:40] ==================== [PASSED] drm_exec =====================
[13:47:40] =========== drm_format_helper_test (17 subtests) ===========
[13:47:40] ============== drm_test_fb_xrgb8888_to_gray8  ==============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[13:47:40] ============= drm_test_fb_xrgb8888_to_rgb332  ==============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[13:47:40] ============= drm_test_fb_xrgb8888_to_rgb565  ==============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[13:47:40] ============ drm_test_fb_xrgb8888_to_xrgb1555  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[13:47:40] ============ drm_test_fb_xrgb8888_to_argb1555  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[13:47:40] ============ drm_test_fb_xrgb8888_to_rgba5551  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[13:47:40] ============= drm_test_fb_xrgb8888_to_rgb888  ==============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[13:47:40] ============= drm_test_fb_xrgb8888_to_bgr888  ==============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[13:47:40] ============ drm_test_fb_xrgb8888_to_argb8888  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[13:47:40] =========== drm_test_fb_xrgb8888_to_xrgb2101010  ===========
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[13:47:40] =========== drm_test_fb_xrgb8888_to_argb2101010  ===========
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[13:47:40] ============== drm_test_fb_xrgb8888_to_mono  ===============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[13:47:40] ==================== drm_test_fb_swab  =====================
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ================ [PASSED] drm_test_fb_swab =================
[13:47:40] ============ drm_test_fb_xrgb8888_to_xbgr8888  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[13:47:40] ============ drm_test_fb_xrgb8888_to_abgr8888  =============
[13:47:40] [PASSED] single_pixel_source_buffer
[13:47:40] [PASSED] single_pixel_clip_rectangle
[13:47:40] [PASSED] well_known_colors
[13:47:40] [PASSED] destination_pitch
[13:47:40] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[13:47:40] ================= drm_test_fb_clip_offset  =================
[13:47:40] [PASSED] pass through
[13:47:40] [PASSED] horizontal offset
[13:47:40] [PASSED] vertical offset
[13:47:40] [PASSED] horizontal and vertical offset
[13:47:40] [PASSED] horizontal offset (custom pitch)
[13:47:40] [PASSED] vertical offset (custom pitch)
[13:47:40] [PASSED] horizontal and vertical offset (custom pitch)
[13:47:40] ============= [PASSED] drm_test_fb_clip_offset =============
[13:47:40] =================== drm_test_fb_memcpy  ====================
[13:47:40] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[13:47:40] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[13:47:40] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[13:47:40] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[13:47:40] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[13:47:40] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[13:47:40] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[13:47:40] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[13:47:40] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[13:47:40] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[13:47:40] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[13:47:40] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[13:47:40] =============== [PASSED] drm_test_fb_memcpy ================
[13:47:40] ============= [PASSED] drm_format_helper_test ==============
[13:47:40] ================= drm_format (18 subtests) =================
[13:47:40] [PASSED] drm_test_format_block_width_invalid
[13:47:40] [PASSED] drm_test_format_block_width_one_plane
[13:47:40] [PASSED] drm_test_format_block_width_two_plane
[13:47:40] [PASSED] drm_test_format_block_width_three_plane
[13:47:40] [PASSED] drm_test_format_block_width_tiled
[13:47:40] [PASSED] drm_test_format_block_height_invalid
[13:47:40] [PASSED] drm_test_format_block_height_one_plane
[13:47:40] [PASSED] drm_test_format_block_height_two_plane
[13:47:40] [PASSED] drm_test_format_block_height_three_plane
[13:47:40] [PASSED] drm_test_format_block_height_tiled
[13:47:40] [PASSED] drm_test_format_min_pitch_invalid
[13:47:40] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[13:47:40] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[13:47:40] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[13:47:40] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[13:47:40] [PASSED] drm_test_format_min_pitch_two_plane
[13:47:40] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[13:47:40] [PASSED] drm_test_format_min_pitch_tiled
[13:47:40] =================== [PASSED] drm_format ====================
[13:47:40] ============== drm_framebuffer (10 subtests) ===============
[13:47:40] ========== drm_test_framebuffer_check_src_coords  ==========
[13:47:40] [PASSED] Success: source fits into fb
[13:47:40] [PASSED] Fail: overflowing fb with x-axis coordinate
[13:47:40] [PASSED] Fail: overflowing fb with y-axis coordinate
[13:47:40] [PASSED] Fail: overflowing fb with source width
[13:47:40] [PASSED] Fail: overflowing fb with source height
[13:47:40] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[13:47:40] [PASSED] drm_test_framebuffer_cleanup
[13:47:40] =============== drm_test_framebuffer_create  ===============
[13:47:40] [PASSED] ABGR8888 normal sizes
[13:47:40] [PASSED] ABGR8888 max sizes
[13:47:40] [PASSED] ABGR8888 pitch greater than min required
[13:47:40] [PASSED] ABGR8888 pitch less than min required
[13:47:40] [PASSED] ABGR8888 Invalid width
[13:47:40] [PASSED] ABGR8888 Invalid buffer handle
[13:47:40] [PASSED] No pixel format
[13:47:40] [PASSED] ABGR8888 Width 0
[13:47:40] [PASSED] ABGR8888 Height 0
[13:47:40] [PASSED] ABGR8888 Out of bound height * pitch combination
[13:47:40] [PASSED] ABGR8888 Large buffer offset
[13:47:40] [PASSED] ABGR8888 Buffer offset for inexistent plane
[13:47:40] [PASSED] ABGR8888 Invalid flag
[13:47:40] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[13:47:40] [PASSED] ABGR8888 Valid buffer modifier
[13:47:40] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[13:47:40] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] NV12 Normal sizes
[13:47:40] [PASSED] NV12 Max sizes
[13:47:40] [PASSED] NV12 Invalid pitch
[13:47:40] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[13:47:40] [PASSED] NV12 different  modifier per-plane
[13:47:40] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[13:47:40] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] NV12 Modifier for inexistent plane
[13:47:40] [PASSED] NV12 Handle for inexistent plane
[13:47:40] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[13:47:40] [PASSED] YVU420 Normal sizes
[13:47:40] [PASSED] YVU420 Max sizes
[13:47:40] [PASSED] YVU420 Invalid pitch
[13:47:40] [PASSED] YVU420 Different pitches
[13:47:40] [PASSED] YVU420 Different buffer offsets/pitches
[13:47:40] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[13:47:40] [PASSED] YVU420 Valid modifier
[13:47:40] [PASSED] YVU420 Different modifiers per plane
[13:47:40] [PASSED] YVU420 Modifier for inexistent plane
[13:47:40] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[13:47:40] [PASSED] X0L2 Normal sizes
[13:47:40] [PASSED] X0L2 Max sizes
[13:47:40] [PASSED] X0L2 Invalid pitch
[13:47:40] [PASSED] X0L2 Pitch greater than minimum required
[13:47:40] [PASSED] X0L2 Handle for inexistent plane
[13:47:40] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[13:47:40] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[13:47:40] [PASSED] X0L2 Valid modifier
[13:47:40] [PASSED] X0L2 Modifier for inexistent plane
[13:47:40] =========== [PASSED] drm_test_framebuffer_create ===========
[13:47:40] [PASSED] drm_test_framebuffer_free
[13:47:40] [PASSED] drm_test_framebuffer_init
[13:47:40] [PASSED] drm_test_framebuffer_init_bad_format
[13:47:40] [PASSED] drm_test_framebuffer_init_dev_mismatch
[13:47:40] [PASSED] drm_test_framebuffer_lookup
[13:47:40] [PASSED] drm_test_framebuffer_lookup_inexistent
[13:47:40] [PASSED] drm_test_framebuffer_modifiers_not_supported
[13:47:40] ================= [PASSED] drm_framebuffer =================
[13:47:40] ================ drm_gem_shmem (8 subtests) ================
[13:47:40] [PASSED] drm_gem_shmem_test_obj_create
[13:47:40] [PASSED] drm_gem_shmem_test_obj_create_private
[13:47:40] [PASSED] drm_gem_shmem_test_pin_pages
[13:47:40] [PASSED] drm_gem_shmem_test_vmap
[13:47:40] [PASSED] drm_gem_shmem_test_get_sg_table
[13:47:40] [PASSED] drm_gem_shmem_test_get_pages_sgt
[13:47:40] [PASSED] drm_gem_shmem_test_madvise
[13:47:40] [PASSED] drm_gem_shmem_test_purge
[13:47:40] ================== [PASSED] drm_gem_shmem ==================
[13:47:40] === drm_atomic_helper_connector_hdmi_check (27 subtests) ===
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[13:47:40] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420  =======
[13:47:40] [PASSED] Automatic
[13:47:40] [PASSED] Full
[13:47:40] [PASSED] Limited 16:235
[13:47:40] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[13:47:40] [PASSED] drm_test_check_disable_connector
[13:47:40] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[13:47:40] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[13:47:40] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[13:47:40] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[13:47:40] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[13:47:40] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[13:47:40] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[13:47:40] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[13:47:40] [PASSED] drm_test_check_output_bpc_dvi
[13:47:40] [PASSED] drm_test_check_output_bpc_format_vic_1
[13:47:40] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[13:47:40] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[13:47:40] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[13:47:40] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[13:47:40] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[13:47:40] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[13:47:40] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[13:47:40] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[13:47:40] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[13:47:40] [PASSED] drm_test_check_broadcast_rgb_value
[13:47:40] [PASSED] drm_test_check_bpc_8_value
[13:47:40] [PASSED] drm_test_check_bpc_10_value
[13:47:40] [PASSED] drm_test_check_bpc_12_value
[13:47:40] [PASSED] drm_test_check_format_value
[13:47:40] [PASSED] drm_test_check_tmds_char_value
[13:47:40] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[13:47:40] = drm_atomic_helper_connector_hdmi_mode_valid (4 subtests) =
[13:47:40] [PASSED] drm_test_check_mode_valid
[13:47:40] [PASSED] drm_test_check_mode_valid_reject
[13:47:40] [PASSED] drm_test_check_mode_valid_reject_rate
[13:47:40] [PASSED] drm_test_check_mode_valid_reject_max_clock
[13:47:40] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[13:47:40] = drm_atomic_helper_connector_hdmi_infoframes (5 subtests) =
[13:47:40] [PASSED] drm_test_check_infoframes
[13:47:40] [PASSED] drm_test_check_reject_avi_infoframe
[13:47:40] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_8
[13:47:40] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_10
[13:47:40] [PASSED] drm_test_check_reject_audio_infoframe
[13:47:40] === [PASSED] drm_atomic_helper_connector_hdmi_infoframes ===
[13:47:40] ================= drm_managed (2 subtests) =================
[13:47:40] [PASSED] drm_test_managed_release_action
[13:47:40] [PASSED] drm_test_managed_run_action
[13:47:40] =================== [PASSED] drm_managed ===================
[13:47:40] =================== drm_mm (6 subtests) ====================
[13:47:40] [PASSED] drm_test_mm_init
[13:47:40] [PASSED] drm_test_mm_debug
[13:47:40] [PASSED] drm_test_mm_align32
[13:47:40] [PASSED] drm_test_mm_align64
[13:47:40] [PASSED] drm_test_mm_lowest
[13:47:40] [PASSED] drm_test_mm_highest
[13:47:40] ===================== [PASSED] drm_mm ======================
[13:47:40] ============= drm_modes_analog_tv (5 subtests) =============
[13:47:40] [PASSED] drm_test_modes_analog_tv_mono_576i
[13:47:40] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[13:47:40] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[13:47:40] [PASSED] drm_test_modes_analog_tv_pal_576i
[13:47:40] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[13:47:40] =============== [PASSED] drm_modes_analog_tv ===============
[13:47:40] ============== drm_plane_helper (2 subtests) ===============
[13:47:40] =============== drm_test_check_plane_state  ================
[13:47:40] [PASSED] clipping_simple
[13:47:40] [PASSED] clipping_rotate_reflect
[13:47:40] [PASSED] positioning_simple
[13:47:40] [PASSED] upscaling
[13:47:40] [PASSED] downscaling
[13:47:40] [PASSED] rounding1
[13:47:40] [PASSED] rounding2
[13:47:40] [PASSED] rounding3
[13:47:40] [PASSED] rounding4
[13:47:40] =========== [PASSED] drm_test_check_plane_state ============
[13:47:40] =========== drm_test_check_invalid_plane_state  ============
[13:47:40] [PASSED] positioning_invalid
[13:47:40] [PASSED] upscaling_invalid
[13:47:40] [PASSED] downscaling_invalid
[13:47:40] ======= [PASSED] drm_test_check_invalid_plane_state ========
[13:47:40] ================ [PASSED] drm_plane_helper =================
[13:47:40] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[13:47:40] ====== drm_test_connector_helper_tv_get_modes_check  =======
[13:47:40] [PASSED] None
[13:47:40] [PASSED] PAL
[13:47:40] [PASSED] NTSC
[13:47:40] [PASSED] Both, NTSC Default
[13:47:40] [PASSED] Both, PAL Default
[13:47:40] [PASSED] Both, NTSC Default, with PAL on command-line
[13:47:40] [PASSED] Both, PAL Default, with NTSC on command-line
[13:47:40] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[13:47:40] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[13:47:40] ================== drm_rect (9 subtests) ===================
[13:47:40] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[13:47:40] [PASSED] drm_test_rect_clip_scaled_not_clipped
[13:47:40] [PASSED] drm_test_rect_clip_scaled_clipped
[13:47:40] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[13:47:40] ================= drm_test_rect_intersect  =================
[13:47:40] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[13:47:40] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[13:47:40] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[13:47:40] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[13:47:40] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[13:47:40] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[13:47:40] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[13:47:40] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[13:47:40] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[13:47:40] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[13:47:40] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[13:47:40] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[13:47:40] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[13:47:40] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[13:47:40] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
stty: 'standard input': Inappropriate ioctl for device
[13:47:40] ============= [PASSED] drm_test_rect_intersect =============
[13:47:40] ================ drm_test_rect_calc_hscale  ================
[13:47:40] [PASSED] normal use
[13:47:40] [PASSED] out of max range
[13:47:40] [PASSED] out of min range
[13:47:40] [PASSED] zero dst
[13:47:40] [PASSED] negative src
[13:47:40] [PASSED] negative dst
[13:47:40] ============ [PASSED] drm_test_rect_calc_hscale ============
[13:47:40] ================ drm_test_rect_calc_vscale  ================
[13:47:40] [PASSED] normal use
[13:47:40] [PASSED] out of max range
[13:47:40] [PASSED] out of min range
[13:47:40] [PASSED] zero dst
[13:47:40] [PASSED] negative src
[13:47:40] [PASSED] negative dst
[13:47:40] ============ [PASSED] drm_test_rect_calc_vscale ============
[13:47:40] ================== drm_test_rect_rotate  ===================
[13:47:40] [PASSED] reflect-x
[13:47:40] [PASSED] reflect-y
[13:47:40] [PASSED] rotate-0
[13:47:40] [PASSED] rotate-90
[13:47:40] [PASSED] rotate-180
[13:47:40] [PASSED] rotate-270
[13:47:40] ============== [PASSED] drm_test_rect_rotate ===============
[13:47:40] ================ drm_test_rect_rotate_inv  =================
[13:47:40] [PASSED] reflect-x
[13:47:40] [PASSED] reflect-y
[13:47:40] [PASSED] rotate-0
[13:47:40] [PASSED] rotate-90
[13:47:40] [PASSED] rotate-180
[13:47:40] [PASSED] rotate-270
[13:47:40] ============ [PASSED] drm_test_rect_rotate_inv =============
[13:47:40] ==================== [PASSED] drm_rect =====================
[13:47:40] ============ drm_sysfb_modeset_test (1 subtest) ============
[13:47:40] ============ drm_test_sysfb_build_fourcc_list  =============
[13:47:40] [PASSED] no native formats
[13:47:40] [PASSED] XRGB8888 as native format
[13:47:40] [PASSED] remove duplicates
[13:47:40] [PASSED] convert alpha formats
[13:47:40] [PASSED] random formats
[13:47:40] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[13:47:40] ============= [PASSED] drm_sysfb_modeset_test ==============
[13:47:40] ================== drm_fixp (2 subtests) ===================
[13:47:40] [PASSED] drm_test_int2fixp
[13:47:40] [PASSED] drm_test_sm2fixp
[13:47:40] ==================== [PASSED] drm_fixp =====================
[13:47:40] ============================================================
[13:47:40] Testing complete. Ran 630 tests: passed: 630
[13:47:40] Elapsed time: 32.636s total, 1.643s configuring, 30.525s building, 0.446s running

+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[13:47:40] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[13:47:42] Building KUnit Kernel ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
Building with:
$ make all compile_commands.json scripts_gdb ARCH=um O=.kunit --jobs=25
[13:47:51] Starting KUnit Kernel (1/1)...
[13:47:51] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[13:47:51] ================= ttm_device (5 subtests) ==================
[13:47:51] [PASSED] ttm_device_init_basic
[13:47:51] [PASSED] ttm_device_init_multiple
[13:47:51] [PASSED] ttm_device_fini_basic
[13:47:51] [PASSED] ttm_device_init_no_vma_man
[13:47:51] ================== ttm_device_init_pools  ==================
[13:47:51] [PASSED] No DMA allocations, no DMA32 required
[13:47:51] [PASSED] DMA allocations, DMA32 required
[13:47:51] [PASSED] No DMA allocations, DMA32 required
[13:47:51] [PASSED] DMA allocations, no DMA32 required
[13:47:51] ============== [PASSED] ttm_device_init_pools ==============
[13:47:51] =================== [PASSED] ttm_device ====================
[13:47:51] ================== ttm_pool (8 subtests) ===================
[13:47:51] ================== ttm_pool_alloc_basic  ===================
[13:47:51] [PASSED] One page
[13:47:51] [PASSED] More than one page
[13:47:51] [PASSED] Above the allocation limit
[13:47:51] [PASSED] One page, with coherent DMA mappings enabled
[13:47:51] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[13:47:51] ============== [PASSED] ttm_pool_alloc_basic ===============
[13:47:51] ============== ttm_pool_alloc_basic_dma_addr  ==============
[13:47:51] [PASSED] One page
[13:47:51] [PASSED] More than one page
[13:47:51] [PASSED] Above the allocation limit
[13:47:51] [PASSED] One page, with coherent DMA mappings enabled
[13:47:51] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[13:47:51] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[13:47:51] [PASSED] ttm_pool_alloc_order_caching_match
[13:47:51] [PASSED] ttm_pool_alloc_caching_mismatch
[13:47:51] [PASSED] ttm_pool_alloc_order_mismatch
[13:47:51] [PASSED] ttm_pool_free_dma_alloc
[13:47:51] [PASSED] ttm_pool_free_no_dma_alloc
[13:47:51] [PASSED] ttm_pool_fini_basic
[13:47:51] ==================== [PASSED] ttm_pool =====================
[13:47:51] ================ ttm_resource (8 subtests) =================
[13:47:51] ================= ttm_resource_init_basic  =================
[13:47:51] [PASSED] Init resource in TTM_PL_SYSTEM
[13:47:51] [PASSED] Init resource in TTM_PL_VRAM
[13:47:51] [PASSED] Init resource in a private placement
[13:47:51] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[13:47:51] ============= [PASSED] ttm_resource_init_basic =============
[13:47:51] [PASSED] ttm_resource_init_pinned
[13:47:51] [PASSED] ttm_resource_fini_basic
[13:47:51] [PASSED] ttm_resource_manager_init_basic
[13:47:51] [PASSED] ttm_resource_manager_usage_basic
[13:47:51] [PASSED] ttm_resource_manager_set_used_basic
[13:47:51] [PASSED] ttm_sys_man_alloc_basic
[13:47:51] [PASSED] ttm_sys_man_free_basic
[13:47:51] ================== [PASSED] ttm_resource ===================
[13:47:51] =================== ttm_tt (15 subtests) ===================
[13:47:51] ==================== ttm_tt_init_basic  ====================
[13:47:51] [PASSED] Page-aligned size
[13:47:51] [PASSED] Extra pages requested
[13:47:51] ================ [PASSED] ttm_tt_init_basic ================
[13:47:51] [PASSED] ttm_tt_init_misaligned
[13:47:51] [PASSED] ttm_tt_fini_basic
[13:47:51] [PASSED] ttm_tt_fini_sg
[13:47:51] [PASSED] ttm_tt_fini_shmem
[13:47:51] [PASSED] ttm_tt_create_basic
[13:47:51] [PASSED] ttm_tt_create_invalid_bo_type
[13:47:51] [PASSED] ttm_tt_create_ttm_exists
[13:47:51] [PASSED] ttm_tt_create_failed
[13:47:51] [PASSED] ttm_tt_destroy_basic
[13:47:51] [PASSED] ttm_tt_populate_null_ttm
[13:47:51] [PASSED] ttm_tt_populate_populated_ttm
[13:47:51] [PASSED] ttm_tt_unpopulate_basic
[13:47:51] [PASSED] ttm_tt_unpopulate_empty_ttm
[13:47:51] [PASSED] ttm_tt_swapin_basic
[13:47:51] ===================== [PASSED] ttm_tt ======================
[13:47:51] =================== ttm_bo (14 subtests) ===================
[13:47:51] =========== ttm_bo_reserve_optimistic_no_ticket  ===========
[13:47:51] [PASSED] Cannot be interrupted and sleeps
[13:47:51] [PASSED] Cannot be interrupted, locks straight away
[13:47:51] [PASSED] Can be interrupted, sleeps
[13:47:51] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[13:47:51] [PASSED] ttm_bo_reserve_locked_no_sleep
[13:47:51] [PASSED] ttm_bo_reserve_no_wait_ticket
[13:47:51] [PASSED] ttm_bo_reserve_double_resv
[13:47:51] [PASSED] ttm_bo_reserve_interrupted
[13:47:51] [PASSED] ttm_bo_reserve_deadlock
[13:47:51] [PASSED] ttm_bo_unreserve_basic
[13:47:51] [PASSED] ttm_bo_unreserve_pinned
[13:47:51] [PASSED] ttm_bo_unreserve_bulk
[13:47:51] [PASSED] ttm_bo_fini_basic
[13:47:51] [PASSED] ttm_bo_fini_shared_resv
[13:47:51] [PASSED] ttm_bo_pin_basic
[13:47:51] [PASSED] ttm_bo_pin_unpin_resource
[13:47:51] [PASSED] ttm_bo_multiple_pin_one_unpin
[13:47:51] ===================== [PASSED] ttm_bo ======================
[13:47:51] ============== ttm_bo_validate (21 subtests) ===============
[13:47:51] ============== ttm_bo_init_reserved_sys_man  ===============
[13:47:51] [PASSED] Buffer object for userspace
[13:47:51] [PASSED] Kernel buffer object
[13:47:51] [PASSED] Shared buffer object
[13:47:51] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[13:47:51] ============== ttm_bo_init_reserved_mock_man  ==============
[13:47:51] [PASSED] Buffer object for userspace
[13:47:51] [PASSED] Kernel buffer object
[13:47:51] [PASSED] Shared buffer object
[13:47:51] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[13:47:51] [PASSED] ttm_bo_init_reserved_resv
[13:47:51] ================== ttm_bo_validate_basic  ==================
[13:47:51] [PASSED] Buffer object for userspace
[13:47:51] [PASSED] Kernel buffer object
[13:47:51] [PASSED] Shared buffer object
[13:47:51] ============== [PASSED] ttm_bo_validate_basic ==============
[13:47:51] [PASSED] ttm_bo_validate_invalid_placement
[13:47:51] ============= ttm_bo_validate_same_placement  ==============
[13:47:51] [PASSED] System manager
[13:47:51] [PASSED] VRAM manager
[13:47:51] ========= [PASSED] ttm_bo_validate_same_placement ==========
[13:47:51] [PASSED] ttm_bo_validate_failed_alloc
[13:47:51] [PASSED] ttm_bo_validate_pinned
[13:47:51] [PASSED] ttm_bo_validate_busy_placement
[13:47:51] ================ ttm_bo_validate_multihop  =================
[13:47:51] [PASSED] Buffer object for userspace
[13:47:51] [PASSED] Kernel buffer object
[13:47:51] [PASSED] Shared buffer object
[13:47:51] ============ [PASSED] ttm_bo_validate_multihop =============
[13:47:51] ========== ttm_bo_validate_no_placement_signaled  ==========
[13:47:51] [PASSED] Buffer object in system domain, no page vector
[13:47:51] [PASSED] Buffer object in system domain with an existing page vector
[13:47:51] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[13:47:51] ======== ttm_bo_validate_no_placement_not_signaled  ========
[13:47:51] [PASSED] Buffer object for userspace
[13:47:51] [PASSED] Kernel buffer object
[13:47:51] [PASSED] Shared buffer object
[13:47:51] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[13:47:51] [PASSED] ttm_bo_validate_move_fence_signaled
[13:47:51] ========= ttm_bo_validate_move_fence_not_signaled  =========
[13:47:51] [PASSED] Waits for GPU
[13:47:51] [PASSED] Tries to lock straight away
[13:47:51] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[13:47:51] [PASSED] ttm_bo_validate_happy_evict
[13:47:51] [PASSED] ttm_bo_validate_all_pinned_evict
[13:47:51] [PASSED] ttm_bo_validate_allowed_only_evict
[13:47:51] [PASSED] ttm_bo_validate_deleted_evict
[13:47:51] [PASSED] ttm_bo_validate_busy_domain_evict
[13:47:51] [PASSED] ttm_bo_validate_evict_gutting
[13:47:51] [PASSED] ttm_bo_validate_recrusive_evict
stty: 'standard input': Inappropriate ioctl for device
[13:47:51] ================= [PASSED] ttm_bo_validate =================
[13:47:51] ============================================================
[13:47:51] Testing complete. Ran 101 tests: passed: 101
[13:47:51] Elapsed time: 11.224s total, 1.648s configuring, 9.359s building, 0.179s running

+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel



^ permalink raw reply	[flat|nested] 8+ messages in thread

* ✓ Xe.CI.BAT: success for Crescent Island PMT support (rev2)
  2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
                   ` (5 preceding siblings ...)
  2026-01-30 13:48 ` ✓ CI.KUnit: success for Crescent Island PMT support (rev2) Patchwork
@ 2026-01-30 14:24 ` Patchwork
  6 siblings, 0 replies; 8+ messages in thread
From: Patchwork @ 2026-01-30 14:24 UTC (permalink / raw)
  To: Michael J. Ruhl; +Cc: intel-xe

[-- Attachment #1: Type: text/plain, Size: 1445 bytes --]

== Series Details ==

Series: Crescent Island PMT support (rev2)
URL   : https://patchwork.freedesktop.org/series/160717/
State : success

== Summary ==

CI Bug Log - changes from xe-4476-feea7da320aa6950f02d3c4633ab678e6e61f7e9_BAT -> xe-pw-160717v2_BAT
====================================================

Summary
-------

  **SUCCESS**

  No regressions found.

  

Participating hosts (12 -> 12)
------------------------------

  No changes in participating hosts

Known issues
------------

  Here are the changes found in xe-pw-160717v2_BAT that come from known issues:

### IGT changes ###

#### Issues hit ####

  * igt@xe_waitfence@reltime:
    - bat-dg2-oem2:       [PASS][1] -> [FAIL][2] ([Intel XE#6520])
   [1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-4476-feea7da320aa6950f02d3c4633ab678e6e61f7e9/bat-dg2-oem2/igt@xe_waitfence@reltime.html
   [2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-160717v2/bat-dg2-oem2/igt@xe_waitfence@reltime.html

  
  [Intel XE#6520]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6520


Build changes
-------------

  * IGT: IGT_8726 -> IGT_8727
  * Linux: xe-4476-feea7da320aa6950f02d3c4633ab678e6e61f7e9 -> xe-pw-160717v2

  IGT_8726: 8726
  IGT_8727: 8727
  xe-4476-feea7da320aa6950f02d3c4633ab678e6e61f7e9: feea7da320aa6950f02d3c4633ab678e6e61f7e9
  xe-pw-160717v2: 160717v2

== Logs ==

For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-160717v2/index.html

[-- Attachment #2: Type: text/html, Size: 2024 bytes --]

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2026-01-30 14:24 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-01-30 13:36 [PATCH v2 0/5] Crescent Island PMT support Michael J. Ruhl
2026-01-30 13:36 ` [PATCH v2 1/5] pmt: Add register access callbacks Michael J. Ruhl
2026-01-30 13:36 ` [PATCH v2 2/5] drm/xe/vsec: Use correct pm state get Michael J. Ruhl
2026-01-30 13:36 ` [PATCH v2 3/5] drm/xe/vsec: Support Crescent Island PMT Michael J. Ruhl
2026-01-30 13:36 ` [PATCH v2 4/5] drm/xe/vsec: Crescent Island PMT decode Michael J. Ruhl
2026-01-30 13:36 ` [PATCH v2 5/5] drm/xe/vsec: Crescent Island PMT callbacks Michael J. Ruhl
2026-01-30 13:48 ` ✓ CI.KUnit: success for Crescent Island PMT support (rev2) Patchwork
2026-01-30 14:24 ` ✓ Xe.CI.BAT: " Patchwork

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox