drm/i915: Nuke not needed members of dram_info

Valid, ranks and bandwidth_kbps are set into dram_info but are not
used anywhere else so nuking it.
Reviewed-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: default avatarJosé Roberto de Souza <jose.souza@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20210128164312.91160-1-jose.souza@intel.com
parent b59c27ca
...@@ -610,8 +610,8 @@ static int i915_driver_hw_probe(struct drm_i915_private *dev_priv) ...@@ -610,8 +610,8 @@ static int i915_driver_hw_probe(struct drm_i915_private *dev_priv)
intel_opregion_setup(dev_priv); intel_opregion_setup(dev_priv);
/* /*
* Fill the dram structure to get the system raw bandwidth and * Fill the dram structure to get the system dram info. This will be
* dram info. This will be used for memory latency calculation. * used for memory latency calculation.
*/ */
intel_dram_detect(dev_priv); intel_dram_detect(dev_priv);
......
...@@ -1125,11 +1125,8 @@ struct drm_i915_private { ...@@ -1125,11 +1125,8 @@ struct drm_i915_private {
} wm; } wm;
struct dram_info { struct dram_info {
bool valid;
bool is_16gb_dimm; bool is_16gb_dimm;
u8 num_channels; u8 num_channels;
u8 ranks;
u32 bandwidth_kbps;
bool symmetric_memory; bool symmetric_memory;
enum intel_dram_type { enum intel_dram_type {
INTEL_DRAM_UNKNOWN, INTEL_DRAM_UNKNOWN,
......
...@@ -201,17 +201,7 @@ skl_dram_get_channels_info(struct drm_i915_private *i915) ...@@ -201,17 +201,7 @@ skl_dram_get_channels_info(struct drm_i915_private *i915)
return -EINVAL; return -EINVAL;
} }
/* if (ch0.ranks == 0 && ch1.ranks == 0) {
* If any of the channel is single rank channel, worst case output
* will be same as if single rank memory, so consider single rank
* memory.
*/
if (ch0.ranks == 1 || ch1.ranks == 1)
dram_info->ranks = 1;
else
dram_info->ranks = max(ch0.ranks, ch1.ranks);
if (dram_info->ranks == 0) {
drm_info(&i915->drm, "couldn't get memory rank information\n"); drm_info(&i915->drm, "couldn't get memory rank information\n");
return -EINVAL; return -EINVAL;
} }
...@@ -269,16 +259,12 @@ skl_get_dram_info(struct drm_i915_private *i915) ...@@ -269,16 +259,12 @@ skl_get_dram_info(struct drm_i915_private *i915)
mem_freq_khz = DIV_ROUND_UP((val & SKL_REQ_DATA_MASK) * mem_freq_khz = DIV_ROUND_UP((val & SKL_REQ_DATA_MASK) *
SKL_MEMORY_FREQ_MULTIPLIER_HZ, 1000); SKL_MEMORY_FREQ_MULTIPLIER_HZ, 1000);
dram_info->bandwidth_kbps = dram_info->num_channels * if (dram_info->num_channels * mem_freq_khz == 0) {
mem_freq_khz * 8;
if (dram_info->bandwidth_kbps == 0) {
drm_info(&i915->drm, drm_info(&i915->drm,
"Couldn't get system memory bandwidth\n"); "Couldn't get system memory bandwidth\n");
return -EINVAL; return -EINVAL;
} }
dram_info->valid = true;
return 0; return 0;
} }
...@@ -365,7 +351,7 @@ static int bxt_get_dram_info(struct drm_i915_private *i915) ...@@ -365,7 +351,7 @@ static int bxt_get_dram_info(struct drm_i915_private *i915)
struct dram_info *dram_info = &i915->dram_info; struct dram_info *dram_info = &i915->dram_info;
u32 dram_channels; u32 dram_channels;
u32 mem_freq_khz, val; u32 mem_freq_khz, val;
u8 num_active_channels; u8 num_active_channels, valid_ranks = 0;
int i; int i;
val = intel_uncore_read(&i915->uncore, BXT_P_CR_MC_BIOS_REQ_0_0_0); val = intel_uncore_read(&i915->uncore, BXT_P_CR_MC_BIOS_REQ_0_0_0);
...@@ -375,10 +361,7 @@ static int bxt_get_dram_info(struct drm_i915_private *i915) ...@@ -375,10 +361,7 @@ static int bxt_get_dram_info(struct drm_i915_private *i915)
dram_channels = val & BXT_DRAM_CHANNEL_ACTIVE_MASK; dram_channels = val & BXT_DRAM_CHANNEL_ACTIVE_MASK;
num_active_channels = hweight32(dram_channels); num_active_channels = hweight32(dram_channels);
/* Each active bit represents 4-byte channel */ if (mem_freq_khz * num_active_channels == 0) {
dram_info->bandwidth_kbps = (mem_freq_khz * num_active_channels * 4);
if (dram_info->bandwidth_kbps == 0) {
drm_info(&i915->drm, drm_info(&i915->drm,
"Couldn't get system memory bandwidth\n"); "Couldn't get system memory bandwidth\n");
return -EINVAL; return -EINVAL;
...@@ -410,27 +393,18 @@ static int bxt_get_dram_info(struct drm_i915_private *i915) ...@@ -410,27 +393,18 @@ static int bxt_get_dram_info(struct drm_i915_private *i915)
dimm.size, dimm.width, dimm.ranks, dimm.size, dimm.width, dimm.ranks,
intel_dram_type_str(type)); intel_dram_type_str(type));
/* if (valid_ranks == 0)
* If any of the channel is single rank channel, valid_ranks = dimm.ranks;
* worst case output will be same as if single rank
* memory, so consider single rank memory.
*/
if (dram_info->ranks == 0)
dram_info->ranks = dimm.ranks;
else if (dimm.ranks == 1)
dram_info->ranks = 1;
if (type != INTEL_DRAM_UNKNOWN) if (type != INTEL_DRAM_UNKNOWN)
dram_info->type = type; dram_info->type = type;
} }
if (dram_info->type == INTEL_DRAM_UNKNOWN || dram_info->ranks == 0) { if (dram_info->type == INTEL_DRAM_UNKNOWN || valid_ranks == 0) {
drm_info(&i915->drm, "couldn't get memory information\n"); drm_info(&i915->drm, "couldn't get memory information\n");
return -EINVAL; return -EINVAL;
} }
dram_info->valid = true;
return 0; return 0;
} }
...@@ -456,11 +430,10 @@ void intel_dram_detect(struct drm_i915_private *i915) ...@@ -456,11 +430,10 @@ void intel_dram_detect(struct drm_i915_private *i915)
if (ret) if (ret)
return; return;
drm_dbg_kms(&i915->drm, "DRAM bandwidth: %u kBps, channels: %u\n", drm_dbg_kms(&i915->drm, "DRAM channels: %u\n", dram_info->num_channels);
dram_info->bandwidth_kbps, dram_info->num_channels);
drm_dbg_kms(&i915->drm, "DRAM ranks: %u, 16Gb DIMMs: %s\n", drm_dbg_kms(&i915->drm, "DRAM 16Gb DIMMs: %s\n",
dram_info->ranks, yesno(dram_info->is_16gb_dimm)); yesno(dram_info->is_16gb_dimm));
} }
static u32 gen9_edram_size_mb(struct drm_i915_private *i915, u32 cap) static u32 gen9_edram_size_mb(struct drm_i915_private *i915, u32 cap)
......
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