amd/stoneyridge: Adjust memory map for reserved

Carve out memory to be reported to the OS as reserved.  This makes
room for a region usable for Boot Error Record Table information.
The BERT region reserved size is larger than likely requried, however
the SMM region's base must be on a boundary matching the granularity
of its size.

BUG=b:65446699
TEST=inspect BERT region, and dmesg, on full patch stack.  Use test
     data plus a failing Grunt system.

Change-Id: I0958f6b6bab3fe9dae36c83e1fd9ae6ed0290a18
Signed-off-by: Marshall Dawson <marshalldawson3rd@gmail.com>
Reviewed-on: https://review.coreboot.org/28474
Reviewed-by: Martin Roth <martinroth@google.com>
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
Marshall Dawson 2018-09-04 13:08:25 -06:00 committed by Martin Roth
parent bb7f1b41e7
commit 4b0f6fa156

View file

@ -23,6 +23,7 @@
#include <cpu/amd/amdfam15.h> #include <cpu/amd/amdfam15.h>
#include <cbmem.h> #include <cbmem.h>
#include <stage_cache.h> #include <stage_cache.h>
#include <arch/bert_storage.h>
#include <soc/northbridge.h> #include <soc/northbridge.h>
#include <soc/southbridge.h> #include <soc/southbridge.h>
@ -36,6 +37,22 @@ uintptr_t restore_top_of_low_cacheable(void)
return biosram_read32(BIOSRAM_CBMEM_TOP); return biosram_read32(BIOSRAM_CBMEM_TOP);
} }
#if IS_ENABLED(CONFIG_ACPI_BERT)
/* SMM_TSEG_SIZE must stay on a boundary appropriate for its granularity */
#define BERT_REGION_MAX_SIZE CONFIG_SMM_TSEG_SIZE
#else
#define BERT_REGION_MAX_SIZE 0
#endif
void bert_reserved_region(void **start, size_t *size)
{
if (IS_ENABLED(CONFIG_ACPI_BERT))
*start = cbmem_top();
else
start = NULL;
*size = BERT_REGION_MAX_SIZE;
}
void *cbmem_top(void) void *cbmem_top(void)
{ {
msr_t tom = rdmsr(TOP_MEM); msr_t tom = rdmsr(TOP_MEM);
@ -45,12 +62,13 @@ void *cbmem_top(void)
else else
/* 8MB alignment to keep MTRR usage low */ /* 8MB alignment to keep MTRR usage low */
return (void *)ALIGN_DOWN(restore_top_of_low_cacheable() return (void *)ALIGN_DOWN(restore_top_of_low_cacheable()
- CONFIG_SMM_TSEG_SIZE, 8*MiB); - CONFIG_SMM_TSEG_SIZE
- BERT_REGION_MAX_SIZE, 8*MiB);
} }
static uintptr_t smm_region_start(void) static uintptr_t smm_region_start(void)
{ {
return (uintptr_t)cbmem_top(); return (uintptr_t)cbmem_top() + BERT_REGION_MAX_SIZE;
} }
static size_t smm_region_size(void) static size_t smm_region_size(void)