提交 b551f610 编写于 作者: A Arkadiusz Hiler 提交者: Joonas Lahtinen

drm/i915/uc: Separate firmware selection and preparation

intel_{h,g}uc_init_fw selects correct firmware and then triggers it's
preparation (fetch + initial parsing).

This change separates out select steps, so those can be called by
the sanitize_options().

Then, during the init_fw(), we prepare the firmware if the firmware was
selected.

Cc: Michal Winiarski <michal.winiarski@intel.com>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Signed-off-by: NArkadiusz Hiler <arkadiusz.hiler@intel.com>
Reviewed-by: NJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
Signed-off-by: NJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
上级 8fc2a4e4
...@@ -393,15 +393,12 @@ int intel_guc_init_hw(struct intel_guc *guc) ...@@ -393,15 +393,12 @@ int intel_guc_init_hw(struct intel_guc *guc)
} }
/** /**
* intel_guc_init_fw() - select and prepare firmware for loading * intel_guc_select_fw() - selects GuC firmware for loading
* @guc: intel_guc struct * @guc: intel_guc struct
* *
* Called early during driver load, but after GEM is initialised. * Return: zero when we know firmware, non-zero in other case
*
* The firmware will be transferred to the GuC's memory later,
* when intel_guc_init_hw() is called.
*/ */
void intel_guc_init_fw(struct intel_guc *guc) int intel_guc_select_fw(struct intel_guc *guc)
{ {
struct drm_i915_private *dev_priv = guc_to_i915(guc); struct drm_i915_private *dev_priv = guc_to_i915(guc);
...@@ -424,11 +421,10 @@ void intel_guc_init_fw(struct intel_guc *guc) ...@@ -424,11 +421,10 @@ void intel_guc_init_fw(struct intel_guc *guc)
guc->fw.minor_ver_wanted = KBL_FW_MINOR; guc->fw.minor_ver_wanted = KBL_FW_MINOR;
} else { } else {
DRM_ERROR("No GuC firmware known for platform with GuC!\n"); DRM_ERROR("No GuC firmware known for platform with GuC!\n");
i915.enable_guc_loading = 0; return -ENOENT;
return;
} }
intel_uc_prepare_fw(dev_priv, &guc->fw); return 0;
} }
/** /**
......
...@@ -141,18 +141,10 @@ static int huc_ucode_xfer(struct drm_i915_private *dev_priv) ...@@ -141,18 +141,10 @@ static int huc_ucode_xfer(struct drm_i915_private *dev_priv)
} }
/** /**
* intel_huc_init_fw() - select and prepare firmware for loading * intel_huc_select_fw() - selects HuC firmware for loading
* @huc: intel_huc struct * @huc: intel_huc struct
*
* Called early during driver load, but after GEM is initialised. The loading
* will continue only when driver explicitly specify firmware name and version.
* All other cases are considered as INTEL_UC_FIRMWARE_NONE either because HW
* is not capable or driver yet support it. And there will be no error message
* for INTEL_UC_FIRMWARE_NONE cases.
*
* The DMA-copying to HW is done later when intel_huc_init_hw() is called.
*/ */
void intel_huc_init_fw(struct intel_huc *huc) void intel_huc_select_fw(struct intel_huc *huc)
{ {
struct drm_i915_private *dev_priv = huc_to_i915(huc); struct drm_i915_private *dev_priv = huc_to_i915(huc);
...@@ -177,8 +169,6 @@ void intel_huc_init_fw(struct intel_huc *huc) ...@@ -177,8 +169,6 @@ void intel_huc_init_fw(struct intel_huc *huc)
DRM_ERROR("No HuC firmware known for platform with HuC!\n"); DRM_ERROR("No HuC firmware known for platform with HuC!\n");
return; return;
} }
intel_uc_prepare_fw(dev_priv, &huc->fw);
} }
/** /**
......
...@@ -66,6 +66,14 @@ void intel_uc_sanitize_options(struct drm_i915_private *dev_priv) ...@@ -66,6 +66,14 @@ void intel_uc_sanitize_options(struct drm_i915_private *dev_priv)
if (!i915.enable_guc_loading) if (!i915.enable_guc_loading)
i915.enable_guc_submission = 0; i915.enable_guc_submission = 0;
} }
if (i915.enable_guc_loading) {
if (HAS_HUC_UCODE(dev_priv))
intel_huc_select_fw(&dev_priv->huc);
if (intel_guc_select_fw(&dev_priv->guc))
i915.enable_guc_loading = 0;
}
} }
void intel_uc_init_early(struct drm_i915_private *dev_priv) void intel_uc_init_early(struct drm_i915_private *dev_priv)
...@@ -75,13 +83,11 @@ void intel_uc_init_early(struct drm_i915_private *dev_priv) ...@@ -75,13 +83,11 @@ void intel_uc_init_early(struct drm_i915_private *dev_priv)
void intel_uc_init_fw(struct drm_i915_private *dev_priv) void intel_uc_init_fw(struct drm_i915_private *dev_priv)
{ {
if (!i915.enable_guc_loading) if (dev_priv->huc.fw.path)
return; intel_uc_prepare_fw(dev_priv, &dev_priv->huc.fw);
if (HAS_HUC_UCODE(dev_priv))
intel_huc_init_fw(&dev_priv->huc);
intel_guc_init_fw(&dev_priv->guc); if (dev_priv->guc.fw.path)
intel_uc_prepare_fw(dev_priv, &dev_priv->guc.fw);
} }
int intel_uc_init_hw(struct drm_i915_private *dev_priv) int intel_uc_init_hw(struct drm_i915_private *dev_priv)
......
...@@ -194,7 +194,7 @@ int intel_guc_send(struct intel_guc *guc, const u32 *action, u32 len); ...@@ -194,7 +194,7 @@ int intel_guc_send(struct intel_guc *guc, const u32 *action, u32 len);
int intel_guc_sample_forcewake(struct intel_guc *guc); int intel_guc_sample_forcewake(struct intel_guc *guc);
/* intel_guc_loader.c */ /* intel_guc_loader.c */
void intel_guc_init_fw(struct intel_guc *guc); int intel_guc_select_fw(struct intel_guc *guc);
int intel_guc_init_hw(struct intel_guc *guc); int intel_guc_init_hw(struct intel_guc *guc);
void intel_guc_fini(struct drm_i915_private *dev_priv); void intel_guc_fini(struct drm_i915_private *dev_priv);
const char *intel_uc_fw_status_repr(enum intel_uc_fw_status status); const char *intel_uc_fw_status_repr(enum intel_uc_fw_status status);
...@@ -226,7 +226,7 @@ static inline u32 guc_ggtt_offset(struct i915_vma *vma) ...@@ -226,7 +226,7 @@ static inline u32 guc_ggtt_offset(struct i915_vma *vma)
} }
/* intel_huc.c */ /* intel_huc.c */
void intel_huc_init_fw(struct intel_huc *huc); void intel_huc_select_fw(struct intel_huc *huc);
void intel_huc_fini(struct drm_i915_private *dev_priv); void intel_huc_fini(struct drm_i915_private *dev_priv);
int intel_huc_init_hw(struct intel_huc *huc); int intel_huc_init_hw(struct intel_huc *huc);
void intel_guc_auth_huc(struct drm_i915_private *dev_priv); void intel_guc_auth_huc(struct drm_i915_private *dev_priv);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册