|
@@ -119,7 +119,9 @@ void intel_uc_init_fw(struct drm_i915_private *dev_priv)
|
|
if (!USES_GUC(dev_priv))
|
|
if (!USES_GUC(dev_priv))
|
|
return;
|
|
return;
|
|
|
|
|
|
- intel_uc_fw_fetch(dev_priv, &dev_priv->huc.fw);
|
|
|
|
|
|
+ if (USES_HUC(dev_priv))
|
|
|
|
+ intel_uc_fw_fetch(dev_priv, &dev_priv->huc.fw);
|
|
|
|
+
|
|
intel_uc_fw_fetch(dev_priv, &dev_priv->guc.fw);
|
|
intel_uc_fw_fetch(dev_priv, &dev_priv->guc.fw);
|
|
}
|
|
}
|
|
|
|
|
|
@@ -129,7 +131,9 @@ void intel_uc_fini_fw(struct drm_i915_private *dev_priv)
|
|
return;
|
|
return;
|
|
|
|
|
|
intel_uc_fw_fini(&dev_priv->guc.fw);
|
|
intel_uc_fw_fini(&dev_priv->guc.fw);
|
|
- intel_uc_fw_fini(&dev_priv->huc.fw);
|
|
|
|
|
|
+
|
|
|
|
+ if (USES_HUC(dev_priv))
|
|
|
|
+ intel_uc_fw_fini(&dev_priv->huc.fw);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -186,6 +190,7 @@ static void guc_disable_communication(struct intel_guc *guc)
|
|
int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
{
|
|
{
|
|
struct intel_guc *guc = &dev_priv->guc;
|
|
struct intel_guc *guc = &dev_priv->guc;
|
|
|
|
+ struct intel_huc *huc = &dev_priv->huc;
|
|
int ret, attempts;
|
|
int ret, attempts;
|
|
|
|
|
|
if (!USES_GUC(dev_priv))
|
|
if (!USES_GUC(dev_priv))
|
|
@@ -233,7 +238,12 @@ int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
if (ret)
|
|
if (ret)
|
|
goto err_submission;
|
|
goto err_submission;
|
|
|
|
|
|
- intel_huc_init_hw(&dev_priv->huc);
|
|
|
|
|
|
+ if (USES_HUC(dev_priv)) {
|
|
|
|
+ ret = intel_huc_init_hw(huc);
|
|
|
|
+ if (ret)
|
|
|
|
+ goto err_submission;
|
|
|
|
+ }
|
|
|
|
+
|
|
intel_guc_init_params(guc);
|
|
intel_guc_init_params(guc);
|
|
ret = intel_guc_fw_upload(guc);
|
|
ret = intel_guc_fw_upload(guc);
|
|
if (ret == 0 || ret != -EAGAIN)
|
|
if (ret == 0 || ret != -EAGAIN)
|
|
@@ -251,7 +261,12 @@ int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
if (ret)
|
|
if (ret)
|
|
goto err_log_capture;
|
|
goto err_log_capture;
|
|
|
|
|
|
- intel_huc_auth(&dev_priv->huc);
|
|
|
|
|
|
+ if (USES_HUC(dev_priv)) {
|
|
|
|
+ ret = intel_huc_auth(huc);
|
|
|
|
+ if (ret)
|
|
|
|
+ goto err_communication;
|
|
|
|
+ }
|
|
|
|
+
|
|
if (USES_GUC_SUBMISSION(dev_priv)) {
|
|
if (USES_GUC_SUBMISSION(dev_priv)) {
|
|
if (i915_modparams.guc_log_level >= 0)
|
|
if (i915_modparams.guc_log_level >= 0)
|
|
gen9_enable_guc_interrupts(dev_priv);
|
|
gen9_enable_guc_interrupts(dev_priv);
|
|
@@ -265,6 +280,8 @@ int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
guc->fw.major_ver_found, guc->fw.minor_ver_found);
|
|
guc->fw.major_ver_found, guc->fw.minor_ver_found);
|
|
dev_info(dev_priv->drm.dev, "GuC submission %s\n",
|
|
dev_info(dev_priv->drm.dev, "GuC submission %s\n",
|
|
enableddisabled(USES_GUC_SUBMISSION(dev_priv)));
|
|
enableddisabled(USES_GUC_SUBMISSION(dev_priv)));
|
|
|
|
+ dev_info(dev_priv->drm.dev, "HuC %s\n",
|
|
|
|
+ enableddisabled(USES_HUC(dev_priv)));
|
|
|
|
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
@@ -272,8 +289,9 @@ int intel_uc_init_hw(struct drm_i915_private *dev_priv)
|
|
* We've failed to load the firmware :(
|
|
* We've failed to load the firmware :(
|
|
*/
|
|
*/
|
|
err_interrupts:
|
|
err_interrupts:
|
|
- guc_disable_communication(guc);
|
|
|
|
gen9_disable_guc_interrupts(dev_priv);
|
|
gen9_disable_guc_interrupts(dev_priv);
|
|
|
|
+err_communication:
|
|
|
|
+ guc_disable_communication(guc);
|
|
err_log_capture:
|
|
err_log_capture:
|
|
guc_capture_load_err_log(guc);
|
|
guc_capture_load_err_log(guc);
|
|
err_submission:
|
|
err_submission:
|