]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
drm/xe: Separate early xe_device initialization
authorMichal Wajdeczko <michal.wajdeczko@intel.com>
Tue, 26 May 2026 19:54:50 +0000 (21:54 +0200)
committerMichal Wajdeczko <michal.wajdeczko@intel.com>
Wed, 27 May 2026 10:51:27 +0000 (12:51 +0200)
We would like to initialize more of the xe_device struct also from
the kunit code, as it should be safe to use most of the generic drm
or xe components without doing any additional tweaks. Separate early
xe initialization code to a new function, so it can be reused.

Signed-off-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Reviewed-by: Raag Jadav <raag.jadav@intel.com>
Reviewed-by: Gustavo Sousa <gustavo.sousa@intel.com>
Link: https://patch.msgid.link/20260526195452.20545-6-michal.wajdeczko@intel.com
drivers/gpu/drm/xe/xe_device.c
drivers/gpu/drm/xe/xe_device.h

index b498147dcf61edc86ac7040624ce6a437a95ed4e..7ba407f73a02f136f5e3d4204b8e561e64118f8d 100644 (file)
@@ -506,27 +506,45 @@ struct xe_device *xe_device_create(struct pci_dev *pdev)
        if (IS_ERR(xe))
                return xe;
 
+       err = xe_device_init_early(xe);
+       if (err)
+               return ERR_PTR(err);
+
+       return xe;
+}
+ALLOW_ERROR_INJECTION(xe_device_create, ERRNO); /* See xe_pci_probe() */
+
+/**
+ * xe_device_init_early() - Initialize a new &xe_device instance
+ * @xe: the &xe_device to initialize
+ *
+ * Return: 0 on success or a negative error code on failure.
+ */
+int xe_device_init_early(struct xe_device *xe)
+{
+       int err;
+
        err = ttm_device_init(&xe->ttm, &xe_ttm_funcs, xe->drm.dev,
                              xe->drm.anon_inode->i_mapping,
                              xe->drm.vma_offset_manager, 0);
-       if (WARN_ON(err))
-               return ERR_PTR(err);
+       if (err)
+               return err;
 
        xe_bo_dev_init(&xe->bo_device);
        err = drmm_add_action_or_reset(&xe->drm, xe_device_destroy, NULL);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
        err = xe_shrinker_create(xe);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
        xe->atomic_svm_timeslice_ms = 5;
        xe->min_run_period_lr_ms = 5;
 
        err = xe_irq_init(xe);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
        xe_validation_device_init(&xe->val);
 
@@ -536,7 +554,7 @@ struct xe_device *xe_device_create(struct pci_dev *pdev)
 
        err = xe_pagemap_shrinker_create(xe);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
        xa_init_flags(&xe->usm.asid_to_vm, XA_FLAGS_ALLOC);
 
@@ -555,7 +573,7 @@ struct xe_device *xe_device_create(struct pci_dev *pdev)
 
        err = xe_bo_pinned_init(xe);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
        xe->preempt_fence_wq = alloc_ordered_workqueue("xe-preempt-fence-wq",
                                                       WQ_MEM_RECLAIM);
@@ -569,16 +587,15 @@ struct xe_device *xe_device_create(struct pci_dev *pdev)
                 * drmm_add_action_or_reset register above
                 */
                drm_err(&xe->drm, "Failed to allocate xe workqueues\n");
-               return ERR_PTR(-ENOMEM);
+               return -ENOMEM;
        }
 
        err = drmm_mutex_init(&xe->drm, &xe->pmt.lock);
        if (err)
-               return ERR_PTR(err);
+               return err;
 
-       return xe;
+       return 0;
 }
-ALLOW_ERROR_INJECTION(xe_device_create, ERRNO); /* See xe_pci_probe() */
 
 static bool xe_driver_flr_disabled(struct xe_device *xe)
 {
index 27cd2329b99f6b67610c4b024d1d3f45950b5c15..975768a6a9c838675d3e92d30151fdf73021f11c 100644 (file)
@@ -44,6 +44,7 @@ static inline struct xe_device *ttm_to_xe_device(struct ttm_device *ttm)
 }
 
 struct xe_device *xe_device_create(struct pci_dev *pdev);
+int xe_device_init_early(struct xe_device *xe);
 int xe_device_probe_early(struct xe_device *xe);
 int xe_device_probe(struct xe_device *xe);
 void xe_device_remove(struct xe_device *xe);