* ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
@ 2026-06-25 5:28 ` Patchwork
2026-06-25 6:03 ` ✗ Xe.CI.BAT: failure " Patchwork
` (3 subsequent siblings)
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-06-25 5:28 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
URL : https://patchwork.freedesktop.org/series/169129/
State : success
== Summary ==
+ trap cleanup EXIT
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/xe/.kunitconfig
[05:27:26] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:27:30] 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
[05:28:02] Starting KUnit Kernel (1/1)...
[05:28:02] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:28:02] ================== guc_buf (11 subtests) ===================
[05:28:02] [PASSED] test_smallest
[05:28:02] [PASSED] test_largest
[05:28:02] [PASSED] test_granular
[05:28:02] [PASSED] test_unique
[05:28:02] [PASSED] test_overlap
[05:28:02] [PASSED] test_reusable
[05:28:02] [PASSED] test_too_big
[05:28:02] [PASSED] test_flush
[05:28:02] [PASSED] test_lookup
[05:28:02] [PASSED] test_data
[05:28:02] [PASSED] test_class
[05:28:02] ===================== [PASSED] guc_buf =====================
[05:28:02] =================== guc_dbm (7 subtests) ===================
[05:28:02] [PASSED] test_empty
[05:28:02] [PASSED] test_default
[05:28:02] ======================== test_size ========================
[05:28:02] [PASSED] 4
[05:28:02] [PASSED] 8
[05:28:02] [PASSED] 32
[05:28:02] [PASSED] 256
[05:28:02] ==================== [PASSED] test_size ====================
[05:28:02] ======================= test_reuse ========================
[05:28:02] [PASSED] 4
[05:28:02] [PASSED] 8
[05:28:02] [PASSED] 32
[05:28:02] [PASSED] 256
[05:28:02] =================== [PASSED] test_reuse ====================
[05:28:02] =================== test_range_overlap ====================
[05:28:02] [PASSED] 4
[05:28:02] [PASSED] 8
[05:28:02] [PASSED] 32
[05:28:02] [PASSED] 256
[05:28:02] =============== [PASSED] test_range_overlap ================
[05:28:02] =================== test_range_compact ====================
[05:28:02] [PASSED] 4
[05:28:02] [PASSED] 8
[05:28:02] [PASSED] 32
[05:28:02] [PASSED] 256
[05:28:02] =============== [PASSED] test_range_compact ================
[05:28:02] ==================== test_range_spare =====================
[05:28:02] [PASSED] 4
[05:28:02] [PASSED] 8
[05:28:02] [PASSED] 32
[05:28:02] [PASSED] 256
[05:28:02] ================ [PASSED] test_range_spare =================
[05:28:02] ===================== [PASSED] guc_dbm =====================
[05:28:02] =================== guc_idm (6 subtests) ===================
[05:28:02] [PASSED] bad_init
[05:28:02] [PASSED] no_init
[05:28:02] [PASSED] init_fini
[05:28:02] [PASSED] check_used
[05:28:02] [PASSED] check_quota
[05:28:02] [PASSED] check_all
[05:28:02] ===================== [PASSED] guc_idm =====================
[05:28:02] ================== no_relay (3 subtests) ===================
[05:28:02] [PASSED] xe_drops_guc2pf_if_not_ready
[05:28:02] [PASSED] xe_drops_guc2vf_if_not_ready
[05:28:02] [PASSED] xe_rejects_send_if_not_ready
[05:28:02] ==================== [PASSED] no_relay =====================
[05:28:02] ================== pf_relay (14 subtests) ==================
[05:28:02] [PASSED] pf_rejects_guc2pf_too_short
[05:28:02] [PASSED] pf_rejects_guc2pf_too_long
[05:28:02] [PASSED] pf_rejects_guc2pf_no_payload
[05:28:02] [PASSED] pf_fails_no_payload
[05:28:02] [PASSED] pf_fails_bad_origin
[05:28:02] [PASSED] pf_fails_bad_type
[05:28:02] [PASSED] pf_txn_reports_error
[05:28:02] [PASSED] pf_txn_sends_pf2guc
[05:28:02] [PASSED] pf_sends_pf2guc
[05:28:02] [SKIPPED] pf_loopback_nop
[05:28:02] [SKIPPED] pf_loopback_echo
[05:28:02] [SKIPPED] pf_loopback_fail
[05:28:02] [SKIPPED] pf_loopback_busy
[05:28:02] [SKIPPED] pf_loopback_retry
[05:28:02] ==================== [PASSED] pf_relay =====================
[05:28:02] ================== vf_relay (3 subtests) ===================
[05:28:02] [PASSED] vf_rejects_guc2vf_too_short
[05:28:02] [PASSED] vf_rejects_guc2vf_too_long
[05:28:02] [PASSED] vf_rejects_guc2vf_no_payload
[05:28:02] ==================== [PASSED] vf_relay =====================
[05:28:02] ================ pf_gt_config (9 subtests) =================
[05:28:02] [PASSED] fair_contexts_1vf
[05:28:02] [PASSED] fair_doorbells_1vf
[05:28:02] [PASSED] fair_ggtt_1vf
[05:28:02] ====================== fair_vram_1vf ======================
[05:28:02] [PASSED] 3.50 GiB
[05:28:02] [PASSED] 11.5 GiB
[05:28:02] [PASSED] 15.5 GiB
[05:28:02] [PASSED] 31.5 GiB
[05:28:02] [PASSED] 63.5 GiB
[05:28:02] [PASSED] 1.91 GiB
[05:28:02] ================== [PASSED] fair_vram_1vf ==================
[05:28:02] ================ fair_vram_1vf_admin_only =================
[05:28:02] [PASSED] 3.50 GiB
[05:28:02] [PASSED] 11.5 GiB
[05:28:02] [PASSED] 15.5 GiB
[05:28:02] [PASSED] 31.5 GiB
[05:28:02] [PASSED] 63.5 GiB
[05:28:02] [PASSED] 1.91 GiB
[05:28:02] ============ [PASSED] fair_vram_1vf_admin_only =============
[05:28:02] ====================== fair_contexts ======================
[05:28:02] [PASSED] 1 VF
[05:28:02] [PASSED] 2 VFs
[05:28:02] [PASSED] 3 VFs
[05:28:02] [PASSED] 4 VFs
[05:28:02] [PASSED] 5 VFs
[05:28:02] [PASSED] 6 VFs
[05:28:02] [PASSED] 7 VFs
[05:28:02] [PASSED] 8 VFs
[05:28:02] [PASSED] 9 VFs
[05:28:02] [PASSED] 10 VFs
[05:28:02] [PASSED] 11 VFs
[05:28:02] [PASSED] 12 VFs
[05:28:02] [PASSED] 13 VFs
[05:28:02] [PASSED] 14 VFs
[05:28:02] [PASSED] 15 VFs
[05:28:02] [PASSED] 16 VFs
[05:28:02] [PASSED] 17 VFs
[05:28:02] [PASSED] 18 VFs
[05:28:02] [PASSED] 19 VFs
[05:28:02] [PASSED] 20 VFs
[05:28:02] [PASSED] 21 VFs
[05:28:02] [PASSED] 22 VFs
[05:28:02] [PASSED] 23 VFs
[05:28:02] [PASSED] 24 VFs
[05:28:02] [PASSED] 25 VFs
[05:28:02] [PASSED] 26 VFs
[05:28:02] [PASSED] 27 VFs
[05:28:02] [PASSED] 28 VFs
[05:28:02] [PASSED] 29 VFs
[05:28:02] [PASSED] 30 VFs
[05:28:02] [PASSED] 31 VFs
[05:28:02] [PASSED] 32 VFs
[05:28:02] [PASSED] 33 VFs
[05:28:02] [PASSED] 34 VFs
[05:28:02] [PASSED] 35 VFs
[05:28:02] [PASSED] 36 VFs
[05:28:02] [PASSED] 37 VFs
[05:28:02] [PASSED] 38 VFs
[05:28:02] [PASSED] 39 VFs
[05:28:02] [PASSED] 40 VFs
[05:28:02] [PASSED] 41 VFs
[05:28:02] [PASSED] 42 VFs
[05:28:02] [PASSED] 43 VFs
[05:28:02] [PASSED] 44 VFs
[05:28:02] [PASSED] 45 VFs
[05:28:02] [PASSED] 46 VFs
[05:28:02] [PASSED] 47 VFs
[05:28:02] [PASSED] 48 VFs
[05:28:02] [PASSED] 49 VFs
[05:28:02] [PASSED] 50 VFs
[05:28:02] [PASSED] 51 VFs
[05:28:02] [PASSED] 52 VFs
[05:28:02] [PASSED] 53 VFs
[05:28:02] [PASSED] 54 VFs
[05:28:02] [PASSED] 55 VFs
[05:28:02] [PASSED] 56 VFs
[05:28:02] [PASSED] 57 VFs
[05:28:02] [PASSED] 58 VFs
[05:28:02] [PASSED] 59 VFs
[05:28:02] [PASSED] 60 VFs
[05:28:02] [PASSED] 61 VFs
[05:28:02] [PASSED] 62 VFs
[05:28:02] [PASSED] 63 VFs
[05:28:02] ================== [PASSED] fair_contexts ==================
[05:28:02] ===================== fair_doorbells ======================
[05:28:02] [PASSED] 1 VF
[05:28:02] [PASSED] 2 VFs
[05:28:02] [PASSED] 3 VFs
[05:28:02] [PASSED] 4 VFs
[05:28:02] [PASSED] 5 VFs
[05:28:02] [PASSED] 6 VFs
[05:28:02] [PASSED] 7 VFs
[05:28:02] [PASSED] 8 VFs
[05:28:02] [PASSED] 9 VFs
[05:28:02] [PASSED] 10 VFs
[05:28:02] [PASSED] 11 VFs
[05:28:02] [PASSED] 12 VFs
[05:28:02] [PASSED] 13 VFs
[05:28:02] [PASSED] 14 VFs
[05:28:02] [PASSED] 15 VFs
[05:28:02] [PASSED] 16 VFs
[05:28:02] [PASSED] 17 VFs
[05:28:02] [PASSED] 18 VFs
[05:28:02] [PASSED] 19 VFs
[05:28:02] [PASSED] 20 VFs
[05:28:02] [PASSED] 21 VFs
[05:28:02] [PASSED] 22 VFs
[05:28:02] [PASSED] 23 VFs
[05:28:02] [PASSED] 24 VFs
[05:28:02] [PASSED] 25 VFs
[05:28:02] [PASSED] 26 VFs
[05:28:02] [PASSED] 27 VFs
[05:28:02] [PASSED] 28 VFs
[05:28:02] [PASSED] 29 VFs
[05:28:02] [PASSED] 30 VFs
[05:28:02] [PASSED] 31 VFs
[05:28:02] [PASSED] 32 VFs
[05:28:02] [PASSED] 33 VFs
[05:28:02] [PASSED] 34 VFs
[05:28:02] [PASSED] 35 VFs
[05:28:02] [PASSED] 36 VFs
[05:28:02] [PASSED] 37 VFs
[05:28:02] [PASSED] 38 VFs
[05:28:02] [PASSED] 39 VFs
[05:28:02] [PASSED] 40 VFs
[05:28:02] [PASSED] 41 VFs
[05:28:02] [PASSED] 42 VFs
[05:28:02] [PASSED] 43 VFs
[05:28:02] [PASSED] 44 VFs
[05:28:02] [PASSED] 45 VFs
[05:28:02] [PASSED] 46 VFs
[05:28:02] [PASSED] 47 VFs
[05:28:02] [PASSED] 48 VFs
[05:28:02] [PASSED] 49 VFs
[05:28:02] [PASSED] 50 VFs
[05:28:02] [PASSED] 51 VFs
[05:28:02] [PASSED] 52 VFs
[05:28:02] [PASSED] 53 VFs
[05:28:02] [PASSED] 54 VFs
[05:28:02] [PASSED] 55 VFs
[05:28:02] [PASSED] 56 VFs
[05:28:02] [PASSED] 57 VFs
[05:28:02] [PASSED] 58 VFs
[05:28:02] [PASSED] 59 VFs
[05:28:02] [PASSED] 60 VFs
[05:28:02] [PASSED] 61 VFs
[05:28:02] [PASSED] 62 VFs
[05:28:02] [PASSED] 63 VFs
[05:28:02] ================= [PASSED] fair_doorbells ==================
[05:28:02] ======================== fair_ggtt ========================
[05:28:02] [PASSED] 1 VF
[05:28:02] [PASSED] 2 VFs
[05:28:02] [PASSED] 3 VFs
[05:28:02] [PASSED] 4 VFs
[05:28:02] [PASSED] 5 VFs
[05:28:02] [PASSED] 6 VFs
[05:28:02] [PASSED] 7 VFs
[05:28:02] [PASSED] 8 VFs
[05:28:02] [PASSED] 9 VFs
[05:28:02] [PASSED] 10 VFs
[05:28:02] [PASSED] 11 VFs
[05:28:02] [PASSED] 12 VFs
[05:28:02] [PASSED] 13 VFs
[05:28:02] [PASSED] 14 VFs
[05:28:02] [PASSED] 15 VFs
[05:28:02] [PASSED] 16 VFs
[05:28:02] [PASSED] 17 VFs
[05:28:02] [PASSED] 18 VFs
[05:28:02] [PASSED] 19 VFs
[05:28:02] [PASSED] 20 VFs
[05:28:02] [PASSED] 21 VFs
[05:28:02] [PASSED] 22 VFs
[05:28:02] [PASSED] 23 VFs
[05:28:02] [PASSED] 24 VFs
[05:28:02] [PASSED] 25 VFs
[05:28:02] [PASSED] 26 VFs
[05:28:02] [PASSED] 27 VFs
[05:28:02] [PASSED] 28 VFs
[05:28:02] [PASSED] 29 VFs
[05:28:02] [PASSED] 30 VFs
[05:28:02] [PASSED] 31 VFs
[05:28:02] [PASSED] 32 VFs
[05:28:02] [PASSED] 33 VFs
[05:28:02] [PASSED] 34 VFs
[05:28:02] [PASSED] 35 VFs
[05:28:02] [PASSED] 36 VFs
[05:28:02] [PASSED] 37 VFs
[05:28:02] [PASSED] 38 VFs
[05:28:02] [PASSED] 39 VFs
[05:28:02] [PASSED] 40 VFs
[05:28:02] [PASSED] 41 VFs
[05:28:02] [PASSED] 42 VFs
[05:28:02] [PASSED] 43 VFs
[05:28:02] [PASSED] 44 VFs
[05:28:02] [PASSED] 45 VFs
[05:28:02] [PASSED] 46 VFs
[05:28:02] [PASSED] 47 VFs
[05:28:02] [PASSED] 48 VFs
[05:28:02] [PASSED] 49 VFs
[05:28:02] [PASSED] 50 VFs
[05:28:02] [PASSED] 51 VFs
[05:28:02] [PASSED] 52 VFs
[05:28:02] [PASSED] 53 VFs
[05:28:02] [PASSED] 54 VFs
[05:28:02] [PASSED] 55 VFs
[05:28:02] [PASSED] 56 VFs
[05:28:02] [PASSED] 57 VFs
[05:28:02] [PASSED] 58 VFs
[05:28:02] [PASSED] 59 VFs
[05:28:02] [PASSED] 60 VFs
[05:28:02] [PASSED] 61 VFs
[05:28:02] [PASSED] 62 VFs
[05:28:02] [PASSED] 63 VFs
[05:28:02] ==================== [PASSED] fair_ggtt ====================
[05:28:02] ======================== fair_vram ========================
[05:28:02] [PASSED] 1 VF
[05:28:02] [PASSED] 2 VFs
[05:28:02] [PASSED] 3 VFs
[05:28:02] [PASSED] 4 VFs
[05:28:02] [PASSED] 5 VFs
[05:28:02] [PASSED] 6 VFs
[05:28:02] [PASSED] 7 VFs
[05:28:02] [PASSED] 8 VFs
[05:28:02] [PASSED] 9 VFs
[05:28:02] [PASSED] 10 VFs
[05:28:02] [PASSED] 11 VFs
[05:28:02] [PASSED] 12 VFs
[05:28:02] [PASSED] 13 VFs
[05:28:02] [PASSED] 14 VFs
[05:28:02] [PASSED] 15 VFs
[05:28:02] [PASSED] 16 VFs
[05:28:02] [PASSED] 17 VFs
[05:28:02] [PASSED] 18 VFs
[05:28:02] [PASSED] 19 VFs
[05:28:02] [PASSED] 20 VFs
[05:28:02] [PASSED] 21 VFs
[05:28:02] [PASSED] 22 VFs
[05:28:02] [PASSED] 23 VFs
[05:28:02] [PASSED] 24 VFs
[05:28:02] [PASSED] 25 VFs
[05:28:02] [PASSED] 26 VFs
[05:28:02] [PASSED] 27 VFs
[05:28:02] [PASSED] 28 VFs
[05:28:02] [PASSED] 29 VFs
[05:28:02] [PASSED] 30 VFs
[05:28:02] [PASSED] 31 VFs
[05:28:02] [PASSED] 32 VFs
[05:28:02] [PASSED] 33 VFs
[05:28:02] [PASSED] 34 VFs
[05:28:02] [PASSED] 35 VFs
[05:28:02] [PASSED] 36 VFs
[05:28:02] [PASSED] 37 VFs
[05:28:02] [PASSED] 38 VFs
[05:28:02] [PASSED] 39 VFs
[05:28:02] [PASSED] 40 VFs
[05:28:02] [PASSED] 41 VFs
[05:28:02] [PASSED] 42 VFs
[05:28:02] [PASSED] 43 VFs
[05:28:02] [PASSED] 44 VFs
[05:28:02] [PASSED] 45 VFs
[05:28:02] [PASSED] 46 VFs
[05:28:02] [PASSED] 47 VFs
[05:28:02] [PASSED] 48 VFs
[05:28:02] [PASSED] 49 VFs
[05:28:02] [PASSED] 50 VFs
[05:28:02] [PASSED] 51 VFs
[05:28:02] [PASSED] 52 VFs
[05:28:02] [PASSED] 53 VFs
[05:28:02] [PASSED] 54 VFs
[05:28:02] [PASSED] 55 VFs
[05:28:02] [PASSED] 56 VFs
[05:28:02] [PASSED] 57 VFs
[05:28:02] [PASSED] 58 VFs
[05:28:02] [PASSED] 59 VFs
[05:28:02] [PASSED] 60 VFs
[05:28:02] [PASSED] 61 VFs
[05:28:02] [PASSED] 62 VFs
[05:28:02] [PASSED] 63 VFs
[05:28:02] ==================== [PASSED] fair_vram ====================
[05:28:02] ================== [PASSED] pf_gt_config ===================
[05:28:02] ===================== lmtt (1 subtest) =====================
[05:28:02] ======================== test_ops =========================
[05:28:02] [PASSED] 2-level
[05:28:02] [PASSED] multi-level
[05:28:02] ==================== [PASSED] test_ops =====================
[05:28:02] ====================== [PASSED] lmtt =======================
[05:28:02] ================= pf_service (11 subtests) =================
[05:28:02] [PASSED] pf_negotiate_any
[05:28:02] [PASSED] pf_negotiate_base_match
[05:28:02] [PASSED] pf_negotiate_base_newer
[05:28:02] [PASSED] pf_negotiate_base_next
[05:28:02] [SKIPPED] pf_negotiate_base_older
[05:28:02] [PASSED] pf_negotiate_base_prev
[05:28:02] [PASSED] pf_negotiate_latest_match
[05:28:02] [PASSED] pf_negotiate_latest_newer
[05:28:02] [PASSED] pf_negotiate_latest_next
[05:28:02] [SKIPPED] pf_negotiate_latest_older
[05:28:02] [SKIPPED] pf_negotiate_latest_prev
[05:28:02] =================== [PASSED] pf_service ====================
[05:28:02] ================= xe_guc_g2g (2 subtests) ==================
[05:28:02] ============== xe_live_guc_g2g_kunit_default ==============
[05:28:02] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[05:28:02] ============== xe_live_guc_g2g_kunit_allmem ===============
[05:28:02] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[05:28:02] =================== [SKIPPED] xe_guc_g2g ===================
[05:28:02] =================== xe_mocs (2 subtests) ===================
[05:28:02] ================ xe_live_mocs_kernel_kunit ================
[05:28:02] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[05:28:02] ================ xe_live_mocs_reset_kunit =================
[05:28:02] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[05:28:02] ==================== [SKIPPED] xe_mocs =====================
[05:28:02] ================= xe_migrate (2 subtests) ==================
[05:28:02] ================= xe_migrate_sanity_kunit =================
[05:28:02] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[05:28:02] ================== xe_validate_ccs_kunit ==================
[05:28:02] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[05:28:02] =================== [SKIPPED] xe_migrate ===================
[05:28:02] ================== xe_dma_buf (1 subtest) ==================
[05:28:02] ==================== xe_dma_buf_kunit =====================
[05:28:02] ================ [SKIPPED] xe_dma_buf_kunit ================
[05:28:02] =================== [SKIPPED] xe_dma_buf ===================
[05:28:02] ================= xe_bo_shrink (1 subtest) =================
[05:28:02] =================== xe_bo_shrink_kunit ====================
[05:28:02] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[05:28:02] ================== [SKIPPED] xe_bo_shrink ==================
[05:28:02] ==================== xe_bo (2 subtests) ====================
[05:28:02] ================== xe_ccs_migrate_kunit ===================
[05:28:02] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[05:28:02] ==================== xe_bo_evict_kunit ====================
[05:28:02] =============== [SKIPPED] xe_bo_evict_kunit ================
[05:28:02] ===================== [SKIPPED] xe_bo ======================
[05:28:02] ==================== args (13 subtests) ====================
[05:28:02] [PASSED] count_args_test
[05:28:02] [PASSED] call_args_example
[05:28:02] [PASSED] call_args_test
[05:28:02] [PASSED] drop_first_arg_example
[05:28:02] [PASSED] drop_first_arg_test
[05:28:02] [PASSED] first_arg_example
[05:28:02] [PASSED] first_arg_test
[05:28:02] [PASSED] last_arg_example
[05:28:02] [PASSED] last_arg_test
[05:28:02] [PASSED] pick_arg_example
[05:28:02] [PASSED] if_args_example
[05:28:02] [PASSED] if_args_test
[05:28:02] [PASSED] sep_comma_example
[05:28:02] ====================== [PASSED] args =======================
[05:28:02] =================== xe_pci (3 subtests) ====================
[05:28:02] ==================== check_graphics_ip ====================
[05:28:02] [PASSED] 12.00 Xe_LP
[05:28:02] [PASSED] 12.10 Xe_LP+
[05:28:02] [PASSED] 12.55 Xe_HPG
[05:28:02] [PASSED] 12.60 Xe_HPC
[05:28:02] [PASSED] 12.70 Xe_LPG
[05:28:02] [PASSED] 12.71 Xe_LPG
[05:28:02] [PASSED] 12.74 Xe_LPG+
[05:28:02] [PASSED] 20.01 Xe2_HPG
[05:28:02] [PASSED] 20.02 Xe2_HPG
[05:28:02] [PASSED] 20.04 Xe2_LPG
[05:28:02] [PASSED] 30.00 Xe3_LPG
[05:28:02] [PASSED] 30.01 Xe3_LPG
[05:28:02] [PASSED] 30.03 Xe3_LPG
[05:28:02] [PASSED] 30.04 Xe3_LPG
[05:28:02] [PASSED] 30.05 Xe3_LPG
[05:28:02] [PASSED] 35.10 Xe3p_LPG
[05:28:02] [PASSED] 35.11 Xe3p_XPC
[05:28:02] ================ [PASSED] check_graphics_ip ================
[05:28:02] ===================== check_media_ip ======================
[05:28:02] [PASSED] 12.00 Xe_M
[05:28:02] [PASSED] 12.55 Xe_HPM
[05:28:02] [PASSED] 13.00 Xe_LPM+
[05:28:02] [PASSED] 13.01 Xe2_HPM
[05:28:02] [PASSED] 20.00 Xe2_LPM
[05:28:02] [PASSED] 30.00 Xe3_LPM
[05:28:02] [PASSED] 30.02 Xe3_LPM
[05:28:02] [PASSED] 35.00 Xe3p_LPM
[05:28:02] [PASSED] 35.03 Xe3p_HPM
[05:28:02] ================= [PASSED] check_media_ip ==================
[05:28:02] =================== check_platform_desc ===================
[05:28:02] [PASSED] 0x9A60 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A68 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A70 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A40 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A49 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A59 (TIGERLAKE)
[05:28:02] [PASSED] 0x9A78 (TIGERLAKE)
[05:28:02] [PASSED] 0x9AC0 (TIGERLAKE)
[05:28:02] [PASSED] 0x9AC9 (TIGERLAKE)
[05:28:02] [PASSED] 0x9AD9 (TIGERLAKE)
[05:28:02] [PASSED] 0x9AF8 (TIGERLAKE)
[05:28:02] [PASSED] 0x4C80 (ROCKETLAKE)
[05:28:02] [PASSED] 0x4C8A (ROCKETLAKE)
[05:28:02] [PASSED] 0x4C8B (ROCKETLAKE)
[05:28:02] [PASSED] 0x4C8C (ROCKETLAKE)
[05:28:02] [PASSED] 0x4C90 (ROCKETLAKE)
[05:28:02] [PASSED] 0x4C9A (ROCKETLAKE)
[05:28:02] [PASSED] 0x4680 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4682 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4688 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x468A (ALDERLAKE_S)
[05:28:02] [PASSED] 0x468B (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4690 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4692 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4693 (ALDERLAKE_S)
[05:28:02] [PASSED] 0x46A0 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46A1 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46A2 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46A3 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46A6 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46A8 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46AA (ALDERLAKE_P)
[05:28:02] [PASSED] 0x462A (ALDERLAKE_P)
[05:28:02] [PASSED] 0x4626 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x4628 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46B0 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46B1 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46B2 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46B3 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46C0 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46C1 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46C2 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46C3 (ALDERLAKE_P)
[05:28:02] [PASSED] 0x46D0 (ALDERLAKE_N)
[05:28:02] [PASSED] 0x46D1 (ALDERLAKE_N)
[05:28:02] [PASSED] 0x46D2 (ALDERLAKE_N)
[05:28:02] [PASSED] 0x46D3 (ALDERLAKE_N)
[05:28:02] [PASSED] 0x46D4 (ALDERLAKE_N)
[05:28:02] [PASSED] 0xA721 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7A1 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7A9 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7AC (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7AD (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA720 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7A0 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7A8 (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7AA (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA7AB (ALDERLAKE_P)
[05:28:02] [PASSED] 0xA780 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA781 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA782 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA783 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA788 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA789 (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA78A (ALDERLAKE_S)
[05:28:02] [PASSED] 0xA78B (ALDERLAKE_S)
[05:28:02] [PASSED] 0x4905 (DG1)
[05:28:02] [PASSED] 0x4906 (DG1)
[05:28:02] [PASSED] 0x4907 (DG1)
[05:28:02] [PASSED] 0x4908 (DG1)
[05:28:02] [PASSED] 0x4909 (DG1)
[05:28:02] [PASSED] 0x56C0 (DG2)
[05:28:02] [PASSED] 0x56C2 (DG2)
[05:28:02] [PASSED] 0x56C1 (DG2)
[05:28:02] [PASSED] 0x7D51 (METEORLAKE)
[05:28:02] [PASSED] 0x7DD1 (METEORLAKE)
[05:28:02] [PASSED] 0x7D41 (METEORLAKE)
[05:28:02] [PASSED] 0x7D67 (METEORLAKE)
[05:28:02] [PASSED] 0xB640 (METEORLAKE)
[05:28:02] [PASSED] 0x56A0 (DG2)
[05:28:02] [PASSED] 0x56A1 (DG2)
[05:28:02] [PASSED] 0x56A2 (DG2)
[05:28:02] [PASSED] 0x56BE (DG2)
[05:28:02] [PASSED] 0x56BF (DG2)
[05:28:02] [PASSED] 0x5690 (DG2)
[05:28:02] [PASSED] 0x5691 (DG2)
[05:28:02] [PASSED] 0x5692 (DG2)
[05:28:02] [PASSED] 0x56A5 (DG2)
[05:28:02] [PASSED] 0x56A6 (DG2)
[05:28:02] [PASSED] 0x56B0 (DG2)
[05:28:02] [PASSED] 0x56B1 (DG2)
[05:28:02] [PASSED] 0x56BA (DG2)
[05:28:02] [PASSED] 0x56BB (DG2)
[05:28:02] [PASSED] 0x56BC (DG2)
[05:28:02] [PASSED] 0x56BD (DG2)
[05:28:02] [PASSED] 0x5693 (DG2)
[05:28:02] [PASSED] 0x5694 (DG2)
[05:28:02] [PASSED] 0x5695 (DG2)
[05:28:02] [PASSED] 0x56A3 (DG2)
[05:28:02] [PASSED] 0x56A4 (DG2)
[05:28:02] [PASSED] 0x56B2 (DG2)
[05:28:02] [PASSED] 0x56B3 (DG2)
[05:28:02] [PASSED] 0x5696 (DG2)
[05:28:02] [PASSED] 0x5697 (DG2)
[05:28:02] [PASSED] 0xB69 (PVC)
[05:28:02] [PASSED] 0xB6E (PVC)
[05:28:02] [PASSED] 0xBD4 (PVC)
[05:28:02] [PASSED] 0xBD5 (PVC)
[05:28:02] [PASSED] 0xBD6 (PVC)
[05:28:02] [PASSED] 0xBD7 (PVC)
[05:28:02] [PASSED] 0xBD8 (PVC)
[05:28:02] [PASSED] 0xBD9 (PVC)
[05:28:02] [PASSED] 0xBDA (PVC)
[05:28:02] [PASSED] 0xBDB (PVC)
[05:28:02] [PASSED] 0xBE0 (PVC)
[05:28:02] [PASSED] 0xBE1 (PVC)
[05:28:02] [PASSED] 0xBE5 (PVC)
[05:28:02] [PASSED] 0x7D40 (METEORLAKE)
[05:28:02] [PASSED] 0x7D45 (METEORLAKE)
[05:28:02] [PASSED] 0x7D55 (METEORLAKE)
[05:28:02] [PASSED] 0x7D60 (METEORLAKE)
[05:28:02] [PASSED] 0x7DD5 (METEORLAKE)
[05:28:02] [PASSED] 0x6420 (LUNARLAKE)
[05:28:02] [PASSED] 0x64A0 (LUNARLAKE)
[05:28:02] [PASSED] 0x64B0 (LUNARLAKE)
[05:28:02] [PASSED] 0xE202 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE209 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE20B (BATTLEMAGE)
[05:28:02] [PASSED] 0xE20C (BATTLEMAGE)
[05:28:02] [PASSED] 0xE20D (BATTLEMAGE)
[05:28:02] [PASSED] 0xE210 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE211 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE212 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE216 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE220 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE221 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE222 (BATTLEMAGE)
[05:28:02] [PASSED] 0xE223 (BATTLEMAGE)
[05:28:02] [PASSED] 0xB080 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB081 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB082 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB083 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB084 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB085 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB086 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB087 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB08F (PANTHERLAKE)
[05:28:02] [PASSED] 0xB090 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB0A0 (PANTHERLAKE)
[05:28:02] [PASSED] 0xB0B0 (PANTHERLAKE)
[05:28:02] [PASSED] 0xFD80 (PANTHERLAKE)
[05:28:02] [PASSED] 0xFD81 (PANTHERLAKE)
[05:28:02] [PASSED] 0xD740 (NOVALAKE_S)
[05:28:02] [PASSED] 0xD741 (NOVALAKE_S)
[05:28:02] [PASSED] 0xD742 (NOVALAKE_S)
[05:28:02] [PASSED] 0xD743 (NOVALAKE_S)
[05:28:02] [PASSED] 0xD745 (NOVALAKE_S)
[05:28:02] [PASSED] 0xD74A (NOVALAKE_S)
[05:28:02] [PASSED] 0xD74B (NOVALAKE_S)
[05:28:02] [PASSED] 0x674C (CRESCENTISLAND)
[05:28:02] [PASSED] 0x674D (CRESCENTISLAND)
[05:28:02] [PASSED] 0x674E (CRESCENTISLAND)
[05:28:02] [PASSED] 0x674F (CRESCENTISLAND)
[05:28:02] [PASSED] 0x6750 (CRESCENTISLAND)
[05:28:02] [PASSED] 0xD750 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD751 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD752 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD753 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD754 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD755 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD756 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD757 (NOVALAKE_P)
[05:28:02] [PASSED] 0xD75F (NOVALAKE_P)
[05:28:02] =============== [PASSED] check_platform_desc ===============
[05:28:02] ===================== [PASSED] xe_pci ======================
[05:28:02] ============= xe_rtp_tables_test (4 subtests) ==============
[05:28:02] ================== xe_rtp_table_gt_test ===================
[05:28:02] [PASSED] gt_was/14011060649
[05:28:02] [PASSED] gt_was/14011059788
[05:28:02] [PASSED] gt_was/14015795083
[05:28:02] [PASSED] gt_was/16021867713
[05:28:02] [PASSED] gt_was/14019449301
[05:28:02] [PASSED] gt_was/16028005424
[05:28:02] [PASSED] gt_was/14026578760
[05:28:02] [PASSED] gt_was/1409420604
[05:28:02] [PASSED] gt_was/1408615072
[05:28:02] [PASSED] gt_was/22010523718
[05:28:02] [PASSED] gt_was/14011006942
[05:28:02] [PASSED] gt_was/14014830051
[05:28:02] [PASSED] gt_was/18018781329
[05:28:02] [PASSED] gt_was/1509235366
[05:28:02] [PASSED] gt_was/18018781329
[05:28:02] [PASSED] gt_was/16016694945
[05:28:02] [PASSED] gt_was/14018575942
[05:28:02] [PASSED] gt_was/22016670082
[05:28:02] [PASSED] gt_was/22016670082
[05:28:02] [PASSED] gt_was/14017421178
[05:28:02] [PASSED] gt_was/16025250150
[05:28:02] [PASSED] gt_was/14021871409
[05:28:02] [PASSED] gt_was/16021865536
[05:28:02] [PASSED] gt_was/14021486841
[05:28:02] [PASSED] gt_was/14025160223
[05:28:02] [PASSED] gt_was/14026144927, 16029437861, 14026127056
[05:28:02] [PASSED] gt_was/14025635424
[05:28:02] [PASSED] gt_was/16028005424
[05:28:02] ============== [PASSED] xe_rtp_table_gt_test ===============
[05:28:02] ================== xe_rtp_table_gt_test ===================
[05:28:02] [PASSED] gt_tunings/Tuning: Blend Fill Caching Optimization Disable
[05:28:02] [PASSED] gt_tunings/Tuning: 32B Access Enable
[05:28:02] [PASSED] gt_tunings/Tuning: L3 cache
[05:28:02] [PASSED] gt_tunings/Tuning: L3 cache - media
[05:28:02] [PASSED] gt_tunings/Tuning: Compression Overfetch
[05:28:02] [PASSED] gt_tunings/Tuning: Compression Overfetch - media
[05:28:02] [PASSED] gt_tunings/Tuning: Enable compressible partial write overfetch in L3
[05:28:02] [PASSED] gt_tunings/Tuning: Enable compressible partial write overfetch in L3 - media
[05:28:02] [PASSED] gt_tunings/Tuning: L2 Overfetch Compressible Only
[05:28:02] [PASSED] gt_tunings/Tuning: L2 Overfetch Compressible Only - media
[05:28:02] [PASSED] gt_tunings/Tuning: Stateless compression control
[05:28:02] [PASSED] gt_tunings/Tuning: Stateless compression control - media
[05:28:02] [PASSED] gt_tunings/Tuning: L3 RW flush all Cache
[05:28:02] [PASSED] gt_tunings/Tuning: L3 RW flush all cache - media
[05:28:02] [PASSED] gt_tunings/Tuning: Set STLB Bank Hash Mode to 4KB
[05:28:02] ============== [PASSED] xe_rtp_table_gt_test ===============
[05:28:02] ================== xe_rtp_table_oob_test ==================
[05:28:02] [PASSED] oob_was/1607983814
[05:28:02] [PASSED] oob_was/16010904313
[05:28:02] [PASSED] oob_was/18022495364
[05:28:02] [PASSED] oob_was/22012773006
[05:28:02] [PASSED] oob_was/14014475959
[05:28:02] [PASSED] oob_was/22011391025
[05:28:02] [PASSED] oob_was/22012727170
[05:28:02] [PASSED] oob_was/22012727685
[05:28:02] [PASSED] oob_was/22016596838
[05:28:02] [PASSED] oob_was/18020744125
[05:28:02] [PASSED] oob_was/1409600907
[05:28:02] [PASSED] oob_was/22014953428
[05:28:02] [PASSED] oob_was/16017236439
[05:28:02] [PASSED] oob_was/14019821291
[05:28:02] [PASSED] oob_was/14015076503
[05:28:02] [PASSED] oob_was/14018913170
[05:28:02] [PASSED] oob_was/14018094691
[05:28:02] [PASSED] oob_was/18024947630
[05:28:02] [PASSED] oob_was/16022287689
[05:28:02] [PASSED] oob_was/13011645652
[05:28:02] [PASSED] oob_was/14022293748
[05:28:02] [PASSED] oob_was/22019794406
[05:28:02] [PASSED] oob_was/22019338487
[05:28:02] [PASSED] oob_was/16023588340
[05:28:02] [PASSED] oob_was/14019789679
[05:28:02] [PASSED] oob_was/14022866841
[05:28:02] [PASSED] oob_was/16021333562
[05:28:02] [PASSED] oob_was/14016712196
[05:28:02] [PASSED] oob_was/14015568240
[05:28:02] [PASSED] oob_was/18013179988
[05:28:02] [PASSED] oob_was/1508761755
[05:28:02] [PASSED] oob_was/16023105232
[05:28:02] [PASSED] oob_was/16026508708
[05:28:02] [PASSED] oob_was/14020001231
[05:28:02] [PASSED] oob_was/16023683509
[05:28:02] [PASSED] oob_was/14025515070
[05:28:02] [PASSED] oob_was/15015404425_disable
[05:28:02] [PASSED] oob_was/16026007364
[05:28:02] [PASSED] oob_was/14020316580
[05:28:02] [PASSED] oob_was/14025883347
[05:28:02] [PASSED] oob_was/16029380221
[05:28:02] ============== [PASSED] xe_rtp_table_oob_test ==============
[05:28:02] ================ xe_rtp_table_dev_oob_test ================
[05:28:02] [PASSED] device_oob_was/22010954014
[05:28:02] [PASSED] device_oob_was/15015404425
[05:28:02] [PASSED] device_oob_was/22019338487_display
[05:28:02] [PASSED] device_oob_was/14022085890
[05:28:02] [PASSED] device_oob_was/14026539277
[05:28:02] [PASSED] device_oob_was/14026633728
[05:28:02] [PASSED] device_oob_was/14026746987
[05:28:02] [PASSED] device_oob_was/14026779378
[05:28:02] ============ [PASSED] xe_rtp_table_dev_oob_test ============
[05:28:02] =============== [PASSED] xe_rtp_tables_test ================
[05:28:02] =================== xe_rtp (3 subtests) ====================
[05:28:02] =================== xe_rtp_rules_tests ====================
[05:28:02] [PASSED] no
[05:28:02] [PASSED] yes
[05:28:02] [PASSED] no-and-no
[05:28:02] [PASSED] no-and-yes
[05:28:02] [PASSED] yes-and-no
[05:28:02] [PASSED] yes-and-yes
[05:28:02] [PASSED] no-or-no
[05:28:02] [PASSED] no-or-yes
[05:28:02] [PASSED] yes-or-no
[05:28:02] [PASSED] yes-or-yes
[05:28:02] [PASSED] no-yes-or-yes-no
[05:28:02] [PASSED] no-yes-or-yes-yes
[05:28:02] [PASSED] yes-yes-or-no-yes
[05:28:02] [PASSED] yes-yes-or-yes-yes
[05:28:02] [PASSED] no-no-or-yes-or-no
[05:28:02] [PASSED] or
[05:28:02] [PASSED] or-yes
[05:28:02] [PASSED] or-no
[05:28:02] [PASSED] yes-or
[05:28:02] [PASSED] no-or
[05:28:02] [PASSED] no-or-or-yes
[05:28:02] [PASSED] yes-or-or-no
[05:28:02] [PASSED] no-or-or-no
[05:28:02] [PASSED] missing-context-engine-class
[05:28:02] [PASSED] missing-context-engine-class-or-yes
[05:28:02] [PASSED] missing-context-engine-class-or-or-yes
[05:28:02] =============== [PASSED] xe_rtp_rules_tests ================
[05:28:02] =============== xe_rtp_process_to_sr_tests ================
[05:28:02] [PASSED] coalesce-same-reg
[05:28:02] [PASSED] coalesce-same-reg-literal-and-func
[05:28:02] [PASSED] no-match-no-add
[05:28:02] [PASSED] two-regs-two-entries
[05:28:02] [PASSED] clr-one-set-other
[05:28:02] [PASSED] set-field
[05:28:02] [PASSED] conflict-duplicate
[05:28:02] [PASSED] conflict-not-disjoint
[05:28:02] [PASSED] conflict-not-disjoint-literal-and-func
[05:28:02] [PASSED] conflict-reg-type
[05:28:02] [PASSED] bad-mcr-reg-forced-to-regular
[05:28:02] [PASSED] bad-regular-reg-forced-to-mcr
[05:28:02] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[05:28:02] ================== xe_rtp_process_tests ===================
[05:28:02] [PASSED] active1
[05:28:02] [PASSED] active2
[05:28:02] [PASSED] active-inactive
[05:28:02] [PASSED] inactive-active
[05:28:02] [PASSED] inactive-active-inactive
[05:28:02] [PASSED] inactive-inactive-inactive
[05:28:02] ============== [PASSED] xe_rtp_process_tests ===============
[05:28:02] ===================== [PASSED] xe_rtp ======================
[05:28:02] ==================== xe_wa (1 subtest) =====================
[05:28:02] ======================== xe_wa_gt =========================
[05:28:02] [PASSED] TIGERLAKE B0
[05:28:02] [PASSED] DG1 A0
[05:28:02] [PASSED] DG1 B0
[05:28:02] [PASSED] ALDERLAKE_S A0
[05:28:02] [PASSED] ALDERLAKE_S B0
[05:28:02] [PASSED] ALDERLAKE_S C0
[05:28:02] [PASSED] ALDERLAKE_S D0
[05:28:02] [PASSED] ALDERLAKE_P A0
[05:28:02] [PASSED] ALDERLAKE_P B0
[05:28:02] [PASSED] ALDERLAKE_P C0
[05:28:02] [PASSED] ALDERLAKE_S RPLS D0
[05:28:02] [PASSED] ALDERLAKE_P RPLU E0
[05:28:02] [PASSED] DG2 G10 C0
[05:28:02] [PASSED] DG2 G11 B1
[05:28:02] [PASSED] DG2 G12 A1
[05:28:02] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[05:28:02] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[05:28:02] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[05:28:02] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[05:28:02] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[05:28:02] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[05:28:02] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[05:28:02] ==================== [PASSED] xe_wa_gt =====================
[05:28:02] ====================== [PASSED] xe_wa ======================
[05:28:02] ============================================================
[05:28:02] Testing complete. Ran 719 tests: passed: 701, skipped: 18
[05:28:02] Elapsed time: 36.525s total, 4.309s configuring, 31.550s building, 0.653s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[05:28:02] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:28:04] 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
[05:28:28] Starting KUnit Kernel (1/1)...
[05:28:28] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:28:28] ============ drm_test_pick_cmdline (2 subtests) ============
[05:28:28] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[05:28:28] =============== drm_test_pick_cmdline_named ===============
[05:28:28] [PASSED] NTSC
[05:28:28] [PASSED] NTSC-J
[05:28:28] [PASSED] PAL
[05:28:28] [PASSED] PAL-M
[05:28:28] =========== [PASSED] drm_test_pick_cmdline_named ===========
[05:28:28] ============== [PASSED] drm_test_pick_cmdline ==============
[05:28:28] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[05:28:28] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[05:28:28] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[05:28:28] =========== drm_validate_clone_mode (2 subtests) ===========
[05:28:28] ============== drm_test_check_in_clone_mode ===============
[05:28:28] [PASSED] in_clone_mode
[05:28:28] [PASSED] not_in_clone_mode
[05:28:28] ========== [PASSED] drm_test_check_in_clone_mode ===========
[05:28:28] =============== drm_test_check_valid_clones ===============
[05:28:28] [PASSED] not_in_clone_mode
[05:28:28] [PASSED] valid_clone
[05:28:28] [PASSED] invalid_clone
[05:28:28] =========== [PASSED] drm_test_check_valid_clones ===========
[05:28:28] ============= [PASSED] drm_validate_clone_mode =============
[05:28:28] ============= drm_validate_modeset (1 subtest) =============
[05:28:28] [PASSED] drm_test_check_connector_changed_modeset
[05:28:28] ============== [PASSED] drm_validate_modeset ===============
[05:28:28] ====== drm_test_bridge_get_current_state (2 subtests) ======
[05:28:28] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[05:28:28] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[05:28:28] ======== [PASSED] drm_test_bridge_get_current_state ========
[05:28:28] ====== drm_test_bridge_helper_reset_crtc (4 subtests) ======
[05:28:28] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[05:28:28] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[05:28:28] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[05:28:28] [PASSED] drm_test_drm_bridge_helper_hdmi_output_bus_fmts
[05:28:28] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[05:28:28] ============== drm_bridge_alloc (2 subtests) ===============
[05:28:28] [PASSED] drm_test_drm_bridge_alloc_basic
[05:28:28] [PASSED] drm_test_drm_bridge_alloc_get_put
[05:28:28] ================ [PASSED] drm_bridge_alloc =================
[05:28:28] ============= drm_bridge_bus_fmt (5 subtests) ==============
[05:28:28] [PASSED] drm_test_bridge_rgb_yuv_rgb
[05:28:28] [PASSED] drm_test_bridge_must_convert_to_yuv444
[05:28:28] [PASSED] drm_test_bridge_hdmi_auto_rgb
[05:28:28] [PASSED] drm_test_bridge_auto_first
[05:28:28] [PASSED] drm_test_bridge_rgb_yuv_no_path
[05:28:28] =============== [PASSED] drm_bridge_bus_fmt ================
[05:28:28] ============= drm_cmdline_parser (40 subtests) =============
[05:28:28] [PASSED] drm_test_cmdline_force_d_only
[05:28:28] [PASSED] drm_test_cmdline_force_D_only_dvi
[05:28:28] [PASSED] drm_test_cmdline_force_D_only_hdmi
[05:28:28] [PASSED] drm_test_cmdline_force_D_only_not_digital
[05:28:28] [PASSED] drm_test_cmdline_force_e_only
[05:28:28] [PASSED] drm_test_cmdline_res
[05:28:28] [PASSED] drm_test_cmdline_res_vesa
[05:28:28] [PASSED] drm_test_cmdline_res_vesa_rblank
[05:28:28] [PASSED] drm_test_cmdline_res_rblank
[05:28:28] [PASSED] drm_test_cmdline_res_bpp
[05:28:28] [PASSED] drm_test_cmdline_res_refresh
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[05:28:28] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[05:28:28] [PASSED] drm_test_cmdline_res_margins_force_on
[05:28:28] [PASSED] drm_test_cmdline_res_vesa_margins
[05:28:28] [PASSED] drm_test_cmdline_name
[05:28:28] [PASSED] drm_test_cmdline_name_bpp
[05:28:28] [PASSED] drm_test_cmdline_name_option
[05:28:28] [PASSED] drm_test_cmdline_name_bpp_option
[05:28:28] [PASSED] drm_test_cmdline_rotate_0
[05:28:28] [PASSED] drm_test_cmdline_rotate_90
[05:28:28] [PASSED] drm_test_cmdline_rotate_180
[05:28:28] [PASSED] drm_test_cmdline_rotate_270
[05:28:28] [PASSED] drm_test_cmdline_hmirror
[05:28:28] [PASSED] drm_test_cmdline_vmirror
[05:28:28] [PASSED] drm_test_cmdline_margin_options
[05:28:28] [PASSED] drm_test_cmdline_multiple_options
[05:28:28] [PASSED] drm_test_cmdline_bpp_extra_and_option
[05:28:28] [PASSED] drm_test_cmdline_extra_and_option
[05:28:28] [PASSED] drm_test_cmdline_freestanding_options
[05:28:28] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[05:28:28] [PASSED] drm_test_cmdline_panel_orientation
[05:28:28] ================ drm_test_cmdline_invalid =================
[05:28:28] [PASSED] margin_only
[05:28:28] [PASSED] interlace_only
[05:28:28] [PASSED] res_missing_x
[05:28:28] [PASSED] res_missing_y
[05:28:28] [PASSED] res_bad_y
[05:28:28] [PASSED] res_missing_y_bpp
[05:28:28] [PASSED] res_bad_bpp
[05:28:28] [PASSED] res_bad_refresh
[05:28:28] [PASSED] res_bpp_refresh_force_on_off
[05:28:28] [PASSED] res_invalid_mode
[05:28:28] [PASSED] res_bpp_wrong_place_mode
[05:28:28] [PASSED] name_bpp_refresh
[05:28:28] [PASSED] name_refresh
[05:28:28] [PASSED] name_refresh_wrong_mode
[05:28:28] [PASSED] name_refresh_invalid_mode
[05:28:28] [PASSED] rotate_multiple
[05:28:28] [PASSED] rotate_invalid_val
[05:28:28] [PASSED] rotate_truncated
[05:28:28] [PASSED] invalid_option
[05:28:28] [PASSED] invalid_tv_option
[05:28:28] [PASSED] truncated_tv_option
[05:28:28] ============ [PASSED] drm_test_cmdline_invalid =============
[05:28:28] =============== drm_test_cmdline_tv_options ===============
[05:28:28] [PASSED] NTSC
[05:28:28] [PASSED] NTSC_443
[05:28:28] [PASSED] NTSC_J
[05:28:28] [PASSED] PAL
[05:28:28] [PASSED] PAL_M
[05:28:28] [PASSED] PAL_N
[05:28:28] [PASSED] SECAM
[05:28:28] [PASSED] MONO_525
[05:28:28] [PASSED] MONO_625
[05:28:28] =========== [PASSED] drm_test_cmdline_tv_options ===========
[05:28:28] =============== [PASSED] drm_cmdline_parser ================
[05:28:28] ========== drmm_connector_hdmi_init (20 subtests) ==========
[05:28:28] [PASSED] drm_test_connector_hdmi_init_valid
[05:28:28] [PASSED] drm_test_connector_hdmi_init_bpc_8
[05:28:28] [PASSED] drm_test_connector_hdmi_init_bpc_10
[05:28:28] [PASSED] drm_test_connector_hdmi_init_bpc_12
[05:28:28] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[05:28:28] [PASSED] drm_test_connector_hdmi_init_bpc_null
[05:28:28] [PASSED] drm_test_connector_hdmi_init_formats_empty
[05:28:28] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[05:28:28] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[05:28:28] [PASSED] supported_formats=0x9 yuv420_allowed=1
[05:28:28] [PASSED] supported_formats=0x9 yuv420_allowed=0
[05:28:28] [PASSED] supported_formats=0x5 yuv420_allowed=1
[05:28:28] [PASSED] supported_formats=0x5 yuv420_allowed=0
[05:28:28] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[05:28:28] [PASSED] drm_test_connector_hdmi_init_null_ddc
[05:28:28] [PASSED] drm_test_connector_hdmi_init_null_product
[05:28:28] [PASSED] drm_test_connector_hdmi_init_null_vendor
[05:28:28] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[05:28:28] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[05:28:28] [PASSED] drm_test_connector_hdmi_init_product_valid
[05:28:28] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[05:28:28] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[05:28:28] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[05:28:28] ========= drm_test_connector_hdmi_init_type_valid =========
[05:28:28] [PASSED] HDMI-A
[05:28:28] [PASSED] HDMI-B
[05:28:28] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[05:28:28] ======== drm_test_connector_hdmi_init_type_invalid ========
[05:28:28] [PASSED] Unknown
[05:28:28] [PASSED] VGA
[05:28:28] [PASSED] DVI-I
[05:28:28] [PASSED] DVI-D
[05:28:28] [PASSED] DVI-A
[05:28:28] [PASSED] Composite
[05:28:28] [PASSED] SVIDEO
[05:28:28] [PASSED] LVDS
[05:28:28] [PASSED] Component
[05:28:28] [PASSED] DIN
[05:28:28] [PASSED] DP
[05:28:28] [PASSED] TV
[05:28:28] [PASSED] eDP
[05:28:28] [PASSED] Virtual
[05:28:28] [PASSED] DSI
[05:28:28] [PASSED] DPI
[05:28:28] [PASSED] Writeback
[05:28:28] [PASSED] SPI
[05:28:28] [PASSED] USB
[05:28:28] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[05:28:28] ============ [PASSED] drmm_connector_hdmi_init =============
[05:28:28] ============= drmm_connector_init (3 subtests) =============
[05:28:28] [PASSED] drm_test_drmm_connector_init
[05:28:28] [PASSED] drm_test_drmm_connector_init_null_ddc
[05:28:28] ========= drm_test_drmm_connector_init_type_valid =========
[05:28:28] [PASSED] Unknown
[05:28:28] [PASSED] VGA
[05:28:28] [PASSED] DVI-I
[05:28:28] [PASSED] DVI-D
[05:28:28] [PASSED] DVI-A
[05:28:28] [PASSED] Composite
[05:28:28] [PASSED] SVIDEO
[05:28:28] [PASSED] LVDS
[05:28:28] [PASSED] Component
[05:28:28] [PASSED] DIN
[05:28:28] [PASSED] DP
[05:28:28] [PASSED] HDMI-A
[05:28:28] [PASSED] HDMI-B
[05:28:28] [PASSED] TV
[05:28:28] [PASSED] eDP
[05:28:28] [PASSED] Virtual
[05:28:28] [PASSED] DSI
[05:28:28] [PASSED] DPI
[05:28:28] [PASSED] Writeback
[05:28:28] [PASSED] SPI
[05:28:28] [PASSED] USB
[05:28:28] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[05:28:28] =============== [PASSED] drmm_connector_init ===============
[05:28:28] ========= drm_connector_dynamic_init (6 subtests) ==========
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_init
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_init_properties
[05:28:28] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[05:28:28] [PASSED] Unknown
[05:28:28] [PASSED] VGA
[05:28:28] [PASSED] DVI-I
[05:28:28] [PASSED] DVI-D
[05:28:28] [PASSED] DVI-A
[05:28:28] [PASSED] Composite
[05:28:28] [PASSED] SVIDEO
[05:28:28] [PASSED] LVDS
[05:28:28] [PASSED] Component
[05:28:28] [PASSED] DIN
[05:28:28] [PASSED] DP
[05:28:28] [PASSED] HDMI-A
[05:28:28] [PASSED] HDMI-B
[05:28:28] [PASSED] TV
[05:28:28] [PASSED] eDP
[05:28:28] [PASSED] Virtual
[05:28:28] [PASSED] DSI
[05:28:28] [PASSED] DPI
[05:28:28] [PASSED] Writeback
[05:28:28] [PASSED] SPI
[05:28:28] [PASSED] USB
[05:28:28] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[05:28:28] ======== drm_test_drm_connector_dynamic_init_name =========
[05:28:28] [PASSED] Unknown
[05:28:28] [PASSED] VGA
[05:28:28] [PASSED] DVI-I
[05:28:28] [PASSED] DVI-D
[05:28:28] [PASSED] DVI-A
[05:28:28] [PASSED] Composite
[05:28:28] [PASSED] SVIDEO
[05:28:28] [PASSED] LVDS
[05:28:28] [PASSED] Component
[05:28:28] [PASSED] DIN
[05:28:28] [PASSED] DP
[05:28:28] [PASSED] HDMI-A
[05:28:28] [PASSED] HDMI-B
[05:28:28] [PASSED] TV
[05:28:28] [PASSED] eDP
[05:28:28] [PASSED] Virtual
[05:28:28] [PASSED] DSI
[05:28:28] [PASSED] DPI
[05:28:28] [PASSED] Writeback
[05:28:28] [PASSED] SPI
[05:28:28] [PASSED] USB
[05:28:28] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[05:28:28] =========== [PASSED] drm_connector_dynamic_init ============
[05:28:28] ==== drm_connector_dynamic_register_early (4 subtests) =====
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[05:28:28] ====== [PASSED] drm_connector_dynamic_register_early =======
[05:28:28] ======= drm_connector_dynamic_register (7 subtests) ========
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[05:28:28] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[05:28:28] ========= [PASSED] drm_connector_dynamic_register ==========
[05:28:28] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[05:28:28] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[05:28:28] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[05:28:28] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[05:28:28] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[05:28:28] ========== drm_test_get_tv_mode_from_name_valid ===========
[05:28:28] [PASSED] NTSC
[05:28:28] [PASSED] NTSC-443
[05:28:28] [PASSED] NTSC-J
[05:28:28] [PASSED] PAL
[05:28:28] [PASSED] PAL-M
[05:28:28] [PASSED] PAL-N
[05:28:28] [PASSED] SECAM
[05:28:28] [PASSED] Mono
[05:28:28] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[05:28:28] [PASSED] drm_test_get_tv_mode_from_name_truncated
[05:28:28] ============ [PASSED] drm_get_tv_mode_from_name ============
[05:28:28] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[05:28:28] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[05:28:28] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[05:28:28] [PASSED] VIC 96
[05:28:28] [PASSED] VIC 97
[05:28:28] [PASSED] VIC 101
[05:28:28] [PASSED] VIC 102
[05:28:28] [PASSED] VIC 106
[05:28:28] [PASSED] VIC 107
[05:28:28] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[05:28:28] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[05:28:28] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[05:28:28] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[05:28:28] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[05:28:28] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[05:28:28] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[05:28:28] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[05:28:28] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[05:28:28] [PASSED] Automatic
[05:28:28] [PASSED] Full
[05:28:28] [PASSED] Limited 16:235
[05:28:28] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[05:28:28] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[05:28:28] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[05:28:28] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[05:28:28] === drm_test_drm_hdmi_connector_get_output_format_name ====
[05:28:28] [PASSED] RGB
[05:28:28] [PASSED] YUV 4:2:0
[05:28:28] [PASSED] YUV 4:2:2
[05:28:28] [PASSED] YUV 4:4:4
[05:28:28] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[05:28:28] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[05:28:28] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[05:28:28] ============= drm_damage_helper (21 subtests) ==============
[05:28:28] [PASSED] drm_test_damage_iter_no_damage
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_src_moved
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_not_visible
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[05:28:28] [PASSED] drm_test_damage_iter_no_damage_no_fb
[05:28:28] [PASSED] drm_test_damage_iter_simple_damage
[05:28:28] [PASSED] drm_test_damage_iter_single_damage
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_outside_src
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_src_moved
[05:28:28] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[05:28:28] [PASSED] drm_test_damage_iter_damage
[05:28:28] [PASSED] drm_test_damage_iter_damage_one_intersect
[05:28:28] [PASSED] drm_test_damage_iter_damage_one_outside
[05:28:28] [PASSED] drm_test_damage_iter_damage_src_moved
[05:28:28] [PASSED] drm_test_damage_iter_damage_not_visible
[05:28:28] ================ [PASSED] drm_damage_helper ================
[05:28:28] ============== drm_dp_mst_helper (3 subtests) ==============
[05:28:28] ============== drm_test_dp_mst_calc_pbn_mode ==============
[05:28:28] [PASSED] Clock 154000 BPP 30 DSC disabled
[05:28:28] [PASSED] Clock 234000 BPP 30 DSC disabled
[05:28:28] [PASSED] Clock 297000 BPP 24 DSC disabled
[05:28:28] [PASSED] Clock 332880 BPP 24 DSC enabled
[05:28:28] [PASSED] Clock 324540 BPP 24 DSC enabled
[05:28:28] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[05:28:28] ============== drm_test_dp_mst_calc_pbn_div ===============
[05:28:28] [PASSED] Link rate 2000000 lane count 4
[05:28:28] [PASSED] Link rate 2000000 lane count 2
[05:28:28] [PASSED] Link rate 2000000 lane count 1
[05:28:28] [PASSED] Link rate 1350000 lane count 4
[05:28:28] [PASSED] Link rate 1350000 lane count 2
[05:28:28] [PASSED] Link rate 1350000 lane count 1
[05:28:28] [PASSED] Link rate 1000000 lane count 4
[05:28:28] [PASSED] Link rate 1000000 lane count 2
[05:28:28] [PASSED] Link rate 1000000 lane count 1
[05:28:28] [PASSED] Link rate 810000 lane count 4
[05:28:28] [PASSED] Link rate 810000 lane count 2
[05:28:28] [PASSED] Link rate 810000 lane count 1
[05:28:28] [PASSED] Link rate 540000 lane count 4
[05:28:28] [PASSED] Link rate 540000 lane count 2
[05:28:28] [PASSED] Link rate 540000 lane count 1
[05:28:28] [PASSED] Link rate 270000 lane count 4
[05:28:28] [PASSED] Link rate 270000 lane count 2
[05:28:28] [PASSED] Link rate 270000 lane count 1
[05:28:28] [PASSED] Link rate 162000 lane count 4
[05:28:28] [PASSED] Link rate 162000 lane count 2
[05:28:28] [PASSED] Link rate 162000 lane count 1
[05:28:28] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[05:28:28] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[05:28:28] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[05:28:28] [PASSED] DP_POWER_UP_PHY with port number
[05:28:28] [PASSED] DP_POWER_DOWN_PHY with port number
[05:28:28] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[05:28:28] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[05:28:28] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[05:28:28] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[05:28:28] [PASSED] DP_QUERY_PAYLOAD with port number
[05:28:28] [PASSED] DP_QUERY_PAYLOAD with VCPI
[05:28:28] [PASSED] DP_REMOTE_DPCD_READ with port number
[05:28:28] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[05:28:28] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[05:28:28] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[05:28:28] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[05:28:28] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[05:28:28] [PASSED] DP_REMOTE_I2C_READ with port number
[05:28:28] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[05:28:28] [PASSED] DP_REMOTE_I2C_READ with transactions array
[05:28:28] [PASSED] DP_REMOTE_I2C_WRITE with port number
[05:28:28] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[05:28:28] [PASSED] DP_REMOTE_I2C_WRITE with data array
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[05:28:28] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[05:28:28] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[05:28:28] ================ [PASSED] drm_dp_mst_helper ================
[05:28:28] ================== drm_exec (7 subtests) ===================
[05:28:28] [PASSED] sanitycheck
[05:28:28] [PASSED] test_lock
[05:28:28] [PASSED] test_lock_unlock
[05:28:28] [PASSED] test_duplicates
[05:28:28] [PASSED] test_prepare
[05:28:28] [PASSED] test_prepare_array
[05:28:28] [PASSED] test_multiple_loops
[05:28:28] ==================== [PASSED] drm_exec =====================
[05:28:28] =========== drm_format_helper_test (17 subtests) ===========
[05:28:28] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[05:28:28] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[05:28:28] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[05:28:28] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[05:28:28] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[05:28:28] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[05:28:28] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[05:28:28] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[05:28:28] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[05:28:28] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[05:28:28] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[05:28:28] ============== drm_test_fb_xrgb8888_to_mono ===============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[05:28:28] ==================== drm_test_fb_swab =====================
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ================ [PASSED] drm_test_fb_swab =================
[05:28:28] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[05:28:28] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[05:28:28] [PASSED] single_pixel_source_buffer
[05:28:28] [PASSED] single_pixel_clip_rectangle
[05:28:28] [PASSED] well_known_colors
[05:28:28] [PASSED] destination_pitch
[05:28:28] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[05:28:28] ================= drm_test_fb_clip_offset =================
[05:28:28] [PASSED] pass through
[05:28:28] [PASSED] horizontal offset
[05:28:28] [PASSED] vertical offset
[05:28:28] [PASSED] horizontal and vertical offset
[05:28:28] [PASSED] horizontal offset (custom pitch)
[05:28:28] [PASSED] vertical offset (custom pitch)
[05:28:28] [PASSED] horizontal and vertical offset (custom pitch)
[05:28:28] ============= [PASSED] drm_test_fb_clip_offset =============
[05:28:28] =================== drm_test_fb_memcpy ====================
[05:28:28] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[05:28:28] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[05:28:28] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[05:28:28] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[05:28:28] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[05:28:28] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[05:28:28] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[05:28:28] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[05:28:28] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[05:28:28] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[05:28:28] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[05:28:28] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[05:28:28] =============== [PASSED] drm_test_fb_memcpy ================
[05:28:28] ============= [PASSED] drm_format_helper_test ==============
[05:28:28] ================= drm_format (18 subtests) =================
[05:28:28] [PASSED] drm_test_format_block_width_invalid
[05:28:28] [PASSED] drm_test_format_block_width_one_plane
[05:28:28] [PASSED] drm_test_format_block_width_two_plane
[05:28:28] [PASSED] drm_test_format_block_width_three_plane
[05:28:28] [PASSED] drm_test_format_block_width_tiled
[05:28:28] [PASSED] drm_test_format_block_height_invalid
[05:28:28] [PASSED] drm_test_format_block_height_one_plane
[05:28:28] [PASSED] drm_test_format_block_height_two_plane
[05:28:28] [PASSED] drm_test_format_block_height_three_plane
[05:28:28] [PASSED] drm_test_format_block_height_tiled
[05:28:28] [PASSED] drm_test_format_min_pitch_invalid
[05:28:28] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[05:28:28] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[05:28:28] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[05:28:28] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[05:28:28] [PASSED] drm_test_format_min_pitch_two_plane
[05:28:28] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[05:28:28] [PASSED] drm_test_format_min_pitch_tiled
[05:28:28] =================== [PASSED] drm_format ====================
[05:28:28] ============== drm_framebuffer (10 subtests) ===============
[05:28:28] ========== drm_test_framebuffer_check_src_coords ==========
[05:28:28] [PASSED] Success: source fits into fb
[05:28:28] [PASSED] Fail: overflowing fb with x-axis coordinate
[05:28:28] [PASSED] Fail: overflowing fb with y-axis coordinate
[05:28:28] [PASSED] Fail: overflowing fb with source width
[05:28:28] [PASSED] Fail: overflowing fb with source height
[05:28:28] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[05:28:28] [PASSED] drm_test_framebuffer_cleanup
[05:28:28] =============== drm_test_framebuffer_create ===============
[05:28:28] [PASSED] ABGR8888 normal sizes
[05:28:28] [PASSED] ABGR8888 max sizes
[05:28:28] [PASSED] ABGR8888 pitch greater than min required
[05:28:28] [PASSED] ABGR8888 pitch less than min required
[05:28:28] [PASSED] ABGR8888 Invalid width
[05:28:28] [PASSED] ABGR8888 Invalid buffer handle
[05:28:28] [PASSED] No pixel format
[05:28:28] [PASSED] ABGR8888 Width 0
[05:28:28] [PASSED] ABGR8888 Height 0
[05:28:28] [PASSED] ABGR8888 Out of bound height * pitch combination
[05:28:28] [PASSED] ABGR8888 Large buffer offset
[05:28:28] [PASSED] ABGR8888 Buffer offset for inexistent plane
[05:28:28] [PASSED] ABGR8888 Invalid flag
[05:28:28] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[05:28:28] [PASSED] ABGR8888 Valid buffer modifier
[05:28:28] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[05:28:28] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] NV12 Normal sizes
[05:28:28] [PASSED] NV12 Max sizes
[05:28:28] [PASSED] NV12 Invalid pitch
[05:28:28] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[05:28:28] [PASSED] NV12 different modifier per-plane
[05:28:28] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[05:28:28] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] NV12 Modifier for inexistent plane
[05:28:28] [PASSED] NV12 Handle for inexistent plane
[05:28:28] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[05:28:28] [PASSED] YVU420 Normal sizes
[05:28:28] [PASSED] YVU420 Max sizes
[05:28:28] [PASSED] YVU420 Invalid pitch
[05:28:28] [PASSED] YVU420 Different pitches
[05:28:28] [PASSED] YVU420 Different buffer offsets/pitches
[05:28:28] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[05:28:28] [PASSED] YVU420 Valid modifier
[05:28:28] [PASSED] YVU420 Different modifiers per plane
[05:28:28] [PASSED] YVU420 Modifier for inexistent plane
[05:28:28] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[05:28:28] [PASSED] X0L2 Normal sizes
[05:28:28] [PASSED] X0L2 Max sizes
[05:28:28] [PASSED] X0L2 Invalid pitch
[05:28:28] [PASSED] X0L2 Pitch greater than minimum required
[05:28:28] [PASSED] X0L2 Handle for inexistent plane
[05:28:28] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[05:28:28] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[05:28:28] [PASSED] X0L2 Valid modifier
[05:28:28] [PASSED] X0L2 Modifier for inexistent plane
[05:28:28] =========== [PASSED] drm_test_framebuffer_create ===========
[05:28:28] [PASSED] drm_test_framebuffer_free
[05:28:28] [PASSED] drm_test_framebuffer_init
[05:28:28] [PASSED] drm_test_framebuffer_init_bad_format
[05:28:28] [PASSED] drm_test_framebuffer_init_dev_mismatch
[05:28:28] [PASSED] drm_test_framebuffer_lookup
[05:28:28] [PASSED] drm_test_framebuffer_lookup_inexistent
[05:28:28] [PASSED] drm_test_framebuffer_modifiers_not_supported
[05:28:28] ================= [PASSED] drm_framebuffer =================
[05:28:28] ================ drm_gem_shmem (8 subtests) ================
[05:28:28] [PASSED] drm_gem_shmem_test_obj_create
[05:28:28] [PASSED] drm_gem_shmem_test_obj_create_private
[05:28:28] [PASSED] drm_gem_shmem_test_pin_pages
[05:28:28] [PASSED] drm_gem_shmem_test_vmap
[05:28:28] [PASSED] drm_gem_shmem_test_get_sg_table
[05:28:28] [PASSED] drm_gem_shmem_test_get_pages_sgt
[05:28:28] [PASSED] drm_gem_shmem_test_madvise
[05:28:28] [PASSED] drm_gem_shmem_test_purge
[05:28:28] ================== [PASSED] drm_gem_shmem ==================
[05:28:28] === drm_atomic_helper_connector_hdmi_check (29 subtests) ===
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[05:28:28] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[05:28:28] [PASSED] Automatic
[05:28:28] [PASSED] Full
[05:28:28] [PASSED] Limited 16:235
[05:28:28] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[05:28:28] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[05:28:28] [PASSED] drm_test_check_disable_connector
[05:28:28] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[05:28:28] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[05:28:28] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[05:28:28] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[05:28:28] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[05:28:28] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[05:28:28] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[05:28:28] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[05:28:28] [PASSED] drm_test_check_output_bpc_dvi
[05:28:28] [PASSED] drm_test_check_output_bpc_format_vic_1
[05:28:28] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[05:28:28] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[05:28:28] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[05:28:28] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[05:28:28] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[05:28:28] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[05:28:28] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[05:28:28] ============ drm_test_check_hdmi_color_format =============
[05:28:28] [PASSED] AUTO -> RGB
[05:28:28] [PASSED] YCBCR422 -> YUV422
[05:28:28] [PASSED] YCBCR420 -> YUV420
[05:28:28] [PASSED] YCBCR444 -> YUV444
[05:28:28] [PASSED] RGB -> RGB
[05:28:28] ======== [PASSED] drm_test_check_hdmi_color_format =========
[05:28:29] ======== drm_test_check_hdmi_color_format_420_only ========
[05:28:29] [PASSED] RGB should fail
[05:28:29] [PASSED] YUV444 should fail
[05:28:29] [PASSED] YUV422 should fail
[05:28:29] [PASSED] YUV420 should work
[05:28:29] ==== [PASSED] drm_test_check_hdmi_color_format_420_only ====
[05:28:29] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[05:28:29] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[05:28:29] [PASSED] drm_test_check_broadcast_rgb_value
[05:28:29] [PASSED] drm_test_check_bpc_8_value
[05:28:29] [PASSED] drm_test_check_bpc_10_value
[05:28:29] [PASSED] drm_test_check_bpc_12_value
[05:28:29] [PASSED] drm_test_check_format_value
[05:28:29] [PASSED] drm_test_check_tmds_char_value
[05:28:29] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[05:28:29] = drm_atomic_helper_connector_hdmi_mode_valid (7 subtests) =
[05:28:29] [PASSED] drm_test_check_mode_valid
[05:28:29] [PASSED] drm_test_check_mode_valid_reject
[05:28:29] [PASSED] drm_test_check_mode_valid_reject_rate
[05:28:29] [PASSED] drm_test_check_mode_valid_reject_max_clock
[05:28:29] [PASSED] drm_test_check_mode_valid_yuv420_only_max_clock
[05:28:29] [PASSED] drm_test_check_mode_valid_reject_yuv420_only_connector
[05:28:29] [PASSED] drm_test_check_mode_valid_accept_yuv420_also_connector_rgb
[05:28:29] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[05:28:29] = drm_atomic_helper_connector_hdmi_infoframes (5 subtests) =
[05:28:29] [PASSED] drm_test_check_infoframes
[05:28:29] [PASSED] drm_test_check_reject_avi_infoframe
[05:28:29] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_8
[05:28:29] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_10
[05:28:29] [PASSED] drm_test_check_reject_audio_infoframe
[05:28:29] === [PASSED] drm_atomic_helper_connector_hdmi_infoframes ===
[05:28:29] ================= drm_managed (2 subtests) =================
[05:28:29] [PASSED] drm_test_managed_release_action
[05:28:29] [PASSED] drm_test_managed_run_action
[05:28:29] =================== [PASSED] drm_managed ===================
[05:28:29] =================== drm_mm (6 subtests) ====================
[05:28:29] [PASSED] drm_test_mm_init
[05:28:29] [PASSED] drm_test_mm_debug
[05:28:29] [PASSED] drm_test_mm_align32
[05:28:29] [PASSED] drm_test_mm_align64
[05:28:29] [PASSED] drm_test_mm_lowest
[05:28:29] [PASSED] drm_test_mm_highest
[05:28:29] ===================== [PASSED] drm_mm ======================
[05:28:29] ============= drm_modes_analog_tv (5 subtests) =============
[05:28:29] [PASSED] drm_test_modes_analog_tv_mono_576i
[05:28:29] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[05:28:29] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[05:28:29] [PASSED] drm_test_modes_analog_tv_pal_576i
[05:28:29] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[05:28:29] =============== [PASSED] drm_modes_analog_tv ===============
[05:28:29] ============== drm_plane_helper (2 subtests) ===============
[05:28:29] =============== drm_test_check_plane_state ================
[05:28:29] [PASSED] clipping_simple
[05:28:29] [PASSED] clipping_rotate_reflect
[05:28:29] [PASSED] positioning_simple
[05:28:29] [PASSED] upscaling
[05:28:29] [PASSED] downscaling
[05:28:29] [PASSED] rounding1
[05:28:29] [PASSED] rounding2
[05:28:29] [PASSED] rounding3
[05:28:29] [PASSED] rounding4
[05:28:29] =========== [PASSED] drm_test_check_plane_state ============
[05:28:29] =========== drm_test_check_invalid_plane_state ============
[05:28:29] [PASSED] positioning_invalid
[05:28:29] [PASSED] upscaling_invalid
[05:28:29] [PASSED] downscaling_invalid
[05:28:29] ======= [PASSED] drm_test_check_invalid_plane_state ========
[05:28:29] ================ [PASSED] drm_plane_helper =================
[05:28:29] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[05:28:29] ====== drm_test_connector_helper_tv_get_modes_check =======
[05:28:29] [PASSED] None
[05:28:29] [PASSED] PAL
[05:28:29] [PASSED] NTSC
[05:28:29] [PASSED] Both, NTSC Default
[05:28:29] [PASSED] Both, PAL Default
[05:28:29] [PASSED] Both, NTSC Default, with PAL on command-line
[05:28:29] [PASSED] Both, PAL Default, with NTSC on command-line
[05:28:29] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[05:28:29] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[05:28:29] ================== drm_rect (9 subtests) ===================
[05:28:29] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[05:28:29] [PASSED] drm_test_rect_clip_scaled_not_clipped
[05:28:29] [PASSED] drm_test_rect_clip_scaled_clipped
[05:28:29] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[05:28:29] ================= drm_test_rect_intersect =================
[05:28:29] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[05:28:29] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[05:28:29] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[05:28:29] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[05:28:29] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[05:28:29] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[05:28:29] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[05:28:29] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[05:28:29] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[05:28:29] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[05:28:29] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[05:28:29] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[05:28:29] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[05:28:29] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[05:28:29] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[05:28:29] ============= [PASSED] drm_test_rect_intersect =============
[05:28:29] ================ drm_test_rect_calc_hscale ================
[05:28:29] [PASSED] normal use
[05:28:29] [PASSED] out of max range
[05:28:29] [PASSED] out of min range
[05:28:29] [PASSED] zero dst
[05:28:29] [PASSED] negative src
[05:28:29] [PASSED] negative dst
[05:28:29] ============ [PASSED] drm_test_rect_calc_hscale ============
[05:28:29] ================ drm_test_rect_calc_vscale ================
[05:28:29] [PASSED] normal use
[05:28:29] [PASSED] out of max range
[05:28:29] [PASSED] out of min range
[05:28:29] [PASSED] zero dst
[05:28:29] [PASSED] negative src
[05:28:29] [PASSED] negative dst
[05:28:29] ============ [PASSED] drm_test_rect_calc_vscale ============
[05:28:29] ================== drm_test_rect_rotate ===================
[05:28:29] [PASSED] reflect-x
[05:28:29] [PASSED] reflect-y
[05:28:29] [PASSED] rotate-0
[05:28:29] [PASSED] rotate-90
[05:28:29] [PASSED] rotate-180
[05:28:29] [PASSED] rotate-270
[05:28:29] ============== [PASSED] drm_test_rect_rotate ===============
[05:28:29] ================ drm_test_rect_rotate_inv =================
[05:28:29] [PASSED] reflect-x
[05:28:29] [PASSED] reflect-y
[05:28:29] [PASSED] rotate-0
[05:28:29] [PASSED] rotate-90
[05:28:29] [PASSED] rotate-180
[05:28:29] [PASSED] rotate-270
[05:28:29] ============ [PASSED] drm_test_rect_rotate_inv =============
[05:28:29] ==================== [PASSED] drm_rect =====================
[05:28:29] ============ drm_sysfb_modeset_test (1 subtest) ============
[05:28:29] ============ drm_test_sysfb_build_fourcc_list =============
[05:28:29] [PASSED] no native formats
[05:28:29] [PASSED] XRGB8888 as native format
[05:28:29] [PASSED] remove duplicates
[05:28:29] [PASSED] convert alpha formats
[05:28:29] [PASSED] random formats
[05:28:29] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[05:28:29] ============= [PASSED] drm_sysfb_modeset_test ==============
[05:28:29] ================== drm_fixp (2 subtests) ===================
[05:28:29] [PASSED] drm_test_int2fixp
[05:28:29] [PASSED] drm_test_sm2fixp
[05:28:29] ==================== [PASSED] drm_fixp =====================
[05:28:29] ============================================================
[05:28:29] Testing complete. Ran 639 tests: passed: 639
[05:28:29] Elapsed time: 26.122s total, 1.731s configuring, 24.226s building, 0.136s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[05:28:29] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:28:30] 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
[05:28:40] Starting KUnit Kernel (1/1)...
[05:28:40] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:28:40] ================= ttm_device (5 subtests) ==================
[05:28:40] [PASSED] ttm_device_init_basic
[05:28:40] [PASSED] ttm_device_init_multiple
[05:28:40] [PASSED] ttm_device_fini_basic
[05:28:40] [PASSED] ttm_device_init_no_vma_man
[05:28:40] ================== ttm_device_init_pools ==================
[05:28:40] [PASSED] No DMA allocations, no DMA32 required
[05:28:40] [PASSED] DMA allocations, DMA32 required
[05:28:40] [PASSED] No DMA allocations, DMA32 required
[05:28:40] [PASSED] DMA allocations, no DMA32 required
[05:28:40] ============== [PASSED] ttm_device_init_pools ==============
[05:28:40] =================== [PASSED] ttm_device ====================
[05:28:40] ================== ttm_pool (8 subtests) ===================
[05:28:40] ================== ttm_pool_alloc_basic ===================
[05:28:40] [PASSED] One page
[05:28:40] [PASSED] More than one page
[05:28:40] [PASSED] Above the allocation limit
[05:28:40] [PASSED] One page, with coherent DMA mappings enabled
[05:28:40] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[05:28:40] ============== [PASSED] ttm_pool_alloc_basic ===============
[05:28:40] ============== ttm_pool_alloc_basic_dma_addr ==============
[05:28:40] [PASSED] One page
[05:28:40] [PASSED] More than one page
[05:28:40] [PASSED] Above the allocation limit
[05:28:40] [PASSED] One page, with coherent DMA mappings enabled
[05:28:40] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[05:28:40] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[05:28:40] [PASSED] ttm_pool_alloc_order_caching_match
[05:28:40] [PASSED] ttm_pool_alloc_caching_mismatch
[05:28:40] [PASSED] ttm_pool_alloc_order_mismatch
[05:28:40] [PASSED] ttm_pool_free_dma_alloc
[05:28:40] [PASSED] ttm_pool_free_no_dma_alloc
[05:28:40] [PASSED] ttm_pool_fini_basic
[05:28:40] ==================== [PASSED] ttm_pool =====================
[05:28:40] ================ ttm_resource (8 subtests) =================
[05:28:40] ================= ttm_resource_init_basic =================
[05:28:40] [PASSED] Init resource in TTM_PL_SYSTEM
[05:28:40] [PASSED] Init resource in TTM_PL_VRAM
[05:28:40] [PASSED] Init resource in a private placement
[05:28:40] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[05:28:40] ============= [PASSED] ttm_resource_init_basic =============
[05:28:40] [PASSED] ttm_resource_init_pinned
[05:28:40] [PASSED] ttm_resource_fini_basic
[05:28:40] [PASSED] ttm_resource_manager_init_basic
[05:28:40] [PASSED] ttm_resource_manager_usage_basic
[05:28:40] [PASSED] ttm_resource_manager_set_used_basic
[05:28:40] [PASSED] ttm_sys_man_alloc_basic
[05:28:40] [PASSED] ttm_sys_man_free_basic
[05:28:40] ================== [PASSED] ttm_resource ===================
[05:28:40] =================== ttm_tt (15 subtests) ===================
[05:28:40] ==================== ttm_tt_init_basic ====================
[05:28:40] [PASSED] Page-aligned size
[05:28:40] [PASSED] Extra pages requested
[05:28:40] ================ [PASSED] ttm_tt_init_basic ================
[05:28:40] [PASSED] ttm_tt_init_misaligned
[05:28:40] [PASSED] ttm_tt_fini_basic
[05:28:40] [PASSED] ttm_tt_fini_sg
[05:28:40] [PASSED] ttm_tt_fini_shmem
[05:28:40] [PASSED] ttm_tt_create_basic
[05:28:40] [PASSED] ttm_tt_create_invalid_bo_type
[05:28:40] [PASSED] ttm_tt_create_ttm_exists
[05:28:40] [PASSED] ttm_tt_create_failed
[05:28:40] [PASSED] ttm_tt_destroy_basic
[05:28:40] [PASSED] ttm_tt_populate_null_ttm
[05:28:40] [PASSED] ttm_tt_populate_populated_ttm
[05:28:40] [PASSED] ttm_tt_unpopulate_basic
[05:28:40] [PASSED] ttm_tt_unpopulate_empty_ttm
[05:28:40] [PASSED] ttm_tt_swapin_basic
[05:28:40] ===================== [PASSED] ttm_tt ======================
[05:28:40] =================== ttm_bo (14 subtests) ===================
[05:28:40] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[05:28:40] [PASSED] Cannot be interrupted and sleeps
[05:28:40] [PASSED] Cannot be interrupted, locks straight away
[05:28:40] [PASSED] Can be interrupted, sleeps
[05:28:40] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[05:28:40] [PASSED] ttm_bo_reserve_locked_no_sleep
[05:28:40] [PASSED] ttm_bo_reserve_no_wait_ticket
[05:28:40] [PASSED] ttm_bo_reserve_double_resv
[05:28:40] [PASSED] ttm_bo_reserve_interrupted
[05:28:40] [PASSED] ttm_bo_reserve_deadlock
[05:28:40] [PASSED] ttm_bo_unreserve_basic
[05:28:40] [PASSED] ttm_bo_unreserve_pinned
[05:28:40] [PASSED] ttm_bo_unreserve_bulk
[05:28:40] [PASSED] ttm_bo_fini_basic
[05:28:40] [PASSED] ttm_bo_fini_shared_resv
[05:28:40] [PASSED] ttm_bo_pin_basic
[05:28:40] [PASSED] ttm_bo_pin_unpin_resource
[05:28:40] [PASSED] ttm_bo_multiple_pin_one_unpin
[05:28:40] ===================== [PASSED] ttm_bo ======================
[05:28:40] ============== ttm_bo_validate (22 subtests) ===============
[05:28:40] ============== ttm_bo_init_reserved_sys_man ===============
[05:28:40] [PASSED] Buffer object for userspace
[05:28:40] [PASSED] Kernel buffer object
[05:28:40] [PASSED] Shared buffer object
[05:28:40] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[05:28:40] ============== ttm_bo_init_reserved_mock_man ==============
[05:28:40] [PASSED] Buffer object for userspace
[05:28:40] [PASSED] Kernel buffer object
[05:28:40] [PASSED] Shared buffer object
[05:28:40] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[05:28:40] [PASSED] ttm_bo_init_reserved_resv
[05:28:40] ================== ttm_bo_validate_basic ==================
[05:28:40] [PASSED] Buffer object for userspace
[05:28:40] [PASSED] Kernel buffer object
[05:28:40] [PASSED] Shared buffer object
[05:28:40] ============== [PASSED] ttm_bo_validate_basic ==============
[05:28:40] [PASSED] ttm_bo_validate_invalid_placement
[05:28:40] ============= ttm_bo_validate_same_placement ==============
[05:28:40] [PASSED] System manager
[05:28:40] [PASSED] VRAM manager
[05:28:40] ========= [PASSED] ttm_bo_validate_same_placement ==========
[05:28:40] [PASSED] ttm_bo_validate_failed_alloc
[05:28:40] [PASSED] ttm_bo_validate_pinned
[05:28:40] [PASSED] ttm_bo_validate_busy_placement
[05:28:40] ================ ttm_bo_validate_multihop =================
[05:28:40] [PASSED] Buffer object for userspace
[05:28:40] [PASSED] Kernel buffer object
[05:28:40] [PASSED] Shared buffer object
[05:28:40] ============ [PASSED] ttm_bo_validate_multihop =============
[05:28:40] ========== ttm_bo_validate_no_placement_signaled ==========
[05:28:40] [PASSED] Buffer object in system domain, no page vector
[05:28:40] [PASSED] Buffer object in system domain with an existing page vector
[05:28:40] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[05:28:40] ======== ttm_bo_validate_no_placement_not_signaled ========
[05:28:40] [PASSED] Buffer object for userspace
[05:28:40] [PASSED] Kernel buffer object
[05:28:40] [PASSED] Shared buffer object
[05:28:40] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[05:28:40] [PASSED] ttm_bo_validate_move_fence_signaled
[05:28:40] ========= ttm_bo_validate_move_fence_not_signaled =========
[05:28:40] [PASSED] Waits for GPU
[05:28:40] [PASSED] Tries to lock straight away
[05:28:40] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[05:28:40] [PASSED] ttm_bo_validate_swapout
[05:28:40] [PASSED] ttm_bo_validate_happy_evict
[05:28:40] [PASSED] ttm_bo_validate_all_pinned_evict
[05:28:40] [PASSED] ttm_bo_validate_allowed_only_evict
[05:28:40] [PASSED] ttm_bo_validate_deleted_evict
[05:28:40] [PASSED] ttm_bo_validate_busy_domain_evict
[05:28:40] [PASSED] ttm_bo_validate_evict_gutting
[05:28:40] [PASSED] ttm_bo_validate_recrusive_evict
[05:28:40] ================= [PASSED] ttm_bo_validate =================
[05:28:40] ============================================================
[05:28:40] Testing complete. Ran 102 tests: passed: 102
[05:28:40] Elapsed time: 11.687s total, 1.704s configuring, 9.768s building, 0.172s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
@ 2026-06-25 5:57 Nitin Gote
2026-06-25 5:28 ` ✓ CI.KUnit: success for " Patchwork
` (4 more replies)
0 siblings, 5 replies; 14+ messages in thread
From: Nitin Gote @ 2026-06-25 5:57 UTC (permalink / raw)
To: intel-xe
Cc: Nitin Gote, stable, Thomas Hellstrom, Christian Konig,
Matthew Auld
When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
fails, no dma_buf reference is held. The exporter can be freed before
the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing a
use-after-free:
Oops: general protection fault, probably for non-canonical address
0x6b6b6b6b6b6b6b9c
Workqueue: ttm ttm_bo_delayed_delete [ttm]
RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
the shared resv available for delayed_delete to release the dma-buf
mapping. A BO whose attach never succeeded has no mapping to release,
yet it keeps bo->base.resv pointing at the exporter resv that
delayed_delete later locks once the exporter is gone.
Fix this by checking bo->base.import_attach, which is only set after
successful dma_buf_dynamic_attach(). Failed imports now individualize
normally, so delayed_delete operates on the BO's private _resv. The
exporter remains alive during individualize as it runs synchronously
in ttm_bo_release(), while the gem_prime_import caller still holds
its dma_buf reference.
Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path for imported bos")
Cc: stable@vger.kernel.org # v6.8+
Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
Cc: Christian Konig <christian.koenig@amd.com>
Cc: Matthew Auld <matthew.auld@intel.com>
Assisted-by: GitHub_Copilot:claude-sonnet-4.6
Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
---
v3:
- Dropped the xe-side reordering approach since importer_priv must be
valid when dma_buf_dynamic_attach() publishes the attachment.
- Per Christian's suggestion on the v1 thread, keyed the check on
import_attach rather than removing the sg guard entirely.
- Exporter lifetime: individualize runs synchronously inside
ttm_bo_release(), called from drm_gem_object_put() in the
gem_prime_import error path while drm_gem_prime_fd_to_handle()
still holds its dma_buf reference.
- Fixes both xe and amdgpu in a single TTM patch.
drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
1 file changed, 15 insertions(+), 9 deletions(-)
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
index bcd76f6bb7f0..bf8eaec0e9ca 100644
--- a/drivers/gpu/drm/ttm/ttm_bo.c
+++ b/drivers/gpu/drm/ttm/ttm_bo.c
@@ -196,6 +196,14 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
if (bo->base.resv == &bo->base._resv)
return 0;
+ /*
+ * Successfully imported sg BOs need the shared resv for dma-buf
+ * cleanup. Failed imports have no attachment or mapping and can
+ * use the private _resv.
+ */
+ if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
+ return 0;
+
BUG_ON(!dma_resv_trylock(&bo->base._resv));
r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv);
@@ -203,15 +211,13 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
if (r)
return r;
- if (bo->type != ttm_bo_type_sg) {
- /* This works because the BO is about to be destroyed and nobody
- * reference it any more. The only tricky case is the trylock on
- * the resv object while holding the lru_lock.
- */
- spin_lock(&bo->bdev->lru_lock);
- bo->base.resv = &bo->base._resv;
- spin_unlock(&bo->bdev->lru_lock);
- }
+ /* This works because the BO is about to be destroyed and nobody
+ * references it any more. The only tricky case is the trylock on
+ * the resv object while holding the lru_lock.
+ */
+ spin_lock(&bo->bdev->lru_lock);
+ bo->base.resv = &bo->base._resv;
+ spin_unlock(&bo->bdev->lru_lock);
return r;
}
--
2.50.1
^ permalink raw reply related [flat|nested] 14+ messages in thread
* ✗ Xe.CI.BAT: failure for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-06-25 5:28 ` ✓ CI.KUnit: success for " Patchwork
@ 2026-06-25 6:03 ` Patchwork
2026-06-25 7:43 ` ✗ Xe.CI.FULL: " Patchwork
` (2 subsequent siblings)
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-06-25 6:03 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 4593 bytes --]
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
URL : https://patchwork.freedesktop.org/series/169129/
State : failure
== Summary ==
CI Bug Log - changes from xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973_BAT -> xe-pw-169129v1_BAT
====================================================
Summary
-------
**FAILURE**
Serious unknown changes coming with xe-pw-169129v1_BAT absolutely need to be
verified manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-169129v1_BAT, 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 (13 -> 13)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-169129v1_BAT:
### IGT changes ###
#### Possible regressions ####
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-userptr-invalidate-race:
- bat-bmg-3: NOTRUN -> [CRASH][1] +3 other tests crash
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-userptr-invalidate-race.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-null-rebind:
- bat-bmg-3: NOTRUN -> [INCOMPLETE][2] +1 other test incomplete
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-null-rebind.html
* igt@xe_query@multigpu-query-invalid-uc-fw-version-mbz:
- bat-bmg-3: NOTRUN -> [FAIL][3]
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_query@multigpu-query-invalid-uc-fw-version-mbz.html
Known issues
------------
Here are the changes found in xe-pw-169129v1_BAT that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-rebind:
- bat-bmg-3: NOTRUN -> [INCOMPLETE][4] ([Intel XE#8439]) +6 other tests incomplete
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-rebind.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr-invalidate:
- bat-bmg-3: NOTRUN -> [CRASH][5] ([Intel XE#8438])
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr-invalidate.html
* igt@xe_peer2peer@read@read-gpua-vram01-gpub-system-p2p:
- bat-bmg-3: NOTRUN -> [SKIP][6] ([Intel XE#6566]) +3 other tests skip
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_peer2peer@read@read-gpua-vram01-gpub-system-p2p.html
#### Possible fixes ####
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-basic-defer-bind:
- bat-bmg-3: [CRASH][7] ([Intel XE#8438]) -> [PASS][8] +1 other test pass
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-basic-defer-bind.html
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-basic-defer-bind.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-null-defer-mmap:
- bat-bmg-3: [INCOMPLETE][9] ([Intel XE#8439]) -> [PASS][10]
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-null-defer-mmap.html
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/bat-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-null-defer-mmap.html
[Intel XE#6566]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6566
[Intel XE#8438]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8438
[Intel XE#8439]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8439
Build changes
-------------
* Linux: xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973 -> xe-pw-169129v1
IGT_8985: d5fe8732b8547454c38fdd220b55f6f0cc841a3b @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973: adbc617250e16fb2db4a4c777b89440927cb8973
xe-pw-169129v1: 169129v1
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/index.html
[-- Attachment #2: Type: text/html, Size: 5531 bytes --]
^ permalink raw reply [flat|nested] 14+ messages in thread
* ✗ Xe.CI.FULL: failure for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-06-25 5:28 ` ✓ CI.KUnit: success for " Patchwork
2026-06-25 6:03 ` ✗ Xe.CI.BAT: failure " Patchwork
@ 2026-06-25 7:43 ` Patchwork
2026-06-25 10:45 ` [PATCH] " Christian König
2026-06-29 9:18 ` Thomas Hellström
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-06-25 7:43 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 95425 bytes --]
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
URL : https://patchwork.freedesktop.org/series/169129/
State : failure
== Summary ==
CI Bug Log - changes from xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973_FULL -> xe-pw-169129v1_FULL
====================================================
Summary
-------
**FAILURE**
Serious unknown changes coming with xe-pw-169129v1_FULL absolutely need to be
verified manually.
If you think the reported changes have nothing to do with the changes
introduced in xe-pw-169129v1_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 (2 -> 2)
------------------------------
No changes in participating hosts
Possible new issues
-------------------
Here are the unknown changes that may have been introduced in xe-pw-169129v1_FULL:
### IGT changes ###
#### Possible regressions ####
* igt@kms_bw@connected-linear-tiling-2-displays-target-3840x2160p:
- shard-bmg: [PASS][1] -> [INCOMPLETE][2] +15 other tests incomplete
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_bw@connected-linear-tiling-2-displays-target-3840x2160p.html
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_bw@connected-linear-tiling-2-displays-target-3840x2160p.html
* igt@kms_flip@flip-vs-dpms-off-vs-modeset-interruptible:
- shard-bmg: [PASS][3] -> [CRASH][4] +1 other test crash
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_flip@flip-vs-dpms-off-vs-modeset-interruptible.html
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_flip@flip-vs-dpms-off-vs-modeset-interruptible.html
* igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-16bpp-4tile-downscaling@pipe-a-valid-mode:
- shard-bmg: [PASS][5] -> [TIMEOUT][6] +4 other tests timeout
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-3/igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-16bpp-4tile-downscaling@pipe-a-valid-mode.html
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-16bpp-4tile-downscaling@pipe-a-valid-mode.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-upscaling:
- shard-bmg: NOTRUN -> [INCOMPLETE][7] +5 other tests incomplete
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-upscaling.html
* igt@kms_plane@pixel-format-yf-tiled-ccs-modifier-source-clamping:
- shard-bmg: NOTRUN -> [TIMEOUT][8] +6 other tests timeout
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_plane@pixel-format-yf-tiled-ccs-modifier-source-clamping.html
* igt@xe_exec_system_allocator@process-many-large-execqueues-malloc-race:
- shard-bmg: [PASS][9] -> [FAIL][10] +13 other tests fail
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@xe_exec_system_allocator@process-many-large-execqueues-malloc-race.html
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@xe_exec_system_allocator@process-many-large-execqueues-malloc-race.html
* igt@xe_exec_system_allocator@process-many-large-execqueues-malloc-race-nomemset:
- shard-lnl: NOTRUN -> [INCOMPLETE][11] +8 other tests incomplete
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_system_allocator@process-many-large-execqueues-malloc-race-nomemset.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-stride-mmap-free-race-nomemset:
- shard-bmg: NOTRUN -> [FAIL][12] +2 other tests fail
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_system_allocator@threads-shared-vm-many-stride-mmap-free-race-nomemset.html
#### Warnings ####
* igt@kms_bw@connected-linear-tiling-3-displays-target-1920x1080p:
- shard-bmg: [SKIP][13] ([Intel XE#8440]) -> [INCOMPLETE][14] +3 other tests incomplete
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_bw@connected-linear-tiling-3-displays-target-1920x1080p.html
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_bw@connected-linear-tiling-3-displays-target-1920x1080p.html
* igt@kms_bw@connected-linear-tiling-4-displays-target-3840x2160p:
- shard-bmg: [SKIP][15] ([Intel XE#7679]) -> [INCOMPLETE][16] +2 other tests incomplete
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_bw@connected-linear-tiling-4-displays-target-3840x2160p.html
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_bw@connected-linear-tiling-4-displays-target-3840x2160p.html
* igt@kms_bw@linear-tiling-2-displays-target-3840x2160p:
- shard-bmg: [TIMEOUT][17] -> [INCOMPLETE][18] +1 other test incomplete
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_bw@linear-tiling-2-displays-target-3840x2160p.html
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_bw@linear-tiling-2-displays-target-3840x2160p.html
* igt@kms_ccs@crc-sprite-planes-basic-y-tiled-gen12-rc-ccs:
- shard-bmg: [SKIP][19] ([Intel XE#2887]) -> [TIMEOUT][20]
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_ccs@crc-sprite-planes-basic-y-tiled-gen12-rc-ccs.html
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_ccs@crc-sprite-planes-basic-y-tiled-gen12-rc-ccs.html
* igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling:
- shard-bmg: [SKIP][21] ([Intel XE#7178] / [Intel XE#7349]) -> [INCOMPLETE][22]
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-4/igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling.html
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling.html
* igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-pri-shrfb-draw-render:
- shard-bmg: [SKIP][23] ([Intel XE#8440]) -> [TIMEOUT][24]
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-pri-shrfb-draw-render.html
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-pri-shrfb-draw-render.html
* igt@kms_frontbuffer_tracking@fbcpsrhdr-2p-scndscrn-pri-indfb-draw-render:
- shard-bmg: [SKIP][25] ([Intel XE#2313]) -> [CRASH][26]
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@kms_frontbuffer_tracking@fbcpsrhdr-2p-scndscrn-pri-indfb-draw-render.html
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcpsrhdr-2p-scndscrn-pri-indfb-draw-render.html
* igt@kms_plane@pixel-format-linear-modifier-source-clamping:
- shard-bmg: [INCOMPLETE][27] ([Intel XE#1035]) -> [TIMEOUT][28]
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@kms_plane@pixel-format-linear-modifier-source-clamping.html
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_plane@pixel-format-linear-modifier-source-clamping.html
* igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf:
- shard-lnl: [TIMEOUT][29] -> [INCOMPLETE][30] +1 other test incomplete
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-8/igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf.html
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_psr2_sf@fbc-psr2-overlay-plane-update-continuous-sf.html
* igt@xe_exec_system_allocator@process-many-large-execqueues-mmap-huge-nomemset:
- shard-bmg: [INCOMPLETE][31] ([Intel XE#8159]) -> [FAIL][32] +1 other test fail
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-4/igt@xe_exec_system_allocator@process-many-large-execqueues-mmap-huge-nomemset.html
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@xe_exec_system_allocator@process-many-large-execqueues-mmap-huge-nomemset.html
* igt@xe_exec_system_allocator@threads-many-stride-free-nomemset:
- shard-bmg: [SKIP][33] ([Intel XE#8441]) -> [SKIP][34] +89 other tests skip
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_system_allocator@threads-many-stride-free-nomemset.html
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@xe_exec_system_allocator@threads-many-stride-free-nomemset.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-mmap-remap-dontunmap-eocheck:
- shard-lnl: [INCOMPLETE][35] ([Intel XE#8437]) -> [INCOMPLETE][36] +313 other tests incomplete
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-5/igt@xe_exec_system_allocator@threads-shared-vm-many-mmap-remap-dontunmap-eocheck.html
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-5/igt@xe_exec_system_allocator@threads-shared-vm-many-mmap-remap-dontunmap-eocheck.html
* igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-invalidate-race:
- shard-bmg: [INCOMPLETE][37] ([Intel XE#8366]) -> [CRASH][38] +1 other test crash
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-invalidate-race.html
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-invalidate-race.html
* igt@xe_fault_injection@inject-fault-probe-function-xe_uc_fw_init:
- shard-bmg: [INCOMPLETE][39] ([Intel XE#8437]) -> [INCOMPLETE][40] +8 other tests incomplete
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_fault_injection@inject-fault-probe-function-xe_uc_fw_init.html
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@xe_fault_injection@inject-fault-probe-function-xe_uc_fw_init.html
Known issues
------------
Here are the changes found in xe-pw-169129v1_FULL that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_addfb_basic@addfb25-y-tiled-small-legacy:
- shard-bmg: NOTRUN -> [SKIP][41] ([Intel XE#2233])
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_addfb_basic@addfb25-y-tiled-small-legacy.html
* igt@kms_async_flips@basic-modeset-with-all-modifiers-formats@pipe-a-dp-2-4-rc-ccs-xrgb2101010:
- shard-bmg: NOTRUN -> [INCOMPLETE][42] ([Intel XE#8437]) +6 other tests incomplete
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_async_flips@basic-modeset-with-all-modifiers-formats@pipe-a-dp-2-4-rc-ccs-xrgb2101010.html
* igt@kms_big_fb@4-tiled-8bpp-rotate-90:
- shard-lnl: NOTRUN -> [SKIP][43] ([Intel XE#1407]) +1 other test skip
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_big_fb@4-tiled-8bpp-rotate-90.html
* igt@kms_big_fb@4-tiled-max-hw-stride-64bpp-rotate-0-hflip:
- shard-bmg: NOTRUN -> [TIMEOUT][44] ([Intel XE#8446])
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_big_fb@4-tiled-max-hw-stride-64bpp-rotate-0-hflip.html
* igt@kms_big_fb@4-tiled-max-hw-stride-64bpp-rotate-180-async-flip:
- shard-lnl: NOTRUN -> [INCOMPLETE][45] ([Intel XE#5643])
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_big_fb@4-tiled-max-hw-stride-64bpp-rotate-180-async-flip.html
* igt@kms_big_fb@linear-max-hw-stride-64bpp-rotate-180-hflip:
- shard-bmg: NOTRUN -> [SKIP][46] ([Intel XE#7059] / [Intel XE#7085])
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_big_fb@linear-max-hw-stride-64bpp-rotate-180-hflip.html
* igt@kms_big_fb@x-tiled-32bpp-rotate-90:
- shard-bmg: NOTRUN -> [SKIP][47] ([Intel XE#2327]) +3 other tests skip
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_big_fb@x-tiled-32bpp-rotate-90.html
* igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-async-flip:
- shard-bmg: [PASS][48] -> [TIMEOUT][49] ([Intel XE#8446]) +1 other test timeout
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
* igt@kms_big_fb@y-tiled-addfb-size-offset-overflow:
- shard-bmg: NOTRUN -> [SKIP][50] ([Intel XE#607] / [Intel XE#7361])
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_big_fb@y-tiled-addfb-size-offset-overflow.html
* igt@kms_big_fb@yf-tiled-32bpp-rotate-0:
- shard-bmg: NOTRUN -> [SKIP][51] ([Intel XE#1124]) +8 other tests skip
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_big_fb@yf-tiled-32bpp-rotate-0.html
* igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-hflip:
- shard-lnl: NOTRUN -> [SKIP][52] ([Intel XE#1124]) +2 other tests skip
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-hflip.html
* igt@kms_bw@linear-tiling-3-displays-target-3840x2160p:
- shard-bmg: NOTRUN -> [SKIP][53] ([Intel XE#367]) +1 other test skip
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_bw@linear-tiling-3-displays-target-3840x2160p.html
* igt@kms_bw@linear-tiling-4-displays-target-2560x1440p:
- shard-lnl: NOTRUN -> [INCOMPLETE][54] ([Intel XE#8445])
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_bw@linear-tiling-4-displays-target-2560x1440p.html
* igt@kms_ccs@crc-primary-suspend-4-tiled-lnl-ccs@pipe-d-hdmi-a-3:
- shard-bmg: NOTRUN -> [SKIP][55] ([Intel XE#2652]) +17 other tests skip
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_ccs@crc-primary-suspend-4-tiled-lnl-ccs@pipe-d-hdmi-a-3.html
* igt@kms_ccs@crc-primary-suspend-4-tiled-mtl-rc-ccs:
- shard-bmg: NOTRUN -> [SKIP][56] ([Intel XE#3432])
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_ccs@crc-primary-suspend-4-tiled-mtl-rc-ccs.html
* igt@kms_ccs@crc-sprite-planes-basic-4-tiled-dg2-rc-ccs:
- shard-bmg: NOTRUN -> [SKIP][57] ([Intel XE#2887]) +7 other tests skip
[57]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_ccs@crc-sprite-planes-basic-4-tiled-dg2-rc-ccs.html
* igt@kms_ccs@missing-ccs-buffer-4-tiled-mtl-rc-ccs-cc:
- shard-lnl: NOTRUN -> [INCOMPLETE][58] ([Intel XE#8437]) +1 other test incomplete
[58]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_ccs@missing-ccs-buffer-4-tiled-mtl-rc-ccs-cc.html
* igt@kms_chamelium_audio@hdmi-audio-edid:
- shard-bmg: NOTRUN -> [SKIP][59] ([Intel XE#2252]) +7 other tests skip
[59]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_chamelium_audio@hdmi-audio-edid.html
* igt@kms_chamelium_color@ctm-0-75:
- shard-bmg: NOTRUN -> [SKIP][60] ([Intel XE#2325] / [Intel XE#7358])
[60]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_chamelium_color@ctm-0-75.html
* igt@kms_chamelium_color_pipeline@plane-lut1d-ctm3x4-lut1d:
- shard-lnl: NOTRUN -> [SKIP][61] ([Intel XE#7358])
[61]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@kms_chamelium_color_pipeline@plane-lut1d-ctm3x4-lut1d.html
* igt@kms_chamelium_color_pipeline@plane-lut1d-lut1d:
- shard-bmg: NOTRUN -> [SKIP][62] ([Intel XE#7358])
[62]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_chamelium_color_pipeline@plane-lut1d-lut1d.html
* igt@kms_content_protection@atomic-dpms-hdcp14@pipe-a-dp-2:
- shard-bmg: NOTRUN -> [FAIL][63] ([Intel XE#3304] / [Intel XE#7374]) +1 other test fail
[63]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_content_protection@atomic-dpms-hdcp14@pipe-a-dp-2.html
* igt@kms_content_protection@atomic-dpms@pipe-a-dp-2:
- shard-bmg: NOTRUN -> [FAIL][64] ([Intel XE#1178] / [Intel XE#3304] / [Intel XE#7374]) +2 other tests fail
[64]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_content_protection@atomic-dpms@pipe-a-dp-2.html
* igt@kms_content_protection@dp-mst-type-1-suspend-resume:
- shard-bmg: NOTRUN -> [SKIP][65] ([Intel XE#6974])
[65]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_content_protection@dp-mst-type-1-suspend-resume.html
* igt@kms_content_protection@lic-type-1:
- shard-lnl: NOTRUN -> [SKIP][66] ([Intel XE#7642])
[66]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_content_protection@lic-type-1.html
* igt@kms_cursor_crc@cursor-offscreen-256x85:
- shard-bmg: NOTRUN -> [SKIP][67] ([Intel XE#2320]) +2 other tests skip
[67]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_cursor_crc@cursor-offscreen-256x85.html
* igt@kms_cursor_crc@cursor-rapid-movement-128x42:
- shard-lnl: NOTRUN -> [SKIP][68] ([Intel XE#1424])
[68]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_cursor_crc@cursor-rapid-movement-128x42.html
* igt@kms_cursor_crc@cursor-sliding-512x512:
- shard-bmg: NOTRUN -> [SKIP][69] ([Intel XE#2321] / [Intel XE#7355]) +1 other test skip
[69]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_cursor_crc@cursor-sliding-512x512.html
* igt@kms_cursor_legacy@short-flip-before-cursor-atomic-transitions:
- shard-bmg: [PASS][70] -> [INCOMPLETE][71] ([Intel XE#8151])
[70]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_cursor_legacy@short-flip-before-cursor-atomic-transitions.html
[71]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_cursor_legacy@short-flip-before-cursor-atomic-transitions.html
* igt@kms_dirtyfb@psr-dirtyfb-ioctl:
- shard-bmg: NOTRUN -> [SKIP][72] ([Intel XE#1508])
[72]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_dirtyfb@psr-dirtyfb-ioctl.html
* igt@kms_dp_link_training@uhbr-mst:
- shard-lnl: NOTRUN -> [SKIP][73] ([Intel XE#4354] / [Intel XE#7386])
[73]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_dp_link_training@uhbr-mst.html
* igt@kms_dsc@dsc-basic-bigjoiner:
- shard-bmg: NOTRUN -> [SKIP][74] ([Intel XE#8265]) +4 other tests skip
[74]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_dsc@dsc-basic-bigjoiner.html
* igt@kms_dsc@dsc-with-bpc-formats-ultrajoiner:
- shard-lnl: NOTRUN -> [SKIP][75] ([Intel XE#8265])
[75]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_dsc@dsc-with-bpc-formats-ultrajoiner.html
* igt@kms_fbcon_fbt@psr-suspend:
- shard-bmg: NOTRUN -> [SKIP][76] ([Intel XE#6126] / [Intel XE#776])
[76]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_fbcon_fbt@psr-suspend.html
* igt@kms_flip@2x-dpms-vs-vblank-race:
- shard-lnl: NOTRUN -> [SKIP][77] ([Intel XE#1421])
[77]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_flip@2x-dpms-vs-vblank-race.html
* igt@kms_flip@2x-flip-vs-dpms-off-vs-modeset-interruptible:
- shard-bmg: NOTRUN -> [INCOMPLETE][78] ([Intel XE#8155])
[78]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_flip@2x-flip-vs-dpms-off-vs-modeset-interruptible.html
* igt@kms_flip@blocking-absolute-wf_vblank-interruptible:
- shard-bmg: [PASS][79] -> [INCOMPLETE][80] ([Intel XE#8155]) +1 other test incomplete
[79]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_flip@blocking-absolute-wf_vblank-interruptible.html
[80]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_flip@blocking-absolute-wf_vblank-interruptible.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-32bpp-ytile-downscaling:
- shard-bmg: NOTRUN -> [SKIP][81] ([Intel XE#7178] / [Intel XE#7351]) +1 other test skip
[81]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-32bpp-ytile-downscaling.html
* igt@kms_flip_scaled_crc@flip-p016-linear-to-p016-linear-reflect-x:
- shard-bmg: NOTRUN -> [SKIP][82] ([Intel XE#7179]) +1 other test skip
[82]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_flip_scaled_crc@flip-p016-linear-to-p016-linear-reflect-x.html
* igt@kms_frontbuffer_tracking@drrs-1p-offscreen-pri-shrfb-draw-mmap-wc:
- shard-lnl: NOTRUN -> [SKIP][83] ([Intel XE#6312]) +1 other test skip
[83]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_frontbuffer_tracking@drrs-1p-offscreen-pri-shrfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@drrs-argb161616f-draw-mmap-wc:
- shard-bmg: NOTRUN -> [SKIP][84] ([Intel XE#7061] / [Intel XE#7356]) +2 other tests skip
[84]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_frontbuffer_tracking@drrs-argb161616f-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@drrshdr-argb161616f-draw-mmap-wc:
- shard-bmg: NOTRUN -> [SKIP][85] ([Intel XE#7061]) +2 other tests skip
[85]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_frontbuffer_tracking@drrshdr-argb161616f-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbc-1p-primscrn-spr-indfb-draw-blt:
- shard-bmg: NOTRUN -> [SKIP][86] ([Intel XE#4141]) +7 other tests skip
[86]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-spr-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@fbc-2p-primscrn-spr-indfb-draw-mmap-wc:
- shard-lnl: NOTRUN -> [SKIP][87] ([Intel XE#656] / [Intel XE#7905]) +7 other tests skip
[87]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_frontbuffer_tracking@fbc-2p-primscrn-spr-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-shrfb-plflip-blt:
- shard-bmg: NOTRUN -> [SKIP][88] ([Intel XE#2311]) +35 other tests skip
[88]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-shrfb-plflip-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-tiling-y:
- shard-bmg: NOTRUN -> [SKIP][89] ([Intel XE#2352] / [Intel XE#7399])
[89]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcdrrs-tiling-y.html
* igt@kms_frontbuffer_tracking@fbchdr-2p-primscrn-indfb-plflip-blt:
- shard-lnl: NOTRUN -> [SKIP][90] ([Intel XE#7905]) +5 other tests skip
[90]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@kms_frontbuffer_tracking@fbchdr-2p-primscrn-indfb-plflip-blt.html
* igt@kms_frontbuffer_tracking@fbchdr-2p-primscrn-spr-indfb-draw-render:
- shard-bmg: [PASS][91] -> [INCOMPLETE][92] ([Intel XE#8368]) +2 other tests incomplete
[91]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-4/igt@kms_frontbuffer_tracking@fbchdr-2p-primscrn-spr-indfb-draw-render.html
[92]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_frontbuffer_tracking@fbchdr-2p-primscrn-spr-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@fbchdr-tiling-y:
- shard-bmg: NOTRUN -> [SKIP][93] ([Intel XE#7399])
[93]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_frontbuffer_tracking@fbchdr-tiling-y.html
* igt@kms_frontbuffer_tracking@fbcpsr-abgr161616f-draw-blt:
- shard-lnl: NOTRUN -> [SKIP][94] ([Intel XE#7061] / [Intel XE#7356])
[94]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_frontbuffer_tracking@fbcpsr-abgr161616f-draw-blt.html
* igt@kms_frontbuffer_tracking@fbcpsr-rgb565-draw-render:
- shard-bmg: NOTRUN -> [SKIP][95] ([Intel XE#2313]) +41 other tests skip
[95]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_frontbuffer_tracking@fbcpsr-rgb565-draw-render.html
* igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-rte:
- shard-lnl: NOTRUN -> [SKIP][96] ([Intel XE#7865]) +4 other tests skip
[96]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-rte.html
* igt@kms_joiner@basic-max-non-joiner:
- shard-bmg: NOTRUN -> [SKIP][97] ([Intel XE#4298] / [Intel XE#5873])
[97]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_joiner@basic-max-non-joiner.html
* igt@kms_joiner@invalid-modeset-big-joiner:
- shard-bmg: NOTRUN -> [SKIP][98] ([Intel XE#6901])
[98]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_joiner@invalid-modeset-big-joiner.html
* igt@kms_plane@pixel-format-4-tiled-bmg-ccs-modifier-source-clamping@pipe-a-plane-0:
- shard-bmg: NOTRUN -> [INCOMPLETE][99] ([Intel XE#1035]) +1 other test incomplete
[99]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_plane@pixel-format-4-tiled-bmg-ccs-modifier-source-clamping@pipe-a-plane-0.html
* igt@kms_plane@pixel-format-x-tiled-modifier@pipe-b-plane-5:
- shard-bmg: NOTRUN -> [SKIP][100] ([Intel XE#8303]) +1 other test skip
[100]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_plane@pixel-format-x-tiled-modifier@pipe-b-plane-5.html
* igt@kms_plane@pixel-format-y-tiled-modifier:
- shard-bmg: NOTRUN -> [SKIP][101] ([Intel XE#7283]) +2 other tests skip
[101]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_plane@pixel-format-y-tiled-modifier.html
* igt@kms_plane_lowres@tiling-y:
- shard-bmg: NOTRUN -> [SKIP][102] ([Intel XE#2393])
[102]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_plane_lowres@tiling-y.html
* igt@kms_plane_multiple@2x-tiling-yf:
- shard-bmg: NOTRUN -> [SKIP][103] ([Intel XE#5021] / [Intel XE#7377])
[103]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_plane_multiple@2x-tiling-yf.html
* igt@kms_plane_multiple@tiling-y:
- shard-bmg: NOTRUN -> [SKIP][104] ([Intel XE#5020] / [Intel XE#7348])
[104]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_plane_multiple@tiling-y.html
* igt@kms_psr2_sf@psr2-overlay-plane-move-continuous-exceed-fully-sf:
- shard-bmg: NOTRUN -> [SKIP][105] ([Intel XE#1489]) +6 other tests skip
[105]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_psr2_sf@psr2-overlay-plane-move-continuous-exceed-fully-sf.html
* igt@kms_psr@psr-suspend:
- shard-bmg: NOTRUN -> [SKIP][106] ([Intel XE#2234] / [Intel XE#2850]) +5 other tests skip
[106]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_psr@psr-suspend.html
* igt@kms_psr_stress_test@invalidate-primary-flip-overlay:
- shard-lnl: NOTRUN -> [SKIP][107] ([Intel XE#8361])
[107]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_psr_stress_test@invalidate-primary-flip-overlay.html
* igt@kms_rotation_crc@primary-rotation-270:
- shard-bmg: NOTRUN -> [SKIP][108] ([Intel XE#3904] / [Intel XE#7342]) +2 other tests skip
[108]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_rotation_crc@primary-rotation-270.html
* igt@kms_rotation_crc@primary-y-tiled-reflect-x-180:
- shard-bmg: NOTRUN -> [SKIP][109] ([Intel XE#2330] / [Intel XE#5813])
[109]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_rotation_crc@primary-y-tiled-reflect-x-180.html
* igt@kms_rotation_crc@primary-yf-tiled-reflect-x-0:
- shard-lnl: NOTRUN -> [SKIP][110] ([Intel XE#1127] / [Intel XE#5813])
[110]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_rotation_crc@primary-yf-tiled-reflect-x-0.html
* igt@kms_vrr@seamless-rr-switch-drrs:
- shard-bmg: NOTRUN -> [SKIP][111] ([Intel XE#1499])
[111]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_vrr@seamless-rr-switch-drrs.html
* igt@xe_eudebug@basic-vm-bind-metadata-discovery:
- shard-bmg: NOTRUN -> [SKIP][112] ([Intel XE#7636]) +10 other tests skip
[112]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_eudebug@basic-vm-bind-metadata-discovery.html
* igt@xe_evict@evict-cm-threads-small:
- shard-lnl: NOTRUN -> [SKIP][113] ([Intel XE#6540] / [Intel XE#688])
[113]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@xe_evict@evict-cm-threads-small.html
* igt@xe_exec_balancer@many-virtual-userptr-rebind:
- shard-lnl: NOTRUN -> [SKIP][114] ([Intel XE#7482]) +2 other tests skip
[114]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_balancer@many-virtual-userptr-rebind.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue:
- shard-bmg: NOTRUN -> [INCOMPLETE][115] ([Intel XE#8439]) +1 other test incomplete
[115]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr:
- shard-lnl: NOTRUN -> [SKIP][116] ([Intel XE#1392])
[116]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr.html
* igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-rebind:
- shard-bmg: NOTRUN -> [SKIP][117] ([Intel XE#2322] / [Intel XE#7372]) +1 other test skip
[117]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-rebind.html
* igt@xe_exec_fault_mode@many-execqueues-bindexecqueue-userptr-rebind-imm:
- shard-bmg: [PASS][118] -> [INCOMPLETE][119] ([Intel XE#8437])
[118]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_fault_mode@many-execqueues-bindexecqueue-userptr-rebind-imm.html
[119]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_exec_fault_mode@many-execqueues-bindexecqueue-userptr-rebind-imm.html
* igt@xe_exec_fault_mode@many-multi-queue-userptr-rebind-prefetch:
- shard-bmg: NOTRUN -> [SKIP][120] ([Intel XE#8374]) +11 other tests skip
[120]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_fault_mode@many-multi-queue-userptr-rebind-prefetch.html
* igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate:
- shard-lnl: NOTRUN -> [SKIP][121] ([Intel XE#8374])
[121]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate.html
* igt@xe_exec_multi_queue@one-queue-preempt-mode-fault-priority:
- shard-lnl: NOTRUN -> [SKIP][122] ([Intel XE#8364]) +2 other tests skip
[122]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@xe_exec_multi_queue@one-queue-preempt-mode-fault-priority.html
* igt@xe_exec_multi_queue@two-queues-preempt-mode-fault-priority:
- shard-bmg: NOTRUN -> [SKIP][123] ([Intel XE#8364]) +11 other tests skip
[123]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@xe_exec_multi_queue@two-queues-preempt-mode-fault-priority.html
* igt@xe_exec_reset@cm-multi-queue-close-fd:
- shard-lnl: NOTRUN -> [SKIP][124] ([Intel XE#8369])
[124]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_reset@cm-multi-queue-close-fd.html
* igt@xe_exec_system_allocator@threads-many-execqueues-mmap-free-huge-nomemset:
- shard-bmg: NOTRUN -> [INCOMPLETE][125] ([Intel XE#8159]) +2 other tests incomplete
[125]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-free-huge-nomemset.html
* igt@xe_exec_system_allocator@threads-many-execqueues-mmap-new-madvise:
- shard-lnl: [PASS][126] -> [TIMEOUT][127] ([Intel XE#8447]) +1 other test timeout
[126]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-3/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-new-madvise.html
[127]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-6/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-new-madvise.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-fork-read-after:
- shard-bmg: [PASS][128] -> [INCOMPLETE][129] ([Intel XE#8159] / [Intel XE#8437]) +1 other test incomplete
[128]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-fork-read-after.html
[129]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-fork-read-after.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-madvise:
- shard-bmg: [PASS][130] -> [INCOMPLETE][131] ([Intel XE#8159]) +30 other tests incomplete
[130]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-3/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-madvise.html
[131]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-madvise.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-stride-malloc-madvise:
- shard-lnl: NOTRUN -> [TIMEOUT][132] ([Intel XE#8447])
[132]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_exec_system_allocator@threads-shared-vm-many-stride-malloc-madvise.html
* igt@xe_exec_threads@threads-bal-mixed-shared-vm-userptr-invalidate-race:
- shard-bmg: [PASS][133] -> [INCOMPLETE][134] ([Intel XE#8366])
[133]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@xe_exec_threads@threads-bal-mixed-shared-vm-userptr-invalidate-race.html
[134]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@xe_exec_threads@threads-bal-mixed-shared-vm-userptr-invalidate-race.html
* igt@xe_exec_threads@threads-multi-queue-hang-fd-userptr-invalidate-race:
- shard-bmg: NOTRUN -> [SKIP][135] ([Intel XE#8378]) +5 other tests skip
[135]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_threads@threads-multi-queue-hang-fd-userptr-invalidate-race.html
* igt@xe_fault_injection@inject-fault-probe-function-xe_ggtt_init_early:
- shard-bmg: [PASS][136] -> [CRASH][137] ([Intel XE#8448]) +1 other test crash
[136]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@xe_fault_injection@inject-fault-probe-function-xe_ggtt_init_early.html
[137]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_fault_injection@inject-fault-probe-function-xe_ggtt_init_early.html
* igt@xe_mmap@pci-membarrier:
- shard-lnl: NOTRUN -> [SKIP][138] ([Intel XE#5100] / [Intel XE#7322] / [Intel XE#7408])
[138]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@xe_mmap@pci-membarrier.html
* igt@xe_multigpu_svm@mgpu-atomic-op-basic:
- shard-bmg: NOTRUN -> [SKIP][139] ([Intel XE#6964]) +3 other tests skip
[139]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_multigpu_svm@mgpu-atomic-op-basic.html
* igt@xe_page_reclaim@binds-null-vma:
- shard-bmg: NOTRUN -> [SKIP][140] ([Intel XE#7793]) +3 other tests skip
[140]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_page_reclaim@binds-null-vma.html
* igt@xe_pat@l2-flush-opt-svm-pat-restrict:
- shard-bmg: NOTRUN -> [SKIP][141] ([Intel XE#7590])
[141]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@xe_pat@l2-flush-opt-svm-pat-restrict.html
* igt@xe_pat@pat-sw-hw-suspend:
- shard-bmg: NOTRUN -> [FAIL][142] ([Intel XE#7695]) +1 other test fail
[142]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@xe_pat@pat-sw-hw-suspend.html
* igt@xe_peer2peer@write:
- shard-bmg: NOTRUN -> [SKIP][143] ([Intel XE#2427] / [Intel XE#6953] / [Intel XE#7326] / [Intel XE#7353]) +1 other test skip
[143]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@xe_peer2peer@write.html
* igt@xe_pm@d3cold-multiple-execs:
- shard-bmg: NOTRUN -> [SKIP][144] ([Intel XE#2284] / [Intel XE#7370]) +1 other test skip
[144]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_pm@d3cold-multiple-execs.html
* igt@xe_pm@s2idle-d3cold-basic-exec:
- shard-lnl: NOTRUN -> [SKIP][145] ([Intel XE#2284] / [Intel XE#366] / [Intel XE#7370])
[145]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@xe_pm@s2idle-d3cold-basic-exec.html
* igt@xe_pm@s3-vm-bind-prefetch:
- shard-lnl: NOTRUN -> [SKIP][146] ([Intel XE#584] / [Intel XE#7369]) +1 other test skip
[146]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_pm@s3-vm-bind-prefetch.html
* igt@xe_pxp@pxp-stale-bo-exec-post-termination-irq:
- shard-bmg: NOTRUN -> [SKIP][147] ([Intel XE#4733] / [Intel XE#7417]) +1 other test skip
[147]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@xe_pxp@pxp-stale-bo-exec-post-termination-irq.html
* igt@xe_query@multigpu-query-gt-list:
- shard-bmg: NOTRUN -> [SKIP][148] ([Intel XE#944])
[148]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_query@multigpu-query-gt-list.html
* igt@xe_query@multigpu-query-invalid-uc-fw-version-mbz:
- shard-lnl: NOTRUN -> [SKIP][149] ([Intel XE#944])
[149]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@xe_query@multigpu-query-invalid-uc-fw-version-mbz.html
* igt@xe_sriov_scheduling@nonpreempt-engine-resets-normal-priority@numvfs-random-gt0-rcs0:
- shard-bmg: NOTRUN -> [ABORT][150] ([Intel XE#8007]) +2 other tests abort
[150]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@xe_sriov_scheduling@nonpreempt-engine-resets-normal-priority@numvfs-random-gt0-rcs0.html
* igt@xe_survivability@runtime-survivability:
- shard-bmg: NOTRUN -> [DMESG-WARN][151] ([Intel XE#6627] / [Intel XE#7419])
[151]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_survivability@runtime-survivability.html
* igt@xe_vm@large-userptr-misaligned-binds-1073741824:
- shard-bmg: [PASS][152] -> [SKIP][153] ([Intel XE#8440]) +22 other tests skip
[152]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_vm@large-userptr-misaligned-binds-1073741824.html
[153]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_vm@large-userptr-misaligned-binds-1073741824.html
#### Possible fixes ####
* igt@kms_atomic_transition@modeset-transition-nonblocking-fencing@1x-outputs:
- shard-bmg: [INCOMPLETE][154] ([Intel XE#8174]) -> [PASS][155] +1 other test pass
[154]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-3/igt@kms_atomic_transition@modeset-transition-nonblocking-fencing@1x-outputs.html
[155]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_atomic_transition@modeset-transition-nonblocking-fencing@1x-outputs.html
* igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip:
- shard-bmg: [TIMEOUT][156] ([Intel XE#8446]) -> [PASS][157] +1 other test pass
[156]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-3/igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip.html
[157]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip.html
* igt@kms_ccs@crc-primary-rotation-180-4-tiled-bmg-ccs:
- shard-bmg: [INCOMPLETE][158] ([Intel XE#8150]) -> [PASS][159]
[158]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@kms_ccs@crc-primary-rotation-180-4-tiled-bmg-ccs.html
[159]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_ccs@crc-primary-rotation-180-4-tiled-bmg-ccs.html
* igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size:
- shard-bmg: [TIMEOUT][160] ([Intel XE#7935]) -> [PASS][161]
[160]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
[161]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_cursor_legacy@cursor-vs-flip-atomic-transitions-varying-size.html
* igt@kms_cursor_legacy@cursora-vs-flipb-atomic-transitions-varying-size:
- shard-bmg: [INCOMPLETE][162] ([Intel XE#8151]) -> [PASS][163]
[162]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_cursor_legacy@cursora-vs-flipb-atomic-transitions-varying-size.html
[163]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_cursor_legacy@cursora-vs-flipb-atomic-transitions-varying-size.html
* igt@kms_flip@2x-single-buffer-flip-vs-dpms-off-vs-modeset:
- shard-bmg: [CRASH][164] -> [PASS][165]
[164]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_flip@2x-single-buffer-flip-vs-dpms-off-vs-modeset.html
[165]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_flip@2x-single-buffer-flip-vs-dpms-off-vs-modeset.html
* igt@kms_flip@flip-vs-expired-vblank@b-edp1:
- shard-lnl: [FAIL][166] ([Intel XE#301]) -> [PASS][167] +1 other test pass
[166]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-5/igt@kms_flip@flip-vs-expired-vblank@b-edp1.html
[167]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-5/igt@kms_flip@flip-vs-expired-vblank@b-edp1.html
* igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-64bpp-4tile-downscaling@pipe-a-valid-mode:
- shard-bmg: [TIMEOUT][168] -> [PASS][169] +4 other tests pass
[168]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-64bpp-4tile-downscaling@pipe-a-valid-mode.html
[169]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_flip_scaled_crc@flip-32bpp-4tile-to-64bpp-4tile-downscaling@pipe-a-valid-mode.html
* igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-shrfb-draw-render:
- shard-bmg: [INCOMPLETE][170] ([Intel XE#8368]) -> [PASS][171] +1 other test pass
[170]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-shrfb-draw-render.html
[171]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-shrfb-draw-render.html
* igt@kms_plane_scaling@plane-downscale-factor-0-75-with-rotation:
- shard-bmg: [INCOMPLETE][172] ([Intel XE#8437]) -> [PASS][173] +19 other tests pass
[172]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_plane_scaling@plane-downscale-factor-0-75-with-rotation.html
[173]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_plane_scaling@plane-downscale-factor-0-75-with-rotation.html
* igt@xe_exec_balancer@many-execqueues-cm-virtual-userptr-rebind:
- shard-bmg: [SKIP][174] ([Intel XE#8440]) -> [PASS][175] +137 other tests pass
[174]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_balancer@many-execqueues-cm-virtual-userptr-rebind.html
[175]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_balancer@many-execqueues-cm-virtual-userptr-rebind.html
* igt@xe_exec_system_allocator@pat-index-madvise-pat-idx-uc-comp-single-vma:
- shard-bmg: [CRASH][176] ([Intel XE#8450]) -> [PASS][177] +1 other test pass
[176]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@xe_exec_system_allocator@pat-index-madvise-pat-idx-uc-comp-single-vma.html
[177]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_system_allocator@pat-index-madvise-pat-idx-uc-comp-single-vma.html
* igt@xe_exec_system_allocator@process-many-large-malloc-mlock-nomemset:
- shard-bmg: [FAIL][178] -> [PASS][179] +11 other tests pass
[178]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@xe_exec_system_allocator@process-many-large-malloc-mlock-nomemset.html
[179]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@xe_exec_system_allocator@process-many-large-malloc-mlock-nomemset.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-execqueues-new-madvise:
- shard-bmg: [TIMEOUT][180] ([Intel XE#8447]) -> [PASS][181]
[180]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_system_allocator@threads-shared-vm-many-execqueues-new-madvise.html
[181]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_system_allocator@threads-shared-vm-many-execqueues-new-madvise.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-stride-malloc-fork-read-after:
- shard-bmg: [INCOMPLETE][182] ([Intel XE#8159]) -> [PASS][183] +27 other tests pass
[182]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_system_allocator@threads-shared-vm-many-stride-malloc-fork-read-after.html
[183]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@xe_exec_system_allocator@threads-shared-vm-many-stride-malloc-fork-read-after.html
* igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled@pf-pt_us-20000:
- shard-bmg: [INCOMPLETE][184] -> [PASS][185]
[184]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled@pf-pt_us-20000.html
[185]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled@pf-pt_us-20000.html
* igt@xe_wedged@wedged-mode-toggle:
- shard-bmg: [ABORT][186] ([Intel XE#8007]) -> [PASS][187]
[186]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@xe_wedged@wedged-mode-toggle.html
[187]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@xe_wedged@wedged-mode-toggle.html
#### Warnings ####
* igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip-async-flip:
- shard-bmg: [SKIP][188] ([Intel XE#8440]) -> [TIMEOUT][189] ([Intel XE#8446]) +1 other test timeout
[188]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip-async-flip.html
[189]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_big_fb@4-tiled-max-hw-stride-32bpp-rotate-180-hflip-async-flip.html
* igt@kms_big_fb@x-tiled-16bpp-rotate-270:
- shard-bmg: [SKIP][190] ([Intel XE#8440]) -> [SKIP][191] ([Intel XE#2327])
[190]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_big_fb@x-tiled-16bpp-rotate-270.html
[191]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_big_fb@x-tiled-16bpp-rotate-270.html
* igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-hflip:
- shard-bmg: [SKIP][192] ([Intel XE#8440]) -> [INCOMPLETE][193] ([Intel XE#5643])
[192]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-hflip.html
[193]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_big_fb@x-tiled-max-hw-stride-32bpp-rotate-180-hflip.html
* igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-0-async-flip:
- shard-lnl: [TIMEOUT][194] ([Intel XE#8446]) -> [INCOMPLETE][195] ([Intel XE#5643]) +2 other tests incomplete
[194]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-8/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-0-async-flip.html
[195]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-0-async-flip.html
- shard-bmg: [INCOMPLETE][196] ([Intel XE#5643]) -> [TIMEOUT][197] ([Intel XE#8446])
[196]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-0-async-flip.html
[197]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-0-async-flip.html
* igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-180-hflip:
- shard-bmg: [TIMEOUT][198] ([Intel XE#8446]) -> [INCOMPLETE][199] ([Intel XE#5643])
[198]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-180-hflip.html
[199]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_big_fb@x-tiled-max-hw-stride-64bpp-rotate-180-hflip.html
* igt@kms_big_fb@yf-tiled-32bpp-rotate-90:
- shard-bmg: [SKIP][200] ([Intel XE#8440]) -> [SKIP][201] ([Intel XE#1124]) +1 other test skip
[200]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_big_fb@yf-tiled-32bpp-rotate-90.html
[201]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_big_fb@yf-tiled-32bpp-rotate-90.html
* igt@kms_big_fb@yf-tiled-max-hw-stride-32bpp-rotate-180-async-flip:
- shard-lnl: [INCOMPLETE][202] ([Intel XE#5643]) -> [TIMEOUT][203] ([Intel XE#8446]) +2 other tests timeout
[202]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-6/igt@kms_big_fb@yf-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
[203]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-4/igt@kms_big_fb@yf-tiled-max-hw-stride-32bpp-rotate-180-async-flip.html
* igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-async-flip:
- shard-lnl: [INCOMPLETE][204] ([Intel XE#5643]) -> [SKIP][205] ([Intel XE#1124]) +1 other test skip
[204]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-6/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-async-flip.html
[205]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-3/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-async-flip.html
* igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-hflip-async-flip:
- shard-lnl: [SKIP][206] ([Intel XE#1124]) -> [INCOMPLETE][207] ([Intel XE#5643])
[206]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-3/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-hflip-async-flip.html
[207]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-6/igt@kms_big_fb@yf-tiled-max-hw-stride-64bpp-rotate-180-hflip-async-flip.html
* igt@kms_bw@connected-linear-tiling-1-displays-target-2160x1440p:
- shard-bmg: [INCOMPLETE][208] ([Intel XE#8437]) -> [CRASH][209] ([Intel XE#8449])
[208]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-4/igt@kms_bw@connected-linear-tiling-1-displays-target-2160x1440p.html
[209]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_bw@connected-linear-tiling-1-displays-target-2160x1440p.html
* igt@kms_bw@connected-linear-tiling-3-displays-target-2560x1440p:
- shard-bmg: [INCOMPLETE][210] ([Intel XE#8437]) -> [SKIP][211] ([Intel XE#7679])
[210]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@kms_bw@connected-linear-tiling-3-displays-target-2560x1440p.html
[211]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_bw@connected-linear-tiling-3-displays-target-2560x1440p.html
* igt@kms_bw@connected-linear-tiling-4-displays-target-2160x1440p:
- shard-lnl: [INCOMPLETE][212] ([Intel XE#8437]) -> [INCOMPLETE][213] ([Intel XE#8445]) +15 other tests incomplete
[212]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-lnl-2/igt@kms_bw@connected-linear-tiling-4-displays-target-2160x1440p.html
[213]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-lnl-2/igt@kms_bw@connected-linear-tiling-4-displays-target-2160x1440p.html
* igt@kms_bw@linear-tiling-1-displays-target-2560x1440p:
- shard-bmg: [INCOMPLETE][214] ([Intel XE#8437]) -> [SKIP][215] ([Intel XE#367]) +1 other test skip
[214]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-2/igt@kms_bw@linear-tiling-1-displays-target-2560x1440p.html
[215]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_bw@linear-tiling-1-displays-target-2560x1440p.html
* igt@kms_ccs@bad-rotation-90-4-tiled-mtl-rc-ccs-cc:
- shard-bmg: [SKIP][216] ([Intel XE#2887]) -> [SKIP][217] ([Intel XE#8440]) +1 other test skip
[216]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_ccs@bad-rotation-90-4-tiled-mtl-rc-ccs-cc.html
[217]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_ccs@bad-rotation-90-4-tiled-mtl-rc-ccs-cc.html
* igt@kms_ccs@crc-primary-suspend-y-tiled-gen12-rc-ccs:
- shard-bmg: [SKIP][218] ([Intel XE#3432]) -> [INCOMPLETE][219] ([Intel XE#8150] / [Intel XE#8437])
[218]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_ccs@crc-primary-suspend-y-tiled-gen12-rc-ccs.html
[219]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_ccs@crc-primary-suspend-y-tiled-gen12-rc-ccs.html
* igt@kms_ccs@crc-primary-suspend-yf-tiled-ccs:
- shard-bmg: [SKIP][220] ([Intel XE#8440]) -> [SKIP][221] ([Intel XE#3432]) +1 other test skip
[220]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_ccs@crc-primary-suspend-yf-tiled-ccs.html
[221]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_ccs@crc-primary-suspend-yf-tiled-ccs.html
* igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs:
- shard-bmg: [SKIP][222] ([Intel XE#8440]) -> [SKIP][223] ([Intel XE#2887]) +2 other tests skip
[222]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs.html
[223]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs.html
* igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs-cc:
- shard-bmg: [INCOMPLETE][224] ([Intel XE#8150]) -> [SKIP][225] ([Intel XE#2887])
[224]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs-cc.html
[225]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_ccs@missing-ccs-buffer-y-tiled-gen12-rc-ccs-cc.html
* igt@kms_cdclk@plane-scaling:
- shard-bmg: [SKIP][226] ([Intel XE#8440]) -> [SKIP][227] ([Intel XE#2724] / [Intel XE#7449])
[226]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_cdclk@plane-scaling.html
[227]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_cdclk@plane-scaling.html
* igt@kms_chamelium_frames@hdmi-cmp-planar-formats:
- shard-bmg: [SKIP][228] ([Intel XE#8440]) -> [SKIP][229] ([Intel XE#2252]) +1 other test skip
[228]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_chamelium_frames@hdmi-cmp-planar-formats.html
[229]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_chamelium_frames@hdmi-cmp-planar-formats.html
* igt@kms_content_protection@dp-mst-lic-type-0-hdcp14:
- shard-bmg: [SKIP][230] ([Intel XE#8440]) -> [SKIP][231] ([Intel XE#6974])
[230]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_content_protection@dp-mst-lic-type-0-hdcp14.html
[231]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_content_protection@dp-mst-lic-type-0-hdcp14.html
* igt@kms_content_protection@legacy-hdcp14:
- shard-bmg: [SKIP][232] ([Intel XE#8440]) -> [FAIL][233] ([Intel XE#1178] / [Intel XE#3304] / [Intel XE#7374])
[232]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_content_protection@legacy-hdcp14.html
[233]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_content_protection@legacy-hdcp14.html
* igt@kms_cursor_crc@cursor-offscreen-max-size:
- shard-bmg: [SKIP][234] ([Intel XE#8440]) -> [SKIP][235] ([Intel XE#2320]) +2 other tests skip
[234]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_cursor_crc@cursor-offscreen-max-size.html
[235]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_cursor_crc@cursor-offscreen-max-size.html
* igt@kms_cursor_legacy@cursora-vs-flipa-atomic-transitions-varying-size:
- shard-bmg: [TIMEOUT][236] ([Intel XE#7935]) -> [TIMEOUT][237] ([Intel XE#8451])
[236]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@kms_cursor_legacy@cursora-vs-flipa-atomic-transitions-varying-size.html
[237]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-9/igt@kms_cursor_legacy@cursora-vs-flipa-atomic-transitions-varying-size.html
* igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size:
- shard-bmg: [TIMEOUT][238] ([Intel XE#8451]) -> [INCOMPLETE][239] ([Intel XE#8151]) +3 other tests incomplete
[238]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size.html
[239]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_cursor_legacy@cursorb-vs-flipb-atomic-transitions-varying-size.html
* igt@kms_cursor_legacy@short-busy-flip-before-cursor-atomic-transitions-varying-size:
- shard-bmg: [INCOMPLETE][240] ([Intel XE#8151]) -> [SKIP][241] ([Intel XE#2286] / [Intel XE#6035]) +1 other test skip
[240]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_cursor_legacy@short-busy-flip-before-cursor-atomic-transitions-varying-size.html
[241]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_cursor_legacy@short-busy-flip-before-cursor-atomic-transitions-varying-size.html
* igt@kms_flip_scaled_crc@flip-32bpp-ytileccs-to-64bpp-ytile-downscaling:
- shard-bmg: [SKIP][242] ([Intel XE#7178] / [Intel XE#7351]) -> [SKIP][243] ([Intel XE#8440])
[242]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_flip_scaled_crc@flip-32bpp-ytileccs-to-64bpp-ytile-downscaling.html
[243]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_flip_scaled_crc@flip-32bpp-ytileccs-to-64bpp-ytile-downscaling.html
* igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling:
- shard-bmg: [SKIP][244] ([Intel XE#8440]) -> [SKIP][245] ([Intel XE#7178] / [Intel XE#7349])
[244]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling.html
[245]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-32bpp-ytilegen12rcccs-upscaling:
- shard-bmg: [INCOMPLETE][246] ([Intel XE#8437]) -> [SKIP][247] ([Intel XE#7178] / [Intel XE#7351])
[246]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-8/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-32bpp-ytilegen12rcccs-upscaling.html
[247]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-32bpp-ytilegen12rcccs-upscaling.html
* igt@kms_frontbuffer_tracking@drrshdr-1p-primscrn-pri-shrfb-draw-render:
- shard-bmg: [SKIP][248] ([Intel XE#2311]) -> [INCOMPLETE][249] ([Intel XE#8368]) +2 other tests incomplete
[248]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@kms_frontbuffer_tracking@drrshdr-1p-primscrn-pri-shrfb-draw-render.html
[249]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_frontbuffer_tracking@drrshdr-1p-primscrn-pri-shrfb-draw-render.html
* igt@kms_frontbuffer_tracking@drrshdr-argb161616f-draw-blt:
- shard-bmg: [SKIP][250] ([Intel XE#8440]) -> [SKIP][251] ([Intel XE#7061]) +1 other test skip
[250]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@drrshdr-argb161616f-draw-blt.html
[251]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_frontbuffer_tracking@drrshdr-argb161616f-draw-blt.html
* igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-blt:
- shard-bmg: [SKIP][252] ([Intel XE#8440]) -> [SKIP][253] ([Intel XE#4141]) +3 other tests skip
[252]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-blt.html
[253]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-cur-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-1p-offscreen-pri-shrfb-draw-blt:
- shard-bmg: [SKIP][254] ([Intel XE#8440]) -> [SKIP][255] ([Intel XE#2311]) +12 other tests skip
[254]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_frontbuffer_tracking@fbcdrrs-1p-offscreen-pri-shrfb-draw-blt.html
[255]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@kms_frontbuffer_tracking@fbcdrrs-1p-offscreen-pri-shrfb-draw-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-cur-indfb-move:
- shard-bmg: [SKIP][256] ([Intel XE#2311]) -> [SKIP][257] ([Intel XE#8440]) +1 other test skip
[256]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-cur-indfb-move.html
[257]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_frontbuffer_tracking@fbcdrrs-2p-primscrn-cur-indfb-move.html
* igt@kms_frontbuffer_tracking@fbcdrrshdr-1p-primscrn-spr-indfb-draw-render:
- shard-bmg: [INCOMPLETE][258] ([Intel XE#8368]) -> [SKIP][259] ([Intel XE#2311])
[258]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-8/igt@kms_frontbuffer_tracking@fbcdrrshdr-1p-primscrn-spr-indfb-draw-render.html
[259]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_frontbuffer_tracking@fbcdrrshdr-1p-primscrn-spr-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-cur-indfb-draw-mmap-wc:
- shard-bmg: [TIMEOUT][260] -> [INCOMPLETE][261] ([Intel XE#8368])
[260]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-8/igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-cur-indfb-draw-mmap-wc.html
[261]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_frontbuffer_tracking@fbchdr-1p-primscrn-cur-indfb-draw-mmap-wc.html
* igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-indfb-draw-render:
- shard-bmg: [SKIP][262] ([Intel XE#8440]) -> [INCOMPLETE][263] ([Intel XE#8368])
[262]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-indfb-draw-render.html
[263]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_frontbuffer_tracking@fbchdr-2p-scndscrn-pri-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-offscreen-pri-indfb-draw-blt:
- shard-bmg: [TIMEOUT][264] -> [SKIP][265] ([Intel XE#2313])
[264]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-offscreen-pri-indfb-draw-blt.html
[265]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@kms_frontbuffer_tracking@fbcpsrhdr-1p-offscreen-pri-indfb-draw-blt.html
* igt@kms_frontbuffer_tracking@pipe-fbc-rte:
- shard-bmg: [SKIP][266] ([Intel XE#4141]) -> [SKIP][267] ([Intel XE#8440]) +1 other test skip
[266]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_frontbuffer_tracking@pipe-fbc-rte.html
[267]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_frontbuffer_tracking@pipe-fbc-rte.html
* igt@kms_frontbuffer_tracking@psr-abgr161616f-draw-render:
- shard-bmg: [SKIP][268] ([Intel XE#8440]) -> [SKIP][269] ([Intel XE#7061] / [Intel XE#7356])
[268]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@psr-abgr161616f-draw-render.html
[269]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_frontbuffer_tracking@psr-abgr161616f-draw-render.html
* igt@kms_frontbuffer_tracking@psrhdr-1p-primscrn-pri-shrfb-draw-render:
- shard-bmg: [SKIP][270] ([Intel XE#8440]) -> [SKIP][271] ([Intel XE#2313]) +17 other tests skip
[270]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_frontbuffer_tracking@psrhdr-1p-primscrn-pri-shrfb-draw-render.html
[271]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_frontbuffer_tracking@psrhdr-1p-primscrn-pri-shrfb-draw-render.html
* igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-cur-indfb-draw-render:
- shard-bmg: [SKIP][272] ([Intel XE#2313]) -> [INCOMPLETE][273] ([Intel XE#8368])
[272]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-8/igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-cur-indfb-draw-render.html
[273]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-cur-indfb-draw-render.html
* igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-pri-shrfb-draw-render:
- shard-bmg: [SKIP][274] ([Intel XE#2313]) -> [SKIP][275] ([Intel XE#8440])
[274]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-pri-shrfb-draw-render.html
[275]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_frontbuffer_tracking@psrhdr-2p-scndscrn-pri-shrfb-draw-render.html
* igt@kms_hdr@brightness-with-hdr:
- shard-bmg: [SKIP][276] ([Intel XE#3544]) -> [SKIP][277] ([Intel XE#3374] / [Intel XE#3544])
[276]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-4/igt@kms_hdr@brightness-with-hdr.html
[277]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-8/igt@kms_hdr@brightness-with-hdr.html
* igt@kms_plane@pixel-format-4-tiled-mtl-mc-ccs-modifier-source-clamping:
- shard-bmg: [INCOMPLETE][278] ([Intel XE#1035]) -> [SKIP][279] ([Intel XE#7283])
[278]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_plane@pixel-format-4-tiled-mtl-mc-ccs-modifier-source-clamping.html
[279]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@kms_plane@pixel-format-4-tiled-mtl-mc-ccs-modifier-source-clamping.html
* igt@kms_plane@pixel-format-y-tiled-gen12-mc-ccs-modifier-source-clamping:
- shard-bmg: [SKIP][280] ([Intel XE#7283]) -> [INCOMPLETE][281] ([Intel XE#1035]) +1 other test incomplete
[280]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_plane@pixel-format-y-tiled-gen12-mc-ccs-modifier-source-clamping.html
[281]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_plane@pixel-format-y-tiled-gen12-mc-ccs-modifier-source-clamping.html
* igt@kms_plane@pixel-format-yf-tiled-ccs-modifier:
- shard-bmg: [SKIP][282] ([Intel XE#7283]) -> [SKIP][283] ([Intel XE#8440])
[282]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_plane@pixel-format-yf-tiled-ccs-modifier.html
[283]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_plane@pixel-format-yf-tiled-ccs-modifier.html
* igt@kms_psr2_sf@pr-overlay-plane-update-sf-dmg-area:
- shard-bmg: [SKIP][284] ([Intel XE#8440]) -> [SKIP][285] ([Intel XE#1489]) +2 other tests skip
[284]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_psr2_sf@pr-overlay-plane-update-sf-dmg-area.html
[285]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_psr2_sf@pr-overlay-plane-update-sf-dmg-area.html
* igt@kms_psr2_su@page_flip-nv12:
- shard-bmg: [SKIP][286] ([Intel XE#8440]) -> [SKIP][287] ([Intel XE#2387] / [Intel XE#7429])
[286]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_psr2_su@page_flip-nv12.html
[287]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_psr2_su@page_flip-nv12.html
* igt@kms_psr@pr-primary-blt:
- shard-bmg: [SKIP][288] ([Intel XE#2234] / [Intel XE#2850]) -> [SKIP][289] ([Intel XE#8440])
[288]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@kms_psr@pr-primary-blt.html
[289]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@kms_psr@pr-primary-blt.html
* igt@kms_psr@psr-basic:
- shard-bmg: [SKIP][290] ([Intel XE#8440]) -> [SKIP][291] ([Intel XE#2234] / [Intel XE#2850]) +1 other test skip
[290]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_psr@psr-basic.html
[291]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_psr@psr-basic.html
* igt@kms_sharpness_filter@filter-tap:
- shard-bmg: [SKIP][292] ([Intel XE#8440]) -> [SKIP][293] ([Intel XE#6503])
[292]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@kms_sharpness_filter@filter-tap.html
[293]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@kms_sharpness_filter@filter-tap.html
* igt@xe_eudebug@basic-vm-access-faultable:
- shard-bmg: [SKIP][294] ([Intel XE#7636]) -> [SKIP][295] ([Intel XE#8440]) +1 other test skip
[294]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_eudebug@basic-vm-access-faultable.html
[295]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_eudebug@basic-vm-access-faultable.html
* igt@xe_eudebug_online@stopped-thread:
- shard-bmg: [SKIP][296] ([Intel XE#8440]) -> [SKIP][297] ([Intel XE#7636]) +2 other tests skip
[296]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_eudebug_online@stopped-thread.html
[297]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_eudebug_online@stopped-thread.html
* igt@xe_evict@evict-small-external-multi-queue-cm:
- shard-bmg: [SKIP][298] ([Intel XE#8440]) -> [SKIP][299] ([Intel XE#8370])
[298]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_evict@evict-small-external-multi-queue-cm.html
[299]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_evict@evict-small-external-multi-queue-cm.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-userptr:
- shard-bmg: [INCOMPLETE][300] ([Intel XE#8439]) -> [SKIP][301] ([Intel XE#2322] / [Intel XE#7372])
[300]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-userptr.html
[301]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-bindexecqueue-userptr.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-rebind:
- shard-bmg: [SKIP][302] ([Intel XE#8440]) -> [SKIP][303] ([Intel XE#2322] / [Intel XE#7372]) +2 other tests skip
[302]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-rebind.html
[303]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-rebind.html
* igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr-invalidate:
- shard-bmg: [SKIP][304] ([Intel XE#2322] / [Intel XE#7372]) -> [SKIP][305] ([Intel XE#8440])
[304]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr-invalidate.html
[305]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_basic@multigpu-many-execqueues-many-vm-userptr-invalidate.html
* igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate:
- shard-bmg: [SKIP][306] ([Intel XE#8440]) -> [INCOMPLETE][307] ([Intel XE#8439])
[306]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate.html
[307]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate.html
* igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate-race:
- shard-bmg: [SKIP][308] ([Intel XE#2322] / [Intel XE#7372]) -> [INCOMPLETE][309] ([Intel XE#8439])
[308]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-7/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate-race.html
[309]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-4/igt@xe_exec_basic@multigpu-no-exec-bindexecqueue-userptr-invalidate-race.html
* igt@xe_exec_fault_mode@once-multi-queue-userptr-imm:
- shard-bmg: [SKIP][310] ([Intel XE#8374]) -> [SKIP][311] ([Intel XE#8440])
[310]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_exec_fault_mode@once-multi-queue-userptr-imm.html
[311]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_fault_mode@once-multi-queue-userptr-imm.html
* igt@xe_exec_multi_queue@two-queues-dyn-priority:
- shard-bmg: [SKIP][312] ([Intel XE#8364]) -> [SKIP][313] ([Intel XE#8440])
[312]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_exec_multi_queue@two-queues-dyn-priority.html
[313]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_exec_multi_queue@two-queues-dyn-priority.html
* igt@xe_exec_multi_queue@two-queues-preempt-mode-priority-smem:
- shard-bmg: [SKIP][314] ([Intel XE#8440]) -> [SKIP][315] ([Intel XE#8364]) +6 other tests skip
[314]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_multi_queue@two-queues-preempt-mode-priority-smem.html
[315]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_multi_queue@two-queues-preempt-mode-priority-smem.html
* igt@xe_exec_system_allocator@threads-many-execqueues-mmap-shared-remap-dontunmap-eocheck:
- shard-bmg: [INCOMPLETE][316] ([Intel XE#8159]) -> [TIMEOUT][317] ([Intel XE#8447])
[316]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-shared-remap-dontunmap-eocheck.html
[317]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@xe_exec_system_allocator@threads-many-execqueues-mmap-shared-remap-dontunmap-eocheck.html
* igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-busy-nomemset:
- shard-bmg: [SKIP][318] ([Intel XE#8440]) -> [INCOMPLETE][319] ([Intel XE#8159]) +2 other tests incomplete
[318]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-busy-nomemset.html
[319]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-10/igt@xe_exec_system_allocator@threads-shared-vm-many-large-execqueues-malloc-busy-nomemset.html
* igt@xe_exec_threads@threads-multi-queue-cm-fd-userptr:
- shard-bmg: [SKIP][320] ([Intel XE#8440]) -> [SKIP][321] ([Intel XE#8378]) +1 other test skip
[320]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-1/igt@xe_exec_threads@threads-multi-queue-cm-fd-userptr.html
[321]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-3/igt@xe_exec_threads@threads-multi-queue-cm-fd-userptr.html
* igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-rebind:
- shard-bmg: [INCOMPLETE][322] ([Intel XE#8366]) -> [SKIP][323] ([Intel XE#8378]) +1 other test skip
[322]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-10/igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-rebind.html
[323]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-7/igt@xe_exec_threads@threads-multi-queue-mixed-shared-vm-userptr-rebind.html
* igt@xe_pat@pat-index-xelpg:
- shard-bmg: [SKIP][324] ([Intel XE#2236] / [Intel XE#7590]) -> [SKIP][325] ([Intel XE#8440])
[324]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_pat@pat-index-xelpg.html
[325]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-1/igt@xe_pat@pat-index-xelpg.html
* igt@xe_pxp@pxp-stale-bo-bind-post-suspend:
- shard-bmg: [SKIP][326] ([Intel XE#8440]) -> [SKIP][327] ([Intel XE#4733] / [Intel XE#7417])
[326]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-5/igt@xe_pxp@pxp-stale-bo-bind-post-suspend.html
[327]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-5/igt@xe_pxp@pxp-stale-bo-bind-post-suspend.html
* igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled:
- shard-bmg: [INCOMPLETE][328] -> [INCOMPLETE][329] ([Intel XE#8437])
[328]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973/shard-bmg-9/igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled.html
[329]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/shard-bmg-2/igt@xe_sriov_admin@preempt-timeout-write-readback-vfs-disabled.html
[Intel XE#1035]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1035
[Intel XE#1124]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1124
[Intel XE#1127]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1127
[Intel XE#1178]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1178
[Intel XE#1392]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1392
[Intel XE#1407]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1407
[Intel XE#1421]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1421
[Intel XE#1424]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1424
[Intel XE#1489]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1489
[Intel XE#1499]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1499
[Intel XE#1508]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1508
[Intel XE#2233]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2233
[Intel XE#2234]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2234
[Intel XE#2236]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2236
[Intel XE#2252]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2252
[Intel XE#2284]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2284
[Intel XE#2286]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2286
[Intel XE#2311]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2311
[Intel XE#2313]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2313
[Intel XE#2320]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2320
[Intel XE#2321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2321
[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#2330]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2330
[Intel XE#2352]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2352
[Intel XE#2387]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2387
[Intel XE#2393]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2393
[Intel XE#2427]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2427
[Intel XE#2652]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2652
[Intel XE#2724]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2724
[Intel XE#2850]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2850
[Intel XE#2887]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2887
[Intel XE#301]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/301
[Intel XE#3304]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3304
[Intel XE#3374]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3374
[Intel XE#3432]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3432
[Intel XE#3544]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3544
[Intel XE#366]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/366
[Intel XE#367]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/367
[Intel XE#3904]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3904
[Intel XE#4141]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4141
[Intel XE#4298]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4298
[Intel XE#4354]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4354
[Intel XE#4733]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4733
[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#5100]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5100
[Intel XE#5643]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5643
[Intel XE#5813]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5813
[Intel XE#584]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/584
[Intel XE#5873]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5873
[Intel XE#6035]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6035
[Intel XE#607]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/607
[Intel XE#6126]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6126
[Intel XE#6312]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6312
[Intel XE#6503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6503
[Intel XE#6540]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6540
[Intel XE#656]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/656
[Intel XE#6627]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6627
[Intel XE#688]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/688
[Intel XE#6901]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6901
[Intel XE#6953]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6953
[Intel XE#6964]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6964
[Intel XE#6974]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6974
[Intel XE#7059]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7059
[Intel XE#7061]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7061
[Intel XE#7085]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7085
[Intel XE#7178]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7178
[Intel XE#7179]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7179
[Intel XE#7283]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7283
[Intel XE#7322]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7322
[Intel XE#7326]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7326
[Intel XE#7342]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7342
[Intel XE#7348]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7348
[Intel XE#7349]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7349
[Intel XE#7351]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7351
[Intel XE#7353]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7353
[Intel XE#7355]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7355
[Intel XE#7356]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7356
[Intel XE#7358]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7358
[Intel XE#7361]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7361
[Intel XE#7369]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7369
[Intel XE#7370]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7370
[Intel XE#7372]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7372
[Intel XE#7374]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7374
[Intel XE#7377]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7377
[Intel XE#7386]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7386
[Intel XE#7399]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7399
[Intel XE#7408]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7408
[Intel XE#7417]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7417
[Intel XE#7419]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7419
[Intel XE#7429]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7429
[Intel XE#7449]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7449
[Intel XE#7482]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7482
[Intel XE#7590]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7590
[Intel XE#7636]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7636
[Intel XE#7642]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7642
[Intel XE#7679]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7679
[Intel XE#7695]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7695
[Intel XE#776]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/776
[Intel XE#7793]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7793
[Intel XE#7865]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7865
[Intel XE#7905]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7905
[Intel XE#7935]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7935
[Intel XE#8007]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8007
[Intel XE#8150]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8150
[Intel XE#8151]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8151
[Intel XE#8155]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8155
[Intel XE#8159]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8159
[Intel XE#8174]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8174
[Intel XE#8265]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8265
[Intel XE#8303]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8303
[Intel XE#8361]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8361
[Intel XE#8364]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8364
[Intel XE#8366]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8366
[Intel XE#8368]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8368
[Intel XE#8369]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8369
[Intel XE#8370]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8370
[Intel XE#8374]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8374
[Intel XE#8378]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8378
[Intel XE#8437]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8437
[Intel XE#8439]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8439
[Intel XE#8440]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8440
[Intel XE#8441]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8441
[Intel XE#8445]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8445
[Intel XE#8446]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8446
[Intel XE#8447]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8447
[Intel XE#8448]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8448
[Intel XE#8449]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8449
[Intel XE#8450]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8450
[Intel XE#8451]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8451
[Intel XE#944]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/944
Build changes
-------------
* Linux: xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973 -> xe-pw-169129v1
IGT_8985: d5fe8732b8547454c38fdd220b55f6f0cc841a3b @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5299-adbc617250e16fb2db4a4c777b89440927cb8973: adbc617250e16fb2db4a4c777b89440927cb8973
xe-pw-169129v1: 169129v1
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v1/index.html
[-- Attachment #2: Type: text/html, Size: 113623 bytes --]
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
` (2 preceding siblings ...)
2026-06-25 7:43 ` ✗ Xe.CI.FULL: " Patchwork
@ 2026-06-25 10:45 ` Christian König
2026-06-25 17:10 ` Gote, Nitin R
2026-06-29 9:18 ` Thomas Hellström
4 siblings, 1 reply; 14+ messages in thread
From: Christian König @ 2026-06-25 10:45 UTC (permalink / raw)
To: Nitin Gote, intel-xe; +Cc: stable, Thomas Hellstrom, Matthew Auld
On 6/25/26 07:57, Nitin Gote wrote:
> When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
> fails, no dma_buf reference is held. The exporter can be freed before
> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing a
> use-after-free:
>
> Oops: general protection fault, probably for non-canonical address
> 0x6b6b6b6b6b6b6b9c
> Workqueue: ttm ttm_bo_delayed_delete [ttm]
> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>
> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
> the shared resv available for delayed_delete to release the dma-buf
> mapping. A BO whose attach never succeeded has no mapping to release,
> yet it keeps bo->base.resv pointing at the exporter resv that
> delayed_delete later locks once the exporter is gone.
>
> Fix this by checking bo->base.import_attach, which is only set after
> successful dma_buf_dynamic_attach(). Failed imports now individualize
> normally, so delayed_delete operates on the BO's private _resv. The
> exporter remains alive during individualize as it runs synchronously
> in ttm_bo_release(), while the gem_prime_import caller still holds
> its dma_buf reference.
>
> Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path for imported bos")
> Cc: stable@vger.kernel.org # v6.8+
> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> Cc: Christian Konig <christian.koenig@amd.com>
> Cc: Matthew Auld <matthew.auld@intel.com>
> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> ---
> v3:
> - Dropped the xe-side reordering approach since importer_priv must be
> valid when dma_buf_dynamic_attach() publishes the attachment.
> - Per Christian's suggestion on the v1 thread, keyed the check on
> import_attach rather than removing the sg guard entirely.
> - Exporter lifetime: individualize runs synchronously inside
> ttm_bo_release(), called from drm_gem_object_put() in the
> gem_prime_import error path while drm_gem_prime_fd_to_handle()
> still holds its dma_buf reference.
> - Fixes both xe and amdgpu in a single TTM patch.
>
> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> 1 file changed, 15 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
> index bcd76f6bb7f0..bf8eaec0e9ca 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -196,6 +196,14 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
> if (bo->base.resv == &bo->base._resv)
> return 0;
>
> + /*
> + * Successfully imported sg BOs need the shared resv for dma-buf
> + * cleanup. Failed imports have no attachment or mapping and can
> + * use the private _resv.
> + */
> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
> + return 0;
> +
Yeah, that approach looks good to me.
I'm only wondering if some other code than the DMA-buf imports who uses ttm_bo_type_sg could potentially be problematic here. The KFD stuff comes to mind for example.
Maybe ask some AI tool who and how ttm_bo_type_sg is used and double check. I don't think there is a problem, but just to be sure.
Thanks,
Christian.
> BUG_ON(!dma_resv_trylock(&bo->base._resv));
>
> r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv);
> @@ -203,15 +211,13 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
> if (r)
> return r;
>
> - if (bo->type != ttm_bo_type_sg) {
> - /* This works because the BO is about to be destroyed and nobody
> - * reference it any more. The only tricky case is the trylock on
> - * the resv object while holding the lru_lock.
> - */
> - spin_lock(&bo->bdev->lru_lock);
> - bo->base.resv = &bo->base._resv;
> - spin_unlock(&bo->bdev->lru_lock);
> - }
> + /* This works because the BO is about to be destroyed and nobody
> + * references it any more. The only tricky case is the trylock on
> + * the resv object while holding the lru_lock.
> + */
> + spin_lock(&bo->bdev->lru_lock);
> + bo->base.resv = &bo->base._resv;
> + spin_unlock(&bo->bdev->lru_lock);
>
> return r;
> }
^ permalink raw reply [flat|nested] 14+ messages in thread
* RE: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 10:45 ` [PATCH] " Christian König
@ 2026-06-25 17:10 ` Gote, Nitin R
2026-06-29 12:09 ` Christian König
0 siblings, 1 reply; 14+ messages in thread
From: Gote, Nitin R @ 2026-06-25 17:10 UTC (permalink / raw)
To: Christian König, intel-xe@lists.freedesktop.org
Cc: stable@vger.kernel.org, Thomas Hellstrom, Auld, Matthew
> -----Original Message-----
> From: Christian König <christian.koenig@amd.com>
> Sent: Thursday, June 25, 2026 4:16 PM
> To: Gote, Nitin R <nitin.r.gote@intel.com>; intel-xe@lists.freedesktop.org
> Cc: stable@vger.kernel.org; Thomas Hellstrom
> <thomas.hellstrom@linux.intel.com>; Auld, Matthew <matthew.auld@intel.com>
> Subject: Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
>
> On 6/25/26 07:57, Nitin Gote wrote:
> > When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
> > pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
> > fails, no dma_buf reference is held. The exporter can be freed before
> > the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing
> > a
> > use-after-free:
> >
> > Oops: general protection fault, probably for non-canonical address
> > 0x6b6b6b6b6b6b6b9c
> > Workqueue: ttm ttm_bo_delayed_delete [ttm]
> > RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
> >
> > ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
> > the shared resv available for delayed_delete to release the dma-buf
> > mapping. A BO whose attach never succeeded has no mapping to release,
> > yet it keeps bo->base.resv pointing at the exporter resv that
> > delayed_delete later locks once the exporter is gone.
> >
> > Fix this by checking bo->base.import_attach, which is only set after
> > successful dma_buf_dynamic_attach(). Failed imports now individualize
> > normally, so delayed_delete operates on the BO's private _resv. The
> > exporter remains alive during individualize as it runs synchronously
> > in ttm_bo_release(), while the gem_prime_import caller still holds its
> > dma_buf reference.
> >
> > Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> > Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path
> > for imported bos")
> > Cc: stable@vger.kernel.org # v6.8+
> > Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> > Cc: Christian Konig <christian.koenig@amd.com>
> > Cc: Matthew Auld <matthew.auld@intel.com>
> > Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> > Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> > ---
> > v3:
> > - Dropped the xe-side reordering approach since importer_priv must be
> > valid when dma_buf_dynamic_attach() publishes the attachment.
> > - Per Christian's suggestion on the v1 thread, keyed the check on
> > import_attach rather than removing the sg guard entirely.
> > - Exporter lifetime: individualize runs synchronously inside
> > ttm_bo_release(), called from drm_gem_object_put() in the
> > gem_prime_import error path while drm_gem_prime_fd_to_handle()
> > still holds its dma_buf reference.
> > - Fixes both xe and amdgpu in a single TTM patch.
> >
> > drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> > 1 file changed, 15 insertions(+), 9 deletions(-)
> >
> > diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
> > b/drivers/gpu/drm/ttm/ttm_bo.c index bcd76f6bb7f0..bf8eaec0e9ca 100644
> > --- a/drivers/gpu/drm/ttm/ttm_bo.c
> > +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> > @@ -196,6 +196,14 @@ static int ttm_bo_individualize_resv(struct
> ttm_buffer_object *bo)
> > if (bo->base.resv == &bo->base._resv)
> > return 0;
> >
> > + /*
> > + * Successfully imported sg BOs need the shared resv for dma-buf
> > + * cleanup. Failed imports have no attachment or mapping and can
> > + * use the private _resv.
> > + */
> > + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
> > + return 0;
> > +
>
> Yeah, that approach looks good to me.
>
> I'm only wondering if some other code than the DMA-buf imports who uses
> ttm_bo_type_sg could potentially be problematic here. The KFD stuff comes to
> mind for example.
>
> Maybe ask some AI tool who and how ttm_bo_type_sg is used and double check.
> I don't think there is a problem, but just to be sure.
>
I went through the other ttm_bo_type_sg users, though I'm not too familiar with the KFD code. Please correct me if I got something wrong.
At KFD create_dmamap_sg_bo(): It creates the sg BO with the parent's resv and never sets import_attach, so with this patch it now individualises.
That looks fine: the new sg BO holds an amdgpu_bo_ref() on the parent until its own amdgpu_bo_destroy(), so the parent resv is still valid
while dma_resv_copy_fences() runs (which reads the source under RCU anyway), and with no dma-buf attachment there's nothing that needs the shared
resv at cleanup.
The rest (KFD doorbell/MMIO and amdgpu_gart) create with resv = NULL, so resv already points at _resv and the first check in ttm_bo_individualize_resv()
returns early, so no change there.
Seems like there is no problem in KFD case.
Regards,
Nitin
> Thanks,
> Christian.
>
> > BUG_ON(!dma_resv_trylock(&bo->base._resv));
> >
> > r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv); @@ -
> 203,15
> > +211,13 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
> > if (r)
> > return r;
> >
> > - if (bo->type != ttm_bo_type_sg) {
> > - /* This works because the BO is about to be destroyed and
> nobody
> > - * reference it any more. The only tricky case is the trylock on
> > - * the resv object while holding the lru_lock.
> > - */
> > - spin_lock(&bo->bdev->lru_lock);
> > - bo->base.resv = &bo->base._resv;
> > - spin_unlock(&bo->bdev->lru_lock);
> > - }
> > + /* This works because the BO is about to be destroyed and nobody
> > + * references it any more. The only tricky case is the trylock on
> > + * the resv object while holding the lru_lock.
> > + */
> > + spin_lock(&bo->bdev->lru_lock);
> > + bo->base.resv = &bo->base._resv;
> > + spin_unlock(&bo->bdev->lru_lock);
> >
> > return r;
> > }
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
` (3 preceding siblings ...)
2026-06-25 10:45 ` [PATCH] " Christian König
@ 2026-06-29 9:18 ` Thomas Hellström
4 siblings, 0 replies; 14+ messages in thread
From: Thomas Hellström @ 2026-06-29 9:18 UTC (permalink / raw)
To: Nitin Gote, intel-xe; +Cc: stable, Christian Konig, Matthew Auld
On Thu, 2026-06-25 at 11:27 +0530, Nitin Gote wrote:
> When a dma-buf importer creates a ttm_bo_type_sg BO with bo-
> >base.resv
> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
> fails, no dma_buf reference is held. The exporter can be freed before
> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing
> a
> use-after-free:
>
> Oops: general protection fault, probably for non-canonical address
> 0x6b6b6b6b6b6b6b9c
> Workqueue: ttm ttm_bo_delayed_delete [ttm]
> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>
> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to
> keep
> the shared resv available for delayed_delete to release the dma-buf
> mapping. A BO whose attach never succeeded has no mapping to release,
> yet it keeps bo->base.resv pointing at the exporter resv that
> delayed_delete later locks once the exporter is gone.
>
> Fix this by checking bo->base.import_attach, which is only set after
> successful dma_buf_dynamic_attach(). Failed imports now individualize
> normally, so delayed_delete operates on the BO's private _resv. The
> exporter remains alive during individualize as it runs synchronously
> in ttm_bo_release(), while the gem_prime_import caller still holds
> its dma_buf reference.
I think since the bo is published on the LRU, a LRU walk can still grab
a bo reference before the prime_import caller calls put(). So this
doesn't necessarily hold?
>
> Closes:
> https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup
> path for imported bos")
> Cc: stable@vger.kernel.org # v6.8+
> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> Cc: Christian Konig <christian.koenig@amd.com>
> Cc: Matthew Auld <matthew.auld@intel.com>
> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> ---
> v3:
> - Dropped the xe-side reordering approach since importer_priv must be
> valid when dma_buf_dynamic_attach() publishes the attachment.
> - Per Christian's suggestion on the v1 thread, keyed the check on
> import_attach rather than removing the sg guard entirely.
> - Exporter lifetime: individualize runs synchronously inside
> ttm_bo_release(), called from drm_gem_object_put() in the
> gem_prime_import error path while drm_gem_prime_fd_to_handle()
> still holds its dma_buf reference.
> - Fixes both xe and amdgpu in a single TTM patch.
>
> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> 1 file changed, 15 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
> b/drivers/gpu/drm/ttm/ttm_bo.c
> index bcd76f6bb7f0..bf8eaec0e9ca 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -196,6 +196,14 @@ static int ttm_bo_individualize_resv(struct
> ttm_buffer_object *bo)
> if (bo->base.resv == &bo->base._resv)
> return 0;
>
> + /*
> + * Successfully imported sg BOs need the shared resv for
> dma-buf
> + * cleanup. Failed imports have no attachment or mapping and
> can
> + * use the private _resv.
> + */
> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
> + return 0;
> +
You would still need to copy the current fences to _resv here, because
otherwise, the object can be premaurely released. It's considered idle
when the fences attached to _resv have all signaled. So this needs to
be moved below the fence duplication below.
Thanks,
Thomas
> BUG_ON(!dma_resv_trylock(&bo->base._resv));
>
> r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv);
> @@ -203,15 +211,13 @@ static int ttm_bo_individualize_resv(struct
> ttm_buffer_object *bo)
> if (r)
> return r;
>
> - if (bo->type != ttm_bo_type_sg) {
> - /* This works because the BO is about to be
> destroyed and nobody
> - * reference it any more. The only tricky case is
> the trylock on
> - * the resv object while holding the lru_lock.
> - */
> - spin_lock(&bo->bdev->lru_lock);
> - bo->base.resv = &bo->base._resv;
> - spin_unlock(&bo->bdev->lru_lock);
> - }
> + /* This works because the BO is about to be destroyed and
> nobody
> + * references it any more. The only tricky case is the
> trylock on
> + * the resv object while holding the lru_lock.
> + */
> + spin_lock(&bo->bdev->lru_lock);
> + bo->base.resv = &bo->base._resv;
> + spin_unlock(&bo->bdev->lru_lock);
>
> return r;
> }
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-06-25 17:10 ` Gote, Nitin R
@ 2026-06-29 12:09 ` Christian König
0 siblings, 0 replies; 14+ messages in thread
From: Christian König @ 2026-06-29 12:09 UTC (permalink / raw)
To: Gote, Nitin R, intel-xe@lists.freedesktop.org
Cc: stable@vger.kernel.org, Thomas Hellstrom, Auld, Matthew
On 6/25/26 19:10, Gote, Nitin R wrote:
>> -----Original Message-----
>> From: Christian König <christian.koenig@amd.com>
>> Sent: Thursday, June 25, 2026 4:16 PM
>> To: Gote, Nitin R <nitin.r.gote@intel.com>; intel-xe@lists.freedesktop.org
>> Cc: stable@vger.kernel.org; Thomas Hellstrom
>> <thomas.hellstrom@linux.intel.com>; Auld, Matthew <matthew.auld@intel.com>
>> Subject: Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
>>
>> On 6/25/26 07:57, Nitin Gote wrote:
>>> When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
>>> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
>>> fails, no dma_buf reference is held. The exporter can be freed before
>>> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing
>>> a
>>> use-after-free:
>>>
>>> Oops: general protection fault, probably for non-canonical address
>>> 0x6b6b6b6b6b6b6b9c
>>> Workqueue: ttm ttm_bo_delayed_delete [ttm]
>>> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>>>
>>> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
>>> the shared resv available for delayed_delete to release the dma-buf
>>> mapping. A BO whose attach never succeeded has no mapping to release,
>>> yet it keeps bo->base.resv pointing at the exporter resv that
>>> delayed_delete later locks once the exporter is gone.
>>>
>>> Fix this by checking bo->base.import_attach, which is only set after
>>> successful dma_buf_dynamic_attach(). Failed imports now individualize
>>> normally, so delayed_delete operates on the BO's private _resv. The
>>> exporter remains alive during individualize as it runs synchronously
>>> in ttm_bo_release(), while the gem_prime_import caller still holds its
>>> dma_buf reference.
>>>
>>> Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
>>> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path
>>> for imported bos")
>>> Cc: stable@vger.kernel.org # v6.8+
>>> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
>>> Cc: Christian Konig <christian.koenig@amd.com>
>>> Cc: Matthew Auld <matthew.auld@intel.com>
>>> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
>>> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
>>> ---
>>> v3:
>>> - Dropped the xe-side reordering approach since importer_priv must be
>>> valid when dma_buf_dynamic_attach() publishes the attachment.
>>> - Per Christian's suggestion on the v1 thread, keyed the check on
>>> import_attach rather than removing the sg guard entirely.
>>> - Exporter lifetime: individualize runs synchronously inside
>>> ttm_bo_release(), called from drm_gem_object_put() in the
>>> gem_prime_import error path while drm_gem_prime_fd_to_handle()
>>> still holds its dma_buf reference.
>>> - Fixes both xe and amdgpu in a single TTM patch.
>>>
>>> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
>>> 1 file changed, 15 insertions(+), 9 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
>>> b/drivers/gpu/drm/ttm/ttm_bo.c index bcd76f6bb7f0..bf8eaec0e9ca 100644
>>> --- a/drivers/gpu/drm/ttm/ttm_bo.c
>>> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
>>> @@ -196,6 +196,14 @@ static int ttm_bo_individualize_resv(struct
>> ttm_buffer_object *bo)
>>> if (bo->base.resv == &bo->base._resv)
>>> return 0;
>>>
>>> + /*
>>> + * Successfully imported sg BOs need the shared resv for dma-buf
>>> + * cleanup. Failed imports have no attachment or mapping and can
>>> + * use the private _resv.
>>> + */
>>> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
>>> + return 0;
>>> +
>>
>> Yeah, that approach looks good to me.
>>
>> I'm only wondering if some other code than the DMA-buf imports who uses
>> ttm_bo_type_sg could potentially be problematic here. The KFD stuff comes to
>> mind for example.
>>
>> Maybe ask some AI tool who and how ttm_bo_type_sg is used and double check.
>> I don't think there is a problem, but just to be sure.
>>
>
> I went through the other ttm_bo_type_sg users, though I'm not too familiar with the KFD code. Please correct me if I got something wrong.
>
> At KFD create_dmamap_sg_bo(): It creates the sg BO with the parent's resv and never sets import_attach, so with this patch it now individualises.
> That looks fine: the new sg BO holds an amdgpu_bo_ref() on the parent until its own amdgpu_bo_destroy(), so the parent resv is still valid
> while dma_resv_copy_fences() runs (which reads the source under RCU anyway), and with no dma-buf attachment there's nothing that needs the shared
> resv at cleanup.
>
> The rest (KFD doorbell/MMIO and amdgpu_gart) create with resv = NULL, so resv already points at _resv and the first check in ttm_bo_individualize_resv()
> returns early, so no change there.
>
> Seems like there is no problem in KFD case.
Sounds good, with the issue mentioned by Thomas fixed I think that this should work.
Please update the patch and send out a new version for review.
Thanks,
Christian.
>
> Regards,
> Nitin
>
>> Thanks,
>> Christian.
>>
>>> BUG_ON(!dma_resv_trylock(&bo->base._resv));
>>>
>>> r = dma_resv_copy_fences(&bo->base._resv, bo->base.resv); @@ -
>> 203,15
>>> +211,13 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
>>> if (r)
>>> return r;
>>>
>>> - if (bo->type != ttm_bo_type_sg) {
>>> - /* This works because the BO is about to be destroyed and
>> nobody
>>> - * reference it any more. The only tricky case is the trylock on
>>> - * the resv object while holding the lru_lock.
>>> - */
>>> - spin_lock(&bo->bdev->lru_lock);
>>> - bo->base.resv = &bo->base._resv;
>>> - spin_unlock(&bo->bdev->lru_lock);
>>> - }
>>> + /* This works because the BO is about to be destroyed and nobody
>>> + * references it any more. The only tricky case is the trylock on
>>> + * the resv object while holding the lru_lock.
>>> + */
>>> + spin_lock(&bo->bdev->lru_lock);
>>> + bo->base.resv = &bo->base._resv;
>>> + spin_unlock(&bo->bdev->lru_lock);
>>>
>>> return r;
>>> }
>
^ permalink raw reply [flat|nested] 14+ messages in thread
* [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
@ 2026-07-01 6:26 Nitin Gote
2026-07-01 8:48 ` Christian König
2026-07-01 12:59 ` Thomas Hellström
0 siblings, 2 replies; 14+ messages in thread
From: Nitin Gote @ 2026-07-01 6:26 UTC (permalink / raw)
To: intel-xe
Cc: Nitin Gote, stable, Thomas Hellstrom, Christian Konig,
Matthew Auld
When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
fails, no dma_buf reference is held. The exporter can be freed before
the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing a
use-after-free:
Oops: general protection fault, probably for non-canonical address
0x6b6b6b6b6b6b6b9c
Workqueue: ttm ttm_bo_delayed_delete [ttm]
RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
the shared resv available for delayed_delete to release the dma-buf
mapping. A BO whose attach never succeeded has no mapping to release,
yet it keeps bo->base.resv pointing at the exporter resv that
delayed_delete later locks once the exporter is gone.
Fix this by checking bo->base.import_attach, which is set only after a
successful attach. The check is placed after dma_resv_copy_fences() so
successful imports still copy fences to _resv before returning, keeping
the shared resv for delayed_delete. Failed imports fall through to swap
resv to _resv, so delayed_delete never locks the stale exporter resv.
Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path for imported bos")
Cc: stable@vger.kernel.org # v6.8+
Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
Cc: Christian Konig <christian.koenig@amd.com>
Cc: Matthew Auld <matthew.auld@intel.com>
Assisted-by: GitHub_Copilot:claude-sonnet-4.6
Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
---
Hi Thomas/Christian,
Thank you for the review. Addressed the v3 review comments in this
v4 version.
v4:
- Moved import_attach check to after dma_resv_copy_fences() so fences
are copied before returning for successful imports (Thomas).
- Removed exporter-alive claim from commit message (Thomas).
v3:
- Dropped the xe-side reordering approach since importer_priv must be
valid when dma_buf_dynamic_attach() publishes the attachment.
- Per Christian's suggestion on the v1 thread, keyed the check on
import_attach rather than removing the sg guard entirely.
- Fixes both xe and amdgpu in a single TTM patch.
drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
1 file changed, 15 insertions(+), 9 deletions(-)
diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
index bcd76f6bb7f0..9b6341f69805 100644
--- a/drivers/gpu/drm/ttm/ttm_bo.c
+++ b/drivers/gpu/drm/ttm/ttm_bo.c
@@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
if (r)
return r;
- if (bo->type != ttm_bo_type_sg) {
- /* This works because the BO is about to be destroyed and nobody
- * reference it any more. The only tricky case is the trylock on
- * the resv object while holding the lru_lock.
- */
- spin_lock(&bo->bdev->lru_lock);
- bo->base.resv = &bo->base._resv;
- spin_unlock(&bo->bdev->lru_lock);
- }
+ /*
+ * Successfully imported sg BOs need the shared resv for dma-buf
+ * cleanup. Failed imports have no attachment or mapping and can
+ * use the private _resv.
+ */
+ if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
+ return 0;
+
+ /* This works because the BO is about to be destroyed and nobody
+ * references it any more. The only tricky case is the trylock on
+ * the resv object while holding the lru_lock.
+ */
+ spin_lock(&bo->bdev->lru_lock);
+ bo->base.resv = &bo->base._resv;
+ spin_unlock(&bo->bdev->lru_lock);
return r;
}
--
2.50.1
^ permalink raw reply related [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-07-01 6:26 Nitin Gote
@ 2026-07-01 8:48 ` Christian König
2026-07-01 12:59 ` Thomas Hellström
1 sibling, 0 replies; 14+ messages in thread
From: Christian König @ 2026-07-01 8:48 UTC (permalink / raw)
To: Nitin Gote, intel-xe; +Cc: stable, Thomas Hellstrom, Matthew Auld
On 7/1/26 08:26, Nitin Gote wrote:
> When a dma-buf importer creates a ttm_bo_type_sg BO with bo->base.resv
> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
> fails, no dma_buf reference is held. The exporter can be freed before
> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing a
> use-after-free:
>
> Oops: general protection fault, probably for non-canonical address
> 0x6b6b6b6b6b6b6b9c
> Workqueue: ttm ttm_bo_delayed_delete [ttm]
> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>
> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to keep
> the shared resv available for delayed_delete to release the dma-buf
> mapping. A BO whose attach never succeeded has no mapping to release,
> yet it keeps bo->base.resv pointing at the exporter resv that
> delayed_delete later locks once the exporter is gone.
>
> Fix this by checking bo->base.import_attach, which is set only after a
> successful attach. The check is placed after dma_resv_copy_fences() so
> successful imports still copy fences to _resv before returning, keeping
> the shared resv for delayed_delete. Failed imports fall through to swap
> resv to _resv, so delayed_delete never locks the stale exporter resv.
>
> Closes: https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup path for imported bos")
> Cc: stable@vger.kernel.org # v6.8+
> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> Cc: Christian Konig <christian.koenig@amd.com>
> Cc: Matthew Auld <matthew.auld@intel.com>
> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
> ---
> Hi Thomas/Christian,
> Thank you for the review. Addressed the v3 review comments in this
> v4 version.
>
> v4:
> - Moved import_attach check to after dma_resv_copy_fences() so fences
> are copied before returning for successful imports (Thomas).
> - Removed exporter-alive claim from commit message (Thomas).
>
> v3:
> - Dropped the xe-side reordering approach since importer_priv must be
> valid when dma_buf_dynamic_attach() publishes the attachment.
> - Per Christian's suggestion on the v1 thread, keyed the check on
> import_attach rather than removing the sg guard entirely.
> - Fixes both xe and amdgpu in a single TTM patch.
>
> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> 1 file changed, 15 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c b/drivers/gpu/drm/ttm/ttm_bo.c
> index bcd76f6bb7f0..9b6341f69805 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct ttm_buffer_object *bo)
> if (r)
> return r;
>
> - if (bo->type != ttm_bo_type_sg) {
> - /* This works because the BO is about to be destroyed and nobody
> - * reference it any more. The only tricky case is the trylock on
> - * the resv object while holding the lru_lock.
> - */
> - spin_lock(&bo->bdev->lru_lock);
> - bo->base.resv = &bo->base._resv;
> - spin_unlock(&bo->bdev->lru_lock);
> - }
> + /*
> + * Successfully imported sg BOs need the shared resv for dma-buf
> + * cleanup. Failed imports have no attachment or mapping and can
> + * use the private _resv.
> + */
> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
> + return 0;
> +
> + /* This works because the BO is about to be destroyed and nobody
> + * references it any more. The only tricky case is the trylock on
> + * the resv object while holding the lru_lock.
> + */
> + spin_lock(&bo->bdev->lru_lock);
> + bo->base.resv = &bo->base._resv;
> + spin_unlock(&bo->bdev->lru_lock);
>
> return r;
> }
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-07-01 6:26 Nitin Gote
2026-07-01 8:48 ` Christian König
@ 2026-07-01 12:59 ` Thomas Hellström
2026-07-01 13:20 ` Christian König
1 sibling, 1 reply; 14+ messages in thread
From: Thomas Hellström @ 2026-07-01 12:59 UTC (permalink / raw)
To: Nitin Gote, intel-xe; +Cc: stable, Christian Konig, Matthew Auld
Hi, Nitin
On Wed, 2026-07-01 at 11:56 +0530, Nitin Gote wrote:
> When a dma-buf importer creates a ttm_bo_type_sg BO with bo-
> >base.resv
> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
> fails, no dma_buf reference is held. The exporter can be freed before
> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing
> a
> use-after-free:
>
> Oops: general protection fault, probably for non-canonical address
> 0x6b6b6b6b6b6b6b9c
> Workqueue: ttm ttm_bo_delayed_delete [ttm]
> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>
> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to
> keep
> the shared resv available for delayed_delete to release the dma-buf
> mapping. A BO whose attach never succeeded has no mapping to release,
> yet it keeps bo->base.resv pointing at the exporter resv that
> delayed_delete later locks once the exporter is gone.
>
> Fix this by checking bo->base.import_attach, which is set only after
> a
> successful attach. The check is placed after dma_resv_copy_fences()
> so
> successful imports still copy fences to _resv before returning,
> keeping
> the shared resv for delayed_delete. Failed imports fall through to
> swap
> resv to _resv, so delayed_delete never locks the stale exporter resv.
>
> Closes:
> https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup
> path for imported bos")
> Cc: stable@vger.kernel.org # v6.8+
> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> Cc: Christian Konig <christian.koenig@amd.com>
> Cc: Matthew Auld <matthew.auld@intel.com>
> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> ---
> Hi Thomas/Christian,
> Thank you for the review. Addressed the v3 review comments in this
> v4 version.
>
> v4:
> - Moved import_attach check to after dma_resv_copy_fences() so fences
> are copied before returning for successful imports (Thomas).
> - Removed exporter-alive claim from commit message (Thomas).
That's not sufficient. What I meant was that this invalidates the
approach in its current form:
A B
prime_import()
exported_get();
exported_lock();
bo_create(); lru_walk():
attach_fail(); bo_get();
bo_put();
exported_unlock(); bo_lock() // exporter_lock
exporter_put();
exporter_free();
bo_unlock(); //UAF
There is no guarantee that the exporter stays alive until
resv individualization happens.
/Thomas
>
> v3:
> - Dropped the xe-side reordering approach since importer_priv must be
> valid when dma_buf_dynamic_attach() publishes the attachment.
> - Per Christian's suggestion on the v1 thread, keyed the check on
> import_attach rather than removing the sg guard entirely.
> - Fixes both xe and amdgpu in a single TTM patch.
>
> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> 1 file changed, 15 insertions(+), 9 deletions(-)
>
> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
> b/drivers/gpu/drm/ttm/ttm_bo.c
> index bcd76f6bb7f0..9b6341f69805 100644
> --- a/drivers/gpu/drm/ttm/ttm_bo.c
> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> @@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct
> ttm_buffer_object *bo)
> if (r)
> return r;
>
> - if (bo->type != ttm_bo_type_sg) {
> - /* This works because the BO is about to be
> destroyed and nobody
> - * reference it any more. The only tricky case is
> the trylock on
> - * the resv object while holding the lru_lock.
> - */
> - spin_lock(&bo->bdev->lru_lock);
> - bo->base.resv = &bo->base._resv;
> - spin_unlock(&bo->bdev->lru_lock);
> - }
> + /*
> + * Successfully imported sg BOs need the shared resv for
> dma-buf
> + * cleanup. Failed imports have no attachment or mapping and
> can
> + * use the private _resv.
> + */
> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
> + return 0;
> +
> + /* This works because the BO is about to be destroyed and
> nobody
> + * references it any more. The only tricky case is the
> trylock on
> + * the resv object while holding the lru_lock.
> + */
> + spin_lock(&bo->bdev->lru_lock);
> + bo->base.resv = &bo->base._resv;
> + spin_unlock(&bo->bdev->lru_lock);
>
> return r;
> }
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-07-01 12:59 ` Thomas Hellström
@ 2026-07-01 13:20 ` Christian König
2026-07-01 15:23 ` Thomas Hellström
0 siblings, 1 reply; 14+ messages in thread
From: Christian König @ 2026-07-01 13:20 UTC (permalink / raw)
To: Thomas Hellström, Nitin Gote, intel-xe; +Cc: stable, Matthew Auld
On 7/1/26 14:59, Thomas Hellström wrote:
> Hi, Nitin
>
> On Wed, 2026-07-01 at 11:56 +0530, Nitin Gote wrote:
>> When a dma-buf importer creates a ttm_bo_type_sg BO with bo-
>>> base.resv
>> pointing at the exporter's dma_buf->resv and dma_buf_dynamic_attach()
>> fails, no dma_buf reference is held. The exporter can be freed before
>> the delayed_delete worker calls dma_resv_lock(bo->base.resv), causing
>> a
>> use-after-free:
>>
>> Oops: general protection fault, probably for non-canonical address
>> 0x6b6b6b6b6b6b6b9c
>> Workqueue: ttm ttm_bo_delayed_delete [ttm]
>> RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
>>
>> ttm_bo_individualize_resv() skips the resv swap for all sg BOs to
>> keep
>> the shared resv available for delayed_delete to release the dma-buf
>> mapping. A BO whose attach never succeeded has no mapping to release,
>> yet it keeps bo->base.resv pointing at the exporter resv that
>> delayed_delete later locks once the exporter is gone.
>>
>> Fix this by checking bo->base.import_attach, which is set only after
>> a
>> successful attach. The check is placed after dma_resv_copy_fences()
>> so
>> successful imports still copy fences to _resv before returning,
>> keeping
>> the shared resv for delayed_delete. Failed imports fall through to
>> swap
>> resv to _resv, so delayed_delete never locks the stale exporter resv.
>>
>> Closes:
>> https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
>> Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup
>> path for imported bos")
>> Cc: stable@vger.kernel.org # v6.8+
>> Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
>> Cc: Christian Konig <christian.koenig@amd.com>
>> Cc: Matthew Auld <matthew.auld@intel.com>
>> Assisted-by: GitHub_Copilot:claude-sonnet-4.6
>> Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
>> ---
>> Hi Thomas/Christian,
>> Thank you for the review. Addressed the v3 review comments in this
>> v4 version.
>>
>> v4:
>> - Moved import_attach check to after dma_resv_copy_fences() so fences
>> are copied before returning for successful imports (Thomas).
>> - Removed exporter-alive claim from commit message (Thomas).
>
> That's not sufficient. What I meant was that this invalidates the
> approach in its current form:
>
> A B
> prime_import()
> exported_get();
> exported_lock();
> bo_create(); lru_walk():
> attach_fail(); bo_get();
> bo_put();
> exported_unlock(); bo_lock() // exporter_lock
> exporter_put();
> exporter_free();
> bo_unlock(); //UAF
>
> There is no guarantee that the exporter stays alive until
> resv individualization happens.
IIRC at least for AMDGPU that shouldn't be possible.
We intentionally create the imported BO as empty shell without ttm_resource object, so it is not on any LRU list.
But to be honest I haven't looked into that in years, so it is perfectly possible that this is messed up again.
Regards,
Christian.
>
> /Thomas
>
>
>>
>> v3:
>> - Dropped the xe-side reordering approach since importer_priv must be
>> valid when dma_buf_dynamic_attach() publishes the attachment.
>> - Per Christian's suggestion on the v1 thread, keyed the check on
>> import_attach rather than removing the sg guard entirely.
>> - Fixes both xe and amdgpu in a single TTM patch.
>>
>> drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
>> 1 file changed, 15 insertions(+), 9 deletions(-)
>>
>> diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
>> b/drivers/gpu/drm/ttm/ttm_bo.c
>> index bcd76f6bb7f0..9b6341f69805 100644
>> --- a/drivers/gpu/drm/ttm/ttm_bo.c
>> +++ b/drivers/gpu/drm/ttm/ttm_bo.c
>> @@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct
>> ttm_buffer_object *bo)
>> if (r)
>> return r;
>>
>> - if (bo->type != ttm_bo_type_sg) {
>> - /* This works because the BO is about to be
>> destroyed and nobody
>> - * reference it any more. The only tricky case is
>> the trylock on
>> - * the resv object while holding the lru_lock.
>> - */
>> - spin_lock(&bo->bdev->lru_lock);
>> - bo->base.resv = &bo->base._resv;
>> - spin_unlock(&bo->bdev->lru_lock);
>> - }
>> + /*
>> + * Successfully imported sg BOs need the shared resv for
>> dma-buf
>> + * cleanup. Failed imports have no attachment or mapping and
>> can
>> + * use the private _resv.
>> + */
>> + if (bo->type == ttm_bo_type_sg && bo->base.import_attach)
>> + return 0;
>> +
>> + /* This works because the BO is about to be destroyed and
>> nobody
>> + * references it any more. The only tricky case is the
>> trylock on
>> + * the resv object while holding the lru_lock.
>> + */
>> + spin_lock(&bo->bdev->lru_lock);
>> + bo->base.resv = &bo->base._resv;
>> + spin_unlock(&bo->bdev->lru_lock);
>>
>> return r;
>> }
^ permalink raw reply [flat|nested] 14+ messages in thread
* Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-07-01 13:20 ` Christian König
@ 2026-07-01 15:23 ` Thomas Hellström
2026-07-03 10:50 ` Gote, Nitin R
0 siblings, 1 reply; 14+ messages in thread
From: Thomas Hellström @ 2026-07-01 15:23 UTC (permalink / raw)
To: Christian König, Nitin Gote, intel-xe; +Cc: stable, Matthew Auld
On Wed, 2026-07-01 at 15:20 +0200, Christian König wrote:
> On 7/1/26 14:59, Thomas Hellström wrote:
> > Hi, Nitin
> >
> > On Wed, 2026-07-01 at 11:56 +0530, Nitin Gote wrote:
> > > When a dma-buf importer creates a ttm_bo_type_sg BO with bo-
> > > > base.resv
> > > pointing at the exporter's dma_buf->resv and
> > > dma_buf_dynamic_attach()
> > > fails, no dma_buf reference is held. The exporter can be freed
> > > before
> > > the delayed_delete worker calls dma_resv_lock(bo->base.resv),
> > > causing
> > > a
> > > use-after-free:
> > >
> > > Oops: general protection fault, probably for non-canonical
> > > address
> > > 0x6b6b6b6b6b6b6b9c
> > > Workqueue: ttm ttm_bo_delayed_delete [ttm]
> > > RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
> > >
> > > ttm_bo_individualize_resv() skips the resv swap for all sg BOs to
> > > keep
> > > the shared resv available for delayed_delete to release the dma-
> > > buf
> > > mapping. A BO whose attach never succeeded has no mapping to
> > > release,
> > > yet it keeps bo->base.resv pointing at the exporter resv that
> > > delayed_delete later locks once the exporter is gone.
> > >
> > > Fix this by checking bo->base.import_attach, which is set only
> > > after
> > > a
> > > successful attach. The check is placed after
> > > dma_resv_copy_fences()
> > > so
> > > successful imports still copy fences to _resv before returning,
> > > keeping
> > > the shared resv for delayed_delete. Failed imports fall through
> > > to
> > > swap
> > > resv to _resv, so delayed_delete never locks the stale exporter
> > > resv.
> > >
> > > Closes:
> > > https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> > > Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup
> > > path for imported bos")
> > > Cc: stable@vger.kernel.org # v6.8+
> > > Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> > > Cc: Christian Konig <christian.koenig@amd.com>
> > > Cc: Matthew Auld <matthew.auld@intel.com>
> > > Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> > > Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> > > ---
> > > Hi Thomas/Christian,
> > > Thank you for the review. Addressed the v3 review comments in
> > > this
> > > v4 version.
> > >
> > > v4:
> > > - Moved import_attach check to after dma_resv_copy_fences() so
> > > fences
> > > are copied before returning for successful imports (Thomas).
> > > - Removed exporter-alive claim from commit message (Thomas).
> >
> > That's not sufficient. What I meant was that this invalidates the
> > approach in its current form:
> >
> > A B
> > prime_import()
> > exported_get();
> > exported_lock();
> > bo_create(); lru_walk():
> > attach_fail(); bo_get();
> > bo_put();
> > exported_unlock(); bo_lock() // exporter_lock
> > exporter_put();
> > exporter_free();
> > bo_unlock(); //UAF
> >
> > There is no guarantee that the exporter stays alive until
> > resv individualization happens.
>
> IIRC at least for AMDGPU that shouldn't be possible.
>
> We intentionally create the imported BO as empty shell without
> ttm_resource object, so it is not on any LRU list.
>
> But to be honest I haven't looked into that in years, so it is
> perfectly possible that this is messed up again.
Yeah, this was recently changed in xe, but I'm not 100% sure we
actually create a bo resource.
In any case if we add an assert
WARN_ON_ONCE(bo->type == ttm_bo_type_sg && bo->res);
just before / after
bo->base.resv = &bo->base._resv;
or something similar, we would hit that if the bo is published on the
LRU and would need an additional fix in the driver.
/Thomas
>
> Regards,
> Christian.
>
> >
> > /Thomas
> >
> >
> > >
> > > v3:
> > > - Dropped the xe-side reordering approach since importer_priv
> > > must be
> > > valid when dma_buf_dynamic_attach() publishes the attachment.
> > > - Per Christian's suggestion on the v1 thread, keyed the check on
> > > import_attach rather than removing the sg guard entirely.
> > > - Fixes both xe and amdgpu in a single TTM patch.
> > >
> > > drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> > > 1 file changed, 15 insertions(+), 9 deletions(-)
> > >
> > > diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
> > > b/drivers/gpu/drm/ttm/ttm_bo.c
> > > index bcd76f6bb7f0..9b6341f69805 100644
> > > --- a/drivers/gpu/drm/ttm/ttm_bo.c
> > > +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> > > @@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct
> > > ttm_buffer_object *bo)
> > > if (r)
> > > return r;
> > >
> > > - if (bo->type != ttm_bo_type_sg) {
> > > - /* This works because the BO is about to be
> > > destroyed and nobody
> > > - * reference it any more. The only tricky case
> > > is
> > > the trylock on
> > > - * the resv object while holding the lru_lock.
> > > - */
> > > - spin_lock(&bo->bdev->lru_lock);
> > > - bo->base.resv = &bo->base._resv;
> > > - spin_unlock(&bo->bdev->lru_lock);
> > > - }
> > > + /*
> > > + * Successfully imported sg BOs need the shared resv for
> > > dma-buf
> > > + * cleanup. Failed imports have no attachment or mapping
> > > and
> > > can
> > > + * use the private _resv.
> > > + */
> > > + if (bo->type == ttm_bo_type_sg && bo-
> > > >base.import_attach)
> > > + return 0;
> > > +
> > > + /* This works because the BO is about to be destroyed
> > > and
> > > nobody
> > > + * references it any more. The only tricky case is the
> > > trylock on
> > > + * the resv object while holding the lru_lock.
> > > + */
> > > + spin_lock(&bo->bdev->lru_lock);
> > > + bo->base.resv = &bo->base._resv;
> > > + spin_unlock(&bo->bdev->lru_lock);
> > >
> > > return r;
> > > }
^ permalink raw reply [flat|nested] 14+ messages in thread
* RE: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
2026-07-01 15:23 ` Thomas Hellström
@ 2026-07-03 10:50 ` Gote, Nitin R
0 siblings, 0 replies; 14+ messages in thread
From: Gote, Nitin R @ 2026-07-03 10:50 UTC (permalink / raw)
To: Thomas Hellström, Christian König,
intel-xe@lists.freedesktop.org
Cc: stable@vger.kernel.org, Auld, Matthew
> -----Original Message-----
> From: Thomas Hellström <thomas.hellstrom@linux.intel.com>
> Sent: Wednesday, July 1, 2026 8:53 PM
> To: Christian König <christian.koenig@amd.com>; Gote, Nitin R
> <nitin.r.gote@intel.com>; intel-xe@lists.freedesktop.org
> Cc: stable@vger.kernel.org; Auld, Matthew <matthew.auld@intel.com>
> Subject: Re: [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
>
> On Wed, 2026-07-01 at 15:20 +0200, Christian König wrote:
> > On 7/1/26 14:59, Thomas Hellström wrote:
> > > Hi, Nitin
> > >
> > > On Wed, 2026-07-01 at 11:56 +0530, Nitin Gote wrote:
> > > > When a dma-buf importer creates a ttm_bo_type_sg BO with bo-
> > > > > base.resv
> > > > pointing at the exporter's dma_buf->resv and
> > > > dma_buf_dynamic_attach()
> > > > fails, no dma_buf reference is held. The exporter can be freed
> > > > before the delayed_delete worker calls
> > > > dma_resv_lock(bo->base.resv), causing a
> > > > use-after-free:
> > > >
> > > > Oops: general protection fault, probably for non-canonical
> > > > address
> > > > 0x6b6b6b6b6b6b6b9c
> > > > Workqueue: ttm ttm_bo_delayed_delete [ttm]
> > > > RIP: 0010:mutex_can_spin_on_owner+0x3f/0xc0
> > > >
> > > > ttm_bo_individualize_resv() skips the resv swap for all sg BOs to
> > > > keep the shared resv available for delayed_delete to release the
> > > > dma- buf mapping. A BO whose attach never succeeded has no mapping
> > > > to release, yet it keeps bo->base.resv pointing at the exporter
> > > > resv that delayed_delete later locks once the exporter is gone.
> > > >
> > > > Fix this by checking bo->base.import_attach, which is set only
> > > > after a successful attach. The check is placed after
> > > > dma_resv_copy_fences()
> > > > so
> > > > successful imports still copy fences to _resv before returning,
> > > > keeping the shared resv for delayed_delete. Failed imports fall
> > > > through to swap resv to _resv, so delayed_delete never locks the
> > > > stale exporter resv.
> > > >
> > > > Closes:
> > > > https://gitlab.freedesktop.org/drm/xe/kernel/-/work_items/8023
> > > > Fixes: d99fbd9aab62 ("drm/ttm: Always take the bo delayed cleanup
> > > > path for imported bos")
> > > > Cc: stable@vger.kernel.org # v6.8+
> > > > Cc: Thomas Hellstrom <thomas.hellstrom@linux.intel.com>
> > > > Cc: Christian Konig <christian.koenig@amd.com>
> > > > Cc: Matthew Auld <matthew.auld@intel.com>
> > > > Assisted-by: GitHub_Copilot:claude-sonnet-4.6
> > > > Signed-off-by: Nitin Gote <nitin.r.gote@intel.com>
> > > > ---
> > > > Hi Thomas/Christian,
> > > > Thank you for the review. Addressed the v3 review comments in this
> > > > v4 version.
> > > >
> > > > v4:
> > > > - Moved import_attach check to after dma_resv_copy_fences() so
> > > > fences
> > > > are copied before returning for successful imports (Thomas).
> > > > - Removed exporter-alive claim from commit message (Thomas).
> > >
> > > That's not sufficient. What I meant was that this invalidates the
> > > approach in its current form:
> > >
> > > A B
> > > prime_import()
> > > exported_get();
> > > exported_lock();
> > > bo_create(); lru_walk():
> > > attach_fail(); bo_get();
> > > bo_put();
> > > exported_unlock(); bo_lock() // exporter_lock
> > > exporter_put();
> > > exporter_free();
> > > bo_unlock(); //UAF
> > >
> > > There is no guarantee that the exporter stays alive until resv
> > > individualization happens.
> >
> > IIRC at least for AMDGPU that shouldn't be possible.
> >
> > We intentionally create the imported BO as empty shell without
> > ttm_resource object, so it is not on any LRU list.
> >
> > But to be honest I haven't looked into that in years, so it is
> > perfectly possible that this is messed up again.
>
> Yeah, this was recently changed in xe, but I'm not 100% sure we actually create a
> bo resource.
>
> In any case if we add an assert
>
> WARN_ON_ONCE(bo->type == ttm_bo_type_sg && bo->res);
>
> just before / after
> bo->base.resv = &bo->base._resv;
>
> or something similar, we would hit that if the bo is published on the LRU and
> would need an additional fix in the driver.
Thank you Thomas. I checked the xe flow.
xe_dma_buf_create_obj() calls xe_bo_init_locked() with system placement for sg BOs, so the BO gets a ttm_resource and can be placed on the LRU before attach is attempted.
So the race you pointed out looks real for xe.
I'll add the WARN_ON_ONCE() around the resv swap and re-run the test, then work on the xe-side fix based on the result.
Regards,
Nitin
>
> /Thomas
>
>
> >
> > Regards,
> > Christian.
> >
> > >
> > > /Thomas
> > >
> > >
> > > >
> > > > v3:
> > > > - Dropped the xe-side reordering approach since importer_priv must
> > > > be
> > > > valid when dma_buf_dynamic_attach() publishes the attachment.
> > > > - Per Christian's suggestion on the v1 thread, keyed the check on
> > > > import_attach rather than removing the sg guard entirely.
> > > > - Fixes both xe and amdgpu in a single TTM patch.
> > > >
> > > > drivers/gpu/drm/ttm/ttm_bo.c | 24 +++++++++++++++---------
> > > > 1 file changed, 15 insertions(+), 9 deletions(-)
> > > >
> > > > diff --git a/drivers/gpu/drm/ttm/ttm_bo.c
> > > > b/drivers/gpu/drm/ttm/ttm_bo.c index bcd76f6bb7f0..9b6341f69805
> > > > 100644
> > > > --- a/drivers/gpu/drm/ttm/ttm_bo.c
> > > > +++ b/drivers/gpu/drm/ttm/ttm_bo.c
> > > > @@ -203,15 +203,21 @@ static int ttm_bo_individualize_resv(struct
> > > > ttm_buffer_object *bo)
> > > > if (r)
> > > > return r;
> > > >
> > > > - if (bo->type != ttm_bo_type_sg) {
> > > > - /* This works because the BO is about to be
> > > > destroyed and nobody
> > > > - * reference it any more. The only tricky case
> > > > is
> > > > the trylock on
> > > > - * the resv object while holding the lru_lock.
> > > > - */
> > > > - spin_lock(&bo->bdev->lru_lock);
> > > > - bo->base.resv = &bo->base._resv;
> > > > - spin_unlock(&bo->bdev->lru_lock);
> > > > - }
> > > > + /*
> > > > + * Successfully imported sg BOs need the shared resv for
> > > > dma-buf
> > > > + * cleanup. Failed imports have no attachment or mapping
> > > > and
> > > > can
> > > > + * use the private _resv.
> > > > + */
> > > > + if (bo->type == ttm_bo_type_sg && bo-
> > > > >base.import_attach)
> > > > + return 0;
> > > > +
> > > > + /* This works because the BO is about to be destroyed
> > > > and
> > > > nobody
> > > > + * references it any more. The only tricky case is the
> > > > trylock on
> > > > + * the resv object while holding the lru_lock.
> > > > + */
> > > > + spin_lock(&bo->bdev->lru_lock);
> > > > + bo->base.resv = &bo->base._resv;
> > > > + spin_unlock(&bo->bdev->lru_lock);
> > > >
> > > > return r;
> > > > }
^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2026-07-03 10:50 UTC | newest]
Thread overview: 14+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-06-25 5:28 ` ✓ CI.KUnit: success for " Patchwork
2026-06-25 6:03 ` ✗ Xe.CI.BAT: failure " Patchwork
2026-06-25 7:43 ` ✗ Xe.CI.FULL: " Patchwork
2026-06-25 10:45 ` [PATCH] " Christian König
2026-06-25 17:10 ` Gote, Nitin R
2026-06-29 12:09 ` Christian König
2026-06-29 9:18 ` Thomas Hellström
-- strict thread matches above, loose matches on Subject: below --
2026-07-01 6:26 Nitin Gote
2026-07-01 8:48 ` Christian König
2026-07-01 12:59 ` Thomas Hellström
2026-07-01 13:20 ` Christian König
2026-07-01 15:23 ` Thomas Hellström
2026-07-03 10:50 ` Gote, Nitin R
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox