drm/i915/guc: init submission structures as part of guc_init
authorDaniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Thu, 25 Jul 2019 17:46:55 +0000 (10:46 -0700)
committerChris Wilson <chris@chris-wilson.co.uk>
Fri, 26 Jul 2019 08:07:08 +0000 (09:07 +0100)
guc->stage_desc_pool is required as part of the init parameters and
there is no reason we have to init them after HuC. This fixes a NULL
ptr dereference due to guc->stage_desc_pool not being set (no fixes
tag since GuC submission can't be enabled yet).

Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
Cc: Michal Wajdeczko <michal.wajdeczko@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Reviewed-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: https://patchwork.freedesktop.org/patch/msgid/20190725174655.24382-1-daniele.ceraolospurio@intel.com
drivers/gpu/drm/i915/gt/uc/intel_guc.c
drivers/gpu/drm/i915/gt/uc/intel_uc.c

index 1ea6a9e50c029a1f8d3e3a86bb9112234c7c0516..13fbbffd05c7567b6b7cfad94e4b42a49715e08a 100644 (file)
@@ -290,6 +290,16 @@ int intel_guc_init(struct intel_guc *guc)
        if (ret)
                goto err_ads;
 
+       if (intel_uc_is_using_guc_submission(&gt->uc)) {
+               /*
+                * This is stuff we need to have available at fw load time
+                * if we are planning to enable submission later
+                */
+               ret = intel_guc_submission_init(guc);
+               if (ret)
+                       goto err_ct;
+       }
+
        /* now that everything is perma-pinned, initialize the parameters */
        guc_init_params(guc);
 
@@ -298,6 +308,8 @@ int intel_guc_init(struct intel_guc *guc)
 
        return 0;
 
+err_ct:
+       intel_guc_ct_fini(&guc->ct);
 err_ads:
        intel_guc_ads_destroy(guc);
 err_log:
@@ -317,6 +329,9 @@ void intel_guc_fini(struct intel_guc *guc)
 
        i915_ggtt_disable_guc(gt->ggtt);
 
+       if (intel_uc_is_using_guc_submission(&gt->uc))
+               intel_guc_submission_fini(guc);
+
        intel_guc_ct_fini(&guc->ct);
 
        intel_guc_ads_destroy(guc);
index 8205b3c810486d174ec198ffb241fe9046f944a2..5b9b20d1cb6d910e9166071d6ed160005928b5bd 100644 (file)
@@ -397,21 +397,8 @@ int intel_uc_init(struct intel_uc *uc)
                        goto err_guc;
        }
 
-       if (intel_uc_is_using_guc_submission(uc)) {
-               /*
-                * This is stuff we need to have available at fw load time
-                * if we are planning to enable submission later
-                */
-               ret = intel_guc_submission_init(guc);
-               if (ret)
-                       goto err_huc;
-       }
-
        return 0;
 
-err_huc:
-       if (intel_uc_is_using_huc(uc))
-               intel_huc_fini(huc);
 err_guc:
        intel_guc_fini(guc);
        return ret;
@@ -426,9 +413,6 @@ void intel_uc_fini(struct intel_uc *uc)
 
        GEM_BUG_ON(!intel_uc_fw_supported(&guc->fw));
 
-       if (intel_uc_is_using_guc_submission(uc))
-               intel_guc_submission_fini(guc);
-
        if (intel_uc_is_using_huc(uc))
                intel_huc_fini(&uc->huc);