提交 ab309a6a 编写于 作者: M Michal Wajdeczko 提交者: Chris Wilson

drm/i915: Unifying debugfs return codes for unsupported features

Instead of trying different seq_puts messages, lets use common
-ENODEV error code to indicate missing/unsupported feature.

v2: don't forget about guc_log_control fops (Sagar)
Suggested-by: NChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: NMichal Wajdeczko <michal.wajdeczko@intel.com>
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Cc: Sagar Arun Kamble <sagar.a.kamble@intel.com>
Cc: Sujaritha Sundaresan <sujaritha.sundaresan@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20171215143635.17884-1-michal.wajdeczko@intel.comReviewed-by: NChris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: NChris Wilson <chris@chris-wilson.co.uk>
上级 7b6da818
...@@ -1602,10 +1602,8 @@ static int i915_fbc_status(struct seq_file *m, void *unused) ...@@ -1602,10 +1602,8 @@ static int i915_fbc_status(struct seq_file *m, void *unused)
{ {
struct drm_i915_private *dev_priv = node_to_i915(m->private); struct drm_i915_private *dev_priv = node_to_i915(m->private);
if (!HAS_FBC(dev_priv)) { if (!HAS_FBC(dev_priv))
seq_puts(m, "FBC unsupported on this chipset\n"); return -ENODEV;
return 0;
}
intel_runtime_pm_get(dev_priv); intel_runtime_pm_get(dev_priv);
mutex_lock(&dev_priv->fbc.lock); mutex_lock(&dev_priv->fbc.lock);
...@@ -1681,10 +1679,8 @@ static int i915_ips_status(struct seq_file *m, void *unused) ...@@ -1681,10 +1679,8 @@ static int i915_ips_status(struct seq_file *m, void *unused)
{ {
struct drm_i915_private *dev_priv = node_to_i915(m->private); struct drm_i915_private *dev_priv = node_to_i915(m->private);
if (!HAS_IPS(dev_priv)) { if (!HAS_IPS(dev_priv))
seq_puts(m, "not supported\n"); return -ENODEV;
return 0;
}
intel_runtime_pm_get(dev_priv); intel_runtime_pm_get(dev_priv);
...@@ -1770,10 +1766,8 @@ static int i915_ring_freq_table(struct seq_file *m, void *unused) ...@@ -1770,10 +1766,8 @@ static int i915_ring_freq_table(struct seq_file *m, void *unused)
int gpu_freq, ia_freq; int gpu_freq, ia_freq;
unsigned int max_gpu_freq, min_gpu_freq; unsigned int max_gpu_freq, min_gpu_freq;
if (!HAS_LLC(dev_priv)) { if (!HAS_LLC(dev_priv))
seq_puts(m, "unsupported on this chipset\n"); return -ENODEV;
return 0;
}
intel_runtime_pm_get(dev_priv); intel_runtime_pm_get(dev_priv);
...@@ -2253,8 +2247,8 @@ static int i915_huc_load_status_info(struct seq_file *m, void *data) ...@@ -2253,8 +2247,8 @@ 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 drm_i915_private *dev_priv = node_to_i915(m->private);
struct drm_printer p; struct drm_printer p;
if (!HAS_HUC_UCODE(dev_priv)) if (!HAS_HUC(dev_priv))
return 0; return -ENODEV;
p = drm_seq_file_printer(m); p = drm_seq_file_printer(m);
intel_uc_fw_dump(&dev_priv->huc.fw, &p); intel_uc_fw_dump(&dev_priv->huc.fw, &p);
...@@ -2272,8 +2266,8 @@ static int i915_guc_load_status_info(struct seq_file *m, void *data) ...@@ -2272,8 +2266,8 @@ static int i915_guc_load_status_info(struct seq_file *m, void *data)
struct drm_printer p; struct drm_printer p;
u32 tmp, i; u32 tmp, i;
if (!HAS_GUC_UCODE(dev_priv)) if (!HAS_GUC(dev_priv))
return 0; return -ENODEV;
p = drm_seq_file_printer(m); p = drm_seq_file_printer(m);
intel_uc_fw_dump(&dev_priv->guc.fw, &p); intel_uc_fw_dump(&dev_priv->guc.fw, &p);
...@@ -2346,29 +2340,16 @@ static void i915_guc_client_info(struct seq_file *m, ...@@ -2346,29 +2340,16 @@ static void i915_guc_client_info(struct seq_file *m,
seq_printf(m, "\tTotal: %llu\n", tot); seq_printf(m, "\tTotal: %llu\n", tot);
} }
static bool check_guc_submission(struct seq_file *m)
{
struct drm_i915_private *dev_priv = node_to_i915(m->private);
const struct intel_guc *guc = &dev_priv->guc;
if (!guc->execbuf_client) {
seq_printf(m, "GuC submission %s\n",
HAS_GUC_SCHED(dev_priv) ?
"disabled" :
"not supported");
return false;
}
return true;
}
static int i915_guc_info(struct seq_file *m, void *data) static int i915_guc_info(struct seq_file *m, void *data)
{ {
struct drm_i915_private *dev_priv = node_to_i915(m->private); struct drm_i915_private *dev_priv = node_to_i915(m->private);
const struct intel_guc *guc = &dev_priv->guc; const struct intel_guc *guc = &dev_priv->guc;
if (!check_guc_submission(m)) if (!USES_GUC_SUBMISSION(dev_priv))
return 0; return -ENODEV;
GEM_BUG_ON(!guc->execbuf_client);
GEM_BUG_ON(!guc->preempt_client);
seq_printf(m, "Doorbell map:\n"); seq_printf(m, "Doorbell map:\n");
seq_printf(m, "\t%*pb\n", GUC_NUM_DOORBELLS, guc->doorbell_bitmap); seq_printf(m, "\t%*pb\n", GUC_NUM_DOORBELLS, guc->doorbell_bitmap);
...@@ -2395,8 +2376,8 @@ static int i915_guc_stage_pool(struct seq_file *m, void *data) ...@@ -2395,8 +2376,8 @@ static int i915_guc_stage_pool(struct seq_file *m, void *data)
unsigned int tmp; unsigned int tmp;
int index; int index;
if (!check_guc_submission(m)) if (!USES_GUC_SUBMISSION(dev_priv))
return 0; return -ENODEV;
for (index = 0; index < GUC_MAX_STAGE_DESCRIPTORS; index++, desc++) { for (index = 0; index < GUC_MAX_STAGE_DESCRIPTORS; index++, desc++) {
struct intel_engine_cs *engine; struct intel_engine_cs *engine;
...@@ -2449,6 +2430,9 @@ static int i915_guc_log_dump(struct seq_file *m, void *data) ...@@ -2449,6 +2430,9 @@ static int i915_guc_log_dump(struct seq_file *m, void *data)
u32 *log; u32 *log;
int i = 0; int i = 0;
if (!HAS_GUC(dev_priv))
return -ENODEV;
if (dump_load_err) if (dump_load_err)
obj = dev_priv->guc.load_err_log; obj = dev_priv->guc.load_err_log;
else if (dev_priv->guc.log.vma) else if (dev_priv->guc.log.vma)
...@@ -2480,6 +2464,9 @@ static int i915_guc_log_control_get(void *data, u64 *val) ...@@ -2480,6 +2464,9 @@ static int i915_guc_log_control_get(void *data, u64 *val)
{ {
struct drm_i915_private *dev_priv = data; struct drm_i915_private *dev_priv = data;
if (!HAS_GUC(dev_priv))
return -ENODEV;
if (!dev_priv->guc.log.vma) if (!dev_priv->guc.log.vma)
return -EINVAL; return -EINVAL;
...@@ -2493,6 +2480,9 @@ static int i915_guc_log_control_set(void *data, u64 val) ...@@ -2493,6 +2480,9 @@ static int i915_guc_log_control_set(void *data, u64 val)
struct drm_i915_private *dev_priv = data; struct drm_i915_private *dev_priv = data;
int ret; int ret;
if (!HAS_GUC(dev_priv))
return -ENODEV;
if (!dev_priv->guc.log.vma) if (!dev_priv->guc.log.vma)
return -EINVAL; return -EINVAL;
...@@ -2543,10 +2533,8 @@ static int i915_edp_psr_status(struct seq_file *m, void *data) ...@@ -2543,10 +2533,8 @@ static int i915_edp_psr_status(struct seq_file *m, void *data)
enum pipe pipe; enum pipe pipe;
bool enabled = false; bool enabled = false;
if (!HAS_PSR(dev_priv)) { if (!HAS_PSR(dev_priv))
seq_puts(m, "PSR not supported\n"); return -ENODEV;
return 0;
}
intel_runtime_pm_get(dev_priv); intel_runtime_pm_get(dev_priv);
...@@ -2785,10 +2773,8 @@ static int i915_dmc_info(struct seq_file *m, void *unused) ...@@ -2785,10 +2773,8 @@ static int i915_dmc_info(struct seq_file *m, void *unused)
struct drm_i915_private *dev_priv = node_to_i915(m->private); struct drm_i915_private *dev_priv = node_to_i915(m->private);
struct intel_csr *csr; struct intel_csr *csr;
if (!HAS_CSR(dev_priv)) { if (!HAS_CSR(dev_priv))
seq_puts(m, "not supported\n"); return -ENODEV;
return 0;
}
csr = &dev_priv->csr; csr = &dev_priv->csr;
...@@ -3324,7 +3310,7 @@ static int i915_ddb_info(struct seq_file *m, void *unused) ...@@ -3324,7 +3310,7 @@ static int i915_ddb_info(struct seq_file *m, void *unused)
int plane; int plane;
if (INTEL_GEN(dev_priv) < 9) if (INTEL_GEN(dev_priv) < 9)
return 0; return -ENODEV;
drm_modeset_lock_all(dev); drm_modeset_lock_all(dev);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册