* [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs
@ 2026-07-01 6:26 Nitin Gote
2026-07-01 5:56 ` ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
` (4 more replies)
0 siblings, 5 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* ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
2026-07-01 6:26 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
@ 2026-07-01 5:56 ` Patchwork
2026-07-01 6:46 ` ✓ Xe.CI.BAT: " Patchwork
` (3 subsequent siblings)
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-07-01 5:56 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
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:55:12] Configuring KUnit Kernel ...
Generating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:55:17] 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
../drivers/gpu/drm/xe/xe_pt.c:1418:13: warning: ‘xe_pt_svm_userptr_notifier_lock’ defined but not used [-Wunused-function]
1418 | static void xe_pt_svm_userptr_notifier_lock(struct xe_vm *vm)
| ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
[05:55:48] Starting KUnit Kernel (1/1)...
[05:55:48] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:55:49] ================== guc_buf (11 subtests) ===================
[05:55:49] [PASSED] test_smallest
[05:55:49] [PASSED] test_largest
[05:55:49] [PASSED] test_granular
[05:55:49] [PASSED] test_unique
[05:55:49] [PASSED] test_overlap
[05:55:49] [PASSED] test_reusable
[05:55:49] [PASSED] test_too_big
[05:55:49] [PASSED] test_flush
[05:55:49] [PASSED] test_lookup
[05:55:49] [PASSED] test_data
[05:55:49] [PASSED] test_class
[05:55:49] ===================== [PASSED] guc_buf =====================
[05:55:49] =================== guc_dbm (7 subtests) ===================
[05:55:49] [PASSED] test_empty
[05:55:49] [PASSED] test_default
[05:55:49] ======================== test_size ========================
[05:55:49] [PASSED] 4
[05:55:49] [PASSED] 8
[05:55:49] [PASSED] 32
[05:55:49] [PASSED] 256
[05:55:49] ==================== [PASSED] test_size ====================
[05:55:49] ======================= test_reuse ========================
[05:55:49] [PASSED] 4
[05:55:49] [PASSED] 8
[05:55:49] [PASSED] 32
[05:55:49] [PASSED] 256
[05:55:49] =================== [PASSED] test_reuse ====================
[05:55:49] =================== test_range_overlap ====================
[05:55:49] [PASSED] 4
[05:55:49] [PASSED] 8
[05:55:49] [PASSED] 32
[05:55:49] [PASSED] 256
[05:55:49] =============== [PASSED] test_range_overlap ================
[05:55:49] =================== test_range_compact ====================
[05:55:49] [PASSED] 4
[05:55:49] [PASSED] 8
[05:55:49] [PASSED] 32
[05:55:49] [PASSED] 256
[05:55:49] =============== [PASSED] test_range_compact ================
[05:55:49] ==================== test_range_spare =====================
[05:55:49] [PASSED] 4
[05:55:49] [PASSED] 8
[05:55:49] [PASSED] 32
[05:55:49] [PASSED] 256
[05:55:49] ================ [PASSED] test_range_spare =================
[05:55:49] ===================== [PASSED] guc_dbm =====================
[05:55:49] =================== guc_idm (6 subtests) ===================
[05:55:49] [PASSED] bad_init
[05:55:49] [PASSED] no_init
[05:55:49] [PASSED] init_fini
[05:55:49] [PASSED] check_used
[05:55:49] [PASSED] check_quota
[05:55:49] [PASSED] check_all
[05:55:49] ===================== [PASSED] guc_idm =====================
[05:55:49] ================== no_relay (3 subtests) ===================
[05:55:49] [PASSED] xe_drops_guc2pf_if_not_ready
[05:55:49] [PASSED] xe_drops_guc2vf_if_not_ready
[05:55:49] [PASSED] xe_rejects_send_if_not_ready
[05:55:49] ==================== [PASSED] no_relay =====================
[05:55:49] ================== pf_relay (14 subtests) ==================
[05:55:49] [PASSED] pf_rejects_guc2pf_too_short
[05:55:49] [PASSED] pf_rejects_guc2pf_too_long
[05:55:49] [PASSED] pf_rejects_guc2pf_no_payload
[05:55:49] [PASSED] pf_fails_no_payload
[05:55:49] [PASSED] pf_fails_bad_origin
[05:55:49] [PASSED] pf_fails_bad_type
[05:55:49] [PASSED] pf_txn_reports_error
[05:55:49] [PASSED] pf_txn_sends_pf2guc
[05:55:49] [PASSED] pf_sends_pf2guc
[05:55:49] [SKIPPED] pf_loopback_nop (requires CONFIG_DRM_XE_DEBUG_SRIOV)
[05:55:49] [SKIPPED] pf_loopback_echo (requires CONFIG_DRM_XE_DEBUG_SRIOV)
[05:55:49] [SKIPPED] pf_loopback_fail (requires CONFIG_DRM_XE_DEBUG_SRIOV)
[05:55:49] [SKIPPED] pf_loopback_busy (requires CONFIG_DRM_XE_DEBUG_SRIOV)
[05:55:49] [SKIPPED] pf_loopback_retry (requires CONFIG_DRM_XE_DEBUG_SRIOV)
[05:55:49] ==================== [PASSED] pf_relay =====================
[05:55:49] ================== vf_relay (3 subtests) ===================
[05:55:49] [PASSED] vf_rejects_guc2vf_too_short
[05:55:49] [PASSED] vf_rejects_guc2vf_too_long
[05:55:49] [PASSED] vf_rejects_guc2vf_no_payload
[05:55:49] ==================== [PASSED] vf_relay =====================
[05:55:49] ================ pf_gt_config (9 subtests) =================
[05:55:49] [PASSED] fair_contexts_1vf
[05:55:49] [PASSED] fair_doorbells_1vf
[05:55:49] [PASSED] fair_ggtt_1vf
[05:55:49] ====================== fair_vram_1vf ======================
[05:55:49] [PASSED] 3.50 GiB
[05:55:49] [PASSED] 11.5 GiB
[05:55:49] [PASSED] 15.5 GiB
[05:55:49] [PASSED] 31.5 GiB
[05:55:49] [PASSED] 63.5 GiB
[05:55:49] [PASSED] 1.91 GiB
[05:55:49] ================== [PASSED] fair_vram_1vf ==================
[05:55:49] ================ fair_vram_1vf_admin_only =================
[05:55:49] [PASSED] 3.50 GiB
[05:55:49] [PASSED] 11.5 GiB
[05:55:49] [PASSED] 15.5 GiB
[05:55:49] [PASSED] 31.5 GiB
[05:55:49] [PASSED] 63.5 GiB
[05:55:49] [PASSED] 1.91 GiB
[05:55:49] ============ [PASSED] fair_vram_1vf_admin_only =============
[05:55:49] ====================== fair_contexts ======================
[05:55:49] [PASSED] 1 VF
[05:55:49] [PASSED] 2 VFs
[05:55:49] [PASSED] 3 VFs
[05:55:49] [PASSED] 4 VFs
[05:55:49] [PASSED] 5 VFs
[05:55:49] [PASSED] 6 VFs
[05:55:49] [PASSED] 7 VFs
[05:55:49] [PASSED] 8 VFs
[05:55:49] [PASSED] 9 VFs
[05:55:49] [PASSED] 10 VFs
[05:55:49] [PASSED] 11 VFs
[05:55:49] [PASSED] 12 VFs
[05:55:49] [PASSED] 13 VFs
[05:55:49] [PASSED] 14 VFs
[05:55:49] [PASSED] 15 VFs
[05:55:49] [PASSED] 16 VFs
[05:55:49] [PASSED] 17 VFs
[05:55:49] [PASSED] 18 VFs
[05:55:49] [PASSED] 19 VFs
[05:55:49] [PASSED] 20 VFs
[05:55:49] [PASSED] 21 VFs
[05:55:49] [PASSED] 22 VFs
[05:55:49] [PASSED] 23 VFs
[05:55:49] [PASSED] 24 VFs
[05:55:49] [PASSED] 25 VFs
[05:55:49] [PASSED] 26 VFs
[05:55:49] [PASSED] 27 VFs
[05:55:49] [PASSED] 28 VFs
[05:55:49] [PASSED] 29 VFs
[05:55:49] [PASSED] 30 VFs
[05:55:49] [PASSED] 31 VFs
[05:55:49] [PASSED] 32 VFs
[05:55:49] [PASSED] 33 VFs
[05:55:49] [PASSED] 34 VFs
[05:55:49] [PASSED] 35 VFs
[05:55:49] [PASSED] 36 VFs
[05:55:49] [PASSED] 37 VFs
[05:55:49] [PASSED] 38 VFs
[05:55:49] [PASSED] 39 VFs
[05:55:49] [PASSED] 40 VFs
[05:55:49] [PASSED] 41 VFs
[05:55:49] [PASSED] 42 VFs
[05:55:49] [PASSED] 43 VFs
[05:55:49] [PASSED] 44 VFs
[05:55:49] [PASSED] 45 VFs
[05:55:49] [PASSED] 46 VFs
[05:55:49] [PASSED] 47 VFs
[05:55:49] [PASSED] 48 VFs
[05:55:49] [PASSED] 49 VFs
[05:55:49] [PASSED] 50 VFs
[05:55:49] [PASSED] 51 VFs
[05:55:49] [PASSED] 52 VFs
[05:55:49] [PASSED] 53 VFs
[05:55:49] [PASSED] 54 VFs
[05:55:49] [PASSED] 55 VFs
[05:55:49] [PASSED] 56 VFs
[05:55:49] [PASSED] 57 VFs
[05:55:49] [PASSED] 58 VFs
[05:55:49] [PASSED] 59 VFs
[05:55:49] [PASSED] 60 VFs
[05:55:49] [PASSED] 61 VFs
[05:55:49] [PASSED] 62 VFs
[05:55:49] [PASSED] 63 VFs
[05:55:49] ================== [PASSED] fair_contexts ==================
[05:55:49] ===================== fair_doorbells ======================
[05:55:49] [PASSED] 1 VF
[05:55:49] [PASSED] 2 VFs
[05:55:49] [PASSED] 3 VFs
[05:55:49] [PASSED] 4 VFs
[05:55:49] [PASSED] 5 VFs
[05:55:49] [PASSED] 6 VFs
[05:55:49] [PASSED] 7 VFs
[05:55:49] [PASSED] 8 VFs
[05:55:49] [PASSED] 9 VFs
[05:55:49] [PASSED] 10 VFs
[05:55:49] [PASSED] 11 VFs
[05:55:49] [PASSED] 12 VFs
[05:55:49] [PASSED] 13 VFs
[05:55:49] [PASSED] 14 VFs
[05:55:49] [PASSED] 15 VFs
[05:55:49] [PASSED] 16 VFs
[05:55:49] [PASSED] 17 VFs
[05:55:49] [PASSED] 18 VFs
[05:55:49] [PASSED] 19 VFs
[05:55:49] [PASSED] 20 VFs
[05:55:49] [PASSED] 21 VFs
[05:55:49] [PASSED] 22 VFs
[05:55:49] [PASSED] 23 VFs
[05:55:49] [PASSED] 24 VFs
[05:55:49] [PASSED] 25 VFs
[05:55:49] [PASSED] 26 VFs
[05:55:49] [PASSED] 27 VFs
[05:55:49] [PASSED] 28 VFs
[05:55:49] [PASSED] 29 VFs
[05:55:49] [PASSED] 30 VFs
[05:55:49] [PASSED] 31 VFs
[05:55:49] [PASSED] 32 VFs
[05:55:49] [PASSED] 33 VFs
[05:55:49] [PASSED] 34 VFs
[05:55:49] [PASSED] 35 VFs
[05:55:49] [PASSED] 36 VFs
[05:55:49] [PASSED] 37 VFs
[05:55:49] [PASSED] 38 VFs
[05:55:49] [PASSED] 39 VFs
[05:55:49] [PASSED] 40 VFs
[05:55:49] [PASSED] 41 VFs
[05:55:49] [PASSED] 42 VFs
[05:55:49] [PASSED] 43 VFs
[05:55:49] [PASSED] 44 VFs
[05:55:49] [PASSED] 45 VFs
[05:55:49] [PASSED] 46 VFs
[05:55:49] [PASSED] 47 VFs
[05:55:49] [PASSED] 48 VFs
[05:55:49] [PASSED] 49 VFs
[05:55:49] [PASSED] 50 VFs
[05:55:49] [PASSED] 51 VFs
[05:55:49] [PASSED] 52 VFs
[05:55:49] [PASSED] 53 VFs
[05:55:49] [PASSED] 54 VFs
[05:55:49] [PASSED] 55 VFs
[05:55:49] [PASSED] 56 VFs
[05:55:49] [PASSED] 57 VFs
[05:55:49] [PASSED] 58 VFs
[05:55:49] [PASSED] 59 VFs
[05:55:49] [PASSED] 60 VFs
[05:55:49] [PASSED] 61 VFs
[05:55:49] [PASSED] 62 VFs
[05:55:49] [PASSED] 63 VFs
[05:55:49] ================= [PASSED] fair_doorbells ==================
[05:55:49] ======================== fair_ggtt ========================
[05:55:49] [PASSED] 1 VF
[05:55:49] [PASSED] 2 VFs
[05:55:49] [PASSED] 3 VFs
[05:55:49] [PASSED] 4 VFs
[05:55:49] [PASSED] 5 VFs
[05:55:49] [PASSED] 6 VFs
[05:55:49] [PASSED] 7 VFs
[05:55:49] [PASSED] 8 VFs
[05:55:49] [PASSED] 9 VFs
[05:55:49] [PASSED] 10 VFs
[05:55:49] [PASSED] 11 VFs
[05:55:49] [PASSED] 12 VFs
[05:55:49] [PASSED] 13 VFs
[05:55:49] [PASSED] 14 VFs
[05:55:49] [PASSED] 15 VFs
[05:55:49] [PASSED] 16 VFs
[05:55:49] [PASSED] 17 VFs
[05:55:49] [PASSED] 18 VFs
[05:55:49] [PASSED] 19 VFs
[05:55:49] [PASSED] 20 VFs
[05:55:49] [PASSED] 21 VFs
[05:55:49] [PASSED] 22 VFs
[05:55:49] [PASSED] 23 VFs
[05:55:49] [PASSED] 24 VFs
[05:55:49] [PASSED] 25 VFs
[05:55:49] [PASSED] 26 VFs
[05:55:49] [PASSED] 27 VFs
[05:55:49] [PASSED] 28 VFs
[05:55:49] [PASSED] 29 VFs
[05:55:49] [PASSED] 30 VFs
[05:55:49] [PASSED] 31 VFs
[05:55:49] [PASSED] 32 VFs
[05:55:49] [PASSED] 33 VFs
[05:55:49] [PASSED] 34 VFs
[05:55:49] [PASSED] 35 VFs
[05:55:49] [PASSED] 36 VFs
[05:55:49] [PASSED] 37 VFs
[05:55:49] [PASSED] 38 VFs
[05:55:49] [PASSED] 39 VFs
[05:55:49] [PASSED] 40 VFs
[05:55:49] [PASSED] 41 VFs
[05:55:49] [PASSED] 42 VFs
[05:55:49] [PASSED] 43 VFs
[05:55:49] [PASSED] 44 VFs
[05:55:49] [PASSED] 45 VFs
[05:55:49] [PASSED] 46 VFs
[05:55:49] [PASSED] 47 VFs
[05:55:49] [PASSED] 48 VFs
[05:55:49] [PASSED] 49 VFs
[05:55:49] [PASSED] 50 VFs
[05:55:49] [PASSED] 51 VFs
[05:55:49] [PASSED] 52 VFs
[05:55:49] [PASSED] 53 VFs
[05:55:49] [PASSED] 54 VFs
[05:55:49] [PASSED] 55 VFs
[05:55:49] [PASSED] 56 VFs
[05:55:49] [PASSED] 57 VFs
[05:55:49] [PASSED] 58 VFs
[05:55:49] [PASSED] 59 VFs
[05:55:49] [PASSED] 60 VFs
[05:55:49] [PASSED] 61 VFs
[05:55:49] [PASSED] 62 VFs
[05:55:49] [PASSED] 63 VFs
[05:55:49] ==================== [PASSED] fair_ggtt ====================
[05:55:49] ======================== fair_vram ========================
[05:55:49] [PASSED] 1 VF
[05:55:49] [PASSED] 2 VFs
[05:55:49] [PASSED] 3 VFs
[05:55:49] [PASSED] 4 VFs
[05:55:49] [PASSED] 5 VFs
[05:55:49] [PASSED] 6 VFs
[05:55:49] [PASSED] 7 VFs
[05:55:49] [PASSED] 8 VFs
[05:55:49] [PASSED] 9 VFs
[05:55:49] [PASSED] 10 VFs
[05:55:49] [PASSED] 11 VFs
[05:55:49] [PASSED] 12 VFs
[05:55:49] [PASSED] 13 VFs
[05:55:49] [PASSED] 14 VFs
[05:55:49] [PASSED] 15 VFs
[05:55:49] [PASSED] 16 VFs
[05:55:49] [PASSED] 17 VFs
[05:55:49] [PASSED] 18 VFs
[05:55:49] [PASSED] 19 VFs
[05:55:49] [PASSED] 20 VFs
[05:55:49] [PASSED] 21 VFs
[05:55:49] [PASSED] 22 VFs
[05:55:49] [PASSED] 23 VFs
[05:55:49] [PASSED] 24 VFs
[05:55:49] [PASSED] 25 VFs
[05:55:49] [PASSED] 26 VFs
[05:55:49] [PASSED] 27 VFs
[05:55:49] [PASSED] 28 VFs
[05:55:49] [PASSED] 29 VFs
[05:55:49] [PASSED] 30 VFs
[05:55:49] [PASSED] 31 VFs
[05:55:49] [PASSED] 32 VFs
[05:55:49] [PASSED] 33 VFs
[05:55:49] [PASSED] 34 VFs
[05:55:49] [PASSED] 35 VFs
[05:55:49] [PASSED] 36 VFs
[05:55:49] [PASSED] 37 VFs
[05:55:49] [PASSED] 38 VFs
[05:55:49] [PASSED] 39 VFs
[05:55:49] [PASSED] 40 VFs
[05:55:49] [PASSED] 41 VFs
[05:55:49] [PASSED] 42 VFs
[05:55:49] [PASSED] 43 VFs
[05:55:49] [PASSED] 44 VFs
[05:55:49] [PASSED] 45 VFs
[05:55:49] [PASSED] 46 VFs
[05:55:49] [PASSED] 47 VFs
[05:55:49] [PASSED] 48 VFs
[05:55:49] [PASSED] 49 VFs
[05:55:49] [PASSED] 50 VFs
[05:55:49] [PASSED] 51 VFs
[05:55:49] [PASSED] 52 VFs
[05:55:49] [PASSED] 53 VFs
[05:55:49] [PASSED] 54 VFs
[05:55:49] [PASSED] 55 VFs
[05:55:49] [PASSED] 56 VFs
[05:55:49] [PASSED] 57 VFs
[05:55:49] [PASSED] 58 VFs
[05:55:49] [PASSED] 59 VFs
[05:55:49] [PASSED] 60 VFs
[05:55:49] [PASSED] 61 VFs
[05:55:49] [PASSED] 62 VFs
[05:55:49] [PASSED] 63 VFs
[05:55:49] ==================== [PASSED] fair_vram ====================
[05:55:49] ================== [PASSED] pf_gt_config ===================
[05:55:49] ===================== lmtt (1 subtest) =====================
[05:55:49] ======================== test_ops =========================
[05:55:49] [PASSED] 2-level
[05:55:49] [PASSED] multi-level
[05:55:49] ==================== [PASSED] test_ops =====================
[05:55:49] ====================== [PASSED] lmtt =======================
[05:55:49] ================= pf_service (11 subtests) =================
[05:55:49] [PASSED] pf_negotiate_any
[05:55:49] [PASSED] pf_negotiate_base_match
[05:55:49] [PASSED] pf_negotiate_base_newer
[05:55:49] [PASSED] pf_negotiate_base_next
[05:55:49] [SKIPPED] pf_negotiate_base_older (no older minor)
[05:55:49] [PASSED] pf_negotiate_base_prev
[05:55:49] [PASSED] pf_negotiate_latest_match
[05:55:49] [PASSED] pf_negotiate_latest_newer
[05:55:49] [PASSED] pf_negotiate_latest_next
[05:55:49] [SKIPPED] pf_negotiate_latest_older (no older minor)
[05:55:49] [SKIPPED] pf_negotiate_latest_prev (no prev major)
[05:55:49] =================== [PASSED] pf_service ====================
[05:55:49] ================= xe_guc_g2g (2 subtests) ==================
[05:55:49] ============== xe_live_guc_g2g_kunit_default ==============
[05:55:49] ========= [SKIPPED] xe_live_guc_g2g_kunit_default ==========
[05:55:49] ============== xe_live_guc_g2g_kunit_allmem ===============
[05:55:49] ========== [SKIPPED] xe_live_guc_g2g_kunit_allmem ==========
[05:55:49] =================== [SKIPPED] xe_guc_g2g ===================
[05:55:49] =================== xe_mocs (2 subtests) ===================
[05:55:49] ================ xe_live_mocs_kernel_kunit ================
[05:55:49] =========== [SKIPPED] xe_live_mocs_kernel_kunit ============
[05:55:49] ================ xe_live_mocs_reset_kunit =================
[05:55:49] ============ [SKIPPED] xe_live_mocs_reset_kunit ============
[05:55:49] ==================== [SKIPPED] xe_mocs =====================
[05:55:49] ================= xe_migrate (2 subtests) ==================
[05:55:49] ================= xe_migrate_sanity_kunit =================
[05:55:49] ============ [SKIPPED] xe_migrate_sanity_kunit =============
[05:55:49] ================== xe_validate_ccs_kunit ==================
[05:55:49] ============= [SKIPPED] xe_validate_ccs_kunit ==============
[05:55:49] =================== [SKIPPED] xe_migrate ===================
[05:55:49] ================== xe_dma_buf (1 subtest) ==================
[05:55:49] ==================== xe_dma_buf_kunit =====================
[05:55:49] ================ [SKIPPED] xe_dma_buf_kunit ================
[05:55:49] =================== [SKIPPED] xe_dma_buf ===================
[05:55:49] ================= xe_bo_shrink (1 subtest) =================
[05:55:49] =================== xe_bo_shrink_kunit ====================
[05:55:49] =============== [SKIPPED] xe_bo_shrink_kunit ===============
[05:55:49] ================== [SKIPPED] xe_bo_shrink ==================
[05:55:49] ==================== xe_bo (2 subtests) ====================
[05:55:49] ================== xe_ccs_migrate_kunit ===================
[05:55:49] ============== [SKIPPED] xe_ccs_migrate_kunit ==============
[05:55:49] ==================== xe_bo_evict_kunit ====================
[05:55:49] =============== [SKIPPED] xe_bo_evict_kunit ================
[05:55:49] ===================== [SKIPPED] xe_bo ======================
[05:55:49] ==================== args (13 subtests) ====================
[05:55:49] [PASSED] count_args_test
[05:55:49] [PASSED] call_args_example
[05:55:49] [PASSED] call_args_test
[05:55:49] [PASSED] drop_first_arg_example
[05:55:49] [PASSED] drop_first_arg_test
[05:55:49] [PASSED] first_arg_example
[05:55:49] [PASSED] first_arg_test
[05:55:49] [PASSED] last_arg_example
[05:55:49] [PASSED] last_arg_test
[05:55:49] [PASSED] pick_arg_example
[05:55:49] [PASSED] if_args_example
[05:55:49] [PASSED] if_args_test
[05:55:49] [PASSED] sep_comma_example
[05:55:49] ====================== [PASSED] args =======================
[05:55:49] =================== xe_pci (3 subtests) ====================
[05:55:49] ==================== check_graphics_ip ====================
[05:55:49] [PASSED] 12.00 Xe_LP
[05:55:49] [PASSED] 12.10 Xe_LP+
[05:55:49] [PASSED] 12.55 Xe_HPG
[05:55:49] [PASSED] 12.60 Xe_HPC
[05:55:49] [PASSED] 12.70 Xe_LPG
[05:55:49] [PASSED] 12.71 Xe_LPG
[05:55:49] [PASSED] 12.74 Xe_LPG+
[05:55:49] [PASSED] 20.01 Xe2_HPG
[05:55:49] [PASSED] 20.02 Xe2_HPG
[05:55:49] [PASSED] 20.04 Xe2_LPG
[05:55:49] [PASSED] 30.00 Xe3_LPG
[05:55:49] [PASSED] 30.01 Xe3_LPG
[05:55:49] [PASSED] 30.03 Xe3_LPG
[05:55:49] [PASSED] 30.04 Xe3_LPG
[05:55:49] [PASSED] 30.05 Xe3_LPG
[05:55:49] [PASSED] 35.10 Xe3p_LPG
[05:55:49] [PASSED] 35.11 Xe3p_XPC
[05:55:49] ================ [PASSED] check_graphics_ip ================
[05:55:49] ===================== check_media_ip ======================
[05:55:49] [PASSED] 12.00 Xe_M
[05:55:49] [PASSED] 12.55 Xe_HPM
[05:55:49] [PASSED] 13.00 Xe_LPM+
[05:55:49] [PASSED] 13.01 Xe2_HPM
[05:55:49] [PASSED] 20.00 Xe2_LPM
[05:55:49] [PASSED] 30.00 Xe3_LPM
[05:55:49] [PASSED] 30.02 Xe3_LPM
[05:55:49] [PASSED] 35.00 Xe3p_LPM
[05:55:49] [PASSED] 35.03 Xe3p_HPM
[05:55:49] ================= [PASSED] check_media_ip ==================
[05:55:49] =================== check_platform_desc ===================
[05:55:49] [PASSED] 0x9A60 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A68 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A70 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A40 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A49 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A59 (TIGERLAKE)
[05:55:49] [PASSED] 0x9A78 (TIGERLAKE)
[05:55:49] [PASSED] 0x9AC0 (TIGERLAKE)
[05:55:49] [PASSED] 0x9AC9 (TIGERLAKE)
[05:55:49] [PASSED] 0x9AD9 (TIGERLAKE)
[05:55:49] [PASSED] 0x9AF8 (TIGERLAKE)
[05:55:49] [PASSED] 0x4C80 (ROCKETLAKE)
[05:55:49] [PASSED] 0x4C8A (ROCKETLAKE)
[05:55:49] [PASSED] 0x4C8B (ROCKETLAKE)
[05:55:49] [PASSED] 0x4C8C (ROCKETLAKE)
[05:55:49] [PASSED] 0x4C90 (ROCKETLAKE)
[05:55:49] [PASSED] 0x4C9A (ROCKETLAKE)
[05:55:49] [PASSED] 0x4680 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4682 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4688 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x468A (ALDERLAKE_S)
[05:55:49] [PASSED] 0x468B (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4690 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4692 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4693 (ALDERLAKE_S)
[05:55:49] [PASSED] 0x46A0 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46A1 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46A2 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46A3 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46A6 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46A8 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46AA (ALDERLAKE_P)
[05:55:49] [PASSED] 0x462A (ALDERLAKE_P)
[05:55:49] [PASSED] 0x4626 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x4628 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46B0 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46B1 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46B2 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46B3 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46C0 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46C1 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46C2 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46C3 (ALDERLAKE_P)
[05:55:49] [PASSED] 0x46D0 (ALDERLAKE_N)
[05:55:49] [PASSED] 0x46D1 (ALDERLAKE_N)
[05:55:49] [PASSED] 0x46D2 (ALDERLAKE_N)
[05:55:49] [PASSED] 0x46D3 (ALDERLAKE_N)
[05:55:49] [PASSED] 0x46D4 (ALDERLAKE_N)
[05:55:49] [PASSED] 0xA721 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7A1 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7A9 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7AC (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7AD (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA720 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7A0 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7A8 (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7AA (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA7AB (ALDERLAKE_P)
[05:55:49] [PASSED] 0xA780 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA781 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA782 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA783 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA788 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA789 (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA78A (ALDERLAKE_S)
[05:55:49] [PASSED] 0xA78B (ALDERLAKE_S)
[05:55:49] [PASSED] 0x4905 (DG1)
[05:55:49] [PASSED] 0x4906 (DG1)
[05:55:49] [PASSED] 0x4907 (DG1)
[05:55:49] [PASSED] 0x4908 (DG1)
[05:55:49] [PASSED] 0x4909 (DG1)
[05:55:49] [PASSED] 0x56C0 (DG2)
[05:55:49] [PASSED] 0x56C2 (DG2)
[05:55:49] [PASSED] 0x56C1 (DG2)
[05:55:49] [PASSED] 0x7D51 (METEORLAKE)
[05:55:49] [PASSED] 0x7DD1 (METEORLAKE)
[05:55:49] [PASSED] 0x7D41 (METEORLAKE)
[05:55:49] [PASSED] 0x7D67 (METEORLAKE)
[05:55:49] [PASSED] 0xB640 (METEORLAKE)
[05:55:49] [PASSED] 0x56A0 (DG2)
[05:55:49] [PASSED] 0x56A1 (DG2)
[05:55:49] [PASSED] 0x56A2 (DG2)
[05:55:49] [PASSED] 0x56BE (DG2)
[05:55:49] [PASSED] 0x56BF (DG2)
[05:55:49] [PASSED] 0x5690 (DG2)
[05:55:49] [PASSED] 0x5691 (DG2)
[05:55:49] [PASSED] 0x5692 (DG2)
[05:55:49] [PASSED] 0x56A5 (DG2)
[05:55:49] [PASSED] 0x56A6 (DG2)
[05:55:49] [PASSED] 0x56B0 (DG2)
[05:55:49] [PASSED] 0x56B1 (DG2)
[05:55:49] [PASSED] 0x56BA (DG2)
[05:55:49] [PASSED] 0x56BB (DG2)
[05:55:49] [PASSED] 0x56BC (DG2)
[05:55:49] [PASSED] 0x56BD (DG2)
[05:55:49] [PASSED] 0x5693 (DG2)
[05:55:49] [PASSED] 0x5694 (DG2)
[05:55:49] [PASSED] 0x5695 (DG2)
[05:55:49] [PASSED] 0x56A3 (DG2)
[05:55:49] [PASSED] 0x56A4 (DG2)
[05:55:49] [PASSED] 0x56B2 (DG2)
[05:55:49] [PASSED] 0x56B3 (DG2)
[05:55:49] [PASSED] 0x5696 (DG2)
[05:55:49] [PASSED] 0x5697 (DG2)
[05:55:49] [PASSED] 0xB69 (PVC)
[05:55:49] [PASSED] 0xB6E (PVC)
[05:55:49] [PASSED] 0xBD4 (PVC)
[05:55:49] [PASSED] 0xBD5 (PVC)
[05:55:49] [PASSED] 0xBD6 (PVC)
[05:55:49] [PASSED] 0xBD7 (PVC)
[05:55:49] [PASSED] 0xBD8 (PVC)
[05:55:49] [PASSED] 0xBD9 (PVC)
[05:55:49] [PASSED] 0xBDA (PVC)
[05:55:49] [PASSED] 0xBDB (PVC)
[05:55:49] [PASSED] 0xBE0 (PVC)
[05:55:49] [PASSED] 0xBE1 (PVC)
[05:55:49] [PASSED] 0xBE5 (PVC)
[05:55:49] [PASSED] 0x7D40 (METEORLAKE)
[05:55:49] [PASSED] 0x7D45 (METEORLAKE)
[05:55:49] [PASSED] 0x7D55 (METEORLAKE)
[05:55:49] [PASSED] 0x7D60 (METEORLAKE)
[05:55:49] [PASSED] 0x7DD5 (METEORLAKE)
[05:55:49] [PASSED] 0x6420 (LUNARLAKE)
[05:55:49] [PASSED] 0x64A0 (LUNARLAKE)
[05:55:49] [PASSED] 0x64B0 (LUNARLAKE)
[05:55:49] [PASSED] 0xE202 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE209 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE20B (BATTLEMAGE)
[05:55:49] [PASSED] 0xE20C (BATTLEMAGE)
[05:55:49] [PASSED] 0xE20D (BATTLEMAGE)
[05:55:49] [PASSED] 0xE210 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE211 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE212 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE216 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE220 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE221 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE222 (BATTLEMAGE)
[05:55:49] [PASSED] 0xE223 (BATTLEMAGE)
[05:55:49] [PASSED] 0xB080 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB081 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB082 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB083 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB084 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB085 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB086 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB087 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB08F (PANTHERLAKE)
[05:55:49] [PASSED] 0xB090 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB0A0 (PANTHERLAKE)
[05:55:49] [PASSED] 0xB0B0 (PANTHERLAKE)
[05:55:49] [PASSED] 0xFD80 (PANTHERLAKE)
[05:55:49] [PASSED] 0xFD81 (PANTHERLAKE)
[05:55:49] [PASSED] 0xD740 (NOVALAKE_S)
[05:55:49] [PASSED] 0xD741 (NOVALAKE_S)
[05:55:49] [PASSED] 0xD742 (NOVALAKE_S)
[05:55:49] [PASSED] 0xD743 (NOVALAKE_S)
[05:55:49] [PASSED] 0xD745 (NOVALAKE_S)
[05:55:49] [PASSED] 0xD74A (NOVALAKE_S)
[05:55:49] [PASSED] 0xD74B (NOVALAKE_S)
[05:55:49] [PASSED] 0x674C (CRESCENTISLAND)
[05:55:49] [PASSED] 0x674D (CRESCENTISLAND)
[05:55:49] [PASSED] 0x674E (CRESCENTISLAND)
[05:55:49] [PASSED] 0x674F (CRESCENTISLAND)
[05:55:49] [PASSED] 0x6750 (CRESCENTISLAND)
[05:55:49] [PASSED] 0xD750 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD751 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD752 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD753 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD754 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD755 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD756 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD757 (NOVALAKE_P)
[05:55:49] [PASSED] 0xD75F (NOVALAKE_P)
[05:55:49] =============== [PASSED] check_platform_desc ===============
[05:55:49] ===================== [PASSED] xe_pci ======================
[05:55:49] ============= xe_rtp_tables_test (5 subtests) ==============
[05:55:49] ================== xe_rtp_table_gt_test ===================
[05:55:49] [PASSED] gt_was/14011060649
[05:55:49] [PASSED] gt_was/14011059788
[05:55:49] [PASSED] gt_was/14015795083
[05:55:49] [PASSED] gt_was/16021867713
[05:55:49] [PASSED] gt_was/14019449301
[05:55:49] [PASSED] gt_was/16028005424
[05:55:49] [PASSED] gt_was/14026578760
[05:55:49] [PASSED] gt_was/1409420604
[05:55:49] [PASSED] gt_was/1408615072
[05:55:49] [PASSED] gt_was/22010523718
[05:55:49] [PASSED] gt_was/14011006942
[05:55:49] [PASSED] gt_was/14014830051
[05:55:49] [PASSED] gt_was/18018781329
[05:55:49] [PASSED] gt_was/1509235366
[05:55:49] [PASSED] gt_was/18018781329
[05:55:49] [PASSED] gt_was/16016694945
[05:55:49] [PASSED] gt_was/14018575942
[05:55:49] [PASSED] gt_was/22016670082
[05:55:49] [PASSED] gt_was/22016670082
[05:55:49] [PASSED] gt_was/14017421178
[05:55:49] [PASSED] gt_was/16025250150
[05:55:49] [PASSED] gt_was/14021871409
[05:55:49] [PASSED] gt_was/16021865536
[05:55:49] [PASSED] gt_was/14021486841
[05:55:49] [PASSED] gt_was/14025160223
[05:55:49] [PASSED] gt_was/14026144927, 16029437861, 14026127056
[05:55:49] [PASSED] gt_was/14025635424
[05:55:49] [PASSED] gt_was/16028005424
[05:55:49] ============== [PASSED] xe_rtp_table_gt_test ===============
[05:55:49] ================== xe_rtp_table_gt_test ===================
[05:55:49] [PASSED] gt_tunings/Tuning: Blend Fill Caching Optimization Disable
[05:55:49] [PASSED] gt_tunings/Tuning: 32B Access Enable
[05:55:49] [PASSED] gt_tunings/Tuning: L3 cache
[05:55:49] [PASSED] gt_tunings/Tuning: L3 cache - media
[05:55:49] [PASSED] gt_tunings/Tuning: Compression Overfetch
[05:55:49] [PASSED] gt_tunings/Tuning: Compression Overfetch - media
[05:55:49] [PASSED] gt_tunings/Tuning: Enable compressible partial write overfetch in L3
[05:55:49] [PASSED] gt_tunings/Tuning: Enable compressible partial write overfetch in L3 - media
[05:55:49] [PASSED] gt_tunings/Tuning: L2 Overfetch Compressible Only
[05:55:49] [PASSED] gt_tunings/Tuning: L2 Overfetch Compressible Only - media
[05:55:49] [PASSED] gt_tunings/Tuning: Stateless compression control
[05:55:49] [PASSED] gt_tunings/Tuning: Stateless compression control - media
[05:55:49] [PASSED] gt_tunings/Tuning: L3 RW flush all Cache
[05:55:49] [PASSED] gt_tunings/Tuning: L3 RW flush all cache - media
[05:55:49] [PASSED] gt_tunings/Tuning: Set STLB Bank Hash Mode to 4KB
[05:55:49] ============== [PASSED] xe_rtp_table_gt_test ===============
[05:55:49] ================== xe_rtp_table_oob_test ==================
[05:55:49] [PASSED] oob_was/1607983814
[05:55:49] [PASSED] oob_was/16010904313
[05:55:49] [PASSED] oob_was/18022495364
[05:55:49] [PASSED] oob_was/22012773006
[05:55:49] [PASSED] oob_was/14014475959
[05:55:49] [PASSED] oob_was/22011391025
[05:55:49] [PASSED] oob_was/22012727170
[05:55:49] [PASSED] oob_was/22012727685
[05:55:49] [PASSED] oob_was/22016596838
[05:55:49] [PASSED] oob_was/18020744125
[05:55:49] [PASSED] oob_was/1409600907
[05:55:49] [PASSED] oob_was/22014953428
[05:55:49] [PASSED] oob_was/16017236439
[05:55:49] [PASSED] oob_was/14019821291
[05:55:49] [PASSED] oob_was/14015076503
[05:55:49] [PASSED] oob_was/14018913170
[05:55:49] [PASSED] oob_was/14018094691
[05:55:49] [PASSED] oob_was/18024947630
[05:55:49] [PASSED] oob_was/16022287689
[05:55:49] [PASSED] oob_was/13011645652
[05:55:49] [PASSED] oob_was/14022293748
[05:55:49] [PASSED] oob_was/22019794406
[05:55:49] [PASSED] oob_was/22019338487
[05:55:49] [PASSED] oob_was/16023588340
[05:55:49] [PASSED] oob_was/14019789679
[05:55:49] [PASSED] oob_was/14022866841
[05:55:49] [PASSED] oob_was/16021333562
[05:55:49] [PASSED] oob_was/14016712196
[05:55:49] [PASSED] oob_was/14015568240
[05:55:49] [PASSED] oob_was/18013179988
[05:55:49] [PASSED] oob_was/1508761755
[05:55:49] [PASSED] oob_was/16023105232
[05:55:49] [PASSED] oob_was/16026508708
[05:55:49] [PASSED] oob_was/14020001231
[05:55:49] [PASSED] oob_was/16023683509
[05:55:49] [PASSED] oob_was/14025515070
[05:55:49] [PASSED] oob_was/15015404425_disable
[05:55:49] [PASSED] oob_was/16026007364
[05:55:49] [PASSED] oob_was/14020316580
[05:55:49] [PASSED] oob_was/14025883347
[05:55:49] [PASSED] oob_was/16029380221
[05:55:49] ============== [PASSED] xe_rtp_table_oob_test ==============
[05:55:49] ================ xe_rtp_table_dev_oob_test ================
[05:55:49] [PASSED] device_oob_was/22010954014
[05:55:49] [PASSED] device_oob_was/15015404425
[05:55:49] [PASSED] device_oob_was/22019338487_display
[05:55:49] [PASSED] device_oob_was/14022085890
[05:55:49] [PASSED] device_oob_was/14026539277
[05:55:49] [PASSED] device_oob_was/14026633728
[05:55:49] [PASSED] device_oob_was/14026746987
[05:55:49] [PASSED] device_oob_was/14026779378
[05:55:49] ============ [PASSED] xe_rtp_table_dev_oob_test ============
[05:55:49] ========== xe_rtp_table_missing_upper_bound_test ==========
[05:55:49] [PASSED] register_whitelist/WaAllowPMDepthAndInvocationCountAccessFromUMD, 1408556865
[05:55:49] [PASSED] register_whitelist/1508744258, 14012131227, 1808121037
[05:55:49] [PASSED] register_whitelist/1806527549
[05:55:49] [PASSED] register_whitelist/allow_read_ctx_timestamp
[05:55:49] [PASSED] register_whitelist/allow_read_queue_timestamp
[05:55:49] [PASSED] register_whitelist/16014440446
[05:55:49] [PASSED] register_whitelist/16017236439
[05:55:49] [PASSED] register_whitelist/16020183090
[05:55:49] [PASSED] register_whitelist/14024997852
[05:55:49] [PASSED] register_whitelist/14024997852
[05:55:49] ====== [PASSED] xe_rtp_table_missing_upper_bound_test ======
[05:55:49] =============== [PASSED] xe_rtp_tables_test ================
[05:55:49] =================== xe_rtp (3 subtests) ====================
[05:55:49] =================== xe_rtp_rules_tests ====================
[05:55:49] [PASSED] no
[05:55:49] [PASSED] yes
[05:55:49] [PASSED] no-and-no
[05:55:49] [PASSED] no-and-yes
[05:55:49] [PASSED] yes-and-no
[05:55:49] [PASSED] yes-and-yes
[05:55:49] [PASSED] no-or-no
[05:55:49] [PASSED] no-or-yes
[05:55:49] [PASSED] yes-or-no
[05:55:49] [PASSED] yes-or-yes
[05:55:49] [PASSED] no-yes-or-yes-no
[05:55:49] [PASSED] no-yes-or-yes-yes
[05:55:49] [PASSED] yes-yes-or-no-yes
[05:55:49] [PASSED] yes-yes-or-yes-yes
[05:55:49] [PASSED] no-no-or-yes-or-no
[05:55:49] [PASSED] or
[05:55:49] [PASSED] or-yes
[05:55:49] [PASSED] or-no
[05:55:49] [PASSED] yes-or
[05:55:49] [PASSED] no-or
[05:55:49] [PASSED] no-or-or-yes
[05:55:49] [PASSED] yes-or-or-no
[05:55:49] [PASSED] no-or-or-no
[05:55:49] [PASSED] missing-context-engine-class
[05:55:49] [PASSED] missing-context-engine-class-or-yes
[05:55:49] [PASSED] missing-context-engine-class-or-or-yes
[05:55:49] =============== [PASSED] xe_rtp_rules_tests ================
[05:55:49] =============== xe_rtp_process_to_sr_tests ================
[05:55:49] [PASSED] coalesce-same-reg
[05:55:49] [PASSED] coalesce-same-reg-literal-and-func
[05:55:49] [PASSED] no-match-no-add
[05:55:49] [PASSED] two-regs-two-entries
[05:55:49] [PASSED] clr-one-set-other
[05:55:49] [PASSED] set-field
[05:55:49] [PASSED] conflict-duplicate
[05:55:49] [PASSED] conflict-not-disjoint
[05:55:49] [PASSED] conflict-not-disjoint-literal-and-func
[05:55:49] [PASSED] conflict-reg-type
[05:55:49] [PASSED] bad-mcr-reg-forced-to-regular
[05:55:49] [PASSED] bad-regular-reg-forced-to-mcr
[05:55:49] =========== [PASSED] xe_rtp_process_to_sr_tests ============
[05:55:49] ================== xe_rtp_process_tests ===================
[05:55:49] [PASSED] active1
[05:55:49] [PASSED] active2
[05:55:49] [PASSED] active-inactive
[05:55:49] [PASSED] inactive-active
[05:55:49] [PASSED] inactive-active-inactive
[05:55:49] [PASSED] inactive-inactive-inactive
[05:55:49] ============== [PASSED] xe_rtp_process_tests ===============
[05:55:49] ===================== [PASSED] xe_rtp ======================
[05:55:49] ==================== xe_wa (1 subtest) =====================
[05:55:49] ======================== xe_wa_gt =========================
[05:55:49] [PASSED] TIGERLAKE B0
[05:55:49] [PASSED] DG1 A0
[05:55:49] [PASSED] DG1 B0
[05:55:49] [PASSED] ALDERLAKE_S A0
[05:55:49] [PASSED] ALDERLAKE_S B0
[05:55:49] [PASSED] ALDERLAKE_S C0
[05:55:49] [PASSED] ALDERLAKE_S D0
[05:55:49] [PASSED] ALDERLAKE_P A0
[05:55:49] [PASSED] ALDERLAKE_P B0
[05:55:49] [PASSED] ALDERLAKE_P C0
[05:55:49] [PASSED] ALDERLAKE_S RPLS D0
[05:55:49] [PASSED] ALDERLAKE_P RPLU E0
[05:55:49] [PASSED] DG2 G10 C0
[05:55:49] [PASSED] DG2 G11 B1
[05:55:49] [PASSED] DG2 G12 A1
[05:55:49] [PASSED] METEORLAKE 12.70(Xe_LPG) A0 13.00(Xe_LPM+) A0
[05:55:49] [PASSED] METEORLAKE 12.71(Xe_LPG) A0 13.00(Xe_LPM+) A0
[05:55:49] [PASSED] METEORLAKE 12.74(Xe_LPG+) A0 13.00(Xe_LPM+) A0
[05:55:49] [PASSED] LUNARLAKE 20.04(Xe2_LPG) A0 20.00(Xe2_LPM) A0
[05:55:49] [PASSED] LUNARLAKE 20.04(Xe2_LPG) B0 20.00(Xe2_LPM) A0
[05:55:49] [PASSED] BATTLEMAGE 20.01(Xe2_HPG) A0 13.01(Xe2_HPM) A1
[05:55:49] [PASSED] PANTHERLAKE 30.00(Xe3_LPG) A0 30.00(Xe3_LPM) A0
[05:55:49] ==================== [PASSED] xe_wa_gt =====================
[05:55:49] ====================== [PASSED] xe_wa ======================
[05:55:49] ============================================================
[05:55:49] Testing complete. Ran 729 tests: passed: 711, skipped: 18
[05:55:49] Elapsed time: 36.837s total, 4.367s configuring, 31.753s building, 0.671s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/tests/.kunitconfig
[05:55:49] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:55:51] 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:56:16] Starting KUnit Kernel (1/1)...
[05:56:16] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:56:16] ============ drm_test_pick_cmdline (2 subtests) ============
[05:56:16] [PASSED] drm_test_pick_cmdline_res_1920_1080_60
[05:56:16] =============== drm_test_pick_cmdline_named ===============
[05:56:16] [PASSED] NTSC
[05:56:16] [PASSED] NTSC-J
[05:56:16] [PASSED] PAL
[05:56:16] [PASSED] PAL-M
[05:56:16] =========== [PASSED] drm_test_pick_cmdline_named ===========
[05:56:16] ============== [PASSED] drm_test_pick_cmdline ==============
[05:56:16] == drm_test_atomic_get_connector_for_encoder (1 subtest) ===
[05:56:16] [PASSED] drm_test_drm_atomic_get_connector_for_encoder
[05:56:16] ==== [PASSED] drm_test_atomic_get_connector_for_encoder ====
[05:56:16] =========== drm_validate_clone_mode (2 subtests) ===========
[05:56:16] ============== drm_test_check_in_clone_mode ===============
[05:56:16] [PASSED] in_clone_mode
[05:56:16] [PASSED] not_in_clone_mode
[05:56:16] ========== [PASSED] drm_test_check_in_clone_mode ===========
[05:56:16] =============== drm_test_check_valid_clones ===============
[05:56:16] [PASSED] not_in_clone_mode
[05:56:16] [PASSED] valid_clone
[05:56:16] [PASSED] invalid_clone
[05:56:16] =========== [PASSED] drm_test_check_valid_clones ===========
[05:56:16] ============= [PASSED] drm_validate_clone_mode =============
[05:56:16] ============= drm_validate_modeset (1 subtest) =============
[05:56:16] [PASSED] drm_test_check_connector_changed_modeset
[05:56:16] ============== [PASSED] drm_validate_modeset ===============
[05:56:16] ====== drm_test_bridge_get_current_state (2 subtests) ======
[05:56:16] [PASSED] drm_test_drm_bridge_get_current_state_atomic
[05:56:16] [PASSED] drm_test_drm_bridge_get_current_state_legacy
[05:56:16] ======== [PASSED] drm_test_bridge_get_current_state ========
[05:56:16] ====== drm_test_bridge_helper_reset_crtc (4 subtests) ======
[05:56:16] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic
[05:56:16] [PASSED] drm_test_drm_bridge_helper_reset_crtc_atomic_disabled
[05:56:16] [PASSED] drm_test_drm_bridge_helper_reset_crtc_legacy
[05:56:16] [PASSED] drm_test_drm_bridge_helper_hdmi_output_bus_fmts
[05:56:16] ======== [PASSED] drm_test_bridge_helper_reset_crtc ========
[05:56:16] ============== drm_bridge_alloc (2 subtests) ===============
[05:56:16] [PASSED] drm_test_drm_bridge_alloc_basic
[05:56:16] [PASSED] drm_test_drm_bridge_alloc_get_put
[05:56:16] ================ [PASSED] drm_bridge_alloc =================
[05:56:16] ============= drm_bridge_bus_fmt (5 subtests) ==============
[05:56:16] [PASSED] drm_test_bridge_rgb_yuv_rgb
[05:56:16] [PASSED] drm_test_bridge_must_convert_to_yuv444
[05:56:16] [PASSED] drm_test_bridge_hdmi_auto_rgb
[05:56:16] [PASSED] drm_test_bridge_auto_first
[05:56:16] [PASSED] drm_test_bridge_rgb_yuv_no_path
[05:56:16] =============== [PASSED] drm_bridge_bus_fmt ================
[05:56:16] ============= drm_cmdline_parser (40 subtests) =============
[05:56:16] [PASSED] drm_test_cmdline_force_d_only
[05:56:16] [PASSED] drm_test_cmdline_force_D_only_dvi
[05:56:16] [PASSED] drm_test_cmdline_force_D_only_hdmi
[05:56:16] [PASSED] drm_test_cmdline_force_D_only_not_digital
[05:56:16] [PASSED] drm_test_cmdline_force_e_only
[05:56:16] [PASSED] drm_test_cmdline_res
[05:56:16] [PASSED] drm_test_cmdline_res_vesa
[05:56:16] [PASSED] drm_test_cmdline_res_vesa_rblank
[05:56:16] [PASSED] drm_test_cmdline_res_rblank
[05:56:16] [PASSED] drm_test_cmdline_res_bpp
[05:56:16] [PASSED] drm_test_cmdline_res_refresh
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_margins
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_force_off
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_analog
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_force_on_digital
[05:56:16] [PASSED] drm_test_cmdline_res_bpp_refresh_interlaced_margins_force_on
[05:56:16] [PASSED] drm_test_cmdline_res_margins_force_on
[05:56:16] [PASSED] drm_test_cmdline_res_vesa_margins
[05:56:16] [PASSED] drm_test_cmdline_name
[05:56:16] [PASSED] drm_test_cmdline_name_bpp
[05:56:16] [PASSED] drm_test_cmdline_name_option
[05:56:16] [PASSED] drm_test_cmdline_name_bpp_option
[05:56:16] [PASSED] drm_test_cmdline_rotate_0
[05:56:16] [PASSED] drm_test_cmdline_rotate_90
[05:56:16] [PASSED] drm_test_cmdline_rotate_180
[05:56:16] [PASSED] drm_test_cmdline_rotate_270
[05:56:16] [PASSED] drm_test_cmdline_hmirror
[05:56:16] [PASSED] drm_test_cmdline_vmirror
[05:56:16] [PASSED] drm_test_cmdline_margin_options
[05:56:16] [PASSED] drm_test_cmdline_multiple_options
[05:56:16] [PASSED] drm_test_cmdline_bpp_extra_and_option
[05:56:16] [PASSED] drm_test_cmdline_extra_and_option
[05:56:16] [PASSED] drm_test_cmdline_freestanding_options
[05:56:16] [PASSED] drm_test_cmdline_freestanding_force_e_and_options
[05:56:16] [PASSED] drm_test_cmdline_panel_orientation
[05:56:16] ================ drm_test_cmdline_invalid =================
[05:56:16] [PASSED] margin_only
[05:56:16] [PASSED] interlace_only
[05:56:16] [PASSED] res_missing_x
[05:56:16] [PASSED] res_missing_y
[05:56:16] [PASSED] res_bad_y
[05:56:16] [PASSED] res_missing_y_bpp
[05:56:16] [PASSED] res_bad_bpp
[05:56:16] [PASSED] res_bad_refresh
[05:56:16] [PASSED] res_bpp_refresh_force_on_off
[05:56:16] [PASSED] res_invalid_mode
[05:56:16] [PASSED] res_bpp_wrong_place_mode
[05:56:16] [PASSED] name_bpp_refresh
[05:56:16] [PASSED] name_refresh
[05:56:16] [PASSED] name_refresh_wrong_mode
[05:56:16] [PASSED] name_refresh_invalid_mode
[05:56:16] [PASSED] rotate_multiple
[05:56:16] [PASSED] rotate_invalid_val
[05:56:16] [PASSED] rotate_truncated
[05:56:16] [PASSED] invalid_option
[05:56:16] [PASSED] invalid_tv_option
[05:56:16] [PASSED] truncated_tv_option
[05:56:16] ============ [PASSED] drm_test_cmdline_invalid =============
[05:56:16] =============== drm_test_cmdline_tv_options ===============
[05:56:16] [PASSED] NTSC
[05:56:16] [PASSED] NTSC_443
[05:56:16] [PASSED] NTSC_J
[05:56:16] [PASSED] PAL
[05:56:16] [PASSED] PAL_M
[05:56:16] [PASSED] PAL_N
[05:56:16] [PASSED] SECAM
[05:56:16] [PASSED] MONO_525
[05:56:16] [PASSED] MONO_625
[05:56:16] =========== [PASSED] drm_test_cmdline_tv_options ===========
[05:56:16] =============== [PASSED] drm_cmdline_parser ================
[05:56:16] ========== drmm_connector_hdmi_init (20 subtests) ==========
[05:56:16] [PASSED] drm_test_connector_hdmi_init_valid
[05:56:16] [PASSED] drm_test_connector_hdmi_init_bpc_8
[05:56:16] [PASSED] drm_test_connector_hdmi_init_bpc_10
[05:56:16] [PASSED] drm_test_connector_hdmi_init_bpc_12
[05:56:16] [PASSED] drm_test_connector_hdmi_init_bpc_invalid
[05:56:16] [PASSED] drm_test_connector_hdmi_init_bpc_null
[05:56:16] [PASSED] drm_test_connector_hdmi_init_formats_empty
[05:56:16] [PASSED] drm_test_connector_hdmi_init_formats_no_rgb
[05:56:16] === drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[05:56:16] [PASSED] supported_formats=0x9 yuv420_allowed=1
[05:56:16] [PASSED] supported_formats=0x9 yuv420_allowed=0
[05:56:16] [PASSED] supported_formats=0x5 yuv420_allowed=1
[05:56:16] [PASSED] supported_formats=0x5 yuv420_allowed=0
[05:56:16] === [PASSED] drm_test_connector_hdmi_init_formats_yuv420_allowed ===
[05:56:16] [PASSED] drm_test_connector_hdmi_init_null_ddc
[05:56:16] [PASSED] drm_test_connector_hdmi_init_null_product
[05:56:16] [PASSED] drm_test_connector_hdmi_init_null_vendor
[05:56:16] [PASSED] drm_test_connector_hdmi_init_product_length_exact
[05:56:16] [PASSED] drm_test_connector_hdmi_init_product_length_too_long
[05:56:16] [PASSED] drm_test_connector_hdmi_init_product_valid
[05:56:16] [PASSED] drm_test_connector_hdmi_init_vendor_length_exact
[05:56:16] [PASSED] drm_test_connector_hdmi_init_vendor_length_too_long
[05:56:16] [PASSED] drm_test_connector_hdmi_init_vendor_valid
[05:56:16] ========= drm_test_connector_hdmi_init_type_valid =========
[05:56:16] [PASSED] HDMI-A
[05:56:16] [PASSED] HDMI-B
[05:56:16] ===== [PASSED] drm_test_connector_hdmi_init_type_valid =====
[05:56:16] ======== drm_test_connector_hdmi_init_type_invalid ========
[05:56:16] [PASSED] Unknown
[05:56:16] [PASSED] VGA
[05:56:16] [PASSED] DVI-I
[05:56:16] [PASSED] DVI-D
[05:56:16] [PASSED] DVI-A
[05:56:16] [PASSED] Composite
[05:56:16] [PASSED] SVIDEO
[05:56:16] [PASSED] LVDS
[05:56:16] [PASSED] Component
[05:56:16] [PASSED] DIN
[05:56:16] [PASSED] DP
[05:56:16] [PASSED] TV
[05:56:16] [PASSED] eDP
[05:56:16] [PASSED] Virtual
[05:56:16] [PASSED] DSI
[05:56:16] [PASSED] DPI
[05:56:16] [PASSED] Writeback
[05:56:16] [PASSED] SPI
[05:56:16] [PASSED] USB
[05:56:16] ==== [PASSED] drm_test_connector_hdmi_init_type_invalid ====
[05:56:16] ============ [PASSED] drmm_connector_hdmi_init =============
[05:56:16] ============= drmm_connector_init (3 subtests) =============
[05:56:16] [PASSED] drm_test_drmm_connector_init
[05:56:16] [PASSED] drm_test_drmm_connector_init_null_ddc
[05:56:16] ========= drm_test_drmm_connector_init_type_valid =========
[05:56:16] [PASSED] Unknown
[05:56:16] [PASSED] VGA
[05:56:16] [PASSED] DVI-I
[05:56:16] [PASSED] DVI-D
[05:56:16] [PASSED] DVI-A
[05:56:16] [PASSED] Composite
[05:56:16] [PASSED] SVIDEO
[05:56:16] [PASSED] LVDS
[05:56:16] [PASSED] Component
[05:56:16] [PASSED] DIN
[05:56:16] [PASSED] DP
[05:56:16] [PASSED] HDMI-A
[05:56:16] [PASSED] HDMI-B
[05:56:16] [PASSED] TV
[05:56:16] [PASSED] eDP
[05:56:16] [PASSED] Virtual
[05:56:16] [PASSED] DSI
[05:56:16] [PASSED] DPI
[05:56:16] [PASSED] Writeback
[05:56:16] [PASSED] SPI
[05:56:16] [PASSED] USB
[05:56:16] ===== [PASSED] drm_test_drmm_connector_init_type_valid =====
[05:56:16] =============== [PASSED] drmm_connector_init ===============
[05:56:16] ========= drm_connector_dynamic_init (6 subtests) ==========
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_init
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_init_null_ddc
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_init_not_added
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_init_properties
[05:56:16] ===== drm_test_drm_connector_dynamic_init_type_valid ======
[05:56:16] [PASSED] Unknown
[05:56:16] [PASSED] VGA
[05:56:16] [PASSED] DVI-I
[05:56:16] [PASSED] DVI-D
[05:56:16] [PASSED] DVI-A
[05:56:16] [PASSED] Composite
[05:56:16] [PASSED] SVIDEO
[05:56:16] [PASSED] LVDS
[05:56:16] [PASSED] Component
[05:56:16] [PASSED] DIN
[05:56:16] [PASSED] DP
[05:56:16] [PASSED] HDMI-A
[05:56:16] [PASSED] HDMI-B
[05:56:16] [PASSED] TV
[05:56:16] [PASSED] eDP
[05:56:16] [PASSED] Virtual
[05:56:16] [PASSED] DSI
[05:56:16] [PASSED] DPI
[05:56:16] [PASSED] Writeback
[05:56:16] [PASSED] SPI
[05:56:16] [PASSED] USB
[05:56:16] = [PASSED] drm_test_drm_connector_dynamic_init_type_valid ==
[05:56:16] ======== drm_test_drm_connector_dynamic_init_name =========
[05:56:16] [PASSED] Unknown
[05:56:16] [PASSED] VGA
[05:56:16] [PASSED] DVI-I
[05:56:16] [PASSED] DVI-D
[05:56:16] [PASSED] DVI-A
[05:56:16] [PASSED] Composite
[05:56:16] [PASSED] SVIDEO
[05:56:16] [PASSED] LVDS
[05:56:16] [PASSED] Component
[05:56:16] [PASSED] DIN
[05:56:16] [PASSED] DP
[05:56:16] [PASSED] HDMI-A
[05:56:16] [PASSED] HDMI-B
[05:56:16] [PASSED] TV
[05:56:16] [PASSED] eDP
[05:56:16] [PASSED] Virtual
[05:56:16] [PASSED] DSI
[05:56:16] [PASSED] DPI
[05:56:16] [PASSED] Writeback
[05:56:16] [PASSED] SPI
[05:56:16] [PASSED] USB
[05:56:16] ==== [PASSED] drm_test_drm_connector_dynamic_init_name =====
[05:56:16] =========== [PASSED] drm_connector_dynamic_init ============
[05:56:16] ==== drm_connector_dynamic_register_early (4 subtests) =====
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_early_on_list
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_early_defer
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_early_no_init
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_early_no_mode_object
[05:56:16] ====== [PASSED] drm_connector_dynamic_register_early =======
[05:56:16] ======= drm_connector_dynamic_register (7 subtests) ========
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_on_list
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_no_defer
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_no_init
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_mode_object
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_sysfs
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_sysfs_name
[05:56:16] [PASSED] drm_test_drm_connector_dynamic_register_debugfs
[05:56:16] ========= [PASSED] drm_connector_dynamic_register ==========
[05:56:16] = drm_connector_attach_broadcast_rgb_property (2 subtests) =
[05:56:16] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property
[05:56:16] [PASSED] drm_test_drm_connector_attach_broadcast_rgb_property_hdmi_connector
[05:56:16] === [PASSED] drm_connector_attach_broadcast_rgb_property ===
[05:56:16] ========== drm_get_tv_mode_from_name (2 subtests) ==========
[05:56:16] ========== drm_test_get_tv_mode_from_name_valid ===========
[05:56:16] [PASSED] NTSC
[05:56:16] [PASSED] NTSC-443
[05:56:16] [PASSED] NTSC-J
[05:56:16] [PASSED] PAL
[05:56:16] [PASSED] PAL-M
[05:56:16] [PASSED] PAL-N
[05:56:16] [PASSED] SECAM
[05:56:16] [PASSED] Mono
[05:56:16] ====== [PASSED] drm_test_get_tv_mode_from_name_valid =======
[05:56:16] [PASSED] drm_test_get_tv_mode_from_name_truncated
[05:56:16] ============ [PASSED] drm_get_tv_mode_from_name ============
[05:56:16] = drm_test_connector_hdmi_compute_mode_clock (12 subtests) =
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_10bpc_vic_1
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_12bpc_vic_1
[05:56:16] [PASSED] drm_test_drm_hdmi_compute_mode_clock_rgb_double
[05:56:16] = drm_test_connector_hdmi_compute_mode_clock_yuv420_valid =
[05:56:16] [PASSED] VIC 96
[05:56:16] [PASSED] VIC 97
[05:56:16] [PASSED] VIC 101
[05:56:16] [PASSED] VIC 102
[05:56:16] [PASSED] VIC 106
[05:56:16] [PASSED] VIC 107
[05:56:16] === [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_valid ===
[05:56:16] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_10_bpc
[05:56:16] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv420_12_bpc
[05:56:16] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_8_bpc
[05:56:16] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_10_bpc
[05:56:16] [PASSED] drm_test_connector_hdmi_compute_mode_clock_yuv422_12_bpc
[05:56:16] === [PASSED] drm_test_connector_hdmi_compute_mode_clock ====
[05:56:16] == drm_hdmi_connector_get_broadcast_rgb_name (2 subtests) ==
[05:56:16] === drm_test_drm_hdmi_connector_get_broadcast_rgb_name ====
[05:56:16] [PASSED] Automatic
[05:56:16] [PASSED] Full
[05:56:16] [PASSED] Limited 16:235
[05:56:16] === [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name ===
[05:56:16] [PASSED] drm_test_drm_hdmi_connector_get_broadcast_rgb_name_invalid
[05:56:16] ==== [PASSED] drm_hdmi_connector_get_broadcast_rgb_name ====
[05:56:16] == drm_hdmi_connector_get_output_format_name (2 subtests) ==
[05:56:16] === drm_test_drm_hdmi_connector_get_output_format_name ====
[05:56:16] [PASSED] RGB
[05:56:16] [PASSED] YUV 4:2:0
[05:56:16] [PASSED] YUV 4:2:2
[05:56:16] [PASSED] YUV 4:4:4
[05:56:16] === [PASSED] drm_test_drm_hdmi_connector_get_output_format_name ===
[05:56:16] [PASSED] drm_test_drm_hdmi_connector_get_output_format_name_invalid
[05:56:16] ==== [PASSED] drm_hdmi_connector_get_output_format_name ====
[05:56:16] ============= drm_damage_helper (21 subtests) ==============
[05:56:16] [PASSED] drm_test_damage_iter_no_damage
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_fractional_src
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_src_moved
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_fractional_src_moved
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_not_visible
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_no_crtc
[05:56:16] [PASSED] drm_test_damage_iter_no_damage_no_fb
[05:56:16] [PASSED] drm_test_damage_iter_simple_damage
[05:56:16] [PASSED] drm_test_damage_iter_single_damage
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_intersect_src
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_outside_src
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_fractional_src
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_intersect_fractional_src
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_outside_fractional_src
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_src_moved
[05:56:16] [PASSED] drm_test_damage_iter_single_damage_fractional_src_moved
[05:56:16] [PASSED] drm_test_damage_iter_damage
[05:56:16] [PASSED] drm_test_damage_iter_damage_one_intersect
[05:56:16] [PASSED] drm_test_damage_iter_damage_one_outside
[05:56:16] [PASSED] drm_test_damage_iter_damage_src_moved
[05:56:16] [PASSED] drm_test_damage_iter_damage_not_visible
[05:56:16] ================ [PASSED] drm_damage_helper ================
[05:56:16] ============== drm_dp_mst_helper (3 subtests) ==============
[05:56:16] ============== drm_test_dp_mst_calc_pbn_mode ==============
[05:56:16] [PASSED] Clock 154000 BPP 30 DSC disabled
[05:56:16] [PASSED] Clock 234000 BPP 30 DSC disabled
[05:56:16] [PASSED] Clock 297000 BPP 24 DSC disabled
[05:56:16] [PASSED] Clock 332880 BPP 24 DSC enabled
[05:56:16] [PASSED] Clock 324540 BPP 24 DSC enabled
[05:56:16] ========== [PASSED] drm_test_dp_mst_calc_pbn_mode ==========
[05:56:16] ============== drm_test_dp_mst_calc_pbn_div ===============
[05:56:16] [PASSED] Link rate 2000000 lane count 4
[05:56:16] [PASSED] Link rate 2000000 lane count 2
[05:56:16] [PASSED] Link rate 2000000 lane count 1
[05:56:16] [PASSED] Link rate 1350000 lane count 4
[05:56:16] [PASSED] Link rate 1350000 lane count 2
[05:56:16] [PASSED] Link rate 1350000 lane count 1
[05:56:16] [PASSED] Link rate 1000000 lane count 4
[05:56:16] [PASSED] Link rate 1000000 lane count 2
[05:56:16] [PASSED] Link rate 1000000 lane count 1
[05:56:16] [PASSED] Link rate 810000 lane count 4
[05:56:16] [PASSED] Link rate 810000 lane count 2
[05:56:16] [PASSED] Link rate 810000 lane count 1
[05:56:16] [PASSED] Link rate 540000 lane count 4
[05:56:16] [PASSED] Link rate 540000 lane count 2
[05:56:16] [PASSED] Link rate 540000 lane count 1
[05:56:16] [PASSED] Link rate 270000 lane count 4
[05:56:16] [PASSED] Link rate 270000 lane count 2
[05:56:16] [PASSED] Link rate 270000 lane count 1
[05:56:16] [PASSED] Link rate 162000 lane count 4
[05:56:16] [PASSED] Link rate 162000 lane count 2
[05:56:16] [PASSED] Link rate 162000 lane count 1
[05:56:16] ========== [PASSED] drm_test_dp_mst_calc_pbn_div ===========
[05:56:16] ========= drm_test_dp_mst_sideband_msg_req_decode =========
[05:56:16] [PASSED] DP_ENUM_PATH_RESOURCES with port number
[05:56:16] [PASSED] DP_POWER_UP_PHY with port number
[05:56:16] [PASSED] DP_POWER_DOWN_PHY with port number
[05:56:16] [PASSED] DP_ALLOCATE_PAYLOAD with SDP stream sinks
[05:56:16] [PASSED] DP_ALLOCATE_PAYLOAD with port number
[05:56:16] [PASSED] DP_ALLOCATE_PAYLOAD with VCPI
[05:56:16] [PASSED] DP_ALLOCATE_PAYLOAD with PBN
[05:56:16] [PASSED] DP_QUERY_PAYLOAD with port number
[05:56:16] [PASSED] DP_QUERY_PAYLOAD with VCPI
[05:56:16] [PASSED] DP_REMOTE_DPCD_READ with port number
[05:56:16] [PASSED] DP_REMOTE_DPCD_READ with DPCD address
[05:56:16] [PASSED] DP_REMOTE_DPCD_READ with max number of bytes
[05:56:16] [PASSED] DP_REMOTE_DPCD_WRITE with port number
[05:56:16] [PASSED] DP_REMOTE_DPCD_WRITE with DPCD address
[05:56:16] [PASSED] DP_REMOTE_DPCD_WRITE with data array
[05:56:16] [PASSED] DP_REMOTE_I2C_READ with port number
[05:56:16] [PASSED] DP_REMOTE_I2C_READ with I2C device ID
[05:56:16] [PASSED] DP_REMOTE_I2C_READ with transactions array
[05:56:16] [PASSED] DP_REMOTE_I2C_WRITE with port number
[05:56:16] [PASSED] DP_REMOTE_I2C_WRITE with I2C device ID
[05:56:16] [PASSED] DP_REMOTE_I2C_WRITE with data array
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream ID
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with client ID
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream event
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with valid stream event
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with stream behavior
[05:56:16] [PASSED] DP_QUERY_STREAM_ENC_STATUS with a valid stream behavior
[05:56:16] ===== [PASSED] drm_test_dp_mst_sideband_msg_req_decode =====
[05:56:16] ================ [PASSED] drm_dp_mst_helper ================
[05:56:16] ================== drm_exec (7 subtests) ===================
[05:56:16] [PASSED] sanitycheck
[05:56:16] [PASSED] test_lock
[05:56:16] [PASSED] test_lock_unlock
[05:56:16] [PASSED] test_duplicates
[05:56:16] [PASSED] test_prepare
[05:56:16] [PASSED] test_prepare_array
[05:56:16] [PASSED] test_multiple_loops
[05:56:16] ==================== [PASSED] drm_exec =====================
[05:56:16] =========== drm_format_helper_test (17 subtests) ===========
[05:56:16] ============== drm_test_fb_xrgb8888_to_gray8 ==============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========== [PASSED] drm_test_fb_xrgb8888_to_gray8 ==========
[05:56:16] ============= drm_test_fb_xrgb8888_to_rgb332 ==============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb332 ==========
[05:56:16] ============= drm_test_fb_xrgb8888_to_rgb565 ==============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb565 ==========
[05:56:16] ============ drm_test_fb_xrgb8888_to_xrgb1555 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_xrgb1555 =========
[05:56:16] ============ drm_test_fb_xrgb8888_to_argb1555 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_argb1555 =========
[05:56:16] ============ drm_test_fb_xrgb8888_to_rgba5551 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_rgba5551 =========
[05:56:16] ============= drm_test_fb_xrgb8888_to_rgb888 ==============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========= [PASSED] drm_test_fb_xrgb8888_to_rgb888 ==========
[05:56:16] ============= drm_test_fb_xrgb8888_to_bgr888 ==============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========= [PASSED] drm_test_fb_xrgb8888_to_bgr888 ==========
[05:56:16] ============ drm_test_fb_xrgb8888_to_argb8888 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_argb8888 =========
[05:56:16] =========== drm_test_fb_xrgb8888_to_xrgb2101010 ===========
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======= [PASSED] drm_test_fb_xrgb8888_to_xrgb2101010 =======
[05:56:16] =========== drm_test_fb_xrgb8888_to_argb2101010 ===========
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======= [PASSED] drm_test_fb_xrgb8888_to_argb2101010 =======
[05:56:16] ============== drm_test_fb_xrgb8888_to_mono ===============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ========== [PASSED] drm_test_fb_xrgb8888_to_mono ===========
[05:56:16] ==================== drm_test_fb_swab =====================
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ================ [PASSED] drm_test_fb_swab =================
[05:56:16] ============ drm_test_fb_xrgb8888_to_xbgr8888 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_xbgr8888 =========
[05:56:16] ============ drm_test_fb_xrgb8888_to_abgr8888 =============
[05:56:16] [PASSED] single_pixel_source_buffer
[05:56:16] [PASSED] single_pixel_clip_rectangle
[05:56:16] [PASSED] well_known_colors
[05:56:16] [PASSED] destination_pitch
[05:56:16] ======== [PASSED] drm_test_fb_xrgb8888_to_abgr8888 =========
[05:56:16] ================= drm_test_fb_clip_offset =================
[05:56:16] [PASSED] pass through
[05:56:16] [PASSED] horizontal offset
[05:56:16] [PASSED] vertical offset
[05:56:16] [PASSED] horizontal and vertical offset
[05:56:16] [PASSED] horizontal offset (custom pitch)
[05:56:16] [PASSED] vertical offset (custom pitch)
[05:56:16] [PASSED] horizontal and vertical offset (custom pitch)
[05:56:16] ============= [PASSED] drm_test_fb_clip_offset =============
[05:56:16] =================== drm_test_fb_memcpy ====================
[05:56:16] [PASSED] single_pixel_source_buffer: XR24 little-endian (0x34325258)
[05:56:16] [PASSED] single_pixel_source_buffer: XRA8 little-endian (0x38415258)
[05:56:16] [PASSED] single_pixel_source_buffer: YU24 little-endian (0x34325559)
[05:56:16] [PASSED] single_pixel_clip_rectangle: XB24 little-endian (0x34324258)
[05:56:16] [PASSED] single_pixel_clip_rectangle: XRA8 little-endian (0x38415258)
[05:56:16] [PASSED] single_pixel_clip_rectangle: YU24 little-endian (0x34325559)
[05:56:16] [PASSED] well_known_colors: XB24 little-endian (0x34324258)
[05:56:16] [PASSED] well_known_colors: XRA8 little-endian (0x38415258)
[05:56:16] [PASSED] well_known_colors: YU24 little-endian (0x34325559)
[05:56:16] [PASSED] destination_pitch: XB24 little-endian (0x34324258)
[05:56:16] [PASSED] destination_pitch: XRA8 little-endian (0x38415258)
[05:56:16] [PASSED] destination_pitch: YU24 little-endian (0x34325559)
[05:56:16] =============== [PASSED] drm_test_fb_memcpy ================
[05:56:16] ============= [PASSED] drm_format_helper_test ==============
[05:56:16] ================= drm_format (18 subtests) =================
[05:56:16] [PASSED] drm_test_format_block_width_invalid
[05:56:16] [PASSED] drm_test_format_block_width_one_plane
[05:56:16] [PASSED] drm_test_format_block_width_two_plane
[05:56:16] [PASSED] drm_test_format_block_width_three_plane
[05:56:16] [PASSED] drm_test_format_block_width_tiled
[05:56:16] [PASSED] drm_test_format_block_height_invalid
[05:56:16] [PASSED] drm_test_format_block_height_one_plane
[05:56:16] [PASSED] drm_test_format_block_height_two_plane
[05:56:16] [PASSED] drm_test_format_block_height_three_plane
[05:56:16] [PASSED] drm_test_format_block_height_tiled
[05:56:16] [PASSED] drm_test_format_min_pitch_invalid
[05:56:16] [PASSED] drm_test_format_min_pitch_one_plane_8bpp
[05:56:16] [PASSED] drm_test_format_min_pitch_one_plane_16bpp
[05:56:16] [PASSED] drm_test_format_min_pitch_one_plane_24bpp
[05:56:16] [PASSED] drm_test_format_min_pitch_one_plane_32bpp
[05:56:16] [PASSED] drm_test_format_min_pitch_two_plane
[05:56:16] [PASSED] drm_test_format_min_pitch_three_plane_8bpp
[05:56:16] [PASSED] drm_test_format_min_pitch_tiled
[05:56:16] =================== [PASSED] drm_format ====================
[05:56:16] ============== drm_framebuffer (10 subtests) ===============
[05:56:16] ========== drm_test_framebuffer_check_src_coords ==========
[05:56:16] [PASSED] Success: source fits into fb
[05:56:16] [PASSED] Fail: overflowing fb with x-axis coordinate
[05:56:16] [PASSED] Fail: overflowing fb with y-axis coordinate
[05:56:16] [PASSED] Fail: overflowing fb with source width
[05:56:16] [PASSED] Fail: overflowing fb with source height
[05:56:16] ====== [PASSED] drm_test_framebuffer_check_src_coords ======
[05:56:16] [PASSED] drm_test_framebuffer_cleanup
[05:56:16] =============== drm_test_framebuffer_create ===============
[05:56:16] [PASSED] ABGR8888 normal sizes
[05:56:16] [PASSED] ABGR8888 max sizes
[05:56:16] [PASSED] ABGR8888 pitch greater than min required
[05:56:16] [PASSED] ABGR8888 pitch less than min required
[05:56:16] [PASSED] ABGR8888 Invalid width
[05:56:16] [PASSED] ABGR8888 Invalid buffer handle
[05:56:16] [PASSED] No pixel format
[05:56:16] [PASSED] ABGR8888 Width 0
[05:56:16] [PASSED] ABGR8888 Height 0
[05:56:16] [PASSED] ABGR8888 Out of bound height * pitch combination
[05:56:16] [PASSED] ABGR8888 Large buffer offset
[05:56:16] [PASSED] ABGR8888 Buffer offset for inexistent plane
[05:56:16] [PASSED] ABGR8888 Invalid flag
[05:56:16] [PASSED] ABGR8888 Set DRM_MODE_FB_MODIFIERS without modifiers
[05:56:16] [PASSED] ABGR8888 Valid buffer modifier
[05:56:16] [PASSED] ABGR8888 Invalid buffer modifier(DRM_FORMAT_MOD_SAMSUNG_64_32_TILE)
[05:56:16] [PASSED] ABGR8888 Extra pitches without DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] ABGR8888 Extra pitches with DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] NV12 Normal sizes
[05:56:16] [PASSED] NV12 Max sizes
[05:56:16] [PASSED] NV12 Invalid pitch
[05:56:16] [PASSED] NV12 Invalid modifier/missing DRM_MODE_FB_MODIFIERS flag
[05:56:16] [PASSED] NV12 different modifier per-plane
[05:56:16] [PASSED] NV12 with DRM_FORMAT_MOD_SAMSUNG_64_32_TILE
[05:56:16] [PASSED] NV12 Valid modifiers without DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] NV12 Modifier for inexistent plane
[05:56:16] [PASSED] NV12 Handle for inexistent plane
[05:56:16] [PASSED] NV12 Handle for inexistent plane without DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] YVU420 DRM_MODE_FB_MODIFIERS set without modifier
[05:56:16] [PASSED] YVU420 Normal sizes
[05:56:16] [PASSED] YVU420 Max sizes
[05:56:16] [PASSED] YVU420 Invalid pitch
[05:56:16] [PASSED] YVU420 Different pitches
[05:56:16] [PASSED] YVU420 Different buffer offsets/pitches
[05:56:16] [PASSED] YVU420 Modifier set just for plane 0, without DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] YVU420 Modifier set just for planes 0, 1, without DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] YVU420 Modifier set just for plane 0, 1, with DRM_MODE_FB_MODIFIERS
[05:56:16] [PASSED] YVU420 Valid modifier
[05:56:16] [PASSED] YVU420 Different modifiers per plane
[05:56:16] [PASSED] YVU420 Modifier for inexistent plane
[05:56:16] [PASSED] YUV420_10BIT Invalid modifier(DRM_FORMAT_MOD_LINEAR)
[05:56:16] [PASSED] X0L2 Normal sizes
[05:56:16] [PASSED] X0L2 Max sizes
[05:56:16] [PASSED] X0L2 Invalid pitch
[05:56:16] [PASSED] X0L2 Pitch greater than minimum required
[05:56:16] [PASSED] X0L2 Handle for inexistent plane
[05:56:16] [PASSED] X0L2 Offset for inexistent plane, without DRM_MODE_FB_MODIFIERS set
[05:56:16] [PASSED] X0L2 Modifier without DRM_MODE_FB_MODIFIERS set
[05:56:16] [PASSED] X0L2 Valid modifier
[05:56:16] [PASSED] X0L2 Modifier for inexistent plane
[05:56:16] =========== [PASSED] drm_test_framebuffer_create ===========
[05:56:16] [PASSED] drm_test_framebuffer_free
[05:56:16] [PASSED] drm_test_framebuffer_init
[05:56:16] [PASSED] drm_test_framebuffer_init_bad_format
[05:56:16] [PASSED] drm_test_framebuffer_init_dev_mismatch
[05:56:16] [PASSED] drm_test_framebuffer_lookup
[05:56:16] [PASSED] drm_test_framebuffer_lookup_inexistent
[05:56:16] [PASSED] drm_test_framebuffer_modifiers_not_supported
[05:56:16] ================= [PASSED] drm_framebuffer =================
[05:56:16] ================ drm_gem_shmem (8 subtests) ================
[05:56:16] [PASSED] drm_gem_shmem_test_obj_create
[05:56:16] [PASSED] drm_gem_shmem_test_obj_create_private
[05:56:16] [PASSED] drm_gem_shmem_test_pin_pages
[05:56:16] [PASSED] drm_gem_shmem_test_vmap
[05:56:16] [PASSED] drm_gem_shmem_test_get_sg_table
[05:56:16] [PASSED] drm_gem_shmem_test_get_pages_sgt
[05:56:16] [PASSED] drm_gem_shmem_test_madvise
[05:56:16] [PASSED] drm_gem_shmem_test_purge
[05:56:16] ================== [PASSED] drm_gem_shmem ==================
[05:56:16] === drm_atomic_helper_connector_hdmi_check (29 subtests) ===
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_auto_cea_mode_vic_1
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_full_cea_mode_vic_1
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_limited_cea_mode_vic_1
[05:56:16] ====== drm_test_check_broadcast_rgb_cea_mode_yuv420 =======
[05:56:16] [PASSED] Automatic
[05:56:16] [PASSED] Full
[05:56:16] [PASSED] Limited 16:235
[05:56:16] == [PASSED] drm_test_check_broadcast_rgb_cea_mode_yuv420 ===
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_changed
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_crtc_mode_not_changed
[05:56:16] [PASSED] drm_test_check_disable_connector
[05:56:16] [PASSED] drm_test_check_hdmi_funcs_reject_rate
[05:56:16] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_rgb
[05:56:16] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_yuv420
[05:56:16] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv422
[05:56:16] [PASSED] drm_test_check_max_tmds_rate_bpc_fallback_ignore_yuv420
[05:56:16] [PASSED] drm_test_check_driver_unsupported_fallback_yuv420
[05:56:16] [PASSED] drm_test_check_output_bpc_crtc_mode_changed
[05:56:16] [PASSED] drm_test_check_output_bpc_crtc_mode_not_changed
[05:56:16] [PASSED] drm_test_check_output_bpc_dvi
[05:56:16] [PASSED] drm_test_check_output_bpc_format_vic_1
[05:56:16] [PASSED] drm_test_check_output_bpc_format_display_8bpc_only
[05:56:16] [PASSED] drm_test_check_output_bpc_format_display_rgb_only
[05:56:16] [PASSED] drm_test_check_output_bpc_format_driver_8bpc_only
[05:56:16] [PASSED] drm_test_check_output_bpc_format_driver_rgb_only
[05:56:16] [PASSED] drm_test_check_tmds_char_rate_rgb_8bpc
[05:56:16] [PASSED] drm_test_check_tmds_char_rate_rgb_10bpc
[05:56:16] [PASSED] drm_test_check_tmds_char_rate_rgb_12bpc
[05:56:16] ============ drm_test_check_hdmi_color_format =============
[05:56:16] [PASSED] AUTO -> RGB
[05:56:16] [PASSED] YCBCR422 -> YUV422
[05:56:16] [PASSED] YCBCR420 -> YUV420
[05:56:16] [PASSED] YCBCR444 -> YUV444
[05:56:16] [PASSED] RGB -> RGB
[05:56:16] ======== [PASSED] drm_test_check_hdmi_color_format =========
[05:56:16] ======== drm_test_check_hdmi_color_format_420_only ========
[05:56:16] [PASSED] RGB should fail
[05:56:16] [PASSED] YUV444 should fail
[05:56:16] [PASSED] YUV422 should fail
[05:56:16] [PASSED] YUV420 should work
[05:56:16] ==== [PASSED] drm_test_check_hdmi_color_format_420_only ====
[05:56:16] ===== [PASSED] drm_atomic_helper_connector_hdmi_check ======
[05:56:16] === drm_atomic_helper_connector_hdmi_reset (6 subtests) ====
[05:56:16] [PASSED] drm_test_check_broadcast_rgb_value
[05:56:16] [PASSED] drm_test_check_bpc_8_value
[05:56:16] [PASSED] drm_test_check_bpc_10_value
[05:56:16] [PASSED] drm_test_check_bpc_12_value
[05:56:16] [PASSED] drm_test_check_format_value
[05:56:16] [PASSED] drm_test_check_tmds_char_value
[05:56:16] ===== [PASSED] drm_atomic_helper_connector_hdmi_reset ======
[05:56:16] = drm_atomic_helper_connector_hdmi_mode_valid (7 subtests) =
[05:56:16] [PASSED] drm_test_check_mode_valid
[05:56:16] [PASSED] drm_test_check_mode_valid_reject
[05:56:16] [PASSED] drm_test_check_mode_valid_reject_rate
[05:56:16] [PASSED] drm_test_check_mode_valid_reject_max_clock
[05:56:16] [PASSED] drm_test_check_mode_valid_yuv420_only_max_clock
[05:56:16] [PASSED] drm_test_check_mode_valid_reject_yuv420_only_connector
[05:56:16] [PASSED] drm_test_check_mode_valid_accept_yuv420_also_connector_rgb
[05:56:16] === [PASSED] drm_atomic_helper_connector_hdmi_mode_valid ===
[05:56:16] = drm_atomic_helper_connector_hdmi_infoframes (5 subtests) =
[05:56:16] [PASSED] drm_test_check_infoframes
[05:56:16] [PASSED] drm_test_check_reject_avi_infoframe
[05:56:16] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_8
[05:56:16] [PASSED] drm_test_check_reject_hdr_infoframe_bpc_10
[05:56:16] [PASSED] drm_test_check_reject_audio_infoframe
[05:56:16] === [PASSED] drm_atomic_helper_connector_hdmi_infoframes ===
[05:56:16] ================= drm_managed (2 subtests) =================
[05:56:16] [PASSED] drm_test_managed_release_action
[05:56:16] [PASSED] drm_test_managed_run_action
[05:56:16] =================== [PASSED] drm_managed ===================
[05:56:16] =================== drm_mm (6 subtests) ====================
[05:56:16] [PASSED] drm_test_mm_init
[05:56:16] [PASSED] drm_test_mm_debug
[05:56:16] [PASSED] drm_test_mm_align32
[05:56:16] [PASSED] drm_test_mm_align64
[05:56:16] [PASSED] drm_test_mm_lowest
[05:56:16] [PASSED] drm_test_mm_highest
[05:56:16] ===================== [PASSED] drm_mm ======================
[05:56:16] ============= drm_modes_analog_tv (5 subtests) =============
[05:56:16] [PASSED] drm_test_modes_analog_tv_mono_576i
[05:56:16] [PASSED] drm_test_modes_analog_tv_ntsc_480i
[05:56:16] [PASSED] drm_test_modes_analog_tv_ntsc_480i_inlined
[05:56:16] [PASSED] drm_test_modes_analog_tv_pal_576i
[05:56:16] [PASSED] drm_test_modes_analog_tv_pal_576i_inlined
[05:56:16] =============== [PASSED] drm_modes_analog_tv ===============
[05:56:16] ============== drm_plane_helper (2 subtests) ===============
[05:56:16] =============== drm_test_check_plane_state ================
[05:56:16] [PASSED] clipping_simple
[05:56:16] [PASSED] clipping_rotate_reflect
[05:56:16] [PASSED] positioning_simple
[05:56:16] [PASSED] upscaling
[05:56:16] [PASSED] downscaling
[05:56:16] [PASSED] rounding1
[05:56:16] [PASSED] rounding2
[05:56:16] [PASSED] rounding3
[05:56:16] [PASSED] rounding4
[05:56:16] =========== [PASSED] drm_test_check_plane_state ============
[05:56:16] =========== drm_test_check_invalid_plane_state ============
[05:56:16] [PASSED] positioning_invalid
[05:56:16] [PASSED] upscaling_invalid
[05:56:16] [PASSED] downscaling_invalid
[05:56:16] ======= [PASSED] drm_test_check_invalid_plane_state ========
[05:56:16] ================ [PASSED] drm_plane_helper =================
[05:56:16] ====== drm_connector_helper_tv_get_modes (1 subtest) =======
[05:56:16] ====== drm_test_connector_helper_tv_get_modes_check =======
[05:56:16] [PASSED] None
[05:56:16] [PASSED] PAL
[05:56:16] [PASSED] NTSC
[05:56:16] [PASSED] Both, NTSC Default
[05:56:16] [PASSED] Both, PAL Default
[05:56:16] [PASSED] Both, NTSC Default, with PAL on command-line
[05:56:16] [PASSED] Both, PAL Default, with NTSC on command-line
[05:56:16] == [PASSED] drm_test_connector_helper_tv_get_modes_check ===
[05:56:16] ======== [PASSED] drm_connector_helper_tv_get_modes ========
[05:56:16] ================== drm_rect (9 subtests) ===================
[05:56:16] [PASSED] drm_test_rect_clip_scaled_div_by_zero
[05:56:16] [PASSED] drm_test_rect_clip_scaled_not_clipped
[05:56:16] [PASSED] drm_test_rect_clip_scaled_clipped
[05:56:16] [PASSED] drm_test_rect_clip_scaled_signed_vs_unsigned
[05:56:16] ================= drm_test_rect_intersect =================
[05:56:16] [PASSED] top-left x bottom-right: 2x2+1+1 x 2x2+0+0
[05:56:16] [PASSED] top-right x bottom-left: 2x2+0+0 x 2x2+1-1
[05:56:16] [PASSED] bottom-left x top-right: 2x2+1-1 x 2x2+0+0
[05:56:16] [PASSED] bottom-right x top-left: 2x2+0+0 x 2x2+1+1
[05:56:16] [PASSED] right x left: 2x1+0+0 x 3x1+1+0
[05:56:16] [PASSED] left x right: 3x1+1+0 x 2x1+0+0
[05:56:16] [PASSED] up x bottom: 1x2+0+0 x 1x3+0-1
[05:56:16] [PASSED] bottom x up: 1x3+0-1 x 1x2+0+0
[05:56:16] [PASSED] touching corner: 1x1+0+0 x 2x2+1+1
[05:56:16] [PASSED] touching side: 1x1+0+0 x 1x1+1+0
[05:56:16] [PASSED] equal rects: 2x2+0+0 x 2x2+0+0
[05:56:16] [PASSED] inside another: 2x2+0+0 x 1x1+1+1
[05:56:16] [PASSED] far away: 1x1+0+0 x 1x1+3+6
[05:56:16] [PASSED] points intersecting: 0x0+5+10 x 0x0+5+10
[05:56:16] [PASSED] points not intersecting: 0x0+0+0 x 0x0+5+10
[05:56:16] ============= [PASSED] drm_test_rect_intersect =============
[05:56:16] ================ drm_test_rect_calc_hscale ================
[05:56:16] [PASSED] normal use
[05:56:16] [PASSED] out of max range
[05:56:16] [PASSED] out of min range
[05:56:16] [PASSED] zero dst
[05:56:16] [PASSED] negative src
[05:56:16] [PASSED] negative dst
[05:56:16] ============ [PASSED] drm_test_rect_calc_hscale ============
[05:56:16] ================ drm_test_rect_calc_vscale ================
[05:56:16] [PASSED] normal use
[05:56:16] [PASSED] out of max range
[05:56:16] [PASSED] out of min range
[05:56:16] [PASSED] zero dst
[05:56:16] [PASSED] negative src
[05:56:16] [PASSED] negative dst
[05:56:16] ============ [PASSED] drm_test_rect_calc_vscale ============
[05:56:16] ================== drm_test_rect_rotate ===================
[05:56:16] [PASSED] reflect-x
[05:56:16] [PASSED] reflect-y
[05:56:16] [PASSED] rotate-0
[05:56:16] [PASSED] rotate-90
[05:56:16] [PASSED] rotate-180
[05:56:16] [PASSED] rotate-270
[05:56:16] ============== [PASSED] drm_test_rect_rotate ===============
[05:56:16] ================ drm_test_rect_rotate_inv =================
[05:56:16] [PASSED] reflect-x
[05:56:16] [PASSED] reflect-y
[05:56:16] [PASSED] rotate-0
[05:56:16] [PASSED] rotate-90
[05:56:16] [PASSED] rotate-180
[05:56:16] [PASSED] rotate-270
[05:56:16] ============ [PASSED] drm_test_rect_rotate_inv =============
[05:56:16] ==================== [PASSED] drm_rect =====================
[05:56:16] ============ drm_sysfb_modeset_test (1 subtest) ============
[05:56:16] ============ drm_test_sysfb_build_fourcc_list =============
[05:56:16] [PASSED] no native formats
[05:56:16] [PASSED] XRGB8888 as native format
[05:56:16] [PASSED] remove duplicates
[05:56:16] [PASSED] convert alpha formats
[05:56:16] [PASSED] random formats
[05:56:16] ======== [PASSED] drm_test_sysfb_build_fourcc_list =========
[05:56:16] ============= [PASSED] drm_sysfb_modeset_test ==============
[05:56:16] ================== drm_fixp (2 subtests) ===================
[05:56:16] [PASSED] drm_test_int2fixp
[05:56:16] [PASSED] drm_test_sm2fixp
[05:56:16] ==================== [PASSED] drm_fixp =====================
[05:56:16] ============================================================
[05:56:16] Testing complete. Ran 639 tests: passed: 639
[05:56:16] Elapsed time: 26.561s total, 1.763s configuring, 24.633s building, 0.142s running
+ /kernel/tools/testing/kunit/kunit.py run --kunitconfig /kernel/drivers/gpu/drm/ttm/tests/.kunitconfig
[05:56:16] Configuring KUnit Kernel ...
Regenerating .config ...
Populating config with:
$ make ARCH=um O=.kunit olddefconfig
[05:56:18] 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:56:28] Starting KUnit Kernel (1/1)...
[05:56:28] ============================================================
Running tests with:
$ .kunit/linux kunit.enable=1 mem=1G console=tty kunit_shutdown=halt
[05:56:28] ================= ttm_device (5 subtests) ==================
[05:56:28] [PASSED] ttm_device_init_basic
[05:56:28] [PASSED] ttm_device_init_multiple
[05:56:28] [PASSED] ttm_device_fini_basic
[05:56:28] [PASSED] ttm_device_init_no_vma_man
[05:56:28] ================== ttm_device_init_pools ==================
[05:56:28] [PASSED] No DMA allocations, no DMA32 required
[05:56:28] [PASSED] DMA allocations, DMA32 required
[05:56:28] [PASSED] No DMA allocations, DMA32 required
[05:56:28] [PASSED] DMA allocations, no DMA32 required
[05:56:28] ============== [PASSED] ttm_device_init_pools ==============
[05:56:28] =================== [PASSED] ttm_device ====================
[05:56:28] ================== ttm_pool (8 subtests) ===================
[05:56:28] ================== ttm_pool_alloc_basic ===================
[05:56:28] [PASSED] One page
[05:56:28] [PASSED] More than one page
[05:56:28] [PASSED] Above the allocation limit
[05:56:28] [PASSED] One page, with coherent DMA mappings enabled
[05:56:28] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[05:56:28] ============== [PASSED] ttm_pool_alloc_basic ===============
[05:56:28] ============== ttm_pool_alloc_basic_dma_addr ==============
[05:56:28] [PASSED] One page
[05:56:28] [PASSED] More than one page
[05:56:28] [PASSED] Above the allocation limit
[05:56:28] [PASSED] One page, with coherent DMA mappings enabled
[05:56:28] [PASSED] Above the allocation limit, with coherent DMA mappings enabled
[05:56:28] ========== [PASSED] ttm_pool_alloc_basic_dma_addr ==========
[05:56:28] [PASSED] ttm_pool_alloc_order_caching_match
[05:56:28] [PASSED] ttm_pool_alloc_caching_mismatch
[05:56:28] [PASSED] ttm_pool_alloc_order_mismatch
[05:56:28] [PASSED] ttm_pool_free_dma_alloc
[05:56:28] [PASSED] ttm_pool_free_no_dma_alloc
[05:56:28] [PASSED] ttm_pool_fini_basic
[05:56:28] ==================== [PASSED] ttm_pool =====================
[05:56:28] ================ ttm_resource (8 subtests) =================
[05:56:28] ================= ttm_resource_init_basic =================
[05:56:28] [PASSED] Init resource in TTM_PL_SYSTEM
[05:56:28] [PASSED] Init resource in TTM_PL_VRAM
[05:56:28] [PASSED] Init resource in a private placement
[05:56:28] [PASSED] Init resource in TTM_PL_SYSTEM, set placement flags
[05:56:28] ============= [PASSED] ttm_resource_init_basic =============
[05:56:28] [PASSED] ttm_resource_init_pinned
[05:56:28] [PASSED] ttm_resource_fini_basic
[05:56:28] [PASSED] ttm_resource_manager_init_basic
[05:56:28] [PASSED] ttm_resource_manager_usage_basic
[05:56:28] [PASSED] ttm_resource_manager_set_used_basic
[05:56:28] [PASSED] ttm_sys_man_alloc_basic
[05:56:28] [PASSED] ttm_sys_man_free_basic
[05:56:28] ================== [PASSED] ttm_resource ===================
[05:56:28] =================== ttm_tt (15 subtests) ===================
[05:56:28] ==================== ttm_tt_init_basic ====================
[05:56:28] [PASSED] Page-aligned size
[05:56:28] [PASSED] Extra pages requested
[05:56:28] ================ [PASSED] ttm_tt_init_basic ================
[05:56:28] [PASSED] ttm_tt_init_misaligned
[05:56:28] [PASSED] ttm_tt_fini_basic
[05:56:28] [PASSED] ttm_tt_fini_sg
[05:56:28] [PASSED] ttm_tt_fini_shmem
[05:56:28] [PASSED] ttm_tt_create_basic
[05:56:28] [PASSED] ttm_tt_create_invalid_bo_type
[05:56:28] [PASSED] ttm_tt_create_ttm_exists
[05:56:28] [PASSED] ttm_tt_create_failed
[05:56:28] [PASSED] ttm_tt_destroy_basic
[05:56:28] [PASSED] ttm_tt_populate_null_ttm
[05:56:28] [PASSED] ttm_tt_populate_populated_ttm
[05:56:28] [PASSED] ttm_tt_unpopulate_basic
[05:56:28] [PASSED] ttm_tt_unpopulate_empty_ttm
[05:56:28] [PASSED] ttm_tt_swapin_basic
[05:56:28] ===================== [PASSED] ttm_tt ======================
[05:56:28] =================== ttm_bo (14 subtests) ===================
[05:56:28] =========== ttm_bo_reserve_optimistic_no_ticket ===========
[05:56:28] [PASSED] Cannot be interrupted and sleeps
[05:56:28] [PASSED] Cannot be interrupted, locks straight away
[05:56:28] [PASSED] Can be interrupted, sleeps
[05:56:28] ======= [PASSED] ttm_bo_reserve_optimistic_no_ticket =======
[05:56:28] [PASSED] ttm_bo_reserve_locked_no_sleep
[05:56:28] [PASSED] ttm_bo_reserve_no_wait_ticket
[05:56:28] [PASSED] ttm_bo_reserve_double_resv
[05:56:28] [PASSED] ttm_bo_reserve_interrupted
[05:56:28] [PASSED] ttm_bo_reserve_deadlock
[05:56:28] [PASSED] ttm_bo_unreserve_basic
[05:56:28] [PASSED] ttm_bo_unreserve_pinned
[05:56:28] [PASSED] ttm_bo_unreserve_bulk
[05:56:28] [PASSED] ttm_bo_fini_basic
[05:56:28] [PASSED] ttm_bo_fini_shared_resv
[05:56:28] [PASSED] ttm_bo_pin_basic
[05:56:28] [PASSED] ttm_bo_pin_unpin_resource
[05:56:28] [PASSED] ttm_bo_multiple_pin_one_unpin
[05:56:28] ===================== [PASSED] ttm_bo ======================
[05:56:28] ============== ttm_bo_validate (22 subtests) ===============
[05:56:28] ============== ttm_bo_init_reserved_sys_man ===============
[05:56:28] [PASSED] Buffer object for userspace
[05:56:28] [PASSED] Kernel buffer object
[05:56:28] [PASSED] Shared buffer object
[05:56:28] ========== [PASSED] ttm_bo_init_reserved_sys_man ===========
[05:56:28] ============== ttm_bo_init_reserved_mock_man ==============
[05:56:28] [PASSED] Buffer object for userspace
[05:56:28] [PASSED] Kernel buffer object
[05:56:28] [PASSED] Shared buffer object
[05:56:28] ========== [PASSED] ttm_bo_init_reserved_mock_man ==========
[05:56:28] [PASSED] ttm_bo_init_reserved_resv
[05:56:28] ================== ttm_bo_validate_basic ==================
[05:56:28] [PASSED] Buffer object for userspace
[05:56:28] [PASSED] Kernel buffer object
[05:56:28] [PASSED] Shared buffer object
[05:56:28] ============== [PASSED] ttm_bo_validate_basic ==============
[05:56:28] [PASSED] ttm_bo_validate_invalid_placement
[05:56:28] ============= ttm_bo_validate_same_placement ==============
[05:56:28] [PASSED] System manager
[05:56:28] [PASSED] VRAM manager
[05:56:28] ========= [PASSED] ttm_bo_validate_same_placement ==========
[05:56:28] [PASSED] ttm_bo_validate_failed_alloc
[05:56:28] [PASSED] ttm_bo_validate_pinned
[05:56:28] [PASSED] ttm_bo_validate_busy_placement
[05:56:28] ================ ttm_bo_validate_multihop =================
[05:56:28] [PASSED] Buffer object for userspace
[05:56:28] [PASSED] Kernel buffer object
[05:56:28] [PASSED] Shared buffer object
[05:56:28] ============ [PASSED] ttm_bo_validate_multihop =============
[05:56:28] ========== ttm_bo_validate_no_placement_signaled ==========
[05:56:28] [PASSED] Buffer object in system domain, no page vector
[05:56:28] [PASSED] Buffer object in system domain with an existing page vector
[05:56:28] ====== [PASSED] ttm_bo_validate_no_placement_signaled ======
[05:56:28] ======== ttm_bo_validate_no_placement_not_signaled ========
[05:56:28] [PASSED] Buffer object for userspace
[05:56:28] [PASSED] Kernel buffer object
[05:56:28] [PASSED] Shared buffer object
[05:56:28] ==== [PASSED] ttm_bo_validate_no_placement_not_signaled ====
[05:56:28] [PASSED] ttm_bo_validate_move_fence_signaled
[05:56:28] ========= ttm_bo_validate_move_fence_not_signaled =========
[05:56:28] [PASSED] Waits for GPU
[05:56:28] [PASSED] Tries to lock straight away
[05:56:28] ===== [PASSED] ttm_bo_validate_move_fence_not_signaled =====
[05:56:28] [PASSED] ttm_bo_validate_swapout
[05:56:28] [PASSED] ttm_bo_validate_happy_evict
[05:56:28] [PASSED] ttm_bo_validate_all_pinned_evict
[05:56:28] [PASSED] ttm_bo_validate_allowed_only_evict
[05:56:28] [PASSED] ttm_bo_validate_deleted_evict
[05:56:28] [PASSED] ttm_bo_validate_busy_domain_evict
[05:56:28] [PASSED] ttm_bo_validate_evict_gutting
[05:56:28] [PASSED] ttm_bo_validate_recrusive_evict
[05:56:28] ================= [PASSED] ttm_bo_validate =================
[05:56:28] ============================================================
[05:56:28] Testing complete. Ran 102 tests: passed: 102
[05:56:28] Elapsed time: 12.005s total, 1.812s configuring, 9.978s building, 0.180s running
+ cleanup
++ stat -c %u:%g /kernel
+ chown -R 1003:1003 /kernel
^ permalink raw reply [flat|nested] 14+ messages in thread* ✓ Xe.CI.BAT: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
2026-07-01 6:26 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-07-01 5:56 ` ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
@ 2026-07-01 6:46 ` Patchwork
2026-07-01 8:48 ` [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Christian König
` (2 subsequent siblings)
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-07-01 6:46 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 967 bytes --]
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
URL : https://patchwork.freedesktop.org/series/169129/
State : success
== Summary ==
CI Bug Log - changes from xe-5316-7100870965845da8c31005c07fd1b390bbe96b20_BAT -> xe-pw-169129v2_BAT
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (13 -> 12)
------------------------------
Missing (1): bat-bmg-2
Changes
-------
No changes found
Build changes
-------------
* Linux: xe-5316-7100870965845da8c31005c07fd1b390bbe96b20 -> xe-pw-169129v2
IGT_8989: a8e2cbd2854d7980a9eccecc6e0c801d0824b88f @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5316-7100870965845da8c31005c07fd1b390bbe96b20: 7100870965845da8c31005c07fd1b390bbe96b20
xe-pw-169129v2: 169129v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/index.html
[-- Attachment #2: Type: text/html, Size: 1515 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-07-01 6:26 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-07-01 5:56 ` ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
2026-07-01 6:46 ` ✓ Xe.CI.BAT: " Patchwork
@ 2026-07-01 8:48 ` Christian König
2026-07-01 12:59 ` Thomas Hellström
2026-07-01 21:55 ` ✓ Xe.CI.FULL: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
4 siblings, 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 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
` (2 preceding siblings ...)
2026-07-01 8:48 ` [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Christian König
@ 2026-07-01 12:59 ` Thomas Hellström
2026-07-01 13:20 ` Christian König
2026-07-01 21:55 ` ✓ Xe.CI.FULL: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
4 siblings, 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
* ✓ Xe.CI.FULL: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
2026-07-01 6:26 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
` (3 preceding siblings ...)
2026-07-01 12:59 ` Thomas Hellström
@ 2026-07-01 21:55 ` Patchwork
4 siblings, 0 replies; 14+ messages in thread
From: Patchwork @ 2026-07-01 21:55 UTC (permalink / raw)
To: Nitin Gote; +Cc: intel-xe
[-- Attachment #1: Type: text/plain, Size: 20276 bytes --]
== Series Details ==
Series: drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2)
URL : https://patchwork.freedesktop.org/series/169129/
State : success
== Summary ==
CI Bug Log - changes from xe-5316-7100870965845da8c31005c07fd1b390bbe96b20_FULL -> xe-pw-169129v2_FULL
====================================================
Summary
-------
**SUCCESS**
No regressions found.
Participating hosts (2 -> 2)
------------------------------
No changes in participating hosts
Known issues
------------
Here are the changes found in xe-pw-169129v2_FULL that come from known issues:
### IGT changes ###
#### Issues hit ####
* igt@kms_big_fb@linear-max-hw-stride-32bpp-rotate-0-hflip:
- shard-bmg: NOTRUN -> [SKIP][1] ([Intel XE#7059] / [Intel XE#7085])
[1]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_big_fb@linear-max-hw-stride-32bpp-rotate-0-hflip.html
* igt@kms_big_fb@y-tiled-8bpp-rotate-270:
- shard-bmg: NOTRUN -> [SKIP][2] ([Intel XE#1124]) +2 other tests skip
[2]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_big_fb@y-tiled-8bpp-rotate-270.html
* igt@kms_bw@linear-tiling-1-displays-target-3840x2160p:
- shard-bmg: NOTRUN -> [SKIP][3] ([Intel XE#367])
[3]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_bw@linear-tiling-1-displays-target-3840x2160p.html
* igt@kms_ccs@bad-aux-stride-yf-tiled-ccs:
- shard-bmg: NOTRUN -> [SKIP][4] ([Intel XE#2887]) +4 other tests skip
[4]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_ccs@bad-aux-stride-yf-tiled-ccs.html
* igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs@pipe-c-dp-2:
- shard-bmg: [PASS][5] -> [INCOMPLETE][6] ([Intel XE#7084] / [Intel XE#8150])
[5]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-2/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs@pipe-c-dp-2.html
[6]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-6/igt@kms_ccs@crc-primary-suspend-4-tiled-bmg-ccs@pipe-c-dp-2.html
* igt@kms_chamelium_color@ctm-negative:
- shard-bmg: NOTRUN -> [SKIP][7] ([Intel XE#2325] / [Intel XE#7358])
[7]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_chamelium_color@ctm-negative.html
* igt@kms_chamelium_edid@dp-edid-stress-resolution-non-4k:
- shard-bmg: NOTRUN -> [SKIP][8] ([Intel XE#2252]) +1 other test skip
[8]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_chamelium_edid@dp-edid-stress-resolution-non-4k.html
* igt@kms_cursor_crc@cursor-random-512x512:
- shard-bmg: NOTRUN -> [SKIP][9] ([Intel XE#2321] / [Intel XE#7355])
[9]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_cursor_crc@cursor-random-512x512.html
* igt@kms_cursor_crc@cursor-sliding-max-size:
- shard-bmg: NOTRUN -> [SKIP][10] ([Intel XE#2320])
[10]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_cursor_crc@cursor-sliding-max-size.html
* igt@kms_cursor_legacy@flip-vs-cursor-legacy:
- shard-bmg: NOTRUN -> [FAIL][11] ([Intel XE#7571])
[11]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_cursor_legacy@flip-vs-cursor-legacy.html
* igt@kms_flip@flip-vs-expired-vblank-interruptible:
- shard-lnl: [PASS][12] -> [FAIL][13] ([Intel XE#301] / [Intel XE#3149]) +1 other test fail
[12]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-lnl-8/igt@kms_flip@flip-vs-expired-vblank-interruptible.html
[13]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-lnl-2/igt@kms_flip@flip-vs-expired-vblank-interruptible.html
* igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling:
- shard-bmg: NOTRUN -> [SKIP][14] ([Intel XE#7178] / [Intel XE#7349])
[14]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_flip_scaled_crc@flip-64bpp-4tile-to-32bpp-4tiledg2rcccs-upscaling.html
* igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling:
- shard-bmg: NOTRUN -> [SKIP][15] ([Intel XE#7178] / [Intel XE#7351]) +1 other test skip
[15]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_flip_scaled_crc@flip-64bpp-ytile-to-16bpp-ytile-downscaling.html
* igt@kms_frontbuffer_tracking@drrs-2p-primscrn-indfb-pgflip-blt:
- shard-bmg: NOTRUN -> [SKIP][16] ([Intel XE#2311]) +13 other tests skip
[16]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_frontbuffer_tracking@drrs-2p-primscrn-indfb-pgflip-blt.html
* igt@kms_frontbuffer_tracking@fbc-1p-primscrn-shrfb-plflip-blt:
- shard-bmg: NOTRUN -> [SKIP][17] ([Intel XE#4141]) +1 other test skip
[17]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_frontbuffer_tracking@fbc-1p-primscrn-shrfb-plflip-blt.html
* igt@kms_frontbuffer_tracking@fbcdrrs-abgr161616f-draw-render:
- shard-bmg: NOTRUN -> [SKIP][18] ([Intel XE#7061] / [Intel XE#7356])
[18]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcdrrs-abgr161616f-draw-render.html
* igt@kms_frontbuffer_tracking@fbcdrrshdr-abgr161616f-draw-blt:
- shard-bmg: NOTRUN -> [SKIP][19] ([Intel XE#7061]) +1 other test skip
[19]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_frontbuffer_tracking@fbcdrrshdr-abgr161616f-draw-blt.html
* igt@kms_frontbuffer_tracking@psr-1p-offscreen-pri-shrfb-draw-mmap-wc:
- shard-bmg: NOTRUN -> [SKIP][20] ([Intel XE#2313]) +15 other tests skip
[20]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_frontbuffer_tracking@psr-1p-offscreen-pri-shrfb-draw-mmap-wc.html
* igt@kms_joiner@basic-ultra-joiner:
- shard-bmg: NOTRUN -> [SKIP][21] ([Intel XE#6911] / [Intel XE#7378])
[21]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_joiner@basic-ultra-joiner.html
* igt@kms_plane_scaling@planes-upscale-factor-0-25-downscale-factor-0-75@pipe-b:
- shard-bmg: NOTRUN -> [SKIP][22] ([Intel XE#2763] / [Intel XE#6886]) +4 other tests skip
[22]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_plane_scaling@planes-upscale-factor-0-25-downscale-factor-0-75@pipe-b.html
* igt@kms_psr2_sf@psr2-primary-plane-update-sf-dmg-area-big-fb:
- shard-bmg: NOTRUN -> [SKIP][23] ([Intel XE#1489]) +1 other test skip
[23]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_psr2_sf@psr2-primary-plane-update-sf-dmg-area-big-fb.html
* igt@kms_psr@fbc-psr2-sprite-blt:
- shard-bmg: NOTRUN -> [SKIP][24] ([Intel XE#2234] / [Intel XE#2850])
[24]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_psr@fbc-psr2-sprite-blt.html
* igt@kms_tiled_display@basic-test-pattern-with-chamelium:
- shard-bmg: NOTRUN -> [SKIP][25] ([Intel XE#2509] / [Intel XE#7437])
[25]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@kms_tiled_display@basic-test-pattern-with-chamelium.html
* igt@xe_eudebug_online@pagefault-write:
- shard-bmg: NOTRUN -> [SKIP][26] ([Intel XE#7636]) +4 other tests skip
[26]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_eudebug_online@pagefault-write.html
* igt@xe_evict@evict-beng-mixed-many-threads-small:
- shard-bmg: [PASS][27] -> [INCOMPLETE][28] ([Intel XE#6321] / [Intel XE#8355])
[27]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-5/igt@xe_evict@evict-beng-mixed-many-threads-small.html
[28]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-10/igt@xe_evict@evict-beng-mixed-many-threads-small.html
* igt@xe_evict@evict-small-multi-queue:
- shard-bmg: NOTRUN -> [SKIP][29] ([Intel XE#8370])
[29]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_evict@evict-small-multi-queue.html
* igt@xe_exec_basic@multigpu-no-exec-null:
- shard-bmg: NOTRUN -> [SKIP][30] ([Intel XE#2322] / [Intel XE#7372]) +1 other test skip
[30]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_exec_basic@multigpu-no-exec-null.html
* igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate-prefetch:
- shard-bmg: NOTRUN -> [SKIP][31] ([Intel XE#8374]) +4 other tests skip
[31]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_exec_fault_mode@once-multi-queue-userptr-invalidate-prefetch.html
* igt@xe_exec_multi_queue@many-execs-close-fd-smem:
- shard-bmg: NOTRUN -> [SKIP][32] ([Intel XE#8364]) +7 other tests skip
[32]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_exec_multi_queue@many-execs-close-fd-smem.html
* igt@xe_exec_reset@cm-multi-queue-cat-error-on-secondary:
- shard-bmg: NOTRUN -> [SKIP][33] ([Intel XE#8369])
[33]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_exec_reset@cm-multi-queue-cat-error-on-secondary.html
* igt@xe_exec_threads@threads-multi-queue-shared-vm-basic:
- shard-bmg: NOTRUN -> [SKIP][34] ([Intel XE#8378])
[34]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_exec_threads@threads-multi-queue-shared-vm-basic.html
* igt@xe_fault_injection@inject-fault-probe-function-xe_add_hw_engine_class_defaults:
- shard-bmg: [PASS][35] -> [ABORT][36] ([Intel XE#8007]) +1 other test abort
[35]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-4/igt@xe_fault_injection@inject-fault-probe-function-xe_add_hw_engine_class_defaults.html
[36]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-2/igt@xe_fault_injection@inject-fault-probe-function-xe_add_hw_engine_class_defaults.html
* igt@xe_media_fill@media-fill:
- shard-bmg: NOTRUN -> [SKIP][37] ([Intel XE#2459] / [Intel XE#2596] / [Intel XE#7321] / [Intel XE#7453])
[37]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_media_fill@media-fill.html
* igt@xe_multigpu_svm@mgpu-coherency-conflict:
- shard-bmg: NOTRUN -> [SKIP][38] ([Intel XE#6964])
[38]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_multigpu_svm@mgpu-coherency-conflict.html
* igt@xe_page_reclaim@binds-large-split:
- shard-bmg: NOTRUN -> [SKIP][39] ([Intel XE#7793])
[39]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_page_reclaim@binds-large-split.html
* igt@xe_pat@pat-index-xelp:
- shard-bmg: NOTRUN -> [SKIP][40] ([Intel XE#2245] / [Intel XE#7590])
[40]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_pat@pat-index-xelp.html
* igt@xe_pm@d3hot-i2c:
- shard-bmg: NOTRUN -> [SKIP][41] ([Intel XE#5742] / [Intel XE#7328] / [Intel XE#7400])
[41]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_pm@d3hot-i2c.html
* igt@xe_pxp@pxp-termination-key-update-post-suspend:
- shard-bmg: NOTRUN -> [SKIP][42] ([Intel XE#4733] / [Intel XE#7417])
[42]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-1/igt@xe_pxp@pxp-termination-key-update-post-suspend.html
* igt@xe_query@multigpu-query-invalid-size:
- shard-bmg: NOTRUN -> [SKIP][43] ([Intel XE#944])
[43]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_query@multigpu-query-invalid-size.html
* igt@xe_sriov_flr@flr-vfs-parallel:
- shard-bmg: NOTRUN -> [FAIL][44] ([Intel XE#7992])
[44]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@xe_sriov_flr@flr-vfs-parallel.html
#### Possible fixes ####
* igt@core_hotunplug@hotreplug-lateclose:
- shard-bmg: [ABORT][45] ([Intel XE#8007]) -> [PASS][46]
[45]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-1/igt@core_hotunplug@hotreplug-lateclose.html
[46]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-4/igt@core_hotunplug@hotreplug-lateclose.html
* igt@kms_hdr@invalid-hdr:
- shard-bmg: [SKIP][47] ([Intel XE#1503]) -> [PASS][48]
[47]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-4/igt@kms_hdr@invalid-hdr.html
[48]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-6/igt@kms_hdr@invalid-hdr.html
* igt@kms_vrr@seamless-rr-switch-virtual@pipe-a-edp-1:
- shard-lnl: [FAIL][49] ([Intel XE#2142]) -> [PASS][50] +1 other test pass
[49]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-lnl-3/igt@kms_vrr@seamless-rr-switch-virtual@pipe-a-edp-1.html
[50]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-lnl-7/igt@kms_vrr@seamless-rr-switch-virtual@pipe-a-edp-1.html
* igt@xe_evict@evict-mixed-many-threads-small:
- shard-bmg: [INCOMPLETE][51] ([Intel XE#6321] / [Intel XE#8355]) -> [PASS][52]
[51]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-3/igt@xe_evict@evict-mixed-many-threads-small.html
[52]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-5/igt@xe_evict@evict-mixed-many-threads-small.html
#### Warnings ####
* igt@kms_tiled_display@basic-test-pattern:
- shard-bmg: [SKIP][53] ([Intel XE#2426] / [Intel XE#5848]) -> [FAIL][54] ([Intel XE#1729] / [Intel XE#7424])
[53]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-bmg-8/igt@kms_tiled_display@basic-test-pattern.html
[54]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-bmg-3/igt@kms_tiled_display@basic-test-pattern.html
* igt@xe_exec_multi_queue@few-execs-preempt-mode-dyn-priority:
- shard-lnl: [SKIP][55] ([Intel XE#8364]) -> [INCOMPLETE][56] ([Intel XE#2594])
[55]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-5316-7100870965845da8c31005c07fd1b390bbe96b20/shard-lnl-2/igt@xe_exec_multi_queue@few-execs-preempt-mode-dyn-priority.html
[56]: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/shard-lnl-7/igt@xe_exec_multi_queue@few-execs-preempt-mode-dyn-priority.html
[Intel XE#1124]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1124
[Intel XE#1489]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1489
[Intel XE#1503]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1503
[Intel XE#1729]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/1729
[Intel XE#2142]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2142
[Intel XE#2234]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2234
[Intel XE#2245]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2245
[Intel XE#2252]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2252
[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#2426]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2426
[Intel XE#2459]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2459
[Intel XE#2509]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2509
[Intel XE#2594]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2594
[Intel XE#2596]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2596
[Intel XE#2763]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2763
[Intel XE#2850]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2850
[Intel XE#2887]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/2887
[Intel XE#301]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/301
[Intel XE#3149]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/3149
[Intel XE#367]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/367
[Intel XE#4141]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4141
[Intel XE#4733]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/4733
[Intel XE#5742]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5742
[Intel XE#5848]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/5848
[Intel XE#6321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6321
[Intel XE#6886]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6886
[Intel XE#6911]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6911
[Intel XE#6964]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/6964
[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#7084]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7084
[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#7321]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7321
[Intel XE#7328]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7328
[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#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#7372]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7372
[Intel XE#7378]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7378
[Intel XE#7400]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7400
[Intel XE#7417]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7417
[Intel XE#7424]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7424
[Intel XE#7437]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7437
[Intel XE#7453]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7453
[Intel XE#7571]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7571
[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#7793]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7793
[Intel XE#7992]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/7992
[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#8355]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8355
[Intel XE#8364]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/8364
[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#944]: https://gitlab.freedesktop.org/drm/xe/kernel/issues/944
Build changes
-------------
* Linux: xe-5316-7100870965845da8c31005c07fd1b390bbe96b20 -> xe-pw-169129v2
IGT_8989: a8e2cbd2854d7980a9eccecc6e0c801d0824b88f @ https://gitlab.freedesktop.org/drm/igt-gpu-tools.git
xe-5316-7100870965845da8c31005c07fd1b390bbe96b20: 7100870965845da8c31005c07fd1b390bbe96b20
xe-pw-169129v2: 169129v2
== Logs ==
For more details see: https://intel-gfx-ci.01.org/tree/intel-xe/xe-pw-169129v2/index.html
[-- Attachment #2: Type: text/html, Size: 22134 bytes --]
^ 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 10:45 ` Christian König
2026-06-29 9:18 ` Thomas Hellström
0 siblings, 2 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* 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
@ 2026-06-25 10:45 ` Christian König
2026-06-25 17:10 ` Gote, Nitin R
2026-06-29 9:18 ` Thomas Hellström
1 sibling, 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 ` 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 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
* 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
2026-06-25 10:45 ` Christian König
@ 2026-06-29 9:18 ` Thomas Hellström
1 sibling, 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
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-07-01 6:26 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-07-01 5:56 ` ✓ CI.KUnit: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
2026-07-01 6:46 ` ✓ Xe.CI.BAT: " Patchwork
2026-07-01 8:48 ` [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs 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
2026-07-01 21:55 ` ✓ Xe.CI.FULL: success for drm/ttm: Fix UAF on dma-buf attach failure for sg BOs (rev2) Patchwork
-- strict thread matches above, loose matches on Subject: below --
2026-06-25 5:57 [PATCH] drm/ttm: Fix UAF on dma-buf attach failure for sg BOs Nitin Gote
2026-06-25 10:45 ` 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
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox