* [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers
@ 2025-10-23 17:58 Zhanjun Dong
2025-10-23 20:39 ` ✓ CI.KUnit: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
` (3 more replies)
0 siblings, 4 replies; 6+ messages in thread
From: Zhanjun Dong @ 2025-10-23 17:58 UTC (permalink / raw)
To: intel-xe; +Cc: michal.wajdeczko, Zhanjun Dong
Cleanup GuC log buffer macros and helpers, add Xe style macro prefix.
Update buffer type values to align with the GuC specification
Update buffer offset calculation.
Remove helper functions, replaced with macros.
Signed-off-by: Zhanjun Dong <zhanjun.dong@intel.com>
---
Cc: michal.wajdeczko@intel.com
---
Change list:
v6: Avoid change same line in series twice, squash into single patch
Correct PAGE_SIZE to 4K
Promote memory layout comment to kernel-doc
v5: Change patch order
Sync macro names across buffer type, size and GUC_CTL_LOG_PARAMS
Replace guc_log_size with macro
Update log buffer layout comments
v4: Replace helper functions with macros
Rename log type xxx_DEBUG to xxx_EVENT_LOG
v3: Update comments
v2: Use SZ_4K, instead of PAGE_SIZE
Expand for loop with switch and fallthrough
---
drivers/gpu/drm/xe/abi/guc_log_abi.h | 4 +-
drivers/gpu/drm/xe/xe_guc.c | 23 ++---
drivers/gpu/drm/xe/xe_guc_capture.c | 16 ++--
drivers/gpu/drm/xe/xe_guc_fwif.h | 6 +-
drivers/gpu/drm/xe/xe_guc_log.c | 129 +++++++++++----------------
drivers/gpu/drm/xe/xe_guc_log.h | 14 ++-
6 files changed, 82 insertions(+), 110 deletions(-)
diff --git a/drivers/gpu/drm/xe/abi/guc_log_abi.h b/drivers/gpu/drm/xe/abi/guc_log_abi.h
index 554630b7ccd9..fb5e2b8e7cf9 100644
--- a/drivers/gpu/drm/xe/abi/guc_log_abi.h
+++ b/drivers/gpu/drm/xe/abi/guc_log_abi.h
@@ -10,9 +10,9 @@
/* GuC logging buffer types */
enum guc_log_buffer_type {
+ GUC_LOG_BUFFER_EVENT_DATA,
GUC_LOG_BUFFER_CRASH_DUMP,
- GUC_LOG_BUFFER_DEBUG,
- GUC_LOG_BUFFER_CAPTURE,
+ GUC_LOG_BUFFER_STATE_CAPTURE,
};
#define GUC_LOG_BUFFER_TYPE_MAX 3
diff --git a/drivers/gpu/drm/xe/xe_guc.c b/drivers/gpu/drm/xe/xe_guc.c
index d94490979adc..c82570c70964 100644
--- a/drivers/gpu/drm/xe/xe_guc.c
+++ b/drivers/gpu/drm/xe/xe_guc.c
@@ -99,7 +99,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
u32 offset = guc_bo_ggtt_addr(guc, guc->log.bo) >> PAGE_SHIFT;
u32 flags;
- #if (((CRASH_BUFFER_SIZE) % SZ_1M) == 0)
+ #if (((XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE) % SZ_1M) == 0)
#define LOG_UNIT SZ_1M
#define LOG_FLAG GUC_LOG_LOG_ALLOC_UNITS
#else
@@ -107,7 +107,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
#define LOG_FLAG 0
#endif
- #if (((CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
+ #if (((XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
#define CAPTURE_UNIT SZ_1M
#define CAPTURE_FLAG GUC_LOG_CAPTURE_ALLOC_UNITS
#else
@@ -115,20 +115,21 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
#define CAPTURE_FLAG 0
#endif
- BUILD_BUG_ON(!CRASH_BUFFER_SIZE);
- BUILD_BUG_ON(!IS_ALIGNED(CRASH_BUFFER_SIZE, LOG_UNIT));
- BUILD_BUG_ON(!DEBUG_BUFFER_SIZE);
- BUILD_BUG_ON(!IS_ALIGNED(DEBUG_BUFFER_SIZE, LOG_UNIT));
- BUILD_BUG_ON(!CAPTURE_BUFFER_SIZE);
- BUILD_BUG_ON(!IS_ALIGNED(CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
+ BUILD_BUG_ON(!XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE);
+ BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE, LOG_UNIT));
+ BUILD_BUG_ON(!XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE);
+ BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE, LOG_UNIT));
+ BUILD_BUG_ON(!XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE);
+ BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
flags = GUC_LOG_VALID |
GUC_LOG_NOTIFY_ON_HALF_FULL |
CAPTURE_FLAG |
LOG_FLAG |
- FIELD_PREP(GUC_LOG_CRASH, CRASH_BUFFER_SIZE / LOG_UNIT - 1) |
- FIELD_PREP(GUC_LOG_DEBUG, DEBUG_BUFFER_SIZE / LOG_UNIT - 1) |
- FIELD_PREP(GUC_LOG_CAPTURE, CAPTURE_BUFFER_SIZE / CAPTURE_UNIT - 1) |
+ FIELD_PREP(GUC_LOG_CRASH_DUMP, XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE / LOG_UNIT - 1) |
+ FIELD_PREP(GUC_LOG_EVENT_DATA, XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE / LOG_UNIT - 1) |
+ FIELD_PREP(GUC_LOG_STATE_CAPTURE, XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE /
+ CAPTURE_UNIT - 1) |
FIELD_PREP(GUC_LOG_BUF_ADDR, offset);
#undef LOG_UNIT
diff --git a/drivers/gpu/drm/xe/xe_guc_capture.c b/drivers/gpu/drm/xe/xe_guc_capture.c
index 0c1fbe97b8bf..4e2c5a51adc8 100644
--- a/drivers/gpu/drm/xe/xe_guc_capture.c
+++ b/drivers/gpu/drm/xe/xe_guc_capture.c
@@ -843,7 +843,7 @@ static void check_guc_capture_size(struct xe_guc *guc)
{
int capture_size = guc_capture_output_size_est(guc);
int spare_size = capture_size * GUC_CAPTURE_OVERBUFFER_MULTIPLIER;
- u32 buffer_size = xe_guc_log_section_size_capture(&guc->log);
+ u32 buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
/*
* NOTE: capture_size is much smaller than the capture region
@@ -949,7 +949,7 @@ guc_capture_init_node(struct xe_guc *guc, struct __guc_capture_parsed_output *no
* ADS module also calls separately for PF vs VF.
*
* --> alloc B: GuC output capture buf (registered via guc_init_params(log_param))
- * Size = #define CAPTURE_BUFFER_SIZE (warns if on too-small)
+ * Size = #define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE (warns if on too-small)
* Note2: 'x 3' to hold multiple capture groups
*
* GUC Runtime notify capture:
@@ -1367,7 +1367,7 @@ static int __guc_capture_flushlog_complete(struct xe_guc *guc)
{
u32 action[] = {
XE_GUC_ACTION_LOG_BUFFER_FILE_FLUSH_COMPLETE,
- GUC_LOG_BUFFER_CAPTURE
+ GUC_LOG_BUFFER_STATE_CAPTURE
};
return xe_guc_ct_send_g2h_handler(&guc->ct, action, ARRAY_SIZE(action));
@@ -1384,8 +1384,8 @@ static void __guc_capture_process_output(struct xe_guc *guc)
u32 log_buf_state_offset;
u32 src_data_offset;
- log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_CAPTURE;
- src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_CAPTURE);
+ log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_STATE_CAPTURE;
+ src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE);
/*
* Make a copy of the state structure, inside GuC log buffer
@@ -1395,15 +1395,15 @@ static void __guc_capture_process_output(struct xe_guc *guc)
xe_map_memcpy_from(guc_to_xe(guc), &log_buf_state_local, &guc->log.bo->vmap,
log_buf_state_offset, sizeof(struct guc_log_buffer_state));
- buffer_size = xe_guc_get_log_buffer_size(&guc->log, GUC_LOG_BUFFER_CAPTURE);
+ buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
read_offset = log_buf_state_local.read_ptr;
write_offset = log_buf_state_local.sampled_write_ptr;
full_count = FIELD_GET(GUC_LOG_BUFFER_STATE_BUFFER_FULL_CNT, log_buf_state_local.flags);
/* Bookkeeping stuff */
tmp = FIELD_GET(GUC_LOG_BUFFER_STATE_FLUSH_TO_FILE, log_buf_state_local.flags);
- guc->log.stats[GUC_LOG_BUFFER_CAPTURE].flush += tmp;
- new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_CAPTURE,
+ guc->log.stats[GUC_LOG_BUFFER_STATE_CAPTURE].flush += tmp;
+ new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE,
full_count);
/* Now copy the actual logs. */
diff --git a/drivers/gpu/drm/xe/xe_guc_fwif.h b/drivers/gpu/drm/xe/xe_guc_fwif.h
index 50c4c2406132..8b5c58b1857c 100644
--- a/drivers/gpu/drm/xe/xe_guc_fwif.h
+++ b/drivers/gpu/drm/xe/xe_guc_fwif.h
@@ -91,9 +91,9 @@ struct guc_update_exec_queue_policy {
#define GUC_LOG_NOTIFY_ON_HALF_FULL BIT(1)
#define GUC_LOG_CAPTURE_ALLOC_UNITS BIT(2)
#define GUC_LOG_LOG_ALLOC_UNITS BIT(3)
-#define GUC_LOG_CRASH REG_GENMASK(5, 4)
-#define GUC_LOG_DEBUG REG_GENMASK(9, 6)
-#define GUC_LOG_CAPTURE REG_GENMASK(11, 10)
+#define GUC_LOG_CRASH_DUMP REG_GENMASK(5, 4)
+#define GUC_LOG_EVENT_DATA REG_GENMASK(9, 6)
+#define GUC_LOG_STATE_CAPTURE REG_GENMASK(11, 10)
#define GUC_LOG_BUF_ADDR REG_GENMASK(31, 12)
#define GUC_CTL_WA 1
diff --git a/drivers/gpu/drm/xe/xe_guc_log.c b/drivers/gpu/drm/xe/xe_guc_log.c
index c01ccb35dc75..995148e3f103 100644
--- a/drivers/gpu/drm/xe/xe_guc_log.c
+++ b/drivers/gpu/drm/xe/xe_guc_log.c
@@ -19,6 +19,45 @@
#include "xe_mmio.h"
#include "xe_module.h"
+/**
+ * DOC: GuC Log buffer Layout
+ *
+ * The in-memory log buffer layout is as follows:
+ * +===============================+ 0000h
+ * | Crash dump state header | ^
+ * +-------------------------------+ 32B |
+ * | Debug state header | |
+ * +-------------------------------+ 64B 4KB
+ * | Capture state header | |
+ * +-------------------------------+ 96B |
+ * | | v
+ * +===============================+ <--- EVENT_DATA offset
+ * | Event logs(raw data) | ^
+ * | | |
+ * | | EVENT_DATA_BUFFER_SIZE
+ * | | |
+ * | | v
+ * +===============================+ <--- CRASH_DUMP offset
+ * | Crash Dump(raw data) | ^
+ * | | |
+ * | | CRASH_DUMP_BUFFER_SIZE
+ * | | |
+ * | | v
+ * +===============================+ <--- STATE_CAPTURE offset
+ * | Error state capture(raw data) | ^
+ * | | |
+ * | | STATE_CAPTURE_BUFFER_SIZE
+ * | | |
+ * | | v
+ * +===============================+ Total: GUC_LOG_SIZE
+ */
+#define GUC_LOG_SIZE (SZ_4K + \
+ XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE + \
+ XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE + \
+ XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE)
+
+#define GUC_LOG_CHUNK_SIZE SZ_2M
+
static struct xe_guc *
log_to_guc(struct xe_guc_log *log)
{
@@ -37,33 +76,6 @@ log_to_xe(struct xe_guc_log *log)
return gt_to_xe(log_to_gt(log));
}
-static size_t guc_log_size(void)
-{
- /*
- * GuC Log buffer Layout
- *
- * +===============================+ 00B
- * | Crash dump state header |
- * +-------------------------------+ 32B
- * | Debug state header |
- * +-------------------------------+ 64B
- * | Capture state header |
- * +-------------------------------+ 96B
- * | |
- * +===============================+ PAGE_SIZE (4KB)
- * | Crash Dump logs |
- * +===============================+ + CRASH_SIZE
- * | Debug logs |
- * +===============================+ + DEBUG_SIZE
- * | Capture logs |
- * +===============================+ + CAPTURE_SIZE
- */
- return PAGE_SIZE + CRASH_BUFFER_SIZE + DEBUG_BUFFER_SIZE +
- CAPTURE_BUFFER_SIZE;
-}
-
-#define GUC_LOG_CHUNK_SIZE SZ_2M
-
static struct xe_guc_log_snapshot *xe_guc_log_snapshot_alloc(struct xe_guc_log *log, bool atomic)
{
struct xe_guc_log_snapshot *snapshot;
@@ -257,7 +269,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
struct xe_tile *tile = gt_to_tile(log_to_gt(log));
struct xe_bo *bo;
- bo = xe_managed_bo_create_pin_map(xe, tile, guc_log_size(),
+ bo = xe_managed_bo_create_pin_map(xe, tile, GUC_LOG_SIZE,
XE_BO_FLAG_SYSTEM |
XE_BO_FLAG_GGTT |
XE_BO_FLAG_GGTT_INVALIDATE |
@@ -265,7 +277,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
if (IS_ERR(bo))
return PTR_ERR(bo);
- xe_map_memset(xe, &bo->vmap, 0, 0, guc_log_size());
+ xe_map_memset(xe, &bo->vmap, 0, 0, GUC_LOG_SIZE);
log->bo = bo;
log->level = xe_modparam.guc_log_level;
@@ -274,49 +286,6 @@ int xe_guc_log_init(struct xe_guc_log *log)
ALLOW_ERROR_INJECTION(xe_guc_log_init, ERRNO); /* See xe_pci_probe() */
-static u32 xe_guc_log_section_size_crash(struct xe_guc_log *log)
-{
- return CRASH_BUFFER_SIZE;
-}
-
-static u32 xe_guc_log_section_size_debug(struct xe_guc_log *log)
-{
- return DEBUG_BUFFER_SIZE;
-}
-
-/**
- * xe_guc_log_section_size_capture - Get capture buffer size within log sections.
- * @log: The log object.
- *
- * This function will return the capture buffer size within log sections.
- *
- * Return: capture buffer size.
- */
-u32 xe_guc_log_section_size_capture(struct xe_guc_log *log)
-{
- return CAPTURE_BUFFER_SIZE;
-}
-
-/**
- * xe_guc_get_log_buffer_size - Get log buffer size for a type.
- * @log: The log object.
- * @type: The log buffer type
- *
- * Return: buffer size.
- */
-u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type)
-{
- switch (type) {
- case GUC_LOG_BUFFER_CRASH_DUMP:
- return xe_guc_log_section_size_crash(log);
- case GUC_LOG_BUFFER_DEBUG:
- return xe_guc_log_section_size_debug(log);
- case GUC_LOG_BUFFER_CAPTURE:
- return xe_guc_log_section_size_capture(log);
- }
- return 0;
-}
-
/**
* xe_guc_get_log_buffer_offset - Get offset in log buffer for a type.
* @log: The log object.
@@ -327,13 +296,17 @@ u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type
*/
u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type)
{
- enum guc_log_buffer_type i;
- u32 offset = PAGE_SIZE;/* for the log_buffer_states */
+ u32 offset = SZ_4K;/* for the log_buffer_states */
- for (i = GUC_LOG_BUFFER_CRASH_DUMP; i < GUC_LOG_BUFFER_TYPE_MAX; ++i) {
- if (i == type)
- break;
- offset += xe_guc_get_log_buffer_size(log, i);
+ switch (type) {
+ case GUC_LOG_BUFFER_STATE_CAPTURE:
+ offset += XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE;
+ fallthrough;
+ case GUC_LOG_BUFFER_CRASH_DUMP:
+ offset += XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE;
+ fallthrough;
+ case GUC_LOG_BUFFER_EVENT_DATA:
+ break;
}
return offset;
diff --git a/drivers/gpu/drm/xe/xe_guc_log.h b/drivers/gpu/drm/xe/xe_guc_log.h
index 98a47ac42b08..a3620462f44c 100644
--- a/drivers/gpu/drm/xe/xe_guc_log.h
+++ b/drivers/gpu/drm/xe/xe_guc_log.h
@@ -13,13 +13,13 @@ struct drm_printer;
struct xe_device;
#if IS_ENABLED(CONFIG_DRM_XE_DEBUG_GUC)
-#define CRASH_BUFFER_SIZE SZ_1M
-#define DEBUG_BUFFER_SIZE SZ_8M
-#define CAPTURE_BUFFER_SIZE SZ_2M
+#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_8M
+#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_1M
+#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_2M
#else
-#define CRASH_BUFFER_SIZE SZ_16K
-#define DEBUG_BUFFER_SIZE SZ_64K
-#define CAPTURE_BUFFER_SIZE SZ_1M
+#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_64K
+#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_16K
+#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_1M
#endif
/*
* While we're using plain log level in i915, GuC controls are much more...
@@ -51,8 +51,6 @@ xe_guc_log_get_level(struct xe_guc_log *log)
return log->level;
}
-u32 xe_guc_log_section_size_capture(struct xe_guc_log *log);
-u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type);
u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type);
bool xe_guc_check_log_buf_overflow(struct xe_guc_log *log,
enum guc_log_buffer_type type,
--
2.34.1
^ permalink raw reply related [flat|nested] 6+ messages in thread
* ✓ CI.KUnit: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
2025-10-23 17:58 [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Zhanjun Dong
@ 2025-10-23 20:39 ` Patchwork
2025-10-23 21:26 ` ✓ Xe.CI.BAT: " Patchwork
` (2 subsequent siblings)
3 siblings, 0 replies; 6+ messages in thread
From: Patchwork @ 2025-10-23 20:39 UTC (permalink / raw)
To: Dong, Zhanjun; +Cc: intel-xe
== Series Details ==
Series: drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
URL : https://patchwork.freedesktop.org/series/155338/
State : success
== Summary ==
+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[20:38:09] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[20:38:14] 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=48
[20:38:44] Starting KUnit Kernel (1/1)...
[20:38:44] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[20:38:45] ================== guc_buf (11 subtests) ===================
[20:38:45] [PASSED] test_smallest
[20:38:45] [PASSED] test_largest
[20:38:45] [PASSED] test_granular
[20:38:45] [PASSED] test_unique
[20:38:45] [PASSED] test_overlap
[20:38:45] [PASSED] test_reusable
[20:38:45] [PASSED] test_too_big
[20:38:45] [PASSED] test_flush
[20:38:45] [PASSED] test_lookup
[20:38:45] [PASSED] test_data
[20:38:45] [PASSED] test_class
[20:38:45] ===================== [PASSED] guc_buf =====================
[20:38:45] =================== guc_dbm (7 subtests) ===================
[20:38:45] [PASSED] test_empty
[20:38:45] [PASSED] test_default
[20:38:45] ======================== test_size ========================
[20:38:45] [PASSED] 4
[20:38:45] [PASSED] 8
[20:38:45] [PASSED] 32
[20:38:45] [PASSED] 256
[20:38:45] ==================== [PASSED] test_size ====================
[20:38:45] ======================= test_reuse ========================
[20:38:45] [PASSED] 4
[20:38:45] [PASSED] 8
[20:38:45] [PASSED] 32
[20:38:45] [PASSED] 256
[20:38:45] =================== [PASSED] test_reuse ====================
[20:38:45] =================== test_range_overlap ====================
[20:38:45] [PASSED] 4
[20:38:45] [PASSED] 8
[20:38:45] [PASSED] 32
[20:38:45] [PASSED] 256
[20:38:45] =============== [PASSED] test_range_overlap ================
[20:38:45] =================== test_range_compact ====================
[20:38:45] [PASSED] 4
[20:38:45] [PASSED] 8
[20:38:45] [PASSED] 32
[20:38:45] [PASSED] 256
[20:38:45] =============== [PASSED] test_range_compact ================
[20:38:45] ==================== test_range_spare =====================
[20:38:45] [PASSED] 4
[20:38:45] [PASSED] 8
[20:38:45] [PASSED] 32
[20:38:45] [PASSED] 256
[20:38:45] ================ [PASSED] test_range_spare =================
[20:38:45] ===================== [PASSED] guc_dbm =====================
[20:38:45] =================== guc_idm (6 subtests) ===================
[20:38:45] [PASSED] bad_init
[20:38:45] [PASSED] no_init
[20:38:45] [PASSED] init_fini
[20:38:45] [PASSED] check_used
[20:38:45] [PASSED] check_quota
[20:38:45] [PASSED] check_all
[20:38:45] ===================== [PASSED] guc_idm =====================
[20:38:45] ================== no_relay (3 subtests) ===================
[20:38:45] [PASSED] xe_drops_guc2pf_if_not_ready
[20:38:45] [PASSED] xe_drops_guc2vf_if_not_ready
[20:38:45] [PASSED] xe_rejects_send_if_not_ready
[20:38:45] ==================== [PASSED] no_relay =====================
[20:38:45] ================== pf_relay (14 subtests) ==================
[20:38:45] [PASSED] pf_rejects_guc2pf_too_short
[20:38:45] [PASSED] pf_rejects_guc2pf_too_long
[20:38:45] [PASSED] pf_rejects_guc2pf_no_payload
[20:38:45] [PASSED] pf_fails_no_payload
[20:38:45] [PASSED] pf_fails_bad_origin
[20:38:45] [PASSED] pf_fails_bad_type
[20:38:45] [PASSED] pf_txn_reports_error
[20:38:45] [PASSED] pf_txn_sends_pf2guc
[20:38:45] [PASSED] pf_sends_pf2guc
[20:38:45] [SKIPPED] pf_loopback_nop
[20:38:45] [SKIPPED] pf_loopback_echo
[20:38:45] [SKIPPED] pf_loopback_fail
[20:38:45] [SKIPPED] pf_loopback_busy
[20:38:45] [SKIPPED] pf_loopback_retry
[20:38:45] ==================== [PASSED] pf_relay =====================
[20:38:45] ================== vf_relay (3 subtests) ===================
[20:38:45] [PASSED] vf_rejects_guc2vf_too_short
[20:38:45] [PASSED] vf_rejects_guc2vf_too_long
[20:38:45] [PASSED] vf_rejects_guc2vf_no_payload
[20:38:45] ==================== [PASSED] vf_relay =====================
[20:38:45] ===================== lmtt (1 subtest) =====================
[20:38:45] ======================== test_ops =========================
[20:38:45] [PASSED] 2-level
[20:38:45] [PASSED] multi-level
[20:38:45] ==================== [PASSED] test_ops =====================
[20:38:45] ====================== [PASSED] lmtt =======================
[20:38:45] ================= pf_service (11 subtests) =================
[20:38:45] [PASSED] pf_negotiate_any
[20:38:45] [PASSED] pf_negotiate_base_match
[20:38:45] [PASSED] pf_negotiate_base_newer
[20:38:45] [PASSED] pf_negotiate_base_next
[20:38:45] [SKIPPED] pf_negotiate_base_older
[20:38:45] [PASSED] pf_negotiate_base_prev
[20:38:45] [PASSED] pf_negotiate_latest_match
[20:38:45] [PASSED] pf_negotiate_latest_newer
[20:38:45] [PASSED] pf_negotiate_latest_next
[20:38:45] [SKIPPED] pf_negotiate_latest_older
[20:38:45] [SKIPPED] pf_negotiate_latest_prev
[20:38:45] =================== [PASSED] pf_service ====================
[20:38:45] ================= xe_guc_g2g (2 subtests) ==================
[20:38:45] ============== xe_live_guc_g2g_kunit_default ==============
[20:38:45] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[20:38:45] ============== xe_live_guc_g2g_kunit_allmem ===============
[20:38:45] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[20:38:45] =================== [SKIPPED] xe_guc_g2g ===================
[20:38:45] =================== xe_mocs (2 subtests) ===================
[20:38:45] ================ xe_live_mocs_kernel_kunit ================
[20:38:45] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[20:38:45] ================ xe_live_mocs_reset_kunit =================
[20:38:45] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[20:38:45] ==================== [SKIPPED] xe_mocs =====================
[20:38:45] ================= xe_migrate (2 subtests) ==================
[20:38:45] ================= xe_migrate_sanity_kunit =================
[20:38:45] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[20:38:45] ================== xe_validate_ccs_kunit ==================
[20:38:45] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[20:38:45] =================== [SKIPPED] xe_migrate ===================
[20:38:45] ================== xe_dma_buf (1 subtest) ==================
[20:38:45] ==================== xe_dma_buf_kunit =====================
[20:38:45] ================ [SKIPPED] xe_dma_buf_kunit ================
[20:38:45] =================== [SKIPPED] xe_dma_buf ===================
[20:38:45] ================= xe_bo_shrink (1 subtest) =================
[20:38:45] =================== xe_bo_shrink_kunit ====================
[20:38:45] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[20:38:45] ================== [SKIPPED] xe_bo_shrink ==================
[20:38:45] ==================== xe_bo (2 subtests) ====================
[20:38:45] ================== xe_ccs_migrate_kunit ===================
[20:38:45] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[20:38:45] ==================== xe_bo_evict_kunit ====================
[20:38:45] =============== [SKIPPED] xe_bo_evict_kunit ================
[20:38:45] ===================== [SKIPPED] xe_bo ======================
[20:38:45] ==================== args (11 subtests) ====================
[20:38:45] [PASSED] count_args_test
[20:38:45] [PASSED] call_args_example
[20:38:45] [PASSED] call_args_test
[20:38:45] [PASSED] drop_first_arg_example
[20:38:45] [PASSED] drop_first_arg_test
[20:38:45] [PASSED] first_arg_example
[20:38:45] [PASSED] first_arg_test
[20:38:45] [PASSED] last_arg_example
[20:38:45] [PASSED] last_arg_test
[20:38:45] [PASSED] pick_arg_example
[20:38:45] [PASSED] sep_comma_example
[20:38:45] ====================== [PASSED] args =======================
[20:38:45] =================== xe_pci (3 subtests) ====================
[20:38:45] ==================== check_graphics_ip ====================
[20:38:45] [PASSED] 12.00 Xe_LP
[20:38:45] [PASSED] 12.10 Xe_LP+
[20:38:45] [PASSED] 12.55 Xe_HPG
[20:38:45] [PASSED] 12.60 Xe_HPC
[20:38:45] [PASSED] 12.70 Xe_LPG
[20:38:45] [PASSED] 12.71 Xe_LPG
[20:38:45] [PASSED] 12.74 Xe_LPG+
[20:38:45] [PASSED] 20.01 Xe2_HPG
[20:38:45] [PASSED] 20.02 Xe2_HPG
[20:38:45] [PASSED] 20.04 Xe2_LPG
[20:38:45] [PASSED] 30.00 Xe3_LPG
[20:38:45] [PASSED] 30.01 Xe3_LPG
[20:38:45] [PASSED] 30.03 Xe3_LPG
[20:38:45] [PASSED] 30.04 Xe3_LPG
[20:38:45] [PASSED] 30.05 Xe3_LPG
[20:38:45] [PASSED] 35.11 Xe3p_XPC
[20:38:45] ================ [PASSED] check_graphics_ip ================
[20:38:45] ===================== check_media_ip ======================
[20:38:45] [PASSED] 12.00 Xe_M
[20:38:45] [PASSED] 12.55 Xe_HPM
[20:38:45] [PASSED] 13.00 Xe_LPM+
[20:38:45] [PASSED] 13.01 Xe2_HPM
[20:38:45] [PASSED] 20.00 Xe2_LPM
[20:38:45] [PASSED] 30.00 Xe3_LPM
[20:38:45] [PASSED] 30.02 Xe3_LPM
[20:38:45] [PASSED] 35.00 Xe3p_LPM
[20:38:45] [PASSED] 35.03 Xe3p_HPM
[20:38:45] ================= [PASSED] check_media_ip ==================
[20:38:45] =================== check_platform_desc ===================
[20:38:45] [PASSED] 0x9A60 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A68 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A70 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A40 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A49 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A59 (TIGERLAKE)
[20:38:45] [PASSED] 0x9A78 (TIGERLAKE)
[20:38:45] [PASSED] 0x9AC0 (TIGERLAKE)
[20:38:45] [PASSED] 0x9AC9 (TIGERLAKE)
[20:38:45] [PASSED] 0x9AD9 (TIGERLAKE)
[20:38:45] [PASSED] 0x9AF8 (TIGERLAKE)
[20:38:45] [PASSED] 0x4C80 (ROCKETLAKE)
[20:38:45] [PASSED] 0x4C8A (ROCKETLAKE)
[20:38:45] [PASSED] 0x4C8B (ROCKETLAKE)
[20:38:45] [PASSED] 0x4C8C (ROCKETLAKE)
[20:38:45] [PASSED] 0x4C90 (ROCKETLAKE)
[20:38:45] [PASSED] 0x4C9A (ROCKETLAKE)
[20:38:45] [PASSED] 0x4680 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4682 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4688 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x468A (ALDERLAKE_S)
[20:38:45] [PASSED] 0x468B (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4690 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4692 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4693 (ALDERLAKE_S)
[20:38:45] [PASSED] 0x46A0 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46A1 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46A2 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46A3 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46A6 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46A8 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46AA (ALDERLAKE_P)
[20:38:45] [PASSED] 0x462A (ALDERLAKE_P)
[20:38:45] [PASSED] 0x4626 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x4628 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46B0 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46B1 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46B2 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46B3 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46C0 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46C1 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46C2 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46C3 (ALDERLAKE_P)
[20:38:45] [PASSED] 0x46D0 (ALDERLAKE_N)
[20:38:45] [PASSED] 0x46D1 (ALDERLAKE_N)
[20:38:45] [PASSED] 0x46D2 (ALDERLAKE_N)
[20:38:45] [PASSED] 0x46D3 (ALDERLAKE_N)
[20:38:45] [PASSED] 0x46D4 (ALDERLAKE_N)
[20:38:45] [PASSED] 0xA721 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7A1 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7A9 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7AC (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7AD (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA720 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7A0 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7A8 (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7AA (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA7AB (ALDERLAKE_P)
[20:38:45] [PASSED] 0xA780 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA781 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA782 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA783 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA788 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA789 (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA78A (ALDERLAKE_S)
[20:38:45] [PASSED] 0xA78B (ALDERLAKE_S)
[20:38:45] [PASSED] 0x4905 (DG1)
[20:38:45] [PASSED] 0x4906 (DG1)
[20:38:45] [PASSED] 0x4907 (DG1)
[20:38:45] [PASSED] 0x4908 (DG1)
[20:38:45] [PASSED] 0x4909 (DG1)
[20:38:45] [PASSED] 0x56C0 (DG2)
[20:38:45] [PASSED] 0x56C2 (DG2)
[20:38:45] [PASSED] 0x56C1 (DG2)
[20:38:45] [PASSED] 0x7D51 (METEORLAKE)
[20:38:45] [PASSED] 0x7DD1 (METEORLAKE)
[20:38:45] [PASSED] 0x7D41 (METEORLAKE)
[20:38:45] [PASSED] 0x7D67 (METEORLAKE)
[20:38:45] [PASSED] 0xB640 (METEORLAKE)
[20:38:45] [PASSED] 0x56A0 (DG2)
[20:38:45] [PASSED] 0x56A1 (DG2)
[20:38:45] [PASSED] 0x56A2 (DG2)
[20:38:45] [PASSED] 0x56BE (DG2)
[20:38:45] [PASSED] 0x56BF (DG2)
[20:38:45] [PASSED] 0x5690 (DG2)
[20:38:45] [PASSED] 0x5691 (DG2)
[20:38:45] [PASSED] 0x5692 (DG2)
[20:38:45] [PASSED] 0x56A5 (DG2)
[20:38:45] [PASSED] 0x56A6 (DG2)
[20:38:45] [PASSED] 0x56B0 (DG2)
[20:38:45] [PASSED] 0x56B1 (DG2)
[20:38:45] [PASSED] 0x56BA (DG2)
[20:38:45] [PASSED] 0x56BB (DG2)
[20:38:45] [PASSED] 0x56BC (DG2)
[20:38:45] [PASSED] 0x56BD (DG2)
[20:38:45] [PASSED] 0x5693 (DG2)
[20:38:45] [PASSED] 0x5694 (DG2)
[20:38:45] [PASSED] 0x5695 (DG2)
[20:38:45] [PASSED] 0x56A3 (DG2)
[20:38:45] [PASSED] 0x56A4 (DG2)
[20:38:45] [PASSED] 0x56B2 (DG2)
[20:38:45] [PASSED] 0x56B3 (DG2)
[20:38:45] [PASSED] 0x5696 (DG2)
[20:38:45] [PASSED] 0x5697 (DG2)
[20:38:45] [PASSED] 0xB69 (PVC)
[20:38:45] [PASSED] 0xB6E (PVC)
[20:38:45] [PASSED] 0xBD4 (PVC)
[20:38:45] [PASSED] 0xBD5 (PVC)
[20:38:45] [PASSED] 0xBD6 (PVC)
[20:38:45] [PASSED] 0xBD7 (PVC)
[20:38:45] [PASSED] 0xBD8 (PVC)
[20:38:45] [PASSED] 0xBD9 (PVC)
[20:38:45] [PASSED] 0xBDA (PVC)
[20:38:45] [PASSED] 0xBDB (PVC)
[20:38:45] [PASSED] 0xBE0 (PVC)
[20:38:45] [PASSED] 0xBE1 (PVC)
[20:38:45] [PASSED] 0xBE5 (PVC)
[20:38:45] [PASSED] 0x7D40 (METEORLAKE)
[20:38:45] [PASSED] 0x7D45 (METEORLAKE)
[20:38:45] [PASSED] 0x7D55 (METEORLAKE)
[20:38:45] [PASSED] 0x7D60 (METEORLAKE)
[20:38:45] [PASSED] 0x7DD5 (METEORLAKE)
[20:38:45] [PASSED] 0x6420 (LUNARLAKE)
[20:38:45] [PASSED] 0x64A0 (LUNARLAKE)
[20:38:45] [PASSED] 0x64B0 (LUNARLAKE)
[20:38:45] [PASSED] 0xE202 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE209 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE20B (BATTLEMAGE)
[20:38:45] [PASSED] 0xE20C (BATTLEMAGE)
[20:38:45] [PASSED] 0xE20D (BATTLEMAGE)
[20:38:45] [PASSED] 0xE210 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE211 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE212 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE216 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE220 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE221 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE222 (BATTLEMAGE)
[20:38:45] [PASSED] 0xE223 (BATTLEMAGE)
[20:38:45] [PASSED] 0xB080 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB081 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB082 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB083 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB084 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB085 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB086 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB087 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB08F (PANTHERLAKE)
[20:38:45] [PASSED] 0xB090 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB0A0 (PANTHERLAKE)
[20:38:45] [PASSED] 0xB0B0 (PANTHERLAKE)
[20:38:45] [PASSED] 0xFD80 (PANTHERLAKE)
[20:38:45] [PASSED] 0xFD81 (PANTHERLAKE)
[20:38:45] [PASSED] 0xD740 (NOVALAKE_S)
[20:38:45] [PASSED] 0xD741 (NOVALAKE_S)
[20:38:45] [PASSED] 0xD742 (NOVALAKE_S)
[20:38:45] [PASSED] 0xD743 (NOVALAKE_S)
[20:38:45] [PASSED] 0xD744 (NOVALAKE_S)
[20:38:45] [PASSED] 0xD745 (NOVALAKE_S)
[20:38:45] [PASSED] 0x674C (CRESCENTISLAND)
[20:38:45] =============== [PASSED] check_platform_desc ===============
[20:38:45] ===================== [PASSED] xe_pci ======================
[20:38:45] =================== xe_rtp (2 subtests) ====================
[20:38:45] =============== xe_rtp_process_to_sr_tests ================
[20:38:45] [PASSED] coalesce-same-reg
[20:38:45] [PASSED] no-match-no-add
[20:38:45] [PASSED] match-or
[20:38:45] [PASSED] match-or-xfail
[20:38:45] [PASSED] no-match-no-add-multiple-rules
[20:38:45] [PASSED] two-regs-two-entries
[20:38:45] [PASSED] clr-one-set-other
[20:38:45] [PASSED] set-field
[20:38:45] [PASSED] conflict-duplicate
[20:38:45] [PASSED] conflict-not-disjoint
[20:38:45] [PASSED] conflict-reg-type
[20:38:45] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[20:38:45] ================== xe_rtp_process_tests ===================
[20:38:45] [PASSED] active1
[20:38:45] [PASSED] active2
[20:38:45] [PASSED] active-inactive
[20:38:45] [PASSED] inactive-active
[20:38:45] [PASSED] inactive-1st_or_active-inactive
[20:38:45] [PASSED] inactive-2nd_or_active-inactive
[20:38:45] [PASSED] inactive-last_or_active-inactive
stty: 'standard input': Inappropriate ioctl for device
[20:38:45] [PASSED] inactive-no_or_active-inactive
[20:38:45] ============== [PASSED] xe_rtp_process_tests ===============
[20:38:45] ===================== [PASSED] xe_rtp ======================
[20:38:45] ==================== xe_wa (1 subtest) =====================
[20:38:45] ======================== xe_wa_gt =========================
[20:38:45] [PASSED] TIGERLAKE B0
[20:38:45] [PASSED] DG1 A0
[20:38:45] [PASSED] DG1 B0
[20:38:45] [PASSED] ALDERLAKE_S A0
[20:38:45] [PASSED] ALDERLAKE_S B0
[20:38:45] [PASSED] ALDERLAKE_S C0
[20:38:45] [PASSED] ALDERLAKE_S D0
[20:38:45] [PASSED] ALDERLAKE_P A0
[20:38:45] [PASSED] ALDERLAKE_P B0
[20:38:45] [PASSED] ALDERLAKE_P C0
[20:38:45] [PASSED] ALDERLAKE_S RPLS D0
[20:38:45] [PASSED] ALDERLAKE_P RPLU E0
[20:38:45] [PASSED] DG2 G10 C0
[20:38:45] [PASSED] DG2 G11 B1
[20:38:45] [PASSED] DG2 G12 A1
[20:38:45] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[20:38:45] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[20:38:45] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[20:38:45] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[20:38:45] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[20:38:45] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[20:38:45] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[20:38:45] ==================== [PASSED] xe_wa_gt =====================
[20:38:45] ====================== [PASSED] xe_wa ======================
[20:38:45] ============================================================
[20:38:45] Testing complete. Ran 318 tests: passed: 300, skipped: 18
[20:38:45] Elapsed time: 35.245s total, 4.157s configuring, 30.722s building, 0.329s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[20:38:45] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[20:38:46] 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=48
[20:39:11] Starting KUnit Kernel (1/1)...
[20:39:11] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[20:39:11] ============ drm_test_pick_cmdline (2 subtests) ============
[20:39:11] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[20:39:11] =============== drm_test_pick_cmdline_named ===============
[20:39:11] [PASSED] NTSC
[20:39:11] [PASSED] NTSC-J
[20:39:11] [PASSED] PAL
[20:39:11] [PASSED] PAL-M
[20:39:11] =========== [PASSED] drm_test_pick_cmdline_named ===========
[20:39:11] ============== [PASSED] drm_test_pick_cmdline ==============
[20:39:11] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[20:39:11] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[20:39:11] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[20:39:11] =========== drm_validate_clone_mode (2 subtests) ===========
[20:39:11] ============== drm_test_check_in_clone_mode ===============
[20:39:11] [PASSED] in_clone_mode
[20:39:11] [PASSED] not_in_clone_mode
[20:39:11] ========== [PASSED] drm_test_check_in_clone_mode ===========
[20:39:11] =============== drm_test_check_valid_clones ===============
[20:39:11] [PASSED] not_in_clone_mode
[20:39:11] [PASSED] valid_clone
[20:39:11] [PASSED] invalid_clone
[20:39:11] =========== [PASSED] drm_test_check_valid_clones ===========
[20:39:11] ============= [PASSED] drm_validate_clone_mode =============
[20:39:11] ============= drm_validate_modeset (1 subtest) =============
[20:39:11] [PASSED] drm_test_check_connector_changed_modeset
[20:39:11] ============== [PASSED] drm_validate_modeset ===============
[20:39:11] ====== drm_test_bridge_get_current_state (2 subtests) ======
[20:39:11] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[20:39:11] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[20:39:11] ======== [PASSED] drm_test_bridge_get_current_state ========
[20:39:11] ====== drm_test_bridge_helper_reset_crtc (3 subtests) ======
[20:39:11] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[20:39:11] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[20:39:11] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[20:39:11] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[20:39:11] ============== drm_bridge_alloc (2 subtests) ===============
[20:39:11] [PASSED] drm_test_drm_bridge_alloc_basic
[20:39:11] [PASSED] drm_test_drm_bridge_alloc_get_put
[20:39:11] ================ [PASSED] drm_bridge_alloc =================
[20:39:11] ================== drm_buddy (8 subtests) ==================
[20:39:11] [PASSED] drm_test_buddy_alloc_limit
[20:39:11] [PASSED] drm_test_buddy_alloc_optimistic
[20:39:11] [PASSED] drm_test_buddy_alloc_pessimistic
[20:39:11] [PASSED] drm_test_buddy_alloc_pathological
[20:39:11] [PASSED] drm_test_buddy_alloc_contiguous
[20:39:11] [PASSED] drm_test_buddy_alloc_clear
[20:39:12] [PASSED] drm_test_buddy_alloc_range_bias
[20:39:12] [PASSED] drm_test_buddy_fragmentation_performance
[20:39:12] ==================== [PASSED] drm_buddy ====================
[20:39:12] ============= drm_cmdline_parser (40 subtests) =============
[20:39:12] [PASSED] drm_test_cmdline_force_d_only
[20:39:12] [PASSED] drm_test_cmdline_force_D_only_dvi
[20:39:12] [PASSED] drm_test_cmdline_force_D_only_hdmi
[20:39:12] [PASSED] drm_test_cmdline_force_D_only_not_digital
[20:39:12] [PASSED] drm_test_cmdline_force_e_only
[20:39:12] [PASSED] drm_test_cmdline_res
[20:39:12] [PASSED] drm_test_cmdline_res_vesa
[20:39:12] [PASSED] drm_test_cmdline_res_vesa_rblank
[20:39:12] [PASSED] drm_test_cmdline_res_rblank
[20:39:12] [PASSED] drm_test_cmdline_res_bpp
[20:39:12] [PASSED] drm_test_cmdline_res_refresh
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[20:39:12] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[20:39:12] [PASSED] drm_test_cmdline_res_margins_force_on
[20:39:12] [PASSED] drm_test_cmdline_res_vesa_margins
[20:39:12] [PASSED] drm_test_cmdline_name
[20:39:12] [PASSED] drm_test_cmdline_name_bpp
[20:39:12] [PASSED] drm_test_cmdline_name_option
[20:39:12] [PASSED] drm_test_cmdline_name_bpp_option
[20:39:12] [PASSED] drm_test_cmdline_rotate_0
[20:39:12] [PASSED] drm_test_cmdline_rotate_90
[20:39:12] [PASSED] drm_test_cmdline_rotate_180
[20:39:12] [PASSED] drm_test_cmdline_rotate_270
[20:39:12] [PASSED] drm_test_cmdline_hmirror
[20:39:12] [PASSED] drm_test_cmdline_vmirror
[20:39:12] [PASSED] drm_test_cmdline_margin_options
[20:39:12] [PASSED] drm_test_cmdline_multiple_options
[20:39:12] [PASSED] drm_test_cmdline_bpp_extra_and_option
[20:39:12] [PASSED] drm_test_cmdline_extra_and_option
[20:39:12] [PASSED] drm_test_cmdline_freestanding_options
[20:39:12] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[20:39:12] [PASSED] drm_test_cmdline_panel_orientation
[20:39:12] ================ drm_test_cmdline_invalid =================
[20:39:12] [PASSED] margin_only
[20:39:12] [PASSED] interlace_only
[20:39:12] [PASSED] res_missing_x
[20:39:12] [PASSED] res_missing_y
[20:39:12] [PASSED] res_bad_y
[20:39:12] [PASSED] res_missing_y_bpp
[20:39:12] [PASSED] res_bad_bpp
[20:39:12] [PASSED] res_bad_refresh
[20:39:12] [PASSED] res_bpp_refresh_force_on_off
[20:39:12] [PASSED] res_invalid_mode
[20:39:12] [PASSED] res_bpp_wrong_place_mode
[20:39:12] [PASSED] name_bpp_refresh
[20:39:12] [PASSED] name_refresh
[20:39:12] [PASSED] name_refresh_wrong_mode
[20:39:12] [PASSED] name_refresh_invalid_mode
[20:39:12] [PASSED] rotate_multiple
[20:39:12] [PASSED] rotate_invalid_val
[20:39:12] [PASSED] rotate_truncated
[20:39:12] [PASSED] invalid_option
[20:39:12] [PASSED] invalid_tv_option
[20:39:12] [PASSED] truncated_tv_option
[20:39:12] ============ [PASSED] drm_test_cmdline_invalid =============
[20:39:12] =============== drm_test_cmdline_tv_options ===============
[20:39:12] [PASSED] NTSC
[20:39:12] [PASSED] NTSC_443
[20:39:12] [PASSED] NTSC_J
[20:39:12] [PASSED] PAL
[20:39:12] [PASSED] PAL_M
[20:39:12] [PASSED] PAL_N
[20:39:12] [PASSED] SECAM
[20:39:12] [PASSED] MONO_525
[20:39:12] [PASSED] MONO_625
[20:39:12] =========== [PASSED] drm_test_cmdline_tv_options ===========
[20:39:12] =============== [PASSED] drm_cmdline_parser ================
[20:39:12] ========== drmm_connector_hdmi_init (20 subtests) ==========
[20:39:12] [PASSED] drm_test_connector_hdmi_init_valid
[20:39:12] [PASSED] drm_test_connector_hdmi_init_bpc_8
[20:39:12] [PASSED] drm_test_connector_hdmi_init_bpc_10
[20:39:12] [PASSED] drm_test_connector_hdmi_init_bpc_12
[20:39:12] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[20:39:12] [PASSED] drm_test_connector_hdmi_init_bpc_null
[20:39:12] [PASSED] drm_test_connector_hdmi_init_formats_empty
[20:39:12] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[20:39:12] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[20:39:12] [PASSED] supported_formats=0x9 yuv420_allowed=1
[20:39:12] [PASSED] supported_formats=0x9 yuv420_allowed=0
[20:39:12] [PASSED] supported_formats=0x3 yuv420_allowed=1
[20:39:12] [PASSED] supported_formats=0x3 yuv420_allowed=0
[20:39:12] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[20:39:12] [PASSED] drm_test_connector_hdmi_init_null_ddc
[20:39:12] [PASSED] drm_test_connector_hdmi_init_null_product
[20:39:12] [PASSED] drm_test_connector_hdmi_init_null_vendor
[20:39:12] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[20:39:12] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[20:39:12] [PASSED] drm_test_connector_hdmi_init_product_valid
[20:39:12] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[20:39:12] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[20:39:12] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[20:39:12] ========= drm_test_connector_hdmi_init_type_valid =========
[20:39:12] [PASSED] HDMI-A
[20:39:12] [PASSED] HDMI-B
[20:39:12] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[20:39:12] ======== drm_test_connector_hdmi_init_type_invalid ========
[20:39:12] [PASSED] Unknown
[20:39:12] [PASSED] VGA
[20:39:12] [PASSED] DVI-I
[20:39:12] [PASSED] DVI-D
[20:39:12] [PASSED] DVI-A
[20:39:12] [PASSED] Composite
[20:39:12] [PASSED] SVIDEO
[20:39:12] [PASSED] LVDS
[20:39:12] [PASSED] Component
[20:39:12] [PASSED] DIN
[20:39:12] [PASSED] DP
[20:39:12] [PASSED] TV
[20:39:12] [PASSED] eDP
[20:39:12] [PASSED] Virtual
[20:39:12] [PASSED] DSI
[20:39:12] [PASSED] DPI
[20:39:12] [PASSED] Writeback
[20:39:12] [PASSED] SPI
[20:39:12] [PASSED] USB
[20:39:12] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[20:39:12] ============ [PASSED] drmm_connector_hdmi_init =============
[20:39:12] ============= drmm_connector_init (3 subtests) =============
[20:39:12] [PASSED] drm_test_drmm_connector_init
[20:39:12] [PASSED] drm_test_drmm_connector_init_null_ddc
[20:39:12] ========= drm_test_drmm_connector_init_type_valid =========
[20:39:12] [PASSED] Unknown
[20:39:12] [PASSED] VGA
[20:39:12] [PASSED] DVI-I
[20:39:12] [PASSED] DVI-D
[20:39:12] [PASSED] DVI-A
[20:39:12] [PASSED] Composite
[20:39:12] [PASSED] SVIDEO
[20:39:12] [PASSED] LVDS
[20:39:12] [PASSED] Component
[20:39:12] [PASSED] DIN
[20:39:12] [PASSED] DP
[20:39:12] [PASSED] HDMI-A
[20:39:12] [PASSED] HDMI-B
[20:39:12] [PASSED] TV
[20:39:12] [PASSED] eDP
[20:39:12] [PASSED] Virtual
[20:39:12] [PASSED] DSI
[20:39:12] [PASSED] DPI
[20:39:12] [PASSED] Writeback
[20:39:12] [PASSED] SPI
[20:39:12] [PASSED] USB
[20:39:12] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[20:39:12] =============== [PASSED] drmm_connector_init ===============
[20:39:12] ========= drm_connector_dynamic_init (6 subtests) ==========
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_init
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_init_properties
[20:39:12] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[20:39:12] [PASSED] Unknown
[20:39:12] [PASSED] VGA
[20:39:12] [PASSED] DVI-I
[20:39:12] [PASSED] DVI-D
[20:39:12] [PASSED] DVI-A
[20:39:12] [PASSED] Composite
[20:39:12] [PASSED] SVIDEO
[20:39:12] [PASSED] LVDS
[20:39:12] [PASSED] Component
[20:39:12] [PASSED] DIN
[20:39:12] [PASSED] DP
[20:39:12] [PASSED] HDMI-A
[20:39:12] [PASSED] HDMI-B
[20:39:12] [PASSED] TV
[20:39:12] [PASSED] eDP
[20:39:12] [PASSED] Virtual
[20:39:12] [PASSED] DSI
[20:39:12] [PASSED] DPI
[20:39:12] [PASSED] Writeback
[20:39:12] [PASSED] SPI
[20:39:12] [PASSED] USB
[20:39:12] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[20:39:12] ======== drm_test_drm_connector_dynamic_init_name =========
[20:39:12] [PASSED] Unknown
[20:39:12] [PASSED] VGA
[20:39:12] [PASSED] DVI-I
[20:39:12] [PASSED] DVI-D
[20:39:12] [PASSED] DVI-A
[20:39:12] [PASSED] Composite
[20:39:12] [PASSED] SVIDEO
[20:39:12] [PASSED] LVDS
[20:39:12] [PASSED] Component
[20:39:12] [PASSED] DIN
[20:39:12] [PASSED] DP
[20:39:12] [PASSED] HDMI-A
[20:39:12] [PASSED] HDMI-B
[20:39:12] [PASSED] TV
[20:39:12] [PASSED] eDP
[20:39:12] [PASSED] Virtual
[20:39:12] [PASSED] DSI
[20:39:12] [PASSED] DPI
[20:39:12] [PASSED] Writeback
[20:39:12] [PASSED] SPI
[20:39:12] [PASSED] USB
[20:39:12] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[20:39:12] =========== [PASSED] drm_connector_dynamic_init ============
[20:39:12] ==== drm_connector_dynamic_register_early (4 subtests) =====
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[20:39:12] ====== [PASSED] drm_connector_dynamic_register_early =======
[20:39:12] ======= drm_connector_dynamic_register (7 subtests) ========
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[20:39:12] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[20:39:12] ========= [PASSED] drm_connector_dynamic_register ==========
[20:39:12] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[20:39:12] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[20:39:12] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[20:39:12] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[20:39:12] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[20:39:12] ========== drm_test_get_tv_mode_from_name_valid ===========
[20:39:12] [PASSED] NTSC
[20:39:12] [PASSED] NTSC-443
[20:39:12] [PASSED] NTSC-J
[20:39:12] [PASSED] PAL
[20:39:12] [PASSED] PAL-M
[20:39:12] [PASSED] PAL-N
[20:39:12] [PASSED] SECAM
[20:39:12] [PASSED] Mono
[20:39:12] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[20:39:12] [PASSED] drm_test_get_tv_mode_from_name_truncated
[20:39:12] ============ [PASSED] drm_get_tv_mode_from_name ============
[20:39:12] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[20:39:12] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[20:39:12] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[20:39:12] [PASSED] VIC 96
[20:39:12] [PASSED] VIC 97
[20:39:12] [PASSED] VIC 101
[20:39:12] [PASSED] VIC 102
[20:39:12] [PASSED] VIC 106
[20:39:12] [PASSED] VIC 107
[20:39:12] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[20:39:12] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[20:39:12] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[20:39:12] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[20:39:12] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[20:39:12] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[20:39:12] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[20:39:12] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[20:39:12] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[20:39:12] [PASSED] Automatic
[20:39:12] [PASSED] Full
[20:39:12] [PASSED] Limited 16:235
[20:39:12] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[20:39:12] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[20:39:12] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[20:39:12] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[20:39:12] === drm_test_drm_hdmi_connector_get_output_format_name ====
[20:39:12] [PASSED] RGB
[20:39:12] [PASSED] YUV 4:2:0
[20:39:12] [PASSED] YUV 4:2:2
[20:39:12] [PASSED] YUV 4:4:4
[20:39:12] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[20:39:12] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[20:39:12] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[20:39:12] ============= drm_damage_helper (21 subtests) ==============
[20:39:12] [PASSED] drm_test_damage_iter_no_damage
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_src_moved
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_not_visible
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[20:39:12] [PASSED] drm_test_damage_iter_no_damage_no_fb
[20:39:12] [PASSED] drm_test_damage_iter_simple_damage
[20:39:12] [PASSED] drm_test_damage_iter_single_damage
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_outside_src
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_src_moved
[20:39:12] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[20:39:12] [PASSED] drm_test_damage_iter_damage
[20:39:12] [PASSED] drm_test_damage_iter_damage_one_intersect
[20:39:12] [PASSED] drm_test_damage_iter_damage_one_outside
[20:39:12] [PASSED] drm_test_damage_iter_damage_src_moved
[20:39:12] [PASSED] drm_test_damage_iter_damage_not_visible
[20:39:12] ================ [PASSED] drm_damage_helper ================
[20:39:12] ============== drm_dp_mst_helper (3 subtests) ==============
[20:39:12] ============== drm_test_dp_mst_calc_pbn_mode ==============
[20:39:12] [PASSED] Clock 154000 BPP 30 DSC disabled
[20:39:12] [PASSED] Clock 234000 BPP 30 DSC disabled
[20:39:12] [PASSED] Clock 297000 BPP 24 DSC disabled
[20:39:12] [PASSED] Clock 332880 BPP 24 DSC enabled
[20:39:12] [PASSED] Clock 324540 BPP 24 DSC enabled
[20:39:12] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[20:39:12] ============== drm_test_dp_mst_calc_pbn_div ===============
[20:39:12] [PASSED] Link rate 2000000 lane count 4
[20:39:12] [PASSED] Link rate 2000000 lane count 2
[20:39:12] [PASSED] Link rate 2000000 lane count 1
[20:39:12] [PASSED] Link rate 1350000 lane count 4
[20:39:12] [PASSED] Link rate 1350000 lane count 2
[20:39:12] [PASSED] Link rate 1350000 lane count 1
[20:39:12] [PASSED] Link rate 1000000 lane count 4
[20:39:12] [PASSED] Link rate 1000000 lane count 2
[20:39:12] [PASSED] Link rate 1000000 lane count 1
[20:39:12] [PASSED] Link rate 810000 lane count 4
[20:39:12] [PASSED] Link rate 810000 lane count 2
[20:39:12] [PASSED] Link rate 810000 lane count 1
[20:39:12] [PASSED] Link rate 540000 lane count 4
[20:39:12] [PASSED] Link rate 540000 lane count 2
[20:39:12] [PASSED] Link rate 540000 lane count 1
[20:39:12] [PASSED] Link rate 270000 lane count 4
[20:39:12] [PASSED] Link rate 270000 lane count 2
[20:39:12] [PASSED] Link rate 270000 lane count 1
[20:39:12] [PASSED] Link rate 162000 lane count 4
[20:39:12] [PASSED] Link rate 162000 lane count 2
[20:39:12] [PASSED] Link rate 162000 lane count 1
[20:39:12] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[20:39:12] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[20:39:12] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[20:39:12] [PASSED] DP_POWER_UP_PHY with port number
[20:39:12] [PASSED] DP_POWER_DOWN_PHY with port number
[20:39:12] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[20:39:12] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[20:39:12] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[20:39:12] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[20:39:12] [PASSED] DP_QUERY_PAYLOAD with port number
[20:39:12] [PASSED] DP_QUERY_PAYLOAD with VCPI
[20:39:12] [PASSED] DP_REMOTE_DPCD_READ with port number
[20:39:12] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[20:39:12] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[20:39:12] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[20:39:12] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[20:39:12] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[20:39:12] [PASSED] DP_REMOTE_I2C_READ with port number
[20:39:12] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[20:39:12] [PASSED] DP_REMOTE_I2C_READ with transactions array
[20:39:12] [PASSED] DP_REMOTE_I2C_WRITE with port number
[20:39:12] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[20:39:12] [PASSED] DP_REMOTE_I2C_WRITE with data array
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[20:39:12] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[20:39:12] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[20:39:12] ================ [PASSED] drm_dp_mst_helper ================
[20:39:12] ================== drm_exec (7 subtests) ===================
[20:39:12] [PASSED] sanitycheck
[20:39:12] [PASSED] test_lock
[20:39:12] [PASSED] test_lock_unlock
[20:39:12] [PASSED] test_duplicates
[20:39:12] [PASSED] test_prepare
[20:39:12] [PASSED] test_prepare_array
[20:39:12] [PASSED] test_multiple_loops
[20:39:12] ==================== [PASSED] drm_exec =====================
[20:39:12] =========== drm_format_helper_test (17 subtests) ===========
[20:39:12] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[20:39:12] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[20:39:12] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[20:39:12] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[20:39:12] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[20:39:12] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[20:39:12] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[20:39:12] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[20:39:12] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[20:39:12] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[20:39:12] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[20:39:12] ============== drm_test_fb_xrgb8888_to_mono ===============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[20:39:12] ==================== drm_test_fb_swab =====================
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ================ [PASSED] drm_test_fb_swab =================
[20:39:12] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[20:39:12] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[20:39:12] [PASSED] single_pixel_source_buffer
[20:39:12] [PASSED] single_pixel_clip_rectangle
[20:39:12] [PASSED] well_known_colors
[20:39:12] [PASSED] destination_pitch
[20:39:12] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[20:39:12] ================= drm_test_fb_clip_offset =================
[20:39:12] [PASSED] pass through
[20:39:12] [PASSED] horizontal offset
[20:39:12] [PASSED] vertical offset
[20:39:12] [PASSED] horizontal and vertical offset
[20:39:12] [PASSED] horizontal offset (custom pitch)
[20:39:12] [PASSED] vertical offset (custom pitch)
[20:39:12] [PASSED] horizontal and vertical offset (custom pitch)
[20:39:12] ============= [PASSED] drm_test_fb_clip_offset =============
[20:39:12] =================== drm_test_fb_memcpy ====================
[20:39:12] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[20:39:12] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[20:39:12] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[20:39:12] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[20:39:12] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[20:39:12] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[20:39:12] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[20:39:12] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[20:39:12] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[20:39:12] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[20:39:12] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[20:39:12] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[20:39:12] =============== [PASSED] drm_test_fb_memcpy ================
[20:39:12] ============= [PASSED] drm_format_helper_test ==============
[20:39:12] ================= drm_format (18 subtests) =================
[20:39:12] [PASSED] drm_test_format_block_width_invalid
[20:39:12] [PASSED] drm_test_format_block_width_one_plane
[20:39:12] [PASSED] drm_test_format_block_width_two_plane
[20:39:12] [PASSED] drm_test_format_block_width_three_plane
[20:39:12] [PASSED] drm_test_format_block_width_tiled
[20:39:12] [PASSED] drm_test_format_block_height_invalid
[20:39:12] [PASSED] drm_test_format_block_height_one_plane
[20:39:12] [PASSED] drm_test_format_block_height_two_plane
[20:39:12] [PASSED] drm_test_format_block_height_three_plane
[20:39:12] [PASSED] drm_test_format_block_height_tiled
[20:39:12] [PASSED] drm_test_format_min_pitch_invalid
[20:39:12] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[20:39:12] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[20:39:12] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[20:39:12] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[20:39:12] [PASSED] drm_test_format_min_pitch_two_plane
[20:39:12] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[20:39:12] [PASSED] drm_test_format_min_pitch_tiled
[20:39:12] =================== [PASSED] drm_format ====================
[20:39:12] ============== drm_framebuffer (10 subtests) ===============
[20:39:12] ========== drm_test_framebuffer_check_src_coords ==========
[20:39:12] [PASSED] Success: source fits into fb
[20:39:12] [PASSED] Fail: overflowing fb with x-axis coordinate
[20:39:12] [PASSED] Fail: overflowing fb with y-axis coordinate
[20:39:12] [PASSED] Fail: overflowing fb with source width
[20:39:12] [PASSED] Fail: overflowing fb with source height
[20:39:12] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[20:39:12] [PASSED] drm_test_framebuffer_cleanup
[20:39:12] =============== drm_test_framebuffer_create ===============
[20:39:12] [PASSED] ABGR8888 normal sizes
[20:39:12] [PASSED] ABGR8888 max sizes
[20:39:12] [PASSED] ABGR8888 pitch greater than min required
[20:39:12] [PASSED] ABGR8888 pitch less than min required
[20:39:12] [PASSED] ABGR8888 Invalid width
[20:39:12] [PASSED] ABGR8888 Invalid buffer handle
[20:39:12] [PASSED] No pixel format
[20:39:12] [PASSED] ABGR8888 Width 0
[20:39:12] [PASSED] ABGR8888 Height 0
[20:39:12] [PASSED] ABGR8888 Out of bound height * pitch combination
[20:39:12] [PASSED] ABGR8888 Large buffer offset
[20:39:12] [PASSED] ABGR8888 Buffer offset for inexistent plane
[20:39:12] [PASSED] ABGR8888 Invalid flag
[20:39:12] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[20:39:12] [PASSED] ABGR8888 Valid buffer modifier
[20:39:12] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[20:39:12] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] NV12 Normal sizes
[20:39:12] [PASSED] NV12 Max sizes
[20:39:12] [PASSED] NV12 Invalid pitch
[20:39:12] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[20:39:12] [PASSED] NV12 different modifier per-plane
[20:39:12] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[20:39:12] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] NV12 Modifier for inexistent plane
[20:39:12] [PASSED] NV12 Handle for inexistent plane
[20:39:12] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[20:39:12] [PASSED] YVU420 Normal sizes
[20:39:12] [PASSED] YVU420 Max sizes
[20:39:12] [PASSED] YVU420 Invalid pitch
[20:39:12] [PASSED] YVU420 Different pitches
[20:39:12] [PASSED] YVU420 Different buffer offsets/pitches
[20:39:12] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[20:39:12] [PASSED] YVU420 Valid modifier
[20:39:12] [PASSED] YVU420 Different modifiers per plane
[20:39:12] [PASSED] YVU420 Modifier for inexistent plane
[20:39:12] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[20:39:12] [PASSED] X0L2 Normal sizes
[20:39:12] [PASSED] X0L2 Max sizes
[20:39:12] [PASSED] X0L2 Invalid pitch
[20:39:12] [PASSED] X0L2 Pitch greater than minimum required
[20:39:12] [PASSED] X0L2 Handle for inexistent plane
[20:39:12] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[20:39:12] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[20:39:12] [PASSED] X0L2 Valid modifier
[20:39:12] [PASSED] X0L2 Modifier for inexistent plane
[20:39:12] =========== [PASSED] drm_test_framebuffer_create ===========
[20:39:12] [PASSED] drm_test_framebuffer_free
[20:39:12] [PASSED] drm_test_framebuffer_init
[20:39:12] [PASSED] drm_test_framebuffer_init_bad_format
[20:39:12] [PASSED] drm_test_framebuffer_init_dev_mismatch
[20:39:12] [PASSED] drm_test_framebuffer_lookup
[20:39:12] [PASSED] drm_test_framebuffer_lookup_inexistent
[20:39:12] [PASSED] drm_test_framebuffer_modifiers_not_supported
[20:39:12] ================= [PASSED] drm_framebuffer =================
[20:39:12] ================ drm_gem_shmem (8 subtests) ================
[20:39:12] [PASSED] drm_gem_shmem_test_obj_create
[20:39:12] [PASSED] drm_gem_shmem_test_obj_create_private
[20:39:12] [PASSED] drm_gem_shmem_test_pin_pages
[20:39:12] [PASSED] drm_gem_shmem_test_vmap
[20:39:12] [PASSED] drm_gem_shmem_test_get_pages_sgt
[20:39:12] [PASSED] drm_gem_shmem_test_get_sg_table
[20:39:12] [PASSED] drm_gem_shmem_test_madvise
[20:39:12] [PASSED] drm_gem_shmem_test_purge
[20:39:12] ================== [PASSED] drm_gem_shmem ==================
[20:39:12] === drm_atomic_helper_connector_hdmi_check (27 subtests) ===
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[20:39:12] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[20:39:12] [PASSED] Automatic
[20:39:12] [PASSED] Full
[20:39:12] [PASSED] Limited 16:235
[20:39:12] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[20:39:12] [PASSED] drm_test_check_disable_connector
[20:39:12] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[20:39:12] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[20:39:12] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[20:39:12] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[20:39:12] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[20:39:12] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[20:39:12] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[20:39:12] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[20:39:12] [PASSED] drm_test_check_output_bpc_dvi
[20:39:12] [PASSED] drm_test_check_output_bpc_format_vic_1
[20:39:12] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[20:39:12] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[20:39:12] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[20:39:12] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[20:39:12] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[20:39:12] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[20:39:12] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[20:39:12] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[20:39:12] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[20:39:12] [PASSED] drm_test_check_broadcast_rgb_value
[20:39:12] [PASSED] drm_test_check_bpc_8_value
[20:39:12] [PASSED] drm_test_check_bpc_10_value
[20:39:12] [PASSED] drm_test_check_bpc_12_value
[20:39:12] [PASSED] drm_test_check_format_value
[20:39:12] [PASSED] drm_test_check_tmds_char_value
[20:39:12] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[20:39:12] = drm_atomic_helper_connector_hdmi_mode_valid (4 subtests) =
[20:39:12] [PASSED] drm_test_check_mode_valid
[20:39:12] [PASSED] drm_test_check_mode_valid_reject
[20:39:12] [PASSED] drm_test_check_mode_valid_reject_rate
[20:39:12] [PASSED] drm_test_check_mode_valid_reject_max_clock
[20:39:12] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[20:39:12] ================= drm_managed (2 subtests) =================
[20:39:12] [PASSED] drm_test_managed_release_action
[20:39:12] [PASSED] drm_test_managed_run_action
[20:39:12] =================== [PASSED] drm_managed ===================
[20:39:12] =================== drm_mm (6 subtests) ====================
[20:39:12] [PASSED] drm_test_mm_init
[20:39:12] [PASSED] drm_test_mm_debug
[20:39:12] [PASSED] drm_test_mm_align32
[20:39:12] [PASSED] drm_test_mm_align64
[20:39:12] [PASSED] drm_test_mm_lowest
[20:39:12] [PASSED] drm_test_mm_highest
[20:39:12] ===================== [PASSED] drm_mm ======================
[20:39:12] ============= drm_modes_analog_tv (5 subtests) =============
[20:39:12] [PASSED] drm_test_modes_analog_tv_mono_576i
[20:39:12] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[20:39:12] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[20:39:12] [PASSED] drm_test_modes_analog_tv_pal_576i
[20:39:12] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[20:39:12] =============== [PASSED] drm_modes_analog_tv ===============
[20:39:12] ============== drm_plane_helper (2 subtests) ===============
[20:39:12] =============== drm_test_check_plane_state ================
[20:39:12] [PASSED] clipping_simple
[20:39:12] [PASSED] clipping_rotate_reflect
[20:39:12] [PASSED] positioning_simple
[20:39:12] [PASSED] upscaling
[20:39:12] [PASSED] downscaling
[20:39:12] [PASSED] rounding1
[20:39:12] [PASSED] rounding2
[20:39:12] [PASSED] rounding3
[20:39:12] [PASSED] rounding4
[20:39:12] =========== [PASSED] drm_test_check_plane_state ============
[20:39:12] =========== drm_test_check_invalid_plane_state ============
[20:39:12] [PASSED] positioning_invalid
[20:39:12] [PASSED] upscaling_invalid
[20:39:12] [PASSED] downscaling_invalid
[20:39:12] ======= [PASSED] drm_test_check_invalid_plane_state ========
[20:39:12] ================ [PASSED] drm_plane_helper =================
[20:39:12] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[20:39:12] ====== drm_test_connector_helper_tv_get_modes_check =======
[20:39:12] [PASSED] None
[20:39:12] [PASSED] PAL
[20:39:12] [PASSED] NTSC
[20:39:12] [PASSED] Both, NTSC Default
[20:39:12] [PASSED] Both, PAL Default
[20:39:12] [PASSED] Both, NTSC Default, with PAL on command-line
[20:39:12] [PASSED] Both, PAL Default, with NTSC on command-line
[20:39:12] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[20:39:12] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[20:39:12] ================== drm_rect (9 subtests) ===================
[20:39:12] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[20:39:12] [PASSED] drm_test_rect_clip_scaled_not_clipped
[20:39:12] [PASSED] drm_test_rect_clip_scaled_clipped
[20:39:12] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[20:39:12] ================= drm_test_rect_intersect =================
[20:39:12] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[20:39:12] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[20:39:12] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[20:39:12] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[20:39:12] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[20:39:12] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[20:39:12] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[20:39:12] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[20:39:12] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[20:39:12] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[20:39:12] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[20:39:12] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[20:39:12] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[20:39:12] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[20:39:12] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[20:39:12] ============= [PASSED] drm_test_rect_intersect =============
[20:39:12] ================ drm_test_rect_calc_hscale ================
[20:39:12] [PASSED] normal use
[20:39:12] [PASSED] out of max range
[20:39:12] [PASSED] out of min range
[20:39:12] [PASSED] zero dst
[20:39:12] [PASSED] negative src
[20:39:12] [PASSED] negative dst
[20:39:12] ============ [PASSED] drm_test_rect_calc_hscale ============
[20:39:12] ================ drm_test_rect_calc_vscale ================
[20:39:12] [PASSED] normal use
stty: 'standard input': Inappropriate ioctl for device
[20:39:12] [PASSED] out of max range
[20:39:12] [PASSED] out of min range
[20:39:12] [PASSED] zero dst
[20:39:12] [PASSED] negative src
[20:39:12] [PASSED] negative dst
[20:39:12] ============ [PASSED] drm_test_rect_calc_vscale ============
[20:39:12] ================== drm_test_rect_rotate ===================
[20:39:12] [PASSED] reflect-x
[20:39:12] [PASSED] reflect-y
[20:39:12] [PASSED] rotate-0
[20:39:12] [PASSED] rotate-90
[20:39:12] [PASSED] rotate-180
[20:39:12] [PASSED] rotate-270
[20:39:12] ============== [PASSED] drm_test_rect_rotate ===============
[20:39:12] ================ drm_test_rect_rotate_inv =================
[20:39:12] [PASSED] reflect-x
[20:39:12] [PASSED] reflect-y
[20:39:12] [PASSED] rotate-0
[20:39:12] [PASSED] rotate-90
[20:39:12] [PASSED] rotate-180
[20:39:12] [PASSED] rotate-270
[20:39:12] ============ [PASSED] drm_test_rect_rotate_inv =============
[20:39:12] ==================== [PASSED] drm_rect =====================
[20:39:12] ============ drm_sysfb_modeset_test (1 subtest) ============
[20:39:12] ============ drm_test_sysfb_build_fourcc_list =============
[20:39:12] [PASSED] no native formats
[20:39:12] [PASSED] XRGB8888 as native format
[20:39:12] [PASSED] remove duplicates
[20:39:12] [PASSED] convert alpha formats
[20:39:12] [PASSED] random formats
[20:39:12] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[20:39:12] ============= [PASSED] drm_sysfb_modeset_test ==============
[20:39:12] ============================================================
[20:39:12] Testing complete. Ran 622 tests: passed: 622
[20:39:12] Elapsed time: 26.999s total, 1.658s configuring, 24.924s building, 0.390s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[20:39:12] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[20:39:14] 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=48
[20:39:23] Starting KUnit Kernel (1/1)...
[20:39:23] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[20:39:23] ================= ttm_device (5 subtests) ==================
[20:39:23] [PASSED] ttm_device_init_basic
[20:39:23] [PASSED] ttm_device_init_multiple
[20:39:23] [PASSED] ttm_device_fini_basic
[20:39:23] [PASSED] ttm_device_init_no_vma_man
[20:39:23] ================== ttm_device_init_pools ==================
[20:39:23] [PASSED] No DMA allocations, no DMA32 required
[20:39:23] [PASSED] DMA allocations, DMA32 required
[20:39:23] [PASSED] No DMA allocations, DMA32 required
[20:39:23] [PASSED] DMA allocations, no DMA32 required
[20:39:23] ============== [PASSED] ttm_device_init_pools ==============
[20:39:23] =================== [PASSED] ttm_device ====================
[20:39:23] ================== ttm_pool (8 subtests) ===================
[20:39:23] ================== ttm_pool_alloc_basic ===================
[20:39:23] [PASSED] One page
[20:39:23] [PASSED] More than one page
[20:39:23] [PASSED] Above the allocation limit
[20:39:23] [PASSED] One page, with coherent DMA mappings enabled
[20:39:23] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[20:39:23] ============== [PASSED] ttm_pool_alloc_basic ===============
[20:39:23] ============== ttm_pool_alloc_basic_dma_addr ==============
[20:39:23] [PASSED] One page
[20:39:23] [PASSED] More than one page
[20:39:23] [PASSED] Above the allocation limit
[20:39:23] [PASSED] One page, with coherent DMA mappings enabled
[20:39:23] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[20:39:23] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[20:39:23] [PASSED] ttm_pool_alloc_order_caching_match
[20:39:23] [PASSED] ttm_pool_alloc_caching_mismatch
[20:39:23] [PASSED] ttm_pool_alloc_order_mismatch
[20:39:23] [PASSED] ttm_pool_free_dma_alloc
[20:39:23] [PASSED] ttm_pool_free_no_dma_alloc
[20:39:23] [PASSED] ttm_pool_fini_basic
[20:39:23] ==================== [PASSED] ttm_pool =====================
[20:39:23] ================ ttm_resource (8 subtests) =================
[20:39:23] ================= ttm_resource_init_basic =================
[20:39:23] [PASSED] Init resource in TTM_PL_SYSTEM
[20:39:23] [PASSED] Init resource in TTM_PL_VRAM
[20:39:23] [PASSED] Init resource in a private placement
[20:39:23] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[20:39:23] ============= [PASSED] ttm_resource_init_basic =============
[20:39:23] [PASSED] ttm_resource_init_pinned
[20:39:23] [PASSED] ttm_resource_fini_basic
[20:39:23] [PASSED] ttm_resource_manager_init_basic
[20:39:23] [PASSED] ttm_resource_manager_usage_basic
[20:39:23] [PASSED] ttm_resource_manager_set_used_basic
[20:39:23] [PASSED] ttm_sys_man_alloc_basic
[20:39:23] [PASSED] ttm_sys_man_free_basic
[20:39:23] ================== [PASSED] ttm_resource ===================
[20:39:23] =================== ttm_tt (15 subtests) ===================
[20:39:23] ==================== ttm_tt_init_basic ====================
[20:39:23] [PASSED] Page-aligned size
[20:39:23] [PASSED] Extra pages requested
[20:39:23] ================ [PASSED] ttm_tt_init_basic ================
[20:39:23] [PASSED] ttm_tt_init_misaligned
[20:39:23] [PASSED] ttm_tt_fini_basic
[20:39:23] [PASSED] ttm_tt_fini_sg
[20:39:23] [PASSED] ttm_tt_fini_shmem
[20:39:23] [PASSED] ttm_tt_create_basic
[20:39:23] [PASSED] ttm_tt_create_invalid_bo_type
[20:39:23] [PASSED] ttm_tt_create_ttm_exists
[20:39:23] [PASSED] ttm_tt_create_failed
[20:39:23] [PASSED] ttm_tt_destroy_basic
[20:39:23] [PASSED] ttm_tt_populate_null_ttm
[20:39:23] [PASSED] ttm_tt_populate_populated_ttm
[20:39:23] [PASSED] ttm_tt_unpopulate_basic
[20:39:23] [PASSED] ttm_tt_unpopulate_empty_ttm
[20:39:23] [PASSED] ttm_tt_swapin_basic
[20:39:23] ===================== [PASSED] ttm_tt ======================
[20:39:23] =================== ttm_bo (14 subtests) ===================
[20:39:23] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[20:39:23] [PASSED] Cannot be interrupted and sleeps
[20:39:23] [PASSED] Cannot be interrupted, locks straight away
[20:39:23] [PASSED] Can be interrupted, sleeps
[20:39:23] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[20:39:23] [PASSED] ttm_bo_reserve_locked_no_sleep
[20:39:23] [PASSED] ttm_bo_reserve_no_wait_ticket
[20:39:23] [PASSED] ttm_bo_reserve_double_resv
[20:39:23] [PASSED] ttm_bo_reserve_interrupted
[20:39:23] [PASSED] ttm_bo_reserve_deadlock
[20:39:23] [PASSED] ttm_bo_unreserve_basic
[20:39:23] [PASSED] ttm_bo_unreserve_pinned
[20:39:23] [PASSED] ttm_bo_unreserve_bulk
[20:39:23] [PASSED] ttm_bo_fini_basic
[20:39:23] [PASSED] ttm_bo_fini_shared_resv
[20:39:23] [PASSED] ttm_bo_pin_basic
[20:39:23] [PASSED] ttm_bo_pin_unpin_resource
[20:39:23] [PASSED] ttm_bo_multiple_pin_one_unpin
[20:39:23] ===================== [PASSED] ttm_bo ======================
[20:39:23] ============== ttm_bo_validate (21 subtests) ===============
[20:39:23] ============== ttm_bo_init_reserved_sys_man ===============
[20:39:23] [PASSED] Buffer object for userspace
[20:39:23] [PASSED] Kernel buffer object
[20:39:23] [PASSED] Shared buffer object
[20:39:23] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[20:39:23] ============== ttm_bo_init_reserved_mock_man ==============
[20:39:23] [PASSED] Buffer object for userspace
[20:39:23] [PASSED] Kernel buffer object
[20:39:23] [PASSED] Shared buffer object
[20:39:23] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[20:39:23] [PASSED] ttm_bo_init_reserved_resv
[20:39:23] ================== ttm_bo_validate_basic ==================
[20:39:23] [PASSED] Buffer object for userspace
[20:39:23] [PASSED] Kernel buffer object
[20:39:23] [PASSED] Shared buffer object
[20:39:23] ============== [PASSED] ttm_bo_validate_basic ==============
[20:39:23] [PASSED] ttm_bo_validate_invalid_placement
[20:39:23] ============= ttm_bo_validate_same_placement ==============
[20:39:23] [PASSED] System manager
[20:39:23] [PASSED] VRAM manager
[20:39:23] ========= [PASSED] ttm_bo_validate_same_placement ==========
[20:39:23] [PASSED] ttm_bo_validate_failed_alloc
[20:39:23] [PASSED] ttm_bo_validate_pinned
[20:39:23] [PASSED] ttm_bo_validate_busy_placement
[20:39:23] ================ ttm_bo_validate_multihop =================
[20:39:23] [PASSED] Buffer object for userspace
[20:39:23] [PASSED] Kernel buffer object
[20:39:23] [PASSED] Shared buffer object
[20:39:23] ============ [PASSED] ttm_bo_validate_multihop =============
[20:39:23] ========== ttm_bo_validate_no_placement_signaled ==========
[20:39:23] [PASSED] Buffer object in system domain, no page vector
[20:39:23] [PASSED] Buffer object in system domain with an existing page vector
[20:39:23] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[20:39:23] ======== ttm_bo_validate_no_placement_not_signaled ========
[20:39:23] [PASSED] Buffer object for userspace
[20:39:23] [PASSED] Kernel buffer object
[20:39:23] [PASSED] Shared buffer object
[20:39:23] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[20:39:23] [PASSED] ttm_bo_validate_move_fence_signaled
[20:39:23] ========= ttm_bo_validate_move_fence_not_signaled =========
[20:39:23] [PASSED] Waits for GPU
[20:39:23] [PASSED] Tries to lock straight away
[20:39:23] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[20:39:23] [PASSED] ttm_bo_validate_happy_evict
[20:39:23] [PASSED] ttm_bo_validate_all_pinned_evict
[20:39:23] [PASSED] ttm_bo_validate_allowed_only_evict
[20:39:23] [PASSED] ttm_bo_validate_deleted_evict
[20:39:23] [PASSED] ttm_bo_validate_busy_domain_evict
[20:39:23] [PASSED] ttm_bo_validate_evict_gutting
[20:39:23] [PASSED] ttm_bo_validate_recrusive_evict
stty: 'standard input': Inappropriate ioctl for device
[20:39:23] ================= [PASSED] ttm_bo_validate =================
[20:39:23] ============================================================
[20:39:23] Testing complete. Ran 101 tests: passed: 101
[20:39:23] Elapsed time: 11.222s total, 1.704s configuring, 9.301s building, 0.178s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 6+ messages in thread
* ✓ Xe.CI.BAT: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
2025-10-23 17:58 [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Zhanjun Dong
2025-10-23 20:39 ` ✓ CI.KUnit: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
@ 2025-10-23 21:26 ` Patchwork
2025-10-23 23:04 ` [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Michal Wajdeczko
2025-10-24 10:52 ` ✗ Xe.CI.Full: failure for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
3 siblings, 0 replies; 6+ messages in thread
From: Patchwork @ 2025-10-23 21:26 UTC (permalink / raw)
To: Dong, Zhanjun; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 8838 bytes --]
== Series Details ==
Series: drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
URL : https://patchwork.freedesktop.org/series/155338/
State : success
== Summary ==
CI Bug Log - changes from xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff_BAT -> xe-pw-155338v3_BAT
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (11 -> 13)
------------------------------
Additional (2): bat-pvc-2 bat-bmg-3
Known issues
------------
Here are the changes found in xe-pw-155338v3_BAT that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@fbdev@eof:
- bat-pvc-2: NOTRUN -> [SKIP][1] ([Intel XE#2134]) +4 other tests skip
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@fbdev@eof.html
* igt@kms_addfb_basic@addfb25-x-tiled-legacy:
- bat-pvc-2: NOTRUN -> [SKIP][2] ([i915#6077]) +30 other tests skip
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_addfb_basic@addfb25-x-tiled-legacy.html
* igt@kms_cursor_legacy@basic-flip-before-cursor-varying-size:
- bat-pvc-2: NOTRUN -> [SKIP][3] ([Intel XE#1024] / [Intel XE#782]) +5 other tests skip
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_cursor_legacy@basic-flip-before-cursor-varying-size.html
* igt@kms_dsc@dsc-basic:
- bat-pvc-2: NOTRUN -> [SKIP][4] ([Intel XE#1024] / [Intel XE#784])
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_dsc@dsc-basic.html
* igt@kms_flip@basic-flip-vs-wf_vblank:
- bat-pvc-2: NOTRUN -> [SKIP][5] ([Intel XE#1024] / [Intel XE#947]) +3 other tests skip
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_flip@basic-flip-vs-wf_vblank.html
* igt@kms_flip@basic-plain-flip@c-edp1:
- bat-adlp-7: [PASS][6] -> [DMESG-WARN][7] ([Intel XE#4543]) +1 other test dmesg-warn
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/bat-adlp-7/igt@kms_flip@basic-plain-flip@c-edp1.html
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-adlp-7/igt@kms_flip@basic-plain-flip@c-edp1.html
* igt@kms_force_connector_basic@force-connector-state:
- bat-pvc-2: NOTRUN -> [SKIP][8] ([Intel XE#540]) +3 other tests skip
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_force_connector_basic@force-connector-state.html
* igt@kms_frontbuffer_tracking@basic:
- bat-pvc-2: NOTRUN -> [SKIP][9] ([Intel XE#1024] / [Intel XE#783])
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_frontbuffer_tracking@basic.html
* igt@kms_pipe_crc_basic@read-crc-frame-sequence:
- bat-pvc-2: NOTRUN -> [SKIP][10] ([Intel XE#829]) +6 other tests skip
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_pipe_crc_basic@read-crc-frame-sequence.html
* igt@kms_prop_blob@basic:
- bat-pvc-2: NOTRUN -> [SKIP][11] ([Intel XE#780])
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_prop_blob@basic.html
* igt@kms_psr@psr-sprite-plane-onoff:
- bat-pvc-2: NOTRUN -> [SKIP][12] ([Intel XE#1024] / [Intel XE#1406]) +2 other tests skip
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@kms_psr@psr-sprite-plane-onoff.html
* igt@sriov_basic@enable-vfs-autoprobe-off:
- bat-pvc-2: NOTRUN -> [SKIP][13] ([Intel XE#2849]) +1 other test skip
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@sriov_basic@enable-vfs-autoprobe-off.html
* igt@xe_create@multigpu-create-massive-size:
- bat-bmg-3: NOTRUN -> [SKIP][14] ([Intel XE#2504])
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-bmg-3/igt@xe_create@multigpu-create-massive-size.html
* igt@xe_eudebug@multigpu-basic-client:
- bat-bmg-3: NOTRUN -> [SKIP][15] ([Intel XE#4837]) +1 other test skip
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-bmg-3/igt@xe_eudebug@multigpu-basic-client.html
* igt@xe_gt_freq@freq_fixed_idle:
- bat-pvc-2: NOTRUN -> [SKIP][16] ([Intel XE#1021]) +1 other test skip
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_gt_freq@freq_fixed_idle.html
* igt@xe_huc_copy@huc_copy:
- bat-pvc-2: NOTRUN -> [SKIP][17] ([Intel XE#255])
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_huc_copy@huc_copy.html
* igt@xe_intel_bb@render:
- bat-pvc-2: NOTRUN -> [SKIP][18] ([Intel XE#532])
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_intel_bb@render.html
* igt@xe_live_ktest@xe_migrate@xe_validate_ccs_kunit:
- bat-pvc-2: NOTRUN -> [SKIP][19] ([Intel XE#2229]) +1 other test skip
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_live_ktest@xe_migrate@xe_validate_ccs_kunit.html
* igt@xe_pat@pat-index-xe2:
- bat-pvc-2: NOTRUN -> [SKIP][20] ([Intel XE#977]) +1 other test skip
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_pat@pat-index-xe2.html
* igt@xe_pat@pat-index-xehpc@render:
- bat-pvc-2: NOTRUN -> [SKIP][21] ([Intel XE#4578])
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_pat@pat-index-xehpc@render.html
* igt@xe_pat@pat-index-xelpg:
- bat-pvc-2: NOTRUN -> [SKIP][22] ([Intel XE#979])
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_pat@pat-index-xelpg.html
* igt@xe_peer2peer@read:
- bat-bmg-3: NOTRUN -> [FAIL][23] ([Intel XE#6433]) +3 other tests fail
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-bmg-3/igt@xe_peer2peer@read.html
* igt@xe_pm_residency@gt-c6-on-idle:
- bat-pvc-2: NOTRUN -> [SKIP][24] ([Intel XE#531])
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_pm_residency@gt-c6-on-idle.html
* igt@xe_sriov_flr@flr-vf1-clear:
- bat-pvc-2: NOTRUN -> [SKIP][25] ([Intel XE#3342])
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/bat-pvc-2/igt@xe_sriov_flr@flr-vf1-clear.html
{name}: This element is suppressed. This means it is ignored when computing
the status of the difference (SUCCESS, WARNING, or FAILURE).
[Intel XE#1021]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1021
[Intel XE#1024]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1024
[Intel XE#1406]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1406
[Intel XE#2134]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2134
[Intel XE#2229]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2229
[Intel XE#2504]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2504
[Intel XE#255]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/255
[Intel XE#2849]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2849
[Intel XE#3342]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3342
[Intel XE#4543]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4543
[Intel XE#4578]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4578
[Intel XE#4837]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4837
[Intel XE#531]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/531
[Intel XE#532]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/532
[Intel XE#540]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/540
[Intel XE#6433]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6433
[Intel XE#780]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/780
[Intel XE#782]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/782
[Intel XE#783]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/783
[Intel XE#784]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/784
[Intel XE#829]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/829
[Intel XE#947]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/947
[Intel XE#977]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/977
[Intel XE#979]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/979
[i915#6077]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/6077
Build changes
-------------
* Linux: xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff -> xe-pw-155338v3
IGT_8596: 8596
xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff: c63ccee28ae7ab4cb57a2433314f08c71da914ff
xe-pw-155338v3: 155338v3
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/index.html
[-- Attachment #2: Type: text/html, Size: 10227 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers
2025-10-23 17:58 [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Zhanjun Dong
2025-10-23 20:39 ` ✓ CI.KUnit: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
2025-10-23 21:26 ` ✓ Xe.CI.BAT: " Patchwork
@ 2025-10-23 23:04 ` Michal Wajdeczko
2025-10-28 0:19 ` Dong, Zhanjun
2025-10-24 10:52 ` ✗ Xe.CI.Full: failure for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
3 siblings, 1 reply; 6+ messages in thread
From: Michal Wajdeczko @ 2025-10-23 23:04 UTC (permalink / raw)
To: Zhanjun Dong, intel-xe
On 10/23/2025 7:58 PM, Zhanjun Dong wrote:
> Cleanup GuC log buffer macros and helpers, add Xe style macro prefix.
> Update buffer type values to align with the GuC specification
> Update buffer offset calculation.
> Remove helper functions, replaced with macros.
>
> Signed-off-by: Zhanjun Dong <zhanjun.dong@intel.com>
> ---
> Cc: michal.wajdeczko@intel.com
> ---
> Change list:
> v6: Avoid change same line in series twice, squash into single patch
> Correct PAGE_SIZE to 4K
> Promote memory layout comment to kernel-doc
> v5: Change patch order
> Sync macro names across buffer type, size and GUC_CTL_LOG_PARAMS
> Replace guc_log_size with macro
> Update log buffer layout comments
> v4: Replace helper functions with macros
> Rename log type xxx_DEBUG to xxx_EVENT_LOG
> v3: Update comments
> v2: Use SZ_4K, instead of PAGE_SIZE
> Expand for loop with switch and fallthrough
> ---
> drivers/gpu/drm/xe/abi/guc_log_abi.h | 4 +-
> drivers/gpu/drm/xe/xe_guc.c | 23 ++---
> drivers/gpu/drm/xe/xe_guc_capture.c | 16 ++--
> drivers/gpu/drm/xe/xe_guc_fwif.h | 6 +-
> drivers/gpu/drm/xe/xe_guc_log.c | 129 +++++++++++----------------
> drivers/gpu/drm/xe/xe_guc_log.h | 14 ++-
> 6 files changed, 82 insertions(+), 110 deletions(-)
>
> diff --git a/drivers/gpu/drm/xe/abi/guc_log_abi.h b/drivers/gpu/drm/xe/abi/guc_log_abi.h
> index 554630b7ccd9..fb5e2b8e7cf9 100644
> --- a/drivers/gpu/drm/xe/abi/guc_log_abi.h
> +++ b/drivers/gpu/drm/xe/abi/guc_log_abi.h
> @@ -10,9 +10,9 @@
>
> /* GuC logging buffer types */
> enum guc_log_buffer_type {
> + GUC_LOG_BUFFER_EVENT_DATA,
> GUC_LOG_BUFFER_CRASH_DUMP,
> - GUC_LOG_BUFFER_DEBUG,
> - GUC_LOG_BUFFER_CAPTURE,
> + GUC_LOG_BUFFER_STATE_CAPTURE,
GUC_LOG_BUFFER_TYPE_EVENT_DATA,
GUC_LOG_BUFFER_TYPE_CRASH_DUMP,
GUC_LOG_BUFFER_TYPE_STATE_CAPTURE,
or
enum guc_log_type {
GUC_LOG_TYPE_EVENT_DATA,
GUC_LOG_TYPE_CRASH_DUMP,
GUC_LOG_TYPE_STATE_CAPTURE,
> };
>
> #define GUC_LOG_BUFFER_TYPE_MAX 3
do we still need this?
> diff --git a/drivers/gpu/drm/xe/xe_guc.c b/drivers/gpu/drm/xe/xe_guc.c
> index d94490979adc..c82570c70964 100644
> --- a/drivers/gpu/drm/xe/xe_guc.c
> +++ b/drivers/gpu/drm/xe/xe_guc.c
> @@ -99,7 +99,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
> u32 offset = guc_bo_ggtt_addr(guc, guc->log.bo) >> PAGE_SHIFT;
> u32 flags;
>
> - #if (((CRASH_BUFFER_SIZE) % SZ_1M) == 0)
> + #if (((XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE) % SZ_1M) == 0)
> #define LOG_UNIT SZ_1M
> #define LOG_FLAG GUC_LOG_LOG_ALLOC_UNITS
> #else
> @@ -107,7 +107,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
> #define LOG_FLAG 0
> #endif
>
> - #if (((CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
> + #if (((XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
> #define CAPTURE_UNIT SZ_1M
> #define CAPTURE_FLAG GUC_LOG_CAPTURE_ALLOC_UNITS
> #else
> @@ -115,20 +115,21 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
> #define CAPTURE_FLAG 0
> #endif
>
> - BUILD_BUG_ON(!CRASH_BUFFER_SIZE);
> - BUILD_BUG_ON(!IS_ALIGNED(CRASH_BUFFER_SIZE, LOG_UNIT));
> - BUILD_BUG_ON(!DEBUG_BUFFER_SIZE);
> - BUILD_BUG_ON(!IS_ALIGNED(DEBUG_BUFFER_SIZE, LOG_UNIT));
> - BUILD_BUG_ON(!CAPTURE_BUFFER_SIZE);
> - BUILD_BUG_ON(!IS_ALIGNED(CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
> + BUILD_BUG_ON(!XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE);
> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE, LOG_UNIT));
> + BUILD_BUG_ON(!XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE);
> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE, LOG_UNIT));
> + BUILD_BUG_ON(!XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE);
> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
>
> flags = GUC_LOG_VALID |
> GUC_LOG_NOTIFY_ON_HALF_FULL |
> CAPTURE_FLAG |
> LOG_FLAG |
> - FIELD_PREP(GUC_LOG_CRASH, CRASH_BUFFER_SIZE / LOG_UNIT - 1) |
> - FIELD_PREP(GUC_LOG_DEBUG, DEBUG_BUFFER_SIZE / LOG_UNIT - 1) |
> - FIELD_PREP(GUC_LOG_CAPTURE, CAPTURE_BUFFER_SIZE / CAPTURE_UNIT - 1) |
> + FIELD_PREP(GUC_LOG_CRASH_DUMP, XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE / LOG_UNIT - 1) |
> + FIELD_PREP(GUC_LOG_EVENT_DATA, XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE / LOG_UNIT - 1) |
> + FIELD_PREP(GUC_LOG_STATE_CAPTURE, XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE /
> + CAPTURE_UNIT - 1) |
> FIELD_PREP(GUC_LOG_BUF_ADDR, offset);
>
> #undef LOG_UNIT
> diff --git a/drivers/gpu/drm/xe/xe_guc_capture.c b/drivers/gpu/drm/xe/xe_guc_capture.c
> index 0c1fbe97b8bf..4e2c5a51adc8 100644
> --- a/drivers/gpu/drm/xe/xe_guc_capture.c
> +++ b/drivers/gpu/drm/xe/xe_guc_capture.c
> @@ -843,7 +843,7 @@ static void check_guc_capture_size(struct xe_guc *guc)
> {
> int capture_size = guc_capture_output_size_est(guc);
> int spare_size = capture_size * GUC_CAPTURE_OVERBUFFER_MULTIPLIER;
> - u32 buffer_size = xe_guc_log_section_size_capture(&guc->log);
> + u32 buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
>
> /*
> * NOTE: capture_size is much smaller than the capture region
> @@ -949,7 +949,7 @@ guc_capture_init_node(struct xe_guc *guc, struct __guc_capture_parsed_output *no
> * ADS module also calls separately for PF vs VF.
> *
> * --> alloc B: GuC output capture buf (registered via guc_init_params(log_param))
> - * Size = #define CAPTURE_BUFFER_SIZE (warns if on too-small)
> + * Size = #define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE (warns if on too-small)
do we need this "#define" ? maybe just:
* Size = &XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE (warns if on too-small)
> * Note2: 'x 3' to hold multiple capture groups
> *
> * GUC Runtime notify capture:
> @@ -1367,7 +1367,7 @@ static int __guc_capture_flushlog_complete(struct xe_guc *guc)
> {
> u32 action[] = {
> XE_GUC_ACTION_LOG_BUFFER_FILE_FLUSH_COMPLETE,
> - GUC_LOG_BUFFER_CAPTURE
> + GUC_LOG_BUFFER_STATE_CAPTURE
> };
>
> return xe_guc_ct_send_g2h_handler(&guc->ct, action, ARRAY_SIZE(action));
> @@ -1384,8 +1384,8 @@ static void __guc_capture_process_output(struct xe_guc *guc)
> u32 log_buf_state_offset;
> u32 src_data_offset;
>
> - log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_CAPTURE;
> - src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_CAPTURE);
> + log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_STATE_CAPTURE;
> + src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE);
>
> /*
> * Make a copy of the state structure, inside GuC log buffer
> @@ -1395,15 +1395,15 @@ static void __guc_capture_process_output(struct xe_guc *guc)
> xe_map_memcpy_from(guc_to_xe(guc), &log_buf_state_local, &guc->log.bo->vmap,
> log_buf_state_offset, sizeof(struct guc_log_buffer_state));
>
> - buffer_size = xe_guc_get_log_buffer_size(&guc->log, GUC_LOG_BUFFER_CAPTURE);
> + buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
> read_offset = log_buf_state_local.read_ptr;
> write_offset = log_buf_state_local.sampled_write_ptr;
> full_count = FIELD_GET(GUC_LOG_BUFFER_STATE_BUFFER_FULL_CNT, log_buf_state_local.flags);
>
> /* Bookkeeping stuff */
> tmp = FIELD_GET(GUC_LOG_BUFFER_STATE_FLUSH_TO_FILE, log_buf_state_local.flags);
> - guc->log.stats[GUC_LOG_BUFFER_CAPTURE].flush += tmp;
> - new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_CAPTURE,
> + guc->log.stats[GUC_LOG_BUFFER_STATE_CAPTURE].flush += tmp;
> + new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE,
> full_count);
>
> /* Now copy the actual logs. */
> diff --git a/drivers/gpu/drm/xe/xe_guc_fwif.h b/drivers/gpu/drm/xe/xe_guc_fwif.h
> index 50c4c2406132..8b5c58b1857c 100644
> --- a/drivers/gpu/drm/xe/xe_guc_fwif.h
> +++ b/drivers/gpu/drm/xe/xe_guc_fwif.h
> @@ -91,9 +91,9 @@ struct guc_update_exec_queue_policy {
> #define GUC_LOG_NOTIFY_ON_HALF_FULL BIT(1)
> #define GUC_LOG_CAPTURE_ALLOC_UNITS BIT(2)
> #define GUC_LOG_LOG_ALLOC_UNITS BIT(3)
> -#define GUC_LOG_CRASH REG_GENMASK(5, 4)
> -#define GUC_LOG_DEBUG REG_GENMASK(9, 6)
> -#define GUC_LOG_CAPTURE REG_GENMASK(11, 10)
> +#define GUC_LOG_CRASH_DUMP REG_GENMASK(5, 4)
> +#define GUC_LOG_EVENT_DATA REG_GENMASK(9, 6)
> +#define GUC_LOG_STATE_CAPTURE REG_GENMASK(11, 10)
> #define GUC_LOG_BUF_ADDR REG_GENMASK(31, 12)
>
> #define GUC_CTL_WA 1
> diff --git a/drivers/gpu/drm/xe/xe_guc_log.c b/drivers/gpu/drm/xe/xe_guc_log.c
> index c01ccb35dc75..995148e3f103 100644
> --- a/drivers/gpu/drm/xe/xe_guc_log.c
> +++ b/drivers/gpu/drm/xe/xe_guc_log.c
> @@ -19,6 +19,45 @@
> #include "xe_mmio.h"
> #include "xe_module.h"
>
> +/**
> + * DOC: GuC Log buffer Layout
> + *
> + * The in-memory log buffer layout is as follows:
... as follows::
and empty line here
> + * +===============================+ 0000h
> + * | Crash dump state header | ^
> + * +-------------------------------+ 32B |
> + * | Debug state header | |
> + * +-------------------------------+ 64B 4KB
> + * | Capture state header | |
> + * +-------------------------------+ 96B |
> + * | | v
> + * +===============================+ <--- EVENT_DATA offset
> + * | Event logs(raw data) | ^
> + * | | |
> + * | | EVENT_DATA_BUFFER_SIZE
> + * | | |
> + * | | v
> + * +===============================+ <--- CRASH_DUMP offset
> + * | Crash Dump(raw data) | ^
> + * | | |
> + * | | CRASH_DUMP_BUFFER_SIZE
> + * | | |
> + * | | v
> + * +===============================+ <--- STATE_CAPTURE offset
> + * | Error state capture(raw data) | ^
> + * | | |
> + * | | STATE_CAPTURE_BUFFER_SIZE
> + * | | |
> + * | | v
> + * +===============================+ Total: GUC_LOG_SIZE
> + */
since above layout is fixed (up to actual data section size) this DOC could be placed in abi/log_abi.h
> +#define GUC_LOG_SIZE (SZ_4K + \
maybe this one should also be defined in .h where other _BUFFER_SIZEs are defined:
#define XE_GUC_LOG_BUFFER_SIZE (SZ_4K + ...CAPTURE_BUFFER_SIZE)
or make all names shorter by using only _SIZEs suffix:
#define XE_GUC_LOG_SIZE (SZ_4K + ...CAPTURE_SIZE)
> + XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE + \
> + XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE + \
> + XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE)
> +
> +#define GUC_LOG_CHUNK_SIZE SZ_2M
> +
> static struct xe_guc *
> log_to_guc(struct xe_guc_log *log)
> {
> @@ -37,33 +76,6 @@ log_to_xe(struct xe_guc_log *log)
> return gt_to_xe(log_to_gt(log));
> }
>
> -static size_t guc_log_size(void)
> -{
> - /*
> - * GuC Log buffer Layout
> - *
> - * +===============================+ 00B
> - * | Crash dump state header |
> - * +-------------------------------+ 32B
> - * | Debug state header |
> - * +-------------------------------+ 64B
> - * | Capture state header |
> - * +-------------------------------+ 96B
> - * | |
> - * +===============================+ PAGE_SIZE (4KB)
> - * | Crash Dump logs |
> - * +===============================+ + CRASH_SIZE
> - * | Debug logs |
> - * +===============================+ + DEBUG_SIZE
> - * | Capture logs |
> - * +===============================+ + CAPTURE_SIZE
> - */
> - return PAGE_SIZE + CRASH_BUFFER_SIZE + DEBUG_BUFFER_SIZE +
> - CAPTURE_BUFFER_SIZE;
> -}
> -
> -#define GUC_LOG_CHUNK_SIZE SZ_2M
> -
> static struct xe_guc_log_snapshot *xe_guc_log_snapshot_alloc(struct xe_guc_log *log, bool atomic)
> {
> struct xe_guc_log_snapshot *snapshot;
> @@ -257,7 +269,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
> struct xe_tile *tile = gt_to_tile(log_to_gt(log));
> struct xe_bo *bo;
>
> - bo = xe_managed_bo_create_pin_map(xe, tile, guc_log_size(),
> + bo = xe_managed_bo_create_pin_map(xe, tile, GUC_LOG_SIZE,
> XE_BO_FLAG_SYSTEM |
> XE_BO_FLAG_GGTT |
> XE_BO_FLAG_GGTT_INVALIDATE |
> @@ -265,7 +277,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
> if (IS_ERR(bo))
> return PTR_ERR(bo);
>
> - xe_map_memset(xe, &bo->vmap, 0, 0, guc_log_size());
> + xe_map_memset(xe, &bo->vmap, 0, 0, GUC_LOG_SIZE);
use xe_bo_size(bo) instead
> log->bo = bo;
> log->level = xe_modparam.guc_log_level;
>
> @@ -274,49 +286,6 @@ int xe_guc_log_init(struct xe_guc_log *log)
>
> ALLOW_ERROR_INJECTION(xe_guc_log_init, ERRNO); /* See xe_pci_probe() */
>
> -static u32 xe_guc_log_section_size_crash(struct xe_guc_log *log)
> -{
> - return CRASH_BUFFER_SIZE;
> -}
> -
> -static u32 xe_guc_log_section_size_debug(struct xe_guc_log *log)
> -{
> - return DEBUG_BUFFER_SIZE;
> -}
> -
> -/**
> - * xe_guc_log_section_size_capture - Get capture buffer size within log sections.
> - * @log: The log object.
> - *
> - * This function will return the capture buffer size within log sections.
> - *
> - * Return: capture buffer size.
> - */
> -u32 xe_guc_log_section_size_capture(struct xe_guc_log *log)
> -{
> - return CAPTURE_BUFFER_SIZE;
> -}
> -
> -/**
> - * xe_guc_get_log_buffer_size - Get log buffer size for a type.
> - * @log: The log object.
> - * @type: The log buffer type
> - *
> - * Return: buffer size.
> - */
> -u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type)
> -{
> - switch (type) {
> - case GUC_LOG_BUFFER_CRASH_DUMP:
> - return xe_guc_log_section_size_crash(log);
> - case GUC_LOG_BUFFER_DEBUG:
> - return xe_guc_log_section_size_debug(log);
> - case GUC_LOG_BUFFER_CAPTURE:
> - return xe_guc_log_section_size_capture(log);
> - }
> - return 0;
> -}
> -
> /**
> * xe_guc_get_log_buffer_offset - Get offset in log buffer for a type.
> * @log: The log object.
> @@ -327,13 +296,17 @@ u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type
> */
> u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type)
> {
> - enum guc_log_buffer_type i;
> - u32 offset = PAGE_SIZE;/* for the log_buffer_states */
> + u32 offset = SZ_4K;/* for the log_buffer_states */
>
> - for (i = GUC_LOG_BUFFER_CRASH_DUMP; i < GUC_LOG_BUFFER_TYPE_MAX; ++i) {
> - if (i == type)
> - break;
> - offset += xe_guc_get_log_buffer_size(log, i);
> + switch (type) {
> + case GUC_LOG_BUFFER_STATE_CAPTURE:
> + offset += XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE;
> + fallthrough;
> + case GUC_LOG_BUFFER_CRASH_DUMP:
> + offset += XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE;
> + fallthrough;
> + case GUC_LOG_BUFFER_EVENT_DATA:
> + break;
> }
>
> return offset;
> diff --git a/drivers/gpu/drm/xe/xe_guc_log.h b/drivers/gpu/drm/xe/xe_guc_log.h
> index 98a47ac42b08..a3620462f44c 100644
> --- a/drivers/gpu/drm/xe/xe_guc_log.h
> +++ b/drivers/gpu/drm/xe/xe_guc_log.h
> @@ -13,13 +13,13 @@ struct drm_printer;
> struct xe_device;
>
> #if IS_ENABLED(CONFIG_DRM_XE_DEBUG_GUC)
> -#define CRASH_BUFFER_SIZE SZ_1M
> -#define DEBUG_BUFFER_SIZE SZ_8M
> -#define CAPTURE_BUFFER_SIZE SZ_2M
> +#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_8M
> +#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_1M
> +#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_2M
> #else
> -#define CRASH_BUFFER_SIZE SZ_16K
> -#define DEBUG_BUFFER_SIZE SZ_64K
> -#define CAPTURE_BUFFER_SIZE SZ_1M
> +#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_64K
> +#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_16K
> +#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_1M
what about using shorter names:
#define XE_GUC_LOG_EVENT_DATA_SIZE SZ_64K
#define XE_GUC_LOG_CRASH_DUMP_SIZE SZ_16K
#define XE_GUC_LOG_STATE_CAPTURE_SIZE SZ_1M
> #endif
then we can also provide here:
#define XE_GUC_LOG_EVENT_DATA_OFFSET SZ_4K /* btw, this fixed 4K header size should be part ABI def */
#define XE_GUC_LOG_CRASH_DUMP_OFFSET (XE_GUC_LOG_EVENT_DATA_OFFSET + XE_GUC_LOG_EVENT_DATA_SIZE)
#define XE_GUC_LOG_STATE_CAPTURE_OFFSET (XE_GUC_LOG_CRASH_DUMP_OFFSET + XE_GUC_LOG_CRASH_DUMP_SIZE)
> /*
> * While we're using plain log level in i915, GuC controls are much more...
> @@ -51,8 +51,6 @@ xe_guc_log_get_level(struct xe_guc_log *log)
> return log->level;
> }
>
> -u32 xe_guc_log_section_size_capture(struct xe_guc_log *log);
> -u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type);
> u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type);
then we can kill this function, as there is only one user which can use XE_GUC_LOG_STATE_CAPTURE_OFFSET directly
> bool xe_guc_check_log_buf_overflow(struct xe_guc_log *log,
> enum guc_log_buffer_type type,
^ permalink raw reply [flat|nested] 6+ messages in thread
* ✗ Xe.CI.Full: failure for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
2025-10-23 17:58 [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Zhanjun Dong
` (2 preceding siblings ...)
2025-10-23 23:04 ` [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Michal Wajdeczko
@ 2025-10-24 10:52 ` Patchwork
3 siblings, 0 replies; 6+ messages in thread
From: Patchwork @ 2025-10-24 10:52 UTC (permalink / raw)
To: Dong, Zhanjun; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 55677 bytes --]
== Series Details ==
Series: drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3)
URL : https://patchwork.freedesktop.org/series/155338/
State : failure
== Summary ==
CI Bug Log - changes from xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff_FULL -> xe-pw-155338v3_FULL
====================================================
Summary
-------
**FAILURE**
Serious unknown changes coming with xe-pw-155338v3_FULL absolutely need to be
verified manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-155338v3_FULL, please notify your bug team (I915-ci-infra@lists.freedesktop.org) to allow them
to document this new failure mode, which will reduce false positives in CI.
Participating hosts (4 -> 4)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-155338v3_FULL:
### IGT changes ###
#### Possible regressions ####
* igt@xe_pmu@engine-activity-most-load@engine-drm_xe_engine_class_video_decode0:
- shard-adlp: [PASS][1] -> [FAIL][2] +5 other tests fail
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-1/igt@xe_pmu@engine-activity-most-load@engine-drm_xe_engine_class_video_decode0.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-9/igt@xe_pmu@engine-activity-most-load@engine-drm_xe_engine_class_video_decode0.html
Known issues
------------
Here are the changes found in xe-pw-155338v3_FULL that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_atomic_transition@plane-all-modeset-transition-fencing-internal-panels:
- shard-bmg: NOTRUN -> [SKIP][3] ([Intel XE#2370])
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_atomic_transition@plane-all-modeset-transition-fencing-internal-panels.html
* igt@kms_big_fb@4-tiled-16bpp-rotate-270:
- shard-bmg: NOTRUN -> [SKIP][4] ([Intel XE#2327]) +1 other test skip
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_big_fb@4-tiled-16bpp-rotate-270.html
* igt@kms_big_fb@y-tiled-max-hw-stride-64bpp-rotate-180-hflip:
- shard-bmg: NOTRUN -> [SKIP][5] ([Intel XE#1124]) +2 other tests skip
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_big_fb@y-tiled-max-hw-stride-64bpp-rotate-180-hflip.html
* igt@kms_big_fb@yf-tiled-32bpp-rotate-0:
- shard-dg2-set2: NOTRUN -> [SKIP][6] ([Intel XE#1124])
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_big_fb@yf-tiled-32bpp-rotate-0.html
* igt@kms_bw@connected-linear-tiling-3-displays-3840x2160p:
- shard-bmg: NOTRUN -> [SKIP][7] ([Intel XE#2314] / [Intel XE#2894])
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_bw@connected-linear-tiling-3-displays-3840x2160p.html
* igt@kms_ccs@bad-aux-stride-4-tiled-mtl-mc-ccs@pipe-a-hdmi-a-6:
- shard-dg2-set2: NOTRUN -> [SKIP][8] ([Intel XE#787]) +34 other tests skip
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_ccs@bad-aux-stride-4-tiled-mtl-mc-ccs@pipe-a-hdmi-a-6.html
* igt@kms_ccs@ccs-on-another-bo-y-tiled-gen12-rc-ccs:
- shard-bmg: NOTRUN -> [SKIP][9] ([Intel XE#2887]) +2 other tests skip
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_ccs@ccs-on-another-bo-y-tiled-gen12-rc-ccs.html
* igt@kms_ccs@ccs-on-another-bo-y-tiled-gen12-rc-ccs-cc@pipe-d-dp-4:
- shard-dg2-set2: NOTRUN -> [SKIP][10] ([Intel XE#455] / [Intel XE#787]) +9 other tests skip
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_ccs@ccs-on-another-bo-y-tiled-gen12-rc-ccs-cc@pipe-d-dp-4.html
* igt@kms_ccs@crc-primary-rotation-180-4-tiled-lnl-ccs@pipe-b-dp-2:
- shard-bmg: NOTRUN -> [SKIP][11] ([Intel XE#2652] / [Intel XE#787]) +3 other tests skip
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_ccs@crc-primary-rotation-180-4-tiled-lnl-ccs@pipe-b-dp-2.html
* igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs:
- shard-bmg: NOTRUN -> [INCOMPLETE][12] ([Intel XE#3862]) +1 other test incomplete
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-d-dp-4:
- shard-dg2-set2: NOTRUN -> [INCOMPLETE][13] ([Intel XE#6168] / [i915#14968])
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-d-dp-4.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-d-hdmi-a-6:
- shard-dg2-set2: NOTRUN -> [DMESG-WARN][14] ([Intel XE#1727] / [Intel XE#3113])
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-d-hdmi-a-6.html
* igt@kms_chamelium_color@ctm-0-50:
- shard-bmg: NOTRUN -> [SKIP][15] ([Intel XE#2325]) +1 other test skip
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_chamelium_color@ctm-0-50.html
* igt@kms_chamelium_edid@hdmi-mode-timings:
- shard-dg2-set2: NOTRUN -> [SKIP][16] ([Intel XE#373]) +1 other test skip
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_chamelium_edid@hdmi-mode-timings.html
* igt@kms_chamelium_hpd@hdmi-hpd-enable-disable-mode:
- shard-bmg: NOTRUN -> [SKIP][17] ([Intel XE#2252])
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_chamelium_hpd@hdmi-hpd-enable-disable-mode.html
* igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size:
- shard-bmg: [PASS][18] -> [DMESG-WARN][19] ([Intel XE#5354])
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-2/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-5/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
* igt@kms_cursor_legacy@cursorb-vs-flipa-legacy:
- shard-bmg: [PASS][20] -> [SKIP][21] ([Intel XE#2291]) +2 other tests skip
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-5/igt@kms_cursor_legacy@cursorb-vs-flipa-legacy.html
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_cursor_legacy@cursorb-vs-flipa-legacy.html
* igt@kms_cursor_legacy@flip-vs-cursor-legacy:
- shard-bmg: [PASS][22] -> [FAIL][23] ([Intel XE#5299])
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-3/igt@kms_cursor_legacy@flip-vs-cursor-legacy.html
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-2/igt@kms_cursor_legacy@flip-vs-cursor-legacy.html
* igt@kms_dp_aux_dev:
- shard-bmg: [PASS][24] -> [SKIP][25] ([Intel XE#3009])
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-5/igt@kms_dp_aux_dev.html
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_dp_aux_dev.html
* igt@kms_feature_discovery@dp-mst:
- shard-bmg: NOTRUN -> [SKIP][26] ([Intel XE#2375])
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_feature_discovery@dp-mst.html
* igt@kms_feature_discovery@psr1:
- shard-dg2-set2: NOTRUN -> [SKIP][27] ([Intel XE#1135])
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_feature_discovery@psr1.html
* igt@kms_flip@2x-flip-vs-dpms:
- shard-bmg: [PASS][28] -> [SKIP][29] ([Intel XE#2316]) +4 other tests skip
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-8/igt@kms_flip@2x-flip-vs-dpms.html
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_flip@2x-flip-vs-dpms.html
* igt@kms_flip@flip-vs-expired-vblank@c-edp1:
- shard-lnl: [PASS][30] -> [FAIL][31] ([Intel XE#301] / [Intel XE#3149]) +1 other test fail
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-lnl-3/igt@kms_flip@flip-vs-expired-vblank@c-edp1.html
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-lnl-3/igt@kms_flip@flip-vs-expired-vblank@c-edp1.html
* igt@kms_flip@flip-vs-suspend:
- shard-adlp: [PASS][32] -> [DMESG-WARN][33] ([Intel XE#2953] / [Intel XE#4173]) +10 other tests dmesg-warn
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-6/igt@kms_flip@flip-vs-suspend.html
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-4/igt@kms_flip@flip-vs-suspend.html
- shard-bmg: [PASS][34] -> [INCOMPLETE][35] ([Intel XE#2049] / [Intel XE#2597]) +1 other test incomplete
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-3/igt@kms_flip@flip-vs-suspend.html
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-2/igt@kms_flip@flip-vs-suspend.html
* igt@kms_flip@plain-flip-ts-check-interruptible@c-hdmi-a1:
- shard-adlp: [PASS][36] -> [DMESG-WARN][37] ([Intel XE#4543]) +7 other tests dmesg-warn
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-3/igt@kms_flip@plain-flip-ts-check-interruptible@c-hdmi-a1.html
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-3/igt@kms_flip@plain-flip-ts-check-interruptible@c-hdmi-a1.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling:
- shard-bmg: NOTRUN -> [SKIP][38] ([Intel XE#2293] / [Intel XE#2380])
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling@pipe-a-valid-mode:
- shard-bmg: NOTRUN -> [SKIP][39] ([Intel XE#2293])
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling@pipe-a-valid-mode.html
* igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-x-to-y:
- shard-adlp: [PASS][40] -> [FAIL][41] ([Intel XE#1874])
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-3/igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-x-to-y.html
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-3/igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-x-to-y.html
* igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-y-to-y:
- shard-adlp: [PASS][42] -> [DMESG-FAIL][43] ([Intel XE#4543])
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-3/igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-y-to-y.html
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-3/igt@kms_flip_tiling@flip-change-tiling@pipe-b-hdmi-a-1-y-to-y.html
* igt@kms_frontbuffer_tracking@fbc-2p-primscrn-shrfb-msflip-blt:
- shard-bmg: NOTRUN -> [SKIP][44] ([Intel XE#5390]) +1 other test skip
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-shrfb-msflip-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-indfb-pgflip-blt:
- shard-bmg: NOTRUN -> [SKIP][45] ([Intel XE#2311]) +6 other tests skip
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-indfb-pgflip-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-pri-shrfb-draw-blt:
- shard-dg2-set2: NOTRUN -> [SKIP][46] ([Intel XE#651]) +3 other tests skip
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-pri-shrfb-draw-blt.html
* igt@kms_frontbuffer_tracking@plane-fbc-rte:
- shard-dg2-set2: NOTRUN -> [SKIP][47] ([Intel XE#1158])
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_frontbuffer_tracking@plane-fbc-rte.html
* igt@kms_frontbuffer_tracking@psr-1p-primscrn-pri-indfb-draw-render:
- shard-bmg: NOTRUN -> [SKIP][48] ([Intel XE#2313]) +7 other tests skip
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_frontbuffer_tracking@psr-1p-primscrn-pri-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@psr-2p-scndscrn-spr-indfb-move:
- shard-dg2-set2: NOTRUN -> [SKIP][49] ([Intel XE#653]) +4 other tests skip
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_frontbuffer_tracking@psr-2p-scndscrn-spr-indfb-move.html
* igt@kms_joiner@basic-force-ultra-joiner:
- shard-dg2-set2: NOTRUN -> [SKIP][50] ([Intel XE#2925])
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_joiner@basic-force-ultra-joiner.html
* igt@kms_plane_multiple@tiling-y:
- shard-bmg: NOTRUN -> [SKIP][51] ([Intel XE#5020])
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_plane_multiple@tiling-y.html
* igt@kms_plane_scaling@planes-upscale-20x20-downscale-factor-0-75@pipe-a:
- shard-bmg: NOTRUN -> [SKIP][52] ([Intel XE#2763]) +4 other tests skip
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_plane_scaling@planes-upscale-20x20-downscale-factor-0-75@pipe-a.html
* igt@kms_psr2_sf@fbc-pr-plane-move-sf-dmg-area:
- shard-dg2-set2: NOTRUN -> [SKIP][53] ([Intel XE#1406] / [Intel XE#1489]) +2 other tests skip
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_psr2_sf@fbc-pr-plane-move-sf-dmg-area.html
* igt@kms_psr2_sf@pr-primary-plane-update-sf-dmg-area-big-fb:
- shard-bmg: NOTRUN -> [SKIP][54] ([Intel XE#1406] / [Intel XE#1489]) +1 other test skip
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_psr2_sf@pr-primary-plane-update-sf-dmg-area-big-fb.html
* igt@kms_psr2_su@page_flip-nv12:
- shard-bmg: NOTRUN -> [SKIP][55] ([Intel XE#1406] / [Intel XE#2387])
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_psr2_su@page_flip-nv12.html
* igt@kms_psr@pr-primary-blt:
- shard-bmg: NOTRUN -> [SKIP][56] ([Intel XE#1406] / [Intel XE#2234] / [Intel XE#2850]) +1 other test skip
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@kms_psr@pr-primary-blt.html
* igt@kms_psr@pr-sprite-plane-move:
- shard-dg2-set2: NOTRUN -> [SKIP][57] ([Intel XE#1406] / [Intel XE#2850] / [Intel XE#929]) +2 other tests skip
[57]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_psr@pr-sprite-plane-move.html
* igt@kms_rotation_crc@primary-y-tiled-reflect-x-0:
- shard-dg2-set2: NOTRUN -> [SKIP][58] ([Intel XE#1127])
[58]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_rotation_crc@primary-y-tiled-reflect-x-0.html
* igt@kms_rotation_crc@sprite-rotation-90:
- shard-bmg: NOTRUN -> [SKIP][59] ([Intel XE#3414] / [Intel XE#3904]) +1 other test skip
[59]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-1/igt@kms_rotation_crc@sprite-rotation-90.html
- shard-dg2-set2: NOTRUN -> [SKIP][60] ([Intel XE#3414])
[60]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_rotation_crc@sprite-rotation-90.html
* igt@kms_setmode@clone-exclusive-crtc:
- shard-bmg: [PASS][61] -> [SKIP][62] ([Intel XE#1435])
[61]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-5/igt@kms_setmode@clone-exclusive-crtc.html
[62]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_setmode@clone-exclusive-crtc.html
* igt@kms_vrr@cmrr@pipe-a-edp-1:
- shard-lnl: [PASS][63] -> [FAIL][64] ([Intel XE#4459]) +1 other test fail
[63]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-lnl-7/igt@kms_vrr@cmrr@pipe-a-edp-1.html
[64]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-lnl-1/igt@kms_vrr@cmrr@pipe-a-edp-1.html
* igt@kms_vrr@flipline:
- shard-dg2-set2: NOTRUN -> [SKIP][65] ([Intel XE#455]) +4 other tests skip
[65]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_vrr@flipline.html
* igt@xe_compute_preempt@compute-preempt-many-vram-evict:
- shard-dg2-set2: NOTRUN -> [SKIP][66] ([Intel XE#6360])
[66]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_compute_preempt@compute-preempt-many-vram-evict.html
* igt@xe_copy_basic@mem-set-linear-0xfd:
- shard-dg2-set2: NOTRUN -> [SKIP][67] ([Intel XE#1126]) +1 other test skip
[67]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_copy_basic@mem-set-linear-0xfd.html
* igt@xe_eudebug@multigpu-basic-client:
- shard-dg2-set2: NOTRUN -> [SKIP][68] ([Intel XE#4837]) +1 other test skip
[68]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_eudebug@multigpu-basic-client.html
* igt@xe_eudebug_online@stopped-thread:
- shard-bmg: NOTRUN -> [SKIP][69] ([Intel XE#4837]) +3 other tests skip
[69]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@xe_eudebug_online@stopped-thread.html
* igt@xe_evict@evict-mixed-many-threads-small:
- shard-bmg: [PASS][70] -> [INCOMPLETE][71] ([Intel XE#6321])
[70]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-4/igt@xe_evict@evict-mixed-many-threads-small.html
[71]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@xe_evict@evict-mixed-many-threads-small.html
* igt@xe_exec_basic@multigpu-no-exec-null-rebind:
- shard-bmg: NOTRUN -> [SKIP][72] ([Intel XE#2322]) +1 other test skip
[72]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@xe_exec_basic@multigpu-no-exec-null-rebind.html
* igt@xe_exec_fault_mode@many-userptr:
- shard-dg2-set2: NOTRUN -> [SKIP][73] ([Intel XE#288]) +4 other tests skip
[73]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_exec_fault_mode@many-userptr.html
* igt@xe_exec_system_allocator@many-stride-malloc-prefetch:
- shard-bmg: [PASS][74] -> [WARN][75] ([Intel XE#5786])
[74]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-8/igt@xe_exec_system_allocator@many-stride-malloc-prefetch.html
[75]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@xe_exec_system_allocator@many-stride-malloc-prefetch.html
* igt@xe_exec_system_allocator@threads-many-execqueues-mmap-prefetch-shared:
- shard-dg2-set2: NOTRUN -> [SKIP][76] ([Intel XE#4915]) +69 other tests skip
[76]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-prefetch-shared.html
* igt@xe_exec_system_allocator@twice-mmap-new-huge:
- shard-bmg: NOTRUN -> [SKIP][77] ([Intel XE#4943]) +1 other test skip
[77]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@xe_exec_system_allocator@twice-mmap-new-huge.html
* igt@xe_oa@mmio-triggered-reports:
- shard-dg2-set2: NOTRUN -> [SKIP][78] ([Intel XE#3573])
[78]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_oa@mmio-triggered-reports.html
* igt@xe_oa@oa-tlb-invalidate:
- shard-bmg: NOTRUN -> [SKIP][79] ([Intel XE#2248])
[79]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@xe_oa@oa-tlb-invalidate.html
* igt@xe_pm@s2idle-vm-bind-prefetch:
- shard-adlp: [PASS][80] -> [INCOMPLETE][81] ([Intel XE#4504])
[80]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-1/igt@xe_pm@s2idle-vm-bind-prefetch.html
[81]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-9/igt@xe_pm@s2idle-vm-bind-prefetch.html
* igt@xe_pmu@fn-engine-activity-sched-if-idle@engine-drm_xe_engine_class_video_enhance1:
- shard-bmg: [PASS][82] -> [DMESG-WARN][83] ([Intel XE#3876] / [Intel XE#3970]) +1 other test dmesg-warn
[82]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-4/igt@xe_pmu@fn-engine-activity-sched-if-idle@engine-drm_xe_engine_class_video_enhance1.html
[83]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@xe_pmu@fn-engine-activity-sched-if-idle@engine-drm_xe_engine_class_video_enhance1.html
* igt@xe_pxp@pxp-optout:
- shard-bmg: NOTRUN -> [SKIP][84] ([Intel XE#4733])
[84]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-4/igt@xe_pxp@pxp-optout.html
* igt@xe_pxp@pxp-termination-key-update-post-suspend:
- shard-dg2-set2: NOTRUN -> [SKIP][85] ([Intel XE#4733])
[85]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_pxp@pxp-termination-key-update-post-suspend.html
* igt@xe_query@multigpu-query-invalid-cs-cycles:
- shard-dg2-set2: NOTRUN -> [SKIP][86] ([Intel XE#944])
[86]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_query@multigpu-query-invalid-cs-cycles.html
* igt@xe_sriov_vram@vf-access-after-resize-up:
- shard-dg2-set2: NOTRUN -> [SKIP][87] ([Intel XE#6318])
[87]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_sriov_vram@vf-access-after-resize-up.html
#### Possible fixes ####
* igt@kms_async_flips@crc-atomic@pipe-b-hdmi-a-1:
- shard-adlp: [DMESG-FAIL][88] ([Intel XE#4543]) -> [PASS][89] +1 other test pass
[88]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-1/igt@kms_async_flips@crc-atomic@pipe-b-hdmi-a-1.html
[89]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-9/igt@kms_async_flips@crc-atomic@pipe-b-hdmi-a-1.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc:
- shard-dg2-set2: [INCOMPLETE][90] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4212] / [Intel XE#4345] / [Intel XE#4522]) -> [PASS][91]
[90]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-463/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc.html
[91]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc@pipe-b-dp-4:
- shard-dg2-set2: [INCOMPLETE][92] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4212] / [Intel XE#4522]) -> [PASS][93]
[92]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-463/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc@pipe-b-dp-4.html
[93]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs-cc@pipe-b-dp-4.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-c-dp-4:
- shard-dg2-set2: [INCOMPLETE][94] ([Intel XE#2705] / [Intel XE#4212]) -> [PASS][95]
[94]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-436/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-c-dp-4.html
[95]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs@pipe-c-dp-4.html
* igt@kms_cursor_crc@cursor-offscreen-256x256:
- shard-adlp: [DMESG-WARN][96] ([Intel XE#2953] / [Intel XE#4173]) -> [PASS][97]
[96]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-4/igt@kms_cursor_crc@cursor-offscreen-256x256.html
[97]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-2/igt@kms_cursor_crc@cursor-offscreen-256x256.html
* igt@kms_cursor_crc@cursor-onscreen-256x256:
- shard-bmg: [SKIP][98] ([Intel XE#2320]) -> [PASS][99] +1 other test pass
[98]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_cursor_crc@cursor-onscreen-256x256.html
[99]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-5/igt@kms_cursor_crc@cursor-onscreen-256x256.html
* igt@kms_cursor_legacy@cursora-vs-flipb-varying-size:
- shard-bmg: [SKIP][100] ([Intel XE#2291]) -> [PASS][101] +1 other test pass
[100]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_cursor_legacy@cursora-vs-flipb-varying-size.html
[101]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-5/igt@kms_cursor_legacy@cursora-vs-flipb-varying-size.html
* igt@kms_flip@2x-flip-vs-modeset-vs-hang:
- shard-bmg: [SKIP][102] ([Intel XE#2316]) -> [PASS][103] +3 other tests pass
[102]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_flip@2x-flip-vs-modeset-vs-hang.html
[103]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@kms_flip@2x-flip-vs-modeset-vs-hang.html
* igt@kms_flip@basic-flip-vs-modeset@c-hdmi-a1:
- shard-adlp: [DMESG-WARN][104] ([Intel XE#4543]) -> [PASS][105] +7 other tests pass
[104]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-8/igt@kms_flip@basic-flip-vs-modeset@c-hdmi-a1.html
[105]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-8/igt@kms_flip@basic-flip-vs-modeset@c-hdmi-a1.html
* igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@a-dp2:
- shard-bmg: [FAIL][106] ([Intel XE#5338] / [Intel XE#5416]) -> [PASS][107] +1 other test pass
[106]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@a-dp2.html
[107]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@a-dp2.html
* igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@c-dp2:
- shard-bmg: [FAIL][108] ([Intel XE#5416]) -> [PASS][109]
[108]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@c-dp2.html
[109]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_flip@flip-vs-absolute-wf_vblank-interruptible@c-dp2.html
* igt@kms_hdr@static-toggle-dpms:
- shard-bmg: [SKIP][110] ([Intel XE#1503]) -> [PASS][111]
[110]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_hdr@static-toggle-dpms.html
[111]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@kms_hdr@static-toggle-dpms.html
* igt@kms_joiner@basic-force-big-joiner:
- shard-bmg: [SKIP][112] ([Intel XE#3012]) -> [PASS][113]
[112]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_joiner@basic-force-big-joiner.html
[113]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@kms_joiner@basic-force-big-joiner.html
* igt@kms_plane_multiple@2x-tiling-none:
- shard-bmg: [SKIP][114] ([Intel XE#4596]) -> [PASS][115]
[114]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_plane_multiple@2x-tiling-none.html
[115]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_plane_multiple@2x-tiling-none.html
* igt@xe_compute_preempt@compute-preempt-many-vram-evict@engine-drm_xe_engine_class_compute:
- shard-bmg: [ABORT][116] ([Intel XE#3970]) -> [PASS][117] +1 other test pass
[116]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-8/igt@xe_compute_preempt@compute-preempt-many-vram-evict@engine-drm_xe_engine_class_compute.html
[117]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-1/igt@xe_compute_preempt@compute-preempt-many-vram-evict@engine-drm_xe_engine_class_compute.html
* igt@xe_exec_basic@multigpu-once-basic:
- shard-dg2-set2: [INCOMPLETE][118] ([Intel XE#4842]) -> [PASS][119]
[118]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@xe_exec_basic@multigpu-once-basic.html
[119]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_exec_basic@multigpu-once-basic.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-large-mmap-new-madvise:
- shard-bmg: [DMESG-WARN][120] ([Intel XE#3428]) -> [PASS][121] +7 other tests pass
[120]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@xe_exec_system_allocator@threads-shared-vm-many-large-mmap-new-madvise.html
[121]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@xe_exec_system_allocator@threads-shared-vm-many-large-mmap-new-madvise.html
* igt@xe_fault_injection@probe-fail-guc-xe_guc_mmio_send_recv:
- shard-dg2-set2: [DMESG-WARN][122] ([Intel XE#5893]) -> [PASS][123]
[122]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@xe_fault_injection@probe-fail-guc-xe_guc_mmio_send_recv.html
[123]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_fault_injection@probe-fail-guc-xe_guc_mmio_send_recv.html
* igt@xe_module_load@load:
- shard-dg2-set2: ([PASS][124], [PASS][125], [PASS][126], [PASS][127], [PASS][128], [PASS][129], [PASS][130], [PASS][131], [PASS][132], [PASS][133], [PASS][134], [PASS][135], [PASS][136], [PASS][137], [PASS][138], [PASS][139], [PASS][140], [PASS][141], [PASS][142], [PASS][143], [PASS][144], [PASS][145], [PASS][146], [PASS][147], [PASS][148], [SKIP][149]) ([Intel XE#378]) -> ([PASS][150], [PASS][151], [PASS][152], [PASS][153], [PASS][154], [PASS][155], [PASS][156], [PASS][157], [PASS][158], [PASS][159], [PASS][160], [PASS][161], [PASS][162], [PASS][163], [PASS][164], [PASS][165], [PASS][166], [PASS][167], [PASS][168], [PASS][169], [PASS][170], [PASS][171], [PASS][172], [PASS][173], [PASS][174])
[124]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-432/igt@xe_module_load@load.html
[125]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-433/igt@xe_module_load@load.html
[126]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-433/igt@xe_module_load@load.html
[127]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@xe_module_load@load.html
[128]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@xe_module_load@load.html
[129]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@xe_module_load@load.html
[130]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-434/igt@xe_module_load@load.html
[131]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-432/igt@xe_module_load@load.html
[132]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-433/igt@xe_module_load@load.html
[133]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-436/igt@xe_module_load@load.html
[134]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-436/igt@xe_module_load@load.html
[135]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-436/igt@xe_module_load@load.html
[136]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-464/igt@xe_module_load@load.html
[137]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-464/igt@xe_module_load@load.html
[138]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-463/igt@xe_module_load@load.html
[139]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-434/igt@xe_module_load@load.html
[140]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-432/igt@xe_module_load@load.html
[141]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-432/igt@xe_module_load@load.html
[142]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-435/igt@xe_module_load@load.html
[143]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-463/igt@xe_module_load@load.html
[144]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-434/igt@xe_module_load@load.html
[145]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-463/igt@xe_module_load@load.html
[146]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-464/igt@xe_module_load@load.html
[147]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-435/igt@xe_module_load@load.html
[148]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-435/igt@xe_module_load@load.html
[149]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-432/igt@xe_module_load@load.html
[150]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_module_load@load.html
[151]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-434/igt@xe_module_load@load.html
[152]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-463/igt@xe_module_load@load.html
[153]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_module_load@load.html
[154]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_module_load@load.html
[155]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-466/igt@xe_module_load@load.html
[156]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-435/igt@xe_module_load@load.html
[157]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-466/igt@xe_module_load@load.html
[158]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-463/igt@xe_module_load@load.html
[159]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-464/igt@xe_module_load@load.html
[160]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-464/igt@xe_module_load@load.html
[161]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-464/igt@xe_module_load@load.html
[162]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-463/igt@xe_module_load@load.html
[163]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_module_load@load.html
[164]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_module_load@load.html
[165]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@xe_module_load@load.html
[166]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-432/igt@xe_module_load@load.html
[167]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-432/igt@xe_module_load@load.html
[168]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-436/igt@xe_module_load@load.html
[169]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-436/igt@xe_module_load@load.html
[170]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-463/igt@xe_module_load@load.html
[171]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-466/igt@xe_module_load@load.html
[172]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-434/igt@xe_module_load@load.html
[173]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-434/igt@xe_module_load@load.html
[174]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-436/igt@xe_module_load@load.html
* igt@xe_sriov_scheduling@nonpreempt-engine-resets@numvfs-random:
- shard-adlp: [DMESG-FAIL][175] ([Intel XE#3868] / [Intel XE#5213]) -> [PASS][176] +1 other test pass
[175]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-9/igt@xe_sriov_scheduling@nonpreempt-engine-resets@numvfs-random.html
[176]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-4/igt@xe_sriov_scheduling@nonpreempt-engine-resets@numvfs-random.html
#### Warnings ####
* igt@kms_async_flips@crc-atomic@pipe-c-hdmi-a-1:
- shard-adlp: [FAIL][177] ([Intel XE#3884]) -> [DMESG-FAIL][178] ([Intel XE#4543])
[177]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-1/igt@kms_async_flips@crc-atomic@pipe-c-hdmi-a-1.html
[178]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-9/igt@kms_async_flips@crc-atomic@pipe-c-hdmi-a-1.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs:
- shard-dg2-set2: [INCOMPLETE][179] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4345] / [Intel XE#6168]) -> [INCOMPLETE][180] ([Intel XE#1727] / [Intel XE#2705] / [Intel XE#3113] / [Intel XE#4212] / [Intel XE#4345] / [Intel XE#4522])
[179]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs.html
[180]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-a-hdmi-a-6:
- shard-dg2-set2: [INCOMPLETE][181] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#6168]) -> [INCOMPLETE][182] ([Intel XE#1727] / [Intel XE#2705] / [Intel XE#3113] / [Intel XE#4212] / [Intel XE#4522])
[181]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-466/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-a-hdmi-a-6.html
[182]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-434/igt@kms_ccs@random-ccs-data-4-tiled-dg2-mc-ccs@pipe-a-hdmi-a-6.html
* igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs:
- shard-dg2-set2: [INCOMPLETE][183] ([Intel XE#2705] / [Intel XE#4212] / [Intel XE#4345]) -> [INCOMPLETE][184] ([Intel XE#1727] / [Intel XE#3113] / [Intel XE#4345] / [Intel XE#6168])
[183]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-436/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs.html
[184]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-433/igt@kms_ccs@random-ccs-data-4-tiled-dg2-rc-ccs.html
* igt@kms_content_protection@legacy:
- shard-bmg: [FAIL][185] ([Intel XE#1178]) -> [SKIP][186] ([Intel XE#2341]) +1 other test skip
[185]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_content_protection@legacy.html
[186]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-5/igt@kms_content_protection@legacy.html
* igt@kms_flip@flip-vs-panning-interruptible:
- shard-adlp: [DMESG-WARN][187] ([Intel XE#4543] / [Intel XE#5208]) -> [DMESG-WARN][188] ([Intel XE#2953] / [Intel XE#4173] / [Intel XE#4543] / [Intel XE#5208])
[187]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-4/igt@kms_flip@flip-vs-panning-interruptible.html
[188]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-2/igt@kms_flip@flip-vs-panning-interruptible.html
* igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc:
- shard-bmg: [SKIP][189] ([Intel XE#2312]) -> [SKIP][190] ([Intel XE#2311]) +8 other tests skip
[189]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc.html
[190]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-pri-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@drrs-2p-scndscrn-pri-indfb-draw-mmap-wc:
- shard-bmg: [SKIP][191] ([Intel XE#2311]) -> [SKIP][192] ([Intel XE#2312]) +11 other tests skip
[191]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-5/igt@kms_frontbuffer_tracking@drrs-2p-scndscrn-pri-indfb-draw-mmap-wc.html
[192]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_frontbuffer_tracking@drrs-2p-scndscrn-pri-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-cur-indfb-draw-render:
- shard-bmg: [SKIP][193] ([Intel XE#2312]) -> [SKIP][194] ([Intel XE#5390]) +5 other tests skip
[193]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-cur-indfb-draw-render.html
[194]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-3/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-cur-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-shrfb-msflip-blt:
- shard-bmg: [SKIP][195] ([Intel XE#5390]) -> [SKIP][196] ([Intel XE#2312]) +6 other tests skip
[195]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-8/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-shrfb-msflip-blt.html
[196]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_frontbuffer_tracking@fbc-2p-scndscrn-shrfb-msflip-blt.html
* igt@kms_frontbuffer_tracking@fbcpsr-2p-primscrn-cur-indfb-draw-blt:
- shard-bmg: [SKIP][197] ([Intel XE#2313]) -> [SKIP][198] ([Intel XE#2312]) +11 other tests skip
[197]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-5/igt@kms_frontbuffer_tracking@fbcpsr-2p-primscrn-cur-indfb-draw-blt.html
[198]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_frontbuffer_tracking@fbcpsr-2p-primscrn-cur-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@psr-2p-primscrn-cur-indfb-onoff:
- shard-bmg: [SKIP][199] ([Intel XE#2312]) -> [SKIP][200] ([Intel XE#2313]) +7 other tests skip
[199]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_frontbuffer_tracking@psr-2p-primscrn-cur-indfb-onoff.html
[200]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-7/igt@kms_frontbuffer_tracking@psr-2p-primscrn-cur-indfb-onoff.html
* igt@kms_plane_multiple@2x-tiling-y:
- shard-bmg: [SKIP][201] ([Intel XE#5021]) -> [SKIP][202] ([Intel XE#4596])
[201]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-8/igt@kms_plane_multiple@2x-tiling-y.html
[202]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-6/igt@kms_plane_multiple@2x-tiling-y.html
* igt@kms_pm_dc@dc9-dpms:
- shard-adlp: [SKIP][203] ([Intel XE#734]) -> [FAIL][204] ([Intel XE#3325])
[203]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-2/igt@kms_pm_dc@dc9-dpms.html
[204]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-8/igt@kms_pm_dc@dc9-dpms.html
* igt@kms_tiled_display@basic-test-pattern:
- shard-dg2-set2: [FAIL][205] ([Intel XE#1729]) -> [SKIP][206] ([Intel XE#362])
[205]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-dg2-464/igt@kms_tiled_display@basic-test-pattern.html
[206]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-dg2-463/igt@kms_tiled_display@basic-test-pattern.html
* igt@kms_tiled_display@basic-test-pattern-with-chamelium:
- shard-bmg: [SKIP][207] ([Intel XE#2426]) -> [SKIP][208] ([Intel XE#2509])
[207]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-6/igt@kms_tiled_display@basic-test-pattern-with-chamelium.html
[208]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-5/igt@kms_tiled_display@basic-test-pattern-with-chamelium.html
* igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv:
- shard-bmg: [ABORT][209] ([Intel XE#4917] / [Intel XE#5466] / [Intel XE#5530]) -> [ABORT][210] ([Intel XE#5466] / [Intel XE#5530])
[209]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-bmg-4/igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv.html
[210]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-bmg-8/igt@xe_fault_injection@probe-fail-guc-xe_guc_ct_send_recv.html
* igt@xe_sriov_scheduling@equal-throughput:
- shard-adlp: [DMESG-FAIL][211] ([Intel XE#3868] / [Intel XE#5213]) -> [DMESG-FAIL][212] ([Intel XE#3868] / [Intel XE#5213] / [Intel XE#5545]) +1 other test dmesg-fail
[211]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff/shard-adlp-1/igt@xe_sriov_scheduling@equal-throughput.html
[212]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/shard-adlp-9/igt@xe_sriov_scheduling@equal-throughput.html
[Intel XE#1124]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1124
[Intel XE#1126]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1126
[Intel XE#1127]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1127
[Intel XE#1135]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1135
[Intel XE#1158]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1158
[Intel XE#1178]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1178
[Intel XE#1406]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1406
[Intel XE#1435]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1435
[Intel XE#1489]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1489
[Intel XE#1503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1503
[Intel XE#1727]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1727
[Intel XE#1729]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1729
[Intel XE#1874]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1874
[Intel XE#2049]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2049
[Intel XE#2234]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2234
[Intel XE#2248]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2248
[Intel XE#2252]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2252
[Intel XE#2291]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2291
[Intel XE#2293]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2293
[Intel XE#2311]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2311
[Intel XE#2312]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2312
[Intel XE#2313]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2313
[Intel XE#2314]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2314
[Intel XE#2316]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2316
[Intel XE#2320]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2320
[Intel XE#2322]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2322
[Intel XE#2325]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2325
[Intel XE#2327]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2327
[Intel XE#2341]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2341
[Intel XE#2370]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2370
[Intel XE#2375]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2375
[Intel XE#2380]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2380
[Intel XE#2387]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2387
[Intel XE#2426]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2426
[Intel XE#2509]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2509
[Intel XE#2597]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2597
[Intel XE#2652]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2652
[Intel XE#2705]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2705
[Intel XE#2763]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2763
[Intel XE#2850]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2850
[Intel XE#288]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/288
[Intel XE#2887]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2887
[Intel XE#2894]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2894
[Intel XE#2925]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2925
[Intel XE#2953]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2953
[Intel XE#3009]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3009
[Intel XE#301]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/301
[Intel XE#3012]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3012
[Intel XE#3113]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3113
[Intel XE#3149]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3149
[Intel XE#3325]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3325
[Intel XE#3414]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3414
[Intel XE#3428]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3428
[Intel XE#3573]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3573
[Intel XE#362]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/362
[Intel XE#373]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/373
[Intel XE#378]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/378
[Intel XE#3862]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3862
[Intel XE#3868]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3868
[Intel XE#3876]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3876
[Intel XE#3884]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3884
[Intel XE#3904]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3904
[Intel XE#3970]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3970
[Intel XE#4173]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4173
[Intel XE#4212]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4212
[Intel XE#4345]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4345
[Intel XE#4459]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4459
[Intel XE#4504]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4504
[Intel XE#4522]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4522
[Intel XE#4543]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4543
[Intel XE#455]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/455
[Intel XE#4596]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4596
[Intel XE#4733]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4733
[Intel XE#4837]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4837
[Intel XE#4842]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4842
[Intel XE#4915]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4915
[Intel XE#4917]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4917
[Intel XE#4943]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4943
[Intel XE#5020]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5020
[Intel XE#5021]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5021
[Intel XE#5208]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5208
[Intel XE#5213]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5213
[Intel XE#5299]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5299
[Intel XE#5338]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5338
[Intel XE#5354]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5354
[Intel XE#5390]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5390
[Intel XE#5416]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5416
[Intel XE#5466]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5466
[Intel XE#5530]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5530
[Intel XE#5545]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5545
[Intel XE#5786]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5786
[Intel XE#5893]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5893
[Intel XE#6168]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6168
[Intel XE#6318]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6318
[Intel XE#6321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6321
[Intel XE#6360]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6360
[Intel XE#651]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/651
[Intel XE#653]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/653
[Intel XE#734]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/734
[Intel XE#787]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/787
[Intel XE#929]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/929
[Intel XE#944]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/944
[i915#14968]: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/14968
Build changes
-------------
* Linux: xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff -> xe-pw-155338v3
IGT_8596: 8596
xe-3974-c63ccee28ae7ab4cb57a2433314f08c71da914ff: c63ccee28ae7ab4cb57a2433314f08c71da914ff
xe-pw-155338v3: 155338v3
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-155338v3/index.html
[-- Attachment #2: Type: text/html, Size: 64423 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers
2025-10-23 23:04 ` [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Michal Wajdeczko
@ 2025-10-28 0:19 ` Dong, Zhanjun
0 siblings, 0 replies; 6+ messages in thread
From: Dong, Zhanjun @ 2025-10-28 0:19 UTC (permalink / raw)
To: Michal Wajdeczko, intel-xe
Please see my inline comments below.
Regards,
Zhanjun Dong
On 2025-10-23 7:04 p.m., Michal Wajdeczko wrote:
>
>
> On 10/23/2025 7:58 PM, Zhanjun Dong wrote:
>> Cleanup GuC log buffer macros and helpers, add Xe style macro prefix.
>> Update buffer type values to align with the GuC specification
>> Update buffer offset calculation.
>> Remove helper functions, replaced with macros.
>>
>> Signed-off-by: Zhanjun Dong <zhanjun.dong@intel.com>
>> ---
>> Cc: michal.wajdeczko@intel.com
>> ---
>> Change list:
>> v6: Avoid change same line in series twice, squash into single patch
>> Correct PAGE_SIZE to 4K
>> Promote memory layout comment to kernel-doc
>> v5: Change patch order
>> Sync macro names across buffer type, size and GUC_CTL_LOG_PARAMS
>> Replace guc_log_size with macro
>> Update log buffer layout comments
>> v4: Replace helper functions with macros
>> Rename log type xxx_DEBUG to xxx_EVENT_LOG
>> v3: Update comments
>> v2: Use SZ_4K, instead of PAGE_SIZE
>> Expand for loop with switch and fallthrough
>> ---
>> drivers/gpu/drm/xe/abi/guc_log_abi.h | 4 +-
>> drivers/gpu/drm/xe/xe_guc.c | 23 ++---
>> drivers/gpu/drm/xe/xe_guc_capture.c | 16 ++--
>> drivers/gpu/drm/xe/xe_guc_fwif.h | 6 +-
>> drivers/gpu/drm/xe/xe_guc_log.c | 129 +++++++++++----------------
>> drivers/gpu/drm/xe/xe_guc_log.h | 14 ++-
>> 6 files changed, 82 insertions(+), 110 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/xe/abi/guc_log_abi.h b/drivers/gpu/drm/xe/abi/guc_log_abi.h
>> index 554630b7ccd9..fb5e2b8e7cf9 100644
>> --- a/drivers/gpu/drm/xe/abi/guc_log_abi.h
>> +++ b/drivers/gpu/drm/xe/abi/guc_log_abi.h
>> @@ -10,9 +10,9 @@
>>
>> /* GuC logging buffer types */
>> enum guc_log_buffer_type {
>> + GUC_LOG_BUFFER_EVENT_DATA,
>> GUC_LOG_BUFFER_CRASH_DUMP,
>> - GUC_LOG_BUFFER_DEBUG,
>> - GUC_LOG_BUFFER_CAPTURE,
>> + GUC_LOG_BUFFER_STATE_CAPTURE,
>
> GUC_LOG_BUFFER_TYPE_EVENT_DATA,
> GUC_LOG_BUFFER_TYPE_CRASH_DUMP,
> GUC_LOG_BUFFER_TYPE_STATE_CAPTURE,
>
> or
>
> enum guc_log_type {
> GUC_LOG_TYPE_EVENT_DATA,
> GUC_LOG_TYPE_CRASH_DUMP,
> GUC_LOG_TYPE_STATE_CAPTURE,
>
>> };
Will change to
/* GuC logging buffer types */ // <- Will leave this to prompt this is
log buffer type
enum guc_log_type {
GUC_LOG_TYPE_EVENT_DATA,
GUC_LOG_TYPE_CRASH_DUMP,
GUC_LOG_TYPE_STATE_CAPTURE,
...
>>
>> #define GUC_LOG_BUFFER_TYPE_MAX 3
>
> do we still need this?
Yes, upcoming LFD feature will need this>
>> diff --git a/drivers/gpu/drm/xe/xe_guc.c b/drivers/gpu/drm/xe/xe_guc.c
>> index d94490979adc..c82570c70964 100644
>> --- a/drivers/gpu/drm/xe/xe_guc.c
>> +++ b/drivers/gpu/drm/xe/xe_guc.c
>> @@ -99,7 +99,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
>> u32 offset = guc_bo_ggtt_addr(guc, guc->log.bo) >> PAGE_SHIFT;
>> u32 flags;
>>
>> - #if (((CRASH_BUFFER_SIZE) % SZ_1M) == 0)
>> + #if (((XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE) % SZ_1M) == 0)
>> #define LOG_UNIT SZ_1M
>> #define LOG_FLAG GUC_LOG_LOG_ALLOC_UNITS
>> #else
>> @@ -107,7 +107,7 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
>> #define LOG_FLAG 0
>> #endif
>>
>> - #if (((CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
>> + #if (((XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE) % SZ_1M) == 0)
>> #define CAPTURE_UNIT SZ_1M
>> #define CAPTURE_FLAG GUC_LOG_CAPTURE_ALLOC_UNITS
>> #else
>> @@ -115,20 +115,21 @@ static u32 guc_ctl_log_params_flags(struct xe_guc *guc)
>> #define CAPTURE_FLAG 0
>> #endif
>>
>> - BUILD_BUG_ON(!CRASH_BUFFER_SIZE);
>> - BUILD_BUG_ON(!IS_ALIGNED(CRASH_BUFFER_SIZE, LOG_UNIT));
>> - BUILD_BUG_ON(!DEBUG_BUFFER_SIZE);
>> - BUILD_BUG_ON(!IS_ALIGNED(DEBUG_BUFFER_SIZE, LOG_UNIT));
>> - BUILD_BUG_ON(!CAPTURE_BUFFER_SIZE);
>> - BUILD_BUG_ON(!IS_ALIGNED(CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
>> + BUILD_BUG_ON(!XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE);
>> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE, LOG_UNIT));
>> + BUILD_BUG_ON(!XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE);
>> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE, LOG_UNIT));
>> + BUILD_BUG_ON(!XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE);
>> + BUILD_BUG_ON(!IS_ALIGNED(XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE, CAPTURE_UNIT));
>>
>> flags = GUC_LOG_VALID |
>> GUC_LOG_NOTIFY_ON_HALF_FULL |
>> CAPTURE_FLAG |
>> LOG_FLAG |
>> - FIELD_PREP(GUC_LOG_CRASH, CRASH_BUFFER_SIZE / LOG_UNIT - 1) |
>> - FIELD_PREP(GUC_LOG_DEBUG, DEBUG_BUFFER_SIZE / LOG_UNIT - 1) |
>> - FIELD_PREP(GUC_LOG_CAPTURE, CAPTURE_BUFFER_SIZE / CAPTURE_UNIT - 1) |
>> + FIELD_PREP(GUC_LOG_CRASH_DUMP, XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE / LOG_UNIT - 1) |
>> + FIELD_PREP(GUC_LOG_EVENT_DATA, XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE / LOG_UNIT - 1) |
>> + FIELD_PREP(GUC_LOG_STATE_CAPTURE, XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE /
>> + CAPTURE_UNIT - 1) |
>> FIELD_PREP(GUC_LOG_BUF_ADDR, offset);
>>
>> #undef LOG_UNIT
>> diff --git a/drivers/gpu/drm/xe/xe_guc_capture.c b/drivers/gpu/drm/xe/xe_guc_capture.c
>> index 0c1fbe97b8bf..4e2c5a51adc8 100644
>> --- a/drivers/gpu/drm/xe/xe_guc_capture.c
>> +++ b/drivers/gpu/drm/xe/xe_guc_capture.c
>> @@ -843,7 +843,7 @@ static void check_guc_capture_size(struct xe_guc *guc)
>> {
>> int capture_size = guc_capture_output_size_est(guc);
>> int spare_size = capture_size * GUC_CAPTURE_OVERBUFFER_MULTIPLIER;
>> - u32 buffer_size = xe_guc_log_section_size_capture(&guc->log);
>> + u32 buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
>>
>> /*
>> * NOTE: capture_size is much smaller than the capture region
>> @@ -949,7 +949,7 @@ guc_capture_init_node(struct xe_guc *guc, struct __guc_capture_parsed_output *no
>> * ADS module also calls separately for PF vs VF.
>> *
>> * --> alloc B: GuC output capture buf (registered via guc_init_params(log_param))
>> - * Size = #define CAPTURE_BUFFER_SIZE (warns if on too-small)
>> + * Size = #define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE (warns if on too-small)
>
> do we need this "#define" ? maybe just:
>
> * Size = &XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE (warns if on too-small)
Sure #define to be removed>
>> * Note2: 'x 3' to hold multiple capture groups
>> *
>> * GUC Runtime notify capture:
>> @@ -1367,7 +1367,7 @@ static int __guc_capture_flushlog_complete(struct xe_guc *guc)
>> {
>> u32 action[] = {
>> XE_GUC_ACTION_LOG_BUFFER_FILE_FLUSH_COMPLETE,
>> - GUC_LOG_BUFFER_CAPTURE
>> + GUC_LOG_BUFFER_STATE_CAPTURE
>> };
>>
>> return xe_guc_ct_send_g2h_handler(&guc->ct, action, ARRAY_SIZE(action));
>> @@ -1384,8 +1384,8 @@ static void __guc_capture_process_output(struct xe_guc *guc)
>> u32 log_buf_state_offset;
>> u32 src_data_offset;
>>
>> - log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_CAPTURE;
>> - src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_CAPTURE);
>> + log_buf_state_offset = sizeof(struct guc_log_buffer_state) * GUC_LOG_BUFFER_STATE_CAPTURE;
>> + src_data_offset = xe_guc_get_log_buffer_offset(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE);
>>
>> /*
>> * Make a copy of the state structure, inside GuC log buffer
>> @@ -1395,15 +1395,15 @@ static void __guc_capture_process_output(struct xe_guc *guc)
>> xe_map_memcpy_from(guc_to_xe(guc), &log_buf_state_local, &guc->log.bo->vmap,
>> log_buf_state_offset, sizeof(struct guc_log_buffer_state));
>>
>> - buffer_size = xe_guc_get_log_buffer_size(&guc->log, GUC_LOG_BUFFER_CAPTURE);
>> + buffer_size = XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE;
>> read_offset = log_buf_state_local.read_ptr;
>> write_offset = log_buf_state_local.sampled_write_ptr;
>> full_count = FIELD_GET(GUC_LOG_BUFFER_STATE_BUFFER_FULL_CNT, log_buf_state_local.flags);
>>
>> /* Bookkeeping stuff */
>> tmp = FIELD_GET(GUC_LOG_BUFFER_STATE_FLUSH_TO_FILE, log_buf_state_local.flags);
>> - guc->log.stats[GUC_LOG_BUFFER_CAPTURE].flush += tmp;
>> - new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_CAPTURE,
>> + guc->log.stats[GUC_LOG_BUFFER_STATE_CAPTURE].flush += tmp;
>> + new_overflow = xe_guc_check_log_buf_overflow(&guc->log, GUC_LOG_BUFFER_STATE_CAPTURE,
>> full_count);
>>
>> /* Now copy the actual logs. */
>> diff --git a/drivers/gpu/drm/xe/xe_guc_fwif.h b/drivers/gpu/drm/xe/xe_guc_fwif.h
>> index 50c4c2406132..8b5c58b1857c 100644
>> --- a/drivers/gpu/drm/xe/xe_guc_fwif.h
>> +++ b/drivers/gpu/drm/xe/xe_guc_fwif.h
>> @@ -91,9 +91,9 @@ struct guc_update_exec_queue_policy {
>> #define GUC_LOG_NOTIFY_ON_HALF_FULL BIT(1)
>> #define GUC_LOG_CAPTURE_ALLOC_UNITS BIT(2)
>> #define GUC_LOG_LOG_ALLOC_UNITS BIT(3)
>> -#define GUC_LOG_CRASH REG_GENMASK(5, 4)
>> -#define GUC_LOG_DEBUG REG_GENMASK(9, 6)
>> -#define GUC_LOG_CAPTURE REG_GENMASK(11, 10)
>> +#define GUC_LOG_CRASH_DUMP REG_GENMASK(5, 4)
>> +#define GUC_LOG_EVENT_DATA REG_GENMASK(9, 6)
>> +#define GUC_LOG_STATE_CAPTURE REG_GENMASK(11, 10)
>> #define GUC_LOG_BUF_ADDR REG_GENMASK(31, 12)
>>
>> #define GUC_CTL_WA 1
>> diff --git a/drivers/gpu/drm/xe/xe_guc_log.c b/drivers/gpu/drm/xe/xe_guc_log.c
>> index c01ccb35dc75..995148e3f103 100644
>> --- a/drivers/gpu/drm/xe/xe_guc_log.c
>> +++ b/drivers/gpu/drm/xe/xe_guc_log.c
>> @@ -19,6 +19,45 @@
>> #include "xe_mmio.h"
>> #include "xe_module.h"
>>
>> +/**
>> + * DOC: GuC Log buffer Layout
>> + *
>> + * The in-memory log buffer layout is as follows:
>
> ... as follows::
>
> and empty line here
will follow>
>> + * +===============================+ 0000h
>> + * | Crash dump state header | ^
>> + * +-------------------------------+ 32B |
>> + * | Debug state header | |
>> + * +-------------------------------+ 64B 4KB
>> + * | Capture state header | |
>> + * +-------------------------------+ 96B |
>> + * | | v
>> + * +===============================+ <--- EVENT_DATA offset
>> + * | Event logs(raw data) | ^
>> + * | | |
>> + * | | EVENT_DATA_BUFFER_SIZE
>> + * | | |
>> + * | | v
>> + * +===============================+ <--- CRASH_DUMP offset
>> + * | Crash Dump(raw data) | ^
>> + * | | |
>> + * | | CRASH_DUMP_BUFFER_SIZE
>> + * | | |
>> + * | | v
>> + * +===============================+ <--- STATE_CAPTURE offset
>> + * | Error state capture(raw data) | ^
>> + * | | |
>> + * | | STATE_CAPTURE_BUFFER_SIZE
>> + * | | |
>> + * | | v
>> + * +===============================+ Total: GUC_LOG_SIZE
>> + */
>
> since above layout is fixed (up to actual data section size) this DOC could be placed in abi/log_abi.h
Yes, to be moved>
>> +#define GUC_LOG_SIZE (SZ_4K + \
>
> maybe this one should also be defined in .h where other _BUFFER_SIZEs are defined:
>
> #define XE_GUC_LOG_BUFFER_SIZE (SZ_4K + ...CAPTURE_BUFFER_SIZE)
Will do.>
> or make all names shorter by using only _SIZEs suffix:
>
> #define XE_GUC_LOG_SIZE (SZ_4K + ...CAPTURE_SIZE)
Refer to my comments below about shorter names.
>
>> + XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE + \
>> + XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE + \
>> + XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE)
>> +
>> +#define GUC_LOG_CHUNK_SIZE SZ_2M
>> +
>> static struct xe_guc *
>> log_to_guc(struct xe_guc_log *log)
>> {
>> @@ -37,33 +76,6 @@ log_to_xe(struct xe_guc_log *log)
>> return gt_to_xe(log_to_gt(log));
>> }
>>
>> -static size_t guc_log_size(void)
>> -{
>> - /*
>> - * GuC Log buffer Layout
>> - *
>> - * +===============================+ 00B
>> - * | Crash dump state header |
>> - * +-------------------------------+ 32B
>> - * | Debug state header |
>> - * +-------------------------------+ 64B
>> - * | Capture state header |
>> - * +-------------------------------+ 96B
>> - * | |
>> - * +===============================+ PAGE_SIZE (4KB)
>> - * | Crash Dump logs |
>> - * +===============================+ + CRASH_SIZE
>> - * | Debug logs |
>> - * +===============================+ + DEBUG_SIZE
>> - * | Capture logs |
>> - * +===============================+ + CAPTURE_SIZE
>> - */
>> - return PAGE_SIZE + CRASH_BUFFER_SIZE + DEBUG_BUFFER_SIZE +
>> - CAPTURE_BUFFER_SIZE;
>> -}
>> -
>> -#define GUC_LOG_CHUNK_SIZE SZ_2M
>> -
>> static struct xe_guc_log_snapshot *xe_guc_log_snapshot_alloc(struct xe_guc_log *log, bool atomic)
>> {
>> struct xe_guc_log_snapshot *snapshot;
>> @@ -257,7 +269,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
>> struct xe_tile *tile = gt_to_tile(log_to_gt(log));
>> struct xe_bo *bo;
>>
>> - bo = xe_managed_bo_create_pin_map(xe, tile, guc_log_size(),
>> + bo = xe_managed_bo_create_pin_map(xe, tile, GUC_LOG_SIZE,
>> XE_BO_FLAG_SYSTEM |
>> XE_BO_FLAG_GGTT |
>> XE_BO_FLAG_GGTT_INVALIDATE |
>> @@ -265,7 +277,7 @@ int xe_guc_log_init(struct xe_guc_log *log)
>> if (IS_ERR(bo))
>> return PTR_ERR(bo);
>>
>> - xe_map_memset(xe, &bo->vmap, 0, 0, guc_log_size());
>> + xe_map_memset(xe, &bo->vmap, 0, 0, GUC_LOG_SIZE);
>
> use xe_bo_size(bo) instead
Good idea.>
>> log->bo = bo;
>> log->level = xe_modparam.guc_log_level;
>>
>> @@ -274,49 +286,6 @@ int xe_guc_log_init(struct xe_guc_log *log)
>>
>> ALLOW_ERROR_INJECTION(xe_guc_log_init, ERRNO); /* See xe_pci_probe() */
>>
>> -static u32 xe_guc_log_section_size_crash(struct xe_guc_log *log)
>> -{
>> - return CRASH_BUFFER_SIZE;
>> -}
>> -
>> -static u32 xe_guc_log_section_size_debug(struct xe_guc_log *log)
>> -{
>> - return DEBUG_BUFFER_SIZE;
>> -}
>> -
>> -/**
>> - * xe_guc_log_section_size_capture - Get capture buffer size within log sections.
>> - * @log: The log object.
>> - *
>> - * This function will return the capture buffer size within log sections.
>> - *
>> - * Return: capture buffer size.
>> - */
>> -u32 xe_guc_log_section_size_capture(struct xe_guc_log *log)
>> -{
>> - return CAPTURE_BUFFER_SIZE;
>> -}
>> -
>> -/**
>> - * xe_guc_get_log_buffer_size - Get log buffer size for a type.
>> - * @log: The log object.
>> - * @type: The log buffer type
>> - *
>> - * Return: buffer size.
>> - */
>> -u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type)
>> -{
>> - switch (type) {
>> - case GUC_LOG_BUFFER_CRASH_DUMP:
>> - return xe_guc_log_section_size_crash(log);
>> - case GUC_LOG_BUFFER_DEBUG:
>> - return xe_guc_log_section_size_debug(log);
>> - case GUC_LOG_BUFFER_CAPTURE:
>> - return xe_guc_log_section_size_capture(log);
>> - }
>> - return 0;
>> -}
>> -
>> /**
>> * xe_guc_get_log_buffer_offset - Get offset in log buffer for a type.
>> * @log: The log object.
>> @@ -327,13 +296,17 @@ u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type
>> */
>> u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type)
>> {
>> - enum guc_log_buffer_type i;
>> - u32 offset = PAGE_SIZE;/* for the log_buffer_states */
>> + u32 offset = SZ_4K;/* for the log_buffer_states */
>>
>> - for (i = GUC_LOG_BUFFER_CRASH_DUMP; i < GUC_LOG_BUFFER_TYPE_MAX; ++i) {
>> - if (i == type)
>> - break;
>> - offset += xe_guc_get_log_buffer_size(log, i);
>> + switch (type) {
>> + case GUC_LOG_BUFFER_STATE_CAPTURE:
>> + offset += XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE;
>> + fallthrough;
>> + case GUC_LOG_BUFFER_CRASH_DUMP:
>> + offset += XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE;
>> + fallthrough;
>> + case GUC_LOG_BUFFER_EVENT_DATA:
>> + break;
>> }
>>
>> return offset;
>> diff --git a/drivers/gpu/drm/xe/xe_guc_log.h b/drivers/gpu/drm/xe/xe_guc_log.h
>> index 98a47ac42b08..a3620462f44c 100644
>> --- a/drivers/gpu/drm/xe/xe_guc_log.h
>> +++ b/drivers/gpu/drm/xe/xe_guc_log.h
>> @@ -13,13 +13,13 @@ struct drm_printer;
>> struct xe_device;
>>
>> #if IS_ENABLED(CONFIG_DRM_XE_DEBUG_GUC)
>> -#define CRASH_BUFFER_SIZE SZ_1M
>> -#define DEBUG_BUFFER_SIZE SZ_8M
>> -#define CAPTURE_BUFFER_SIZE SZ_2M
>> +#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_8M
>> +#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_1M
>> +#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_2M
>> #else
>> -#define CRASH_BUFFER_SIZE SZ_16K
>> -#define DEBUG_BUFFER_SIZE SZ_64K
>> -#define CAPTURE_BUFFER_SIZE SZ_1M
>> +#define XE_GUC_LOG_EVENT_DATA_BUFFER_SIZE SZ_64K
>> +#define XE_GUC_LOG_CRASH_DUMP_BUFFER_SIZE SZ_16K
>> +#define XE_GUC_LOG_STATE_CAPTURE_BUFFER_SIZE SZ_1M
>
> what about using shorter names:
>
> #define XE_GUC_LOG_EVENT_DATA_SIZE SZ_64K
> #define XE_GUC_LOG_CRASH_DUMP_SIZE SZ_16K
> #define XE_GUC_LOG_STATE_CAPTURE_SIZE SZ_1M
With BUFFER_SIZE, it is clear is the size of buffer, not data size.
Without BUFFER_SIZE, XE_GUC_LOG_EVENT_DATA_SIZE might mislead meaning to
data size.
>
>> #endif
>
> then we can also provide here:
>
> #define XE_GUC_LOG_EVENT_DATA_OFFSET SZ_4K /* btw, this fixed 4K header size should be part ABI def */
> #define XE_GUC_LOG_CRASH_DUMP_OFFSET (XE_GUC_LOG_EVENT_DATA_OFFSET + XE_GUC_LOG_EVENT_DATA_SIZE)
> #define XE_GUC_LOG_STATE_CAPTURE_OFFSET (XE_GUC_LOG_CRASH_DUMP_OFFSET + XE_GUC_LOG_CRASH_DUMP_SIZE)
Good idea>
>
>> /*
>> * While we're using plain log level in i915, GuC controls are much more...
>> @@ -51,8 +51,6 @@ xe_guc_log_get_level(struct xe_guc_log *log)
>> return log->level;
>> }
>>
>> -u32 xe_guc_log_section_size_capture(struct xe_guc_log *log);
>> -u32 xe_guc_get_log_buffer_size(struct xe_guc_log *log, enum guc_log_buffer_type type);
>> u32 xe_guc_get_log_buffer_offset(struct xe_guc_log *log, enum guc_log_buffer_type type);
>
> then we can kill this function, as there is only one user which can use XE_GUC_LOG_STATE_CAPTURE_OFFSET directly
Good idea >
>> bool xe_guc_check_log_buf_overflow(struct xe_guc_log *log,
>> enum guc_log_buffer_type type,
>
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2025-10-28 0:19 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-10-23 17:58 [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Zhanjun Dong
2025-10-23 20:39 ` ✓ CI.KUnit: success for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
2025-10-23 21:26 ` ✓ Xe.CI.BAT: " Patchwork
2025-10-23 23:04 ` [PATCH v6] drm/xe/guc: Cleanup GuC log buffer macros and helpers Michal Wajdeczko
2025-10-28 0:19 ` Dong, Zhanjun
2025-10-24 10:52 ` ✗ Xe.CI.Full: failure for drm/xe/guc: Cleanup GuC log buffer macros and helpers (rev3) Patchwork
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox