[coreboot] New patch to review for coreboot: 50e9f32 Drop Kconfig VAR_MTRR_HOLE option
Kyösti Mälkki (kyosti.malkki@gmail.com)
gerrit at coreboot.org
Thu Jul 12 01:16:07 CEST 2012
Kyösti Mälkki (kyosti.malkki at gmail.com) just uploaded a new patch set to gerrit, which you can find at http://review.coreboot.org/1213
-gerrit
commit 50e9f32b1fed83731c6f30cbef749a51ced2a43d
Author: Kyösti Mälkki <kyosti.malkki at gmail.com>
Date: Wed Jul 11 14:40:19 2012 +0300
Drop Kconfig VAR_MTRR_HOLE option
All but one board use the default value of enabled. Disabling
this can only increase the number of MTRR registers used.
Change-Id: I7d28adc31b9fae2301e4ff78fcb96486f81d5ec2
Signed-off-by: Kyösti Mälkki <kyosti.malkki at gmail.com>
---
src/cpu/Kconfig | 7 -------
src/cpu/x86/mtrr/mtrr.c | 16 ++++------------
src/mainboard/msi/ms9652_fam10/Kconfig | 4 ----
3 files changed, 4 insertions(+), 23 deletions(-)
diff --git a/src/cpu/Kconfig b/src/cpu/Kconfig
index acb9bb5..85e83d4 100644
--- a/src/cpu/Kconfig
+++ b/src/cpu/Kconfig
@@ -61,11 +61,4 @@ config SSE2
streaming SIMD instructions. Some parts of coreboot can be built
with more efficient code if SSE2 instructions are available.
-config VAR_MTRR_HOLE
- bool
- default y
- help
- Unset this if you don't want the MTRR code to use
- subtractive MTRRs
-
endif # ARCH_X86
diff --git a/src/cpu/x86/mtrr/mtrr.c b/src/cpu/x86/mtrr/mtrr.c
index 851c8c4..1ffec0e 100644
--- a/src/cpu/x86/mtrr/mtrr.c
+++ b/src/cpu/x86/mtrr/mtrr.c
@@ -338,10 +338,6 @@ static void set_fixed_mtrr_resource(void *gp, struct device *dev, struct resourc
}
-#ifndef CONFIG_VAR_MTRR_HOLE
-#define CONFIG_VAR_MTRR_HOLE 1
-#endif
-
struct var_mtrr_state {
unsigned long range_startk, range_sizek;
unsigned int reg;
@@ -369,7 +365,6 @@ void set_var_mtrr_resource(void *gp, struct device *dev, struct resource *res)
}
/* Write the range mtrrs */
if (state->range_sizek != 0) {
-#if CONFIG_VAR_MTRR_HOLE
if (state->hole_sizek == 0 && state->above4gb != 2) {
/* We need to put that on to hole */
unsigned long endk = basek + sizek;
@@ -378,15 +373,14 @@ void set_var_mtrr_resource(void *gp, struct device *dev, struct resource *res)
state->range_sizek = endk - state->range_startk;
return;
}
-#endif
state->reg = range_to_mtrr(state->reg, state->range_startk,
state->range_sizek, basek, MTRR_TYPE_WRBACK,
state->address_bits, state->above4gb);
-#if CONFIG_VAR_MTRR_HOLE
+
state->reg = range_to_mtrr(state->reg, state->hole_startk,
state->hole_sizek, basek, MTRR_TYPE_UNCACHEABLE,
state->address_bits, state->above4gb);
-#endif
+
state->range_startk = 0;
state->range_sizek = 0;
state->hole_startk = 0;
@@ -466,25 +460,23 @@ void x86_setup_var_mtrrs(unsigned int address_bits, unsigned int above4gb)
if (var_state.hole_startk || var_state.hole_sizek) {
printk(BIOS_DEBUG, "Warning: Can't set up MTRR hole for UMA due to pre-existing MTRR hole.\n");
} else {
-#if CONFIG_VAR_MTRR_HOLE
// Increase the base range and set up UMA as an UC hole instead
if (above4gb != 2)
var_state.range_sizek += (uma_memory_size >> 10);
var_state.hole_startk = (uma_memory_base >> 10);
var_state.hole_sizek = (uma_memory_size >> 10);
-#endif
}
#endif
/* Write the last range */
var_state.reg = range_to_mtrr(var_state.reg, var_state.range_startk,
var_state.range_sizek, 0, MTRR_TYPE_WRBACK,
var_state.address_bits, var_state.above4gb);
-#if CONFIG_VAR_MTRR_HOLE
+
var_state.reg = range_to_mtrr(var_state.reg, var_state.hole_startk,
var_state.hole_sizek, 0, MTRR_TYPE_UNCACHEABLE,
var_state.address_bits, var_state.above4gb);
-#endif
+
printk(BIOS_DEBUG, "DONE variable MTRRs\n");
printk(BIOS_DEBUG, "Clear out the extra MTRR's\n");
/* Clear out the extra MTRR's */
diff --git a/src/mainboard/msi/ms9652_fam10/Kconfig b/src/mainboard/msi/ms9652_fam10/Kconfig
index a1f69c8..2bb4a61 100644
--- a/src/mainboard/msi/ms9652_fam10/Kconfig
+++ b/src/mainboard/msi/ms9652_fam10/Kconfig
@@ -137,10 +137,6 @@ config SB_HT_CHAIN_ON_BUS0
int
default 1
-config VAR_MTRR_HOLE
- bool
- default n
-
config APIC_ID_OFFSET
hex
default 0x00
More information about the coreboot
mailing list