drm/i915: Add csr programming registers to dmc debugfs entry
We check these to determine firmware loading status. Include them to help to debug causes of firmware loading fails. v2: Move all CSR specific registers to i915_reg.h (Ville) v3: Rebase v4: Rebase (RPM ref) Signed-off-by: Mika Kuoppala <mika.kuoppala@intel.com> Reviewed-by: Imre Deak <imre.deak@intel.com> Link: http://patchwork.freedesktop.org/patch/msgid/1446220487-32691-1-git-send-email-mika.kuoppala@intel.com Tested-by: Daniel Stone <daniels@collabora.com> # SKL Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com>
This commit is contained in:
Родитель
16e11b9946
Коммит
6fb403de36
|
@ -2802,17 +2802,17 @@ static int i915_dmc_info(struct seq_file *m, void *unused)
|
||||||
|
|
||||||
csr = &dev_priv->csr;
|
csr = &dev_priv->csr;
|
||||||
|
|
||||||
|
intel_runtime_pm_get(dev_priv);
|
||||||
|
|
||||||
seq_printf(m, "fw loaded: %s\n", yesno(csr->dmc_payload != NULL));
|
seq_printf(m, "fw loaded: %s\n", yesno(csr->dmc_payload != NULL));
|
||||||
seq_printf(m, "path: %s\n", csr->fw_path);
|
seq_printf(m, "path: %s\n", csr->fw_path);
|
||||||
|
|
||||||
if (!csr->dmc_payload)
|
if (!csr->dmc_payload)
|
||||||
return 0;
|
goto out;
|
||||||
|
|
||||||
seq_printf(m, "version: %d.%d\n", CSR_VERSION_MAJOR(csr->version),
|
seq_printf(m, "version: %d.%d\n", CSR_VERSION_MAJOR(csr->version),
|
||||||
CSR_VERSION_MINOR(csr->version));
|
CSR_VERSION_MINOR(csr->version));
|
||||||
|
|
||||||
intel_runtime_pm_get(dev_priv);
|
|
||||||
|
|
||||||
if (IS_SKYLAKE(dev) && csr->version >= CSR_VERSION(1, 6)) {
|
if (IS_SKYLAKE(dev) && csr->version >= CSR_VERSION(1, 6)) {
|
||||||
seq_printf(m, "DC3 -> DC5 count: %d\n",
|
seq_printf(m, "DC3 -> DC5 count: %d\n",
|
||||||
I915_READ(SKL_CSR_DC3_DC5_COUNT));
|
I915_READ(SKL_CSR_DC3_DC5_COUNT));
|
||||||
|
@ -2823,6 +2823,11 @@ static int i915_dmc_info(struct seq_file *m, void *unused)
|
||||||
I915_READ(BXT_CSR_DC3_DC5_COUNT));
|
I915_READ(BXT_CSR_DC3_DC5_COUNT));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out:
|
||||||
|
seq_printf(m, "program base: 0x%08x\n", I915_READ(CSR_PROGRAM(0)));
|
||||||
|
seq_printf(m, "ssp base: 0x%08x\n", I915_READ(CSR_SSP_BASE));
|
||||||
|
seq_printf(m, "htp: 0x%08x\n", I915_READ(CSR_HTP_SKL));
|
||||||
|
|
||||||
intel_runtime_pm_put(dev_priv);
|
intel_runtime_pm_put(dev_priv);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -5698,6 +5698,16 @@ enum skl_disp_power_wells {
|
||||||
#define GAMMA_MODE_MODE_SPLIT (3 << 0)
|
#define GAMMA_MODE_MODE_SPLIT (3 << 0)
|
||||||
|
|
||||||
/* DMC/CSR */
|
/* DMC/CSR */
|
||||||
|
#define CSR_PROGRAM(i) (0x80000 + (i) * 4)
|
||||||
|
#define CSR_SSP_BASE_ADDR_GEN9 0x00002FC0
|
||||||
|
#define CSR_HTP_ADDR_SKL 0x00500034
|
||||||
|
#define CSR_SSP_BASE 0x8F074
|
||||||
|
#define CSR_HTP_SKL 0x8F004
|
||||||
|
#define CSR_LAST_WRITE 0x8F034
|
||||||
|
#define CSR_LAST_WRITE_VALUE 0xc003b400
|
||||||
|
/* MMIO address range for CSR program (0x80000 - 0x82FFF) */
|
||||||
|
#define CSR_MMIO_START_RANGE 0x80000
|
||||||
|
#define CSR_MMIO_END_RANGE 0x8FFFF
|
||||||
#define SKL_CSR_DC3_DC5_COUNT 0x80030
|
#define SKL_CSR_DC3_DC5_COUNT 0x80030
|
||||||
#define SKL_CSR_DC5_DC6_COUNT 0x8002C
|
#define SKL_CSR_DC5_DC6_COUNT 0x8002C
|
||||||
#define BXT_CSR_DC3_DC5_COUNT 0x80038
|
#define BXT_CSR_DC3_DC5_COUNT 0x80038
|
||||||
|
|
|
@ -49,21 +49,8 @@ MODULE_FIRMWARE(I915_CSR_BXT);
|
||||||
|
|
||||||
#define SKL_CSR_VERSION_REQUIRED CSR_VERSION(1, 23)
|
#define SKL_CSR_VERSION_REQUIRED CSR_VERSION(1, 23)
|
||||||
|
|
||||||
/*
|
|
||||||
* SKL CSR registers for DC5 and DC6
|
|
||||||
*/
|
|
||||||
#define CSR_PROGRAM(i) (0x80000 + (i) * 4)
|
|
||||||
#define CSR_SSP_BASE_ADDR_GEN9 0x00002FC0
|
|
||||||
#define CSR_HTP_ADDR_SKL 0x00500034
|
|
||||||
#define CSR_SSP_BASE 0x8F074
|
|
||||||
#define CSR_HTP_SKL 0x8F004
|
|
||||||
#define CSR_LAST_WRITE 0x8F034
|
|
||||||
#define CSR_LAST_WRITE_VALUE 0xc003b400
|
|
||||||
/* MMIO address range for CSR program (0x80000 - 0x82FFF) */
|
|
||||||
#define CSR_MAX_FW_SIZE 0x2FFF
|
#define CSR_MAX_FW_SIZE 0x2FFF
|
||||||
#define CSR_DEFAULT_FW_OFFSET 0xFFFFFFFF
|
#define CSR_DEFAULT_FW_OFFSET 0xFFFFFFFF
|
||||||
#define CSR_MMIO_START_RANGE 0x80000
|
|
||||||
#define CSR_MMIO_END_RANGE 0x8FFFF
|
|
||||||
|
|
||||||
struct intel_css_header {
|
struct intel_css_header {
|
||||||
/* 0x09 for DMC */
|
/* 0x09 for DMC */
|
||||||
|
|
Загрузка…
Ссылка в новой задаче