Timothy Pearson (tpearson(a)raptorengineeringinc.com) just uploaded a new patch set to gerrit, which you can find at http://review.coreboot.org/12054
-gerrit
commit 3281d33e248ec25dca4ca7abe0791fffe0c0aed8
Author: Timothy Pearson <tpearson(a)raptorengineeringinc.com>
Date: Thu Aug 20 15:53:25 2015 -0500
northbridge/amd/amdfam10: Work around sporadic lockups when CC6 enabled
Change-Id: If31140651f25f9c524a824b2da552ce3690eae18
Signed-off-by: Timothy Pearson <tpearson(a)raptorengineeringinc.com>
---
src/northbridge/amd/amdfam10/northbridge.c | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/src/northbridge/amd/amdfam10/northbridge.c b/src/northbridge/amd/amdfam10/northbridge.c
index 60ad8c4..3177a5f 100644
--- a/src/northbridge/amd/amdfam10/northbridge.c
+++ b/src/northbridge/amd/amdfam10/northbridge.c
@@ -812,6 +812,20 @@ static void amdfam10_domain_read_resources(device_t dev)
else
qword = 0x1000000;
+ /* FIXME
+ * The BKDG appears to be incorrect as to the location of the CC6 save region
+ * lower boundary on non-interleaved systems, causing lockups on attempted write
+ * to the CC6 save region.
+ *
+ * For now, work around by allocating the maximum possible CC6 save region size.
+ *
+ * Determine if this is a BKDG error or a setup problem and remove this warning!
+ */
+ qword = (0x1 << 27);
+ max_range_limit = (((uint64_t)(pci_read_config32(get_node_pci(max_node, 1), 0x124) & 0x1fffff)) << 27) - 1;
+
+ printk(BIOS_INFO, "Reserving CC6 save segment base: %08llx size: %08llx\n", (max_range_limit + 1), qword);
+
/* Reserve the CC6 save segment */
reserved_ram_resource(dev, 8, (max_range_limit + 1) >> 10, qword >> 10);
}