summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/mainboard/aopen/dxplplusu/Kconfig1
-rw-r--r--src/mainboard/aopen/dxplplusu/romstage.c12
-rw-r--r--src/northbridge/intel/e7505/Kconfig4
-rw-r--r--src/northbridge/intel/e7505/raminit.c102
-rw-r--r--src/northbridge/intel/e7505/raminit.h1
5 files changed, 0 insertions, 120 deletions
diff --git a/src/mainboard/aopen/dxplplusu/Kconfig b/src/mainboard/aopen/dxplplusu/Kconfig
index 8e3178529e..85c45d51f3 100644
--- a/src/mainboard/aopen/dxplplusu/Kconfig
+++ b/src/mainboard/aopen/dxplplusu/Kconfig
@@ -12,7 +12,6 @@ config BOARD_SPECIFIC_OPTIONS
select UDELAY_TSC
select HAVE_ACPI_TABLES
select BOARD_ROMSIZE_KB_2048
-# select HW_SCRUBBER
config MAINBOARD_DIR
string
diff --git a/src/mainboard/aopen/dxplplusu/romstage.c b/src/mainboard/aopen/dxplplusu/romstage.c
index 73a9ce07e3..75aad28093 100644
--- a/src/mainboard/aopen/dxplplusu/romstage.c
+++ b/src/mainboard/aopen/dxplplusu/romstage.c
@@ -66,18 +66,6 @@ void mainboard_romstage_entry(unsigned long bist)
/* The real MCH initialisation. */
e7505_mch_init(memctrl);
- /*
- * ECC scrub invalidates cache, so all stack in CAR
- * is lost. Only return addresses from main() and
- * scrub_ecc() are recovered to stack via xmm0-xmm3.
- */
-#if IS_ENABLED(CONFIG_HW_SCRUBBER)
-#if !IS_ENABLED(CONFIG_USBDEBUG_IN_ROMSTAGE)
- unsigned long ret_addr = (unsigned long)((unsigned long*)&bist - 1);
- e7505_mch_scrub_ecc(ret_addr);
-#endif
-#endif
-
/* Hook for post ECC scrub settings and debug. */
e7505_mch_done(memctrl);
diff --git a/src/northbridge/intel/e7505/Kconfig b/src/northbridge/intel/e7505/Kconfig
index 7f905f26a6..a774c0e8f5 100644
--- a/src/northbridge/intel/e7505/Kconfig
+++ b/src/northbridge/intel/e7505/Kconfig
@@ -24,8 +24,4 @@ config NORTHBRIDGE_SPECIFIC_OPTIONS # dummy
select HAVE_DEBUG_RAM_SETUP
select POSTCAR_STAGE
-config HW_SCRUBBER
- bool
- default n
-
endif
diff --git a/src/northbridge/intel/e7505/raminit.c b/src/northbridge/intel/e7505/raminit.c
index 8a44b271b4..6550bb5cb6 100644
--- a/src/northbridge/intel/e7505/raminit.c
+++ b/src/northbridge/intel/e7505/raminit.c
@@ -905,95 +905,6 @@ static void configure_e7501_ram_addresses(const struct mem_controller
}
/**
- * Execute ECC full-speed scrub once and leave scrubber disabled.
- *
- * NOTE: All cache and stack is lost during ECC scrub loop.
- */
-static __always_inline void
- initialize_ecc(unsigned long ret_addr, unsigned long ret_addr2)
-{
- uint16_t scrubbed = pci_read_config16(MCHDEV, MCHCFGNS) & 0x08;
-
- if (!scrubbed) {
- RAM_DEBUG_MESSAGE("Initializing ECC state...\n");
-
- /* ECC scrub flushes cache-lines and stack, need to
- * store return address from romstage.c:main().
- */
- asm volatile(
- "movd %0, %%xmm0;"
- "movd (%0), %%xmm1;"
- "movd %1, %%xmm2;"
- "movd (%1), %%xmm3;"
- :: "r" (ret_addr), "r" (ret_addr2) :
- );
-
- /* NOTE: All cache is lost during this loop.
- * Make sure PCI access does not use stack.
- */
-
- pci_write_config16(MCHDEV, MCHCFGNS, 0x01);
- do {
- scrubbed = pci_read_config16(MCHDEV, MCHCFGNS);
- } while (! (scrubbed & 0x08));
- pci_write_config16(MCHDEV, MCHCFGNS, (scrubbed & ~0x07) | 0x04);
-
- /* Some problem remains with XIP cache from ROM, so for
- * now, I disable XIP and also invalidate cache (again)
- * before the remaining small portion of romstage.
- *
- * Adding NOPs here has unexpected results, making
- * the first do_printk()/vtxprintf() after ECC scrub
- * fail midway. Sometimes vtxprintf() dumps strings
- * completely but with every 4th (fourth) character as "/".
- *
- * An inlined dump to console of the same string,
- * before vtxprintf() call, is successful. So the
- * source string should be completely in cache already.
- *
- * I need to review this again with CPU microcode
- * update applied pre-CAR.
- */
-
- /* Disable and invalidate all cache. */
- msr_t xip_mtrr = rdmsr(MTRR_PHYS_MASK(1));
- xip_mtrr.lo &= ~MTRR_PHYS_MASK_VALID;
- invd();
- wrmsr(MTRR_PHYS_MASK(1), xip_mtrr);
- invd();
-
- RAM_DEBUG_MESSAGE("ECC state initialized.\n");
-
- /* Recover IP for return from main. */
- asm volatile(
- "movd %%xmm0, %%edi;"
- "movd %%xmm1, (%%edi);"
- "movd %%xmm2, %%edi;"
- "movd %%xmm3, (%%edi);"
- ::: "edi"
- );
-
-#if IS_ENABLED(CONFIG_DEBUG_RAM_SETUP)
- unsigned int a1, a2;
- asm volatile("movd %%xmm2, %%eax;" : "=a" (a1) ::);
- asm volatile("movd %%xmm3, %%eax;" : "=a" (a2) ::);
- printk(BIOS_DEBUG, "return EIP @ %x = %x\n", a1, a2);
- asm volatile("movd %%xmm0, %%eax;" : "=a" (a1) ::);
- asm volatile("movd %%xmm1, %%eax;" : "=a" (a2) ::);
- printk(BIOS_DEBUG, "return EIP @ %x = %x\n", a1, a2);
-#endif
- }
-
- /* Clear the ECC error bits. */
- pci_write_config8(RASDEV, DRAM_FERR, 0x03);
- pci_write_config8(RASDEV, DRAM_NERR, 0x03);
-
- /* Clear DRAM Interface error bits. */
- pci_write_config32(RASDEV, FERR_GLOBAL, 1 << 18);
- pci_write_config32(RASDEV, NERR_GLOBAL, 1 << 18);
-}
-
-/**
* Program the DRAM Timing register (DRT) of the E7501 (except for CAS#
* latency, which is assumed to have been programmed already), based on the
* parameters of the various installed DIMMs.
@@ -1862,19 +1773,6 @@ void e7505_mch_init(const struct mem_controller *memctrl)
sdram_enable(memctrl);
}
-/**
- * Scrub and reset error counts for ECC dimms.
- *
- * NOTE: this will invalidate cache and disable XIP cache for the
- * short remaining part of romstage.
- */
-void e7505_mch_scrub_ecc(unsigned long ret_addr)
-{
- unsigned long ret_addr2 = (unsigned long)((unsigned long*)&ret_addr-1);
- if ((pci_read_config32(MCHDEV, DRC)>>20 & 3) == 2)
- initialize_ecc(ret_addr, ret_addr2);
-}
-
void e7505_mch_done(const struct mem_controller *memctrl)
{
sdram_post_ecc(memctrl);
diff --git a/src/northbridge/intel/e7505/raminit.h b/src/northbridge/intel/e7505/raminit.h
index cdfc92a965..f3fc264200 100644
--- a/src/northbridge/intel/e7505/raminit.h
+++ b/src/northbridge/intel/e7505/raminit.h
@@ -31,7 +31,6 @@ struct mem_controller {
};
void e7505_mch_init(const struct mem_controller *memctrl);
-void e7505_mch_scrub_ecc(unsigned long ret_addr);
void e7505_mch_done(const struct mem_controller *memctrl);
int e7505_mch_is_ready(void);