drm/i915/huc: Add debugfs for HuC loading status check
authorAnusha Srivatsa <anusha.srivatsa@intel.com>
Wed, 18 Jan 2017 16:05:56 +0000 (08:05 -0800)
committerJani Nikula <jani.nikula@intel.com>
Thu, 19 Jan 2017 09:19:04 +0000 (11:19 +0200)
Add debugfs entry for HuC loading status check.

v2: rebased on top of drm-tip.

Cc: Michal wajdeczko <michal.wajdeczko@intel.com>
Tested-by: Xiang Haihao <haihao.xiang@intel.com>
Signed-off-by: Anusha Srivatsa <anusha.srivatsa@intel.com>
Signed-off-by: Alex Dai <yu.dai@intel.com>
Signed-off-by: Peter Antoine <peter.antoine@intel.com>
Reviewed-by: Jeff McGee <jeff.mcgee@intel.com>
Reviewed-by: Michal Wajdeczko <michal.wajdeczko@intel.com>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/1484755558-1234-4-git-send-email-anusha.srivatsa@intel.com
drivers/gpu/drm/i915/i915_debugfs.c

index 129aab71fadf8e1d12b11c33b80f4873b4efcc83..fa69d72fdcb9ff45e6590402bb59b9b325d65c38 100644 (file)
@@ -2352,6 +2352,36 @@ static int i915_llc(struct seq_file *m, void *data)
        return 0;
 }
 
+static int i915_huc_load_status_info(struct seq_file *m, void *data)
+{
+       struct drm_i915_private *dev_priv = node_to_i915(m->private);
+       struct intel_uc_fw *huc_fw = &dev_priv->huc.fw;
+
+       if (!HAS_HUC_UCODE(dev_priv))
+               return 0;
+
+       seq_puts(m, "HuC firmware status:\n");
+       seq_printf(m, "\tpath: %s\n", huc_fw->path);
+       seq_printf(m, "\tfetch: %s\n",
+               intel_uc_fw_status_repr(huc_fw->fetch_status));
+       seq_printf(m, "\tload: %s\n",
+               intel_uc_fw_status_repr(huc_fw->load_status));
+       seq_printf(m, "\tversion wanted: %d.%d\n",
+               huc_fw->major_ver_wanted, huc_fw->minor_ver_wanted);
+       seq_printf(m, "\tversion found: %d.%d\n",
+               huc_fw->major_ver_found, huc_fw->minor_ver_found);
+       seq_printf(m, "\theader: offset is %d; size = %d\n",
+               huc_fw->header_offset, huc_fw->header_size);
+       seq_printf(m, "\tuCode: offset is %d; size = %d\n",
+               huc_fw->ucode_offset, huc_fw->ucode_size);
+       seq_printf(m, "\tRSA: offset is %d; size = %d\n",
+               huc_fw->rsa_offset, huc_fw->rsa_size);
+
+       seq_printf(m, "\nHuC status 0x%08x:\n", I915_READ(HUC_STATUS2));
+
+       return 0;
+}
+
 static int i915_guc_load_status_info(struct seq_file *m, void *data)
 {
        struct drm_i915_private *dev_priv = node_to_i915(m->private);
@@ -4609,6 +4639,7 @@ static const struct drm_info_list i915_debugfs_list[] = {
        {"i915_guc_info", i915_guc_info, 0},
        {"i915_guc_load_status", i915_guc_load_status_info, 0},
        {"i915_guc_log_dump", i915_guc_log_dump, 0},
+       {"i915_huc_load_status", i915_huc_load_status_info, 0},
        {"i915_frequency_info", i915_frequency_info, 0},
        {"i915_hangcheck_info", i915_hangcheck_info, 0},
        {"i915_drpc_info", i915_drpc_info, 0},