Commit 6c77055a authored by Jani Nikula's avatar Jani Nikula

drm/i915: move dmc to display.dmc

Move display dmc related members under drm_i915_private display
sub-struct.
Signed-off-by: default avatarJani Nikula <jani.nikula@intel.com>
Reviewed-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/7cb91222e099b96b82c74b5f086d50c43459d61b.1661346845.git.jani.nikula@intel.com
parent 12dc5082
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <linux/types.h> #include <linux/types.h>
#include <linux/wait.h> #include <linux/wait.h>
#include "intel_dmc.h"
#include "intel_gmbus.h" #include "intel_gmbus.h"
struct drm_i915_private; struct drm_i915_private;
...@@ -106,6 +107,9 @@ struct intel_display { ...@@ -106,6 +107,9 @@ struct intel_display {
/* protects panel power sequencer state */ /* protects panel power sequencer state */
struct mutex mutex; struct mutex mutex;
} pps; } pps;
/* Grouping using named structs. Keep sorted. */
struct intel_dmc dmc;
}; };
#endif /* __INTEL_DISPLAY_CORE_H__ */ #endif /* __INTEL_DISPLAY_CORE_H__ */
...@@ -269,7 +269,7 @@ sanitize_target_dc_state(struct drm_i915_private *dev_priv, ...@@ -269,7 +269,7 @@ sanitize_target_dc_state(struct drm_i915_private *dev_priv,
if (target_dc_state != states[i]) if (target_dc_state != states[i])
continue; continue;
if (dev_priv->dmc.allowed_dc_mask & target_dc_state) if (dev_priv->display.dmc.allowed_dc_mask & target_dc_state)
break; break;
target_dc_state = states[i + 1]; target_dc_state = states[i + 1];
...@@ -302,7 +302,7 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv, ...@@ -302,7 +302,7 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv,
state = sanitize_target_dc_state(dev_priv, state); state = sanitize_target_dc_state(dev_priv, state);
if (state == dev_priv->dmc.target_dc_state) if (state == dev_priv->display.dmc.target_dc_state)
goto unlock; goto unlock;
dc_off_enabled = intel_power_well_is_enabled(dev_priv, power_well); dc_off_enabled = intel_power_well_is_enabled(dev_priv, power_well);
...@@ -313,7 +313,7 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv, ...@@ -313,7 +313,7 @@ void intel_display_power_set_target_dc_state(struct drm_i915_private *dev_priv,
if (!dc_off_enabled) if (!dc_off_enabled)
intel_power_well_enable(dev_priv, power_well); intel_power_well_enable(dev_priv, power_well);
dev_priv->dmc.target_dc_state = state; dev_priv->display.dmc.target_dc_state = state;
if (!dc_off_enabled) if (!dc_off_enabled)
intel_power_well_disable(dev_priv, power_well); intel_power_well_disable(dev_priv, power_well);
...@@ -982,10 +982,10 @@ int intel_power_domains_init(struct drm_i915_private *dev_priv) ...@@ -982,10 +982,10 @@ int intel_power_domains_init(struct drm_i915_private *dev_priv)
dev_priv->params.disable_power_well = dev_priv->params.disable_power_well =
sanitize_disable_power_well_option(dev_priv, sanitize_disable_power_well_option(dev_priv,
dev_priv->params.disable_power_well); dev_priv->params.disable_power_well);
dev_priv->dmc.allowed_dc_mask = dev_priv->display.dmc.allowed_dc_mask =
get_allowed_dc_mask(dev_priv, dev_priv->params.enable_dc); get_allowed_dc_mask(dev_priv, dev_priv->params.enable_dc);
dev_priv->dmc.target_dc_state = dev_priv->display.dmc.target_dc_state =
sanitize_target_dc_state(dev_priv, DC_STATE_EN_UPTO_DC6); sanitize_target_dc_state(dev_priv, DC_STATE_EN_UPTO_DC6);
mutex_init(&power_domains->lock); mutex_init(&power_domains->lock);
...@@ -2046,7 +2046,7 @@ void intel_power_domains_suspend(struct drm_i915_private *i915, ...@@ -2046,7 +2046,7 @@ void intel_power_domains_suspend(struct drm_i915_private *i915,
* resources as required and also enable deeper system power states * resources as required and also enable deeper system power states
* that would be blocked if the firmware was inactive. * that would be blocked if the firmware was inactive.
*/ */
if (!(i915->dmc.allowed_dc_mask & DC_STATE_EN_DC9) && if (!(i915->display.dmc.allowed_dc_mask & DC_STATE_EN_DC9) &&
suspend_mode == I915_DRM_SUSPEND_IDLE && suspend_mode == I915_DRM_SUSPEND_IDLE &&
intel_dmc_has_payload(i915)) { intel_dmc_has_payload(i915)) {
intel_display_power_flush_work(i915); intel_display_power_flush_work(i915);
...@@ -2239,10 +2239,10 @@ void intel_display_power_resume(struct drm_i915_private *i915) ...@@ -2239,10 +2239,10 @@ void intel_display_power_resume(struct drm_i915_private *i915)
bxt_disable_dc9(i915); bxt_disable_dc9(i915);
icl_display_core_init(i915, true); icl_display_core_init(i915, true);
if (intel_dmc_has_payload(i915)) { if (intel_dmc_has_payload(i915)) {
if (i915->dmc.allowed_dc_mask & if (i915->display.dmc.allowed_dc_mask &
DC_STATE_EN_UPTO_DC6) DC_STATE_EN_UPTO_DC6)
skl_enable_dc6(i915); skl_enable_dc6(i915);
else if (i915->dmc.allowed_dc_mask & else if (i915->display.dmc.allowed_dc_mask &
DC_STATE_EN_UPTO_DC5) DC_STATE_EN_UPTO_DC5)
gen9_enable_dc5(i915); gen9_enable_dc5(i915);
} }
...@@ -2250,7 +2250,7 @@ void intel_display_power_resume(struct drm_i915_private *i915) ...@@ -2250,7 +2250,7 @@ void intel_display_power_resume(struct drm_i915_private *i915)
bxt_disable_dc9(i915); bxt_disable_dc9(i915);
bxt_display_core_init(i915, true); bxt_display_core_init(i915, true);
if (intel_dmc_has_payload(i915) && if (intel_dmc_has_payload(i915) &&
(i915->dmc.allowed_dc_mask & DC_STATE_EN_UPTO_DC5)) (i915->display.dmc.allowed_dc_mask & DC_STATE_EN_UPTO_DC5))
gen9_enable_dc5(i915); gen9_enable_dc5(i915);
} else if (IS_HASWELL(i915) || IS_BROADWELL(i915)) { } else if (IS_HASWELL(i915) || IS_BROADWELL(i915)) {
hsw_disable_pc8(i915); hsw_disable_pc8(i915);
......
...@@ -711,8 +711,8 @@ void gen9_sanitize_dc_state(struct drm_i915_private *dev_priv) ...@@ -711,8 +711,8 @@ void gen9_sanitize_dc_state(struct drm_i915_private *dev_priv)
drm_dbg_kms(&dev_priv->drm, drm_dbg_kms(&dev_priv->drm,
"Resetting DC state tracking from %02x to %02x\n", "Resetting DC state tracking from %02x to %02x\n",
dev_priv->dmc.dc_state, val); dev_priv->display.dmc.dc_state, val);
dev_priv->dmc.dc_state = val; dev_priv->display.dmc.dc_state = val;
} }
/** /**
...@@ -747,8 +747,8 @@ void gen9_set_dc_state(struct drm_i915_private *dev_priv, u32 state) ...@@ -747,8 +747,8 @@ void gen9_set_dc_state(struct drm_i915_private *dev_priv, u32 state)
return; return;
if (drm_WARN_ON_ONCE(&dev_priv->drm, if (drm_WARN_ON_ONCE(&dev_priv->drm,
state & ~dev_priv->dmc.allowed_dc_mask)) state & ~dev_priv->display.dmc.allowed_dc_mask))
state &= dev_priv->dmc.allowed_dc_mask; state &= dev_priv->display.dmc.allowed_dc_mask;
val = intel_de_read(dev_priv, DC_STATE_EN); val = intel_de_read(dev_priv, DC_STATE_EN);
mask = gen9_dc_mask(dev_priv); mask = gen9_dc_mask(dev_priv);
...@@ -756,16 +756,16 @@ void gen9_set_dc_state(struct drm_i915_private *dev_priv, u32 state) ...@@ -756,16 +756,16 @@ void gen9_set_dc_state(struct drm_i915_private *dev_priv, u32 state)
val & mask, state); val & mask, state);
/* Check if DMC is ignoring our DC state requests */ /* Check if DMC is ignoring our DC state requests */
if ((val & mask) != dev_priv->dmc.dc_state) if ((val & mask) != dev_priv->display.dmc.dc_state)
drm_err(&dev_priv->drm, "DC state mismatch (0x%x -> 0x%x)\n", drm_err(&dev_priv->drm, "DC state mismatch (0x%x -> 0x%x)\n",
dev_priv->dmc.dc_state, val & mask); dev_priv->display.dmc.dc_state, val & mask);
val &= ~mask; val &= ~mask;
val |= state; val |= state;
gen9_write_dc_state(dev_priv, val); gen9_write_dc_state(dev_priv, val);
dev_priv->dmc.dc_state = val & mask; dev_priv->display.dmc.dc_state = val & mask;
} }
static void tgl_enable_dc3co(struct drm_i915_private *dev_priv) static void tgl_enable_dc3co(struct drm_i915_private *dev_priv)
...@@ -959,7 +959,7 @@ void gen9_disable_dc_states(struct drm_i915_private *dev_priv) ...@@ -959,7 +959,7 @@ void gen9_disable_dc_states(struct drm_i915_private *dev_priv)
{ {
struct intel_cdclk_config cdclk_config = {}; struct intel_cdclk_config cdclk_config = {};
if (dev_priv->dmc.target_dc_state == DC_STATE_EN_DC3CO) { if (dev_priv->display.dmc.target_dc_state == DC_STATE_EN_DC3CO) {
tgl_disable_dc3co(dev_priv); tgl_disable_dc3co(dev_priv);
return; return;
} }
...@@ -1001,7 +1001,7 @@ static void gen9_dc_off_power_well_disable(struct drm_i915_private *dev_priv, ...@@ -1001,7 +1001,7 @@ static void gen9_dc_off_power_well_disable(struct drm_i915_private *dev_priv,
if (!intel_dmc_has_payload(dev_priv)) if (!intel_dmc_has_payload(dev_priv))
return; return;
switch (dev_priv->dmc.target_dc_state) { switch (dev_priv->display.dmc.target_dc_state) {
case DC_STATE_EN_DC3CO: case DC_STATE_EN_DC3CO:
tgl_enable_dc3co(dev_priv); tgl_enable_dc3co(dev_priv);
break; break;
......
...@@ -250,7 +250,7 @@ struct stepping_info { ...@@ -250,7 +250,7 @@ struct stepping_info {
static bool has_dmc_id_fw(struct drm_i915_private *i915, int dmc_id) static bool has_dmc_id_fw(struct drm_i915_private *i915, int dmc_id)
{ {
return i915->dmc.dmc_info[dmc_id].payload; return i915->display.dmc.dmc_info[dmc_id].payload;
} }
bool intel_dmc_has_payload(struct drm_i915_private *i915) bool intel_dmc_has_payload(struct drm_i915_private *i915)
...@@ -417,7 +417,7 @@ static void pipedmc_clock_gating_wa(struct drm_i915_private *i915, bool enable) ...@@ -417,7 +417,7 @@ static void pipedmc_clock_gating_wa(struct drm_i915_private *i915, bool enable)
*/ */
void intel_dmc_load_program(struct drm_i915_private *dev_priv) void intel_dmc_load_program(struct drm_i915_private *dev_priv)
{ {
struct intel_dmc *dmc = &dev_priv->dmc; struct intel_dmc *dmc = &dev_priv->display.dmc;
u32 id, i; u32 id, i;
if (!intel_dmc_has_payload(dev_priv)) if (!intel_dmc_has_payload(dev_priv))
...@@ -448,7 +448,7 @@ void intel_dmc_load_program(struct drm_i915_private *dev_priv) ...@@ -448,7 +448,7 @@ void intel_dmc_load_program(struct drm_i915_private *dev_priv)
} }
} }
dev_priv->dmc.dc_state = 0; dev_priv->display.dmc.dc_state = 0;
gen9_set_dc_state_debugmask(dev_priv); gen9_set_dc_state_debugmask(dev_priv);
...@@ -482,7 +482,7 @@ void intel_dmc_disable_program(struct drm_i915_private *i915) ...@@ -482,7 +482,7 @@ void intel_dmc_disable_program(struct drm_i915_private *i915)
void assert_dmc_loaded(struct drm_i915_private *i915) void assert_dmc_loaded(struct drm_i915_private *i915)
{ {
drm_WARN_ONCE(&i915->drm, drm_WARN_ONCE(&i915->drm,
!intel_de_read(i915, DMC_PROGRAM(i915->dmc.dmc_info[DMC_FW_MAIN].start_mmioaddr, 0)), !intel_de_read(i915, DMC_PROGRAM(i915->display.dmc.dmc_info[DMC_FW_MAIN].start_mmioaddr, 0)),
"DMC program storage start is NULL\n"); "DMC program storage start is NULL\n");
drm_WARN_ONCE(&i915->drm, !intel_de_read(i915, DMC_SSP_BASE), drm_WARN_ONCE(&i915->drm, !intel_de_read(i915, DMC_SSP_BASE),
"DMC SSP Base Not fine\n"); "DMC SSP Base Not fine\n");
...@@ -519,7 +519,7 @@ static void dmc_set_fw_offset(struct intel_dmc *dmc, ...@@ -519,7 +519,7 @@ static void dmc_set_fw_offset(struct intel_dmc *dmc,
{ {
unsigned int i, id; unsigned int i, id;
struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), dmc); struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), display.dmc);
for (i = 0; i < num_entries; i++) { for (i = 0; i < num_entries; i++) {
id = package_ver <= 1 ? DMC_FW_MAIN : fw_info[i].dmc_id; id = package_ver <= 1 ? DMC_FW_MAIN : fw_info[i].dmc_id;
...@@ -547,7 +547,7 @@ static bool dmc_mmio_addr_sanity_check(struct intel_dmc *dmc, ...@@ -547,7 +547,7 @@ static bool dmc_mmio_addr_sanity_check(struct intel_dmc *dmc,
const u32 *mmioaddr, u32 mmio_count, const u32 *mmioaddr, u32 mmio_count,
int header_ver, u8 dmc_id) int header_ver, u8 dmc_id)
{ {
struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), dmc); struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), display.dmc);
u32 start_range, end_range; u32 start_range, end_range;
int i; int i;
...@@ -585,7 +585,7 @@ static u32 parse_dmc_fw_header(struct intel_dmc *dmc, ...@@ -585,7 +585,7 @@ static u32 parse_dmc_fw_header(struct intel_dmc *dmc,
const struct intel_dmc_header_base *dmc_header, const struct intel_dmc_header_base *dmc_header,
size_t rem_size, u8 dmc_id) size_t rem_size, u8 dmc_id)
{ {
struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), dmc); struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), display.dmc);
struct dmc_fw_info *dmc_info = &dmc->dmc_info[dmc_id]; struct dmc_fw_info *dmc_info = &dmc->dmc_info[dmc_id];
unsigned int header_len_bytes, dmc_header_size, payload_size, i; unsigned int header_len_bytes, dmc_header_size, payload_size, i;
const u32 *mmioaddr, *mmiodata; const u32 *mmioaddr, *mmiodata;
...@@ -696,7 +696,7 @@ parse_dmc_fw_package(struct intel_dmc *dmc, ...@@ -696,7 +696,7 @@ parse_dmc_fw_package(struct intel_dmc *dmc,
const struct stepping_info *si, const struct stepping_info *si,
size_t rem_size) size_t rem_size)
{ {
struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), dmc); struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), display.dmc);
u32 package_size = sizeof(struct intel_package_header); u32 package_size = sizeof(struct intel_package_header);
u32 num_entries, max_entries; u32 num_entries, max_entries;
const struct intel_fw_info *fw_info; const struct intel_fw_info *fw_info;
...@@ -750,7 +750,7 @@ static u32 parse_dmc_fw_css(struct intel_dmc *dmc, ...@@ -750,7 +750,7 @@ static u32 parse_dmc_fw_css(struct intel_dmc *dmc,
struct intel_css_header *css_header, struct intel_css_header *css_header,
size_t rem_size) size_t rem_size)
{ {
struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), dmc); struct drm_i915_private *i915 = container_of(dmc, typeof(*i915), display.dmc);
if (rem_size < sizeof(struct intel_css_header)) { if (rem_size < sizeof(struct intel_css_header)) {
drm_err(&i915->drm, "Truncated DMC firmware, refusing.\n"); drm_err(&i915->drm, "Truncated DMC firmware, refusing.\n");
...@@ -787,7 +787,7 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv, ...@@ -787,7 +787,7 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv,
struct intel_css_header *css_header; struct intel_css_header *css_header;
struct intel_package_header *package_header; struct intel_package_header *package_header;
struct intel_dmc_header_base *dmc_header; struct intel_dmc_header_base *dmc_header;
struct intel_dmc *dmc = &dev_priv->dmc; struct intel_dmc *dmc = &dev_priv->display.dmc;
struct stepping_info display_info = { '*', '*'}; struct stepping_info display_info = { '*', '*'};
const struct stepping_info *si = intel_get_stepping_info(dev_priv, &display_info); const struct stepping_info *si = intel_get_stepping_info(dev_priv, &display_info);
u32 readcount = 0; u32 readcount = 0;
...@@ -814,7 +814,7 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv, ...@@ -814,7 +814,7 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv,
readcount += r; readcount += r;
for (id = 0; id < DMC_FW_MAX; id++) { for (id = 0; id < DMC_FW_MAX; id++) {
if (!dev_priv->dmc.dmc_info[id].present) if (!dev_priv->display.dmc.dmc_info[id].present)
continue; continue;
offset = readcount + dmc->dmc_info[id].dmc_offset * 4; offset = readcount + dmc->dmc_info[id].dmc_offset * 4;
...@@ -830,15 +830,15 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv, ...@@ -830,15 +830,15 @@ static void parse_dmc_fw(struct drm_i915_private *dev_priv,
static void intel_dmc_runtime_pm_get(struct drm_i915_private *dev_priv) static void intel_dmc_runtime_pm_get(struct drm_i915_private *dev_priv)
{ {
drm_WARN_ON(&dev_priv->drm, dev_priv->dmc.wakeref); drm_WARN_ON(&dev_priv->drm, dev_priv->display.dmc.wakeref);
dev_priv->dmc.wakeref = dev_priv->display.dmc.wakeref =
intel_display_power_get(dev_priv, POWER_DOMAIN_INIT); intel_display_power_get(dev_priv, POWER_DOMAIN_INIT);
} }
static void intel_dmc_runtime_pm_put(struct drm_i915_private *dev_priv) static void intel_dmc_runtime_pm_put(struct drm_i915_private *dev_priv)
{ {
intel_wakeref_t wakeref __maybe_unused = intel_wakeref_t wakeref __maybe_unused =
fetch_and_zero(&dev_priv->dmc.wakeref); fetch_and_zero(&dev_priv->display.dmc.wakeref);
intel_display_power_put(dev_priv, POWER_DOMAIN_INIT, wakeref); intel_display_power_put(dev_priv, POWER_DOMAIN_INIT, wakeref);
} }
...@@ -849,10 +849,10 @@ static void dmc_load_work_fn(struct work_struct *work) ...@@ -849,10 +849,10 @@ static void dmc_load_work_fn(struct work_struct *work)
struct intel_dmc *dmc; struct intel_dmc *dmc;
const struct firmware *fw = NULL; const struct firmware *fw = NULL;
dev_priv = container_of(work, typeof(*dev_priv), dmc.work); dev_priv = container_of(work, typeof(*dev_priv), display.dmc.work);
dmc = &dev_priv->dmc; dmc = &dev_priv->display.dmc;
request_firmware(&fw, dev_priv->dmc.fw_path, dev_priv->drm.dev); request_firmware(&fw, dev_priv->display.dmc.fw_path, dev_priv->drm.dev);
parse_dmc_fw(dev_priv, fw); parse_dmc_fw(dev_priv, fw);
if (intel_dmc_has_payload(dev_priv)) { if (intel_dmc_has_payload(dev_priv)) {
...@@ -861,7 +861,7 @@ static void dmc_load_work_fn(struct work_struct *work) ...@@ -861,7 +861,7 @@ static void dmc_load_work_fn(struct work_struct *work)
drm_info(&dev_priv->drm, drm_info(&dev_priv->drm,
"Finished loading DMC firmware %s (v%u.%u)\n", "Finished loading DMC firmware %s (v%u.%u)\n",
dev_priv->dmc.fw_path, DMC_VERSION_MAJOR(dmc->version), dev_priv->display.dmc.fw_path, DMC_VERSION_MAJOR(dmc->version),
DMC_VERSION_MINOR(dmc->version)); DMC_VERSION_MINOR(dmc->version));
} else { } else {
drm_notice(&dev_priv->drm, drm_notice(&dev_priv->drm,
...@@ -884,9 +884,9 @@ static void dmc_load_work_fn(struct work_struct *work) ...@@ -884,9 +884,9 @@ static void dmc_load_work_fn(struct work_struct *work)
*/ */
void intel_dmc_ucode_init(struct drm_i915_private *dev_priv) void intel_dmc_ucode_init(struct drm_i915_private *dev_priv)
{ {
struct intel_dmc *dmc = &dev_priv->dmc; struct intel_dmc *dmc = &dev_priv->display.dmc;
INIT_WORK(&dev_priv->dmc.work, dmc_load_work_fn); INIT_WORK(&dev_priv->display.dmc.work, dmc_load_work_fn);
if (!HAS_DMC(dev_priv)) if (!HAS_DMC(dev_priv))
return; return;
...@@ -969,7 +969,7 @@ void intel_dmc_ucode_init(struct drm_i915_private *dev_priv) ...@@ -969,7 +969,7 @@ void intel_dmc_ucode_init(struct drm_i915_private *dev_priv)
} }
drm_dbg_kms(&dev_priv->drm, "Loading %s\n", dmc->fw_path); drm_dbg_kms(&dev_priv->drm, "Loading %s\n", dmc->fw_path);
schedule_work(&dev_priv->dmc.work); schedule_work(&dev_priv->display.dmc.work);
} }
/** /**
...@@ -985,7 +985,7 @@ void intel_dmc_ucode_suspend(struct drm_i915_private *dev_priv) ...@@ -985,7 +985,7 @@ void intel_dmc_ucode_suspend(struct drm_i915_private *dev_priv)
if (!HAS_DMC(dev_priv)) if (!HAS_DMC(dev_priv))
return; return;
flush_work(&dev_priv->dmc.work); flush_work(&dev_priv->display.dmc.work);
/* Drop the reference held in case DMC isn't loaded. */ /* Drop the reference held in case DMC isn't loaded. */
if (!intel_dmc_has_payload(dev_priv)) if (!intel_dmc_has_payload(dev_priv))
...@@ -1027,16 +1027,16 @@ void intel_dmc_ucode_fini(struct drm_i915_private *dev_priv) ...@@ -1027,16 +1027,16 @@ void intel_dmc_ucode_fini(struct drm_i915_private *dev_priv)
return; return;
intel_dmc_ucode_suspend(dev_priv); intel_dmc_ucode_suspend(dev_priv);
drm_WARN_ON(&dev_priv->drm, dev_priv->dmc.wakeref); drm_WARN_ON(&dev_priv->drm, dev_priv->display.dmc.wakeref);
for (id = 0; id < DMC_FW_MAX; id++) for (id = 0; id < DMC_FW_MAX; id++)
kfree(dev_priv->dmc.dmc_info[id].payload); kfree(dev_priv->display.dmc.dmc_info[id].payload);
} }
void intel_dmc_print_error_state(struct drm_i915_error_state_buf *m, void intel_dmc_print_error_state(struct drm_i915_error_state_buf *m,
struct drm_i915_private *i915) struct drm_i915_private *i915)
{ {
struct intel_dmc *dmc = &i915->dmc; struct intel_dmc *dmc = &i915->display.dmc;
if (!HAS_DMC(i915)) if (!HAS_DMC(i915))
return; return;
...@@ -1058,7 +1058,7 @@ static int intel_dmc_debugfs_status_show(struct seq_file *m, void *unused) ...@@ -1058,7 +1058,7 @@ static int intel_dmc_debugfs_status_show(struct seq_file *m, void *unused)
if (!HAS_DMC(i915)) if (!HAS_DMC(i915))
return -ENODEV; return -ENODEV;
dmc = &i915->dmc; dmc = &i915->display.dmc;
wakeref = intel_runtime_pm_get(&i915->runtime_pm); wakeref = intel_runtime_pm_get(&i915->runtime_pm);
......
...@@ -706,7 +706,7 @@ tgl_dc3co_exitline_compute_config(struct intel_dp *intel_dp, ...@@ -706,7 +706,7 @@ tgl_dc3co_exitline_compute_config(struct intel_dp *intel_dp,
if (crtc_state->enable_psr2_sel_fetch) if (crtc_state->enable_psr2_sel_fetch)
return; return;
if (!(dev_priv->dmc.allowed_dc_mask & DC_STATE_EN_DC3CO)) if (!(dev_priv->display.dmc.allowed_dc_mask & DC_STATE_EN_DC3CO))
return; return;
if (!dc3co_is_pipe_port_compatible(intel_dp, crtc_state)) if (!dc3co_is_pipe_port_compatible(intel_dp, crtc_state))
......
...@@ -41,7 +41,6 @@ ...@@ -41,7 +41,6 @@
#include "display/intel_display.h" #include "display/intel_display.h"
#include "display/intel_display_core.h" #include "display/intel_display_core.h"
#include "display/intel_display_power.h" #include "display/intel_display_power.h"
#include "display/intel_dmc.h"
#include "display/intel_dpll_mgr.h" #include "display/intel_dpll_mgr.h"
#include "display/intel_dsb.h" #include "display/intel_dsb.h"
#include "display/intel_fbc.h" #include "display/intel_fbc.h"
...@@ -379,8 +378,6 @@ struct drm_i915_private { ...@@ -379,8 +378,6 @@ struct drm_i915_private {
struct intel_wopcm wopcm; struct intel_wopcm wopcm;
struct intel_dmc dmc;
/* MMIO base address for MIPI regs */ /* MMIO base address for MIPI regs */
u32 mipi_mmio_base; u32 mipi_mmio_base;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment