AGESA and binaryPI boards have no easy way to determine correct cbmem_top() location early enough when GFXUMA is enabled, so they will use these functions with EARLY_CBMEM_INIT as well. At the end of AmdInitPost() the decisions of UMA base and size have not been written to hardware yet. The decisions are stored inside AGESA heap object we cannot locate from coreboot proper until after AmdInitEnv(). Modify code such that weak backup functions are only defined for LATE_CBMEM_INIT; they are somewhat troublesome to handle. Change-Id: Ifef4f75b36bc6dee6cd56d1d9164281d9b2a4f2a Signed-off-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-on: https://review.coreboot.org/19306 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
71 lines
1.7 KiB
C
71 lines
1.7 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
|
|
#include <stdlib.h>
|
|
#include <console/console.h>
|
|
#include <cbmem.h>
|
|
#include <arch/acpi.h>
|
|
|
|
#if IS_ENABLED(CONFIG_LATE_CBMEM_INIT)
|
|
|
|
void __attribute__((weak)) backup_top_of_ram(uint64_t ramtop)
|
|
{
|
|
/* Do nothing. Chipset may have implementation to save ramtop in NVRAM.
|
|
*/
|
|
}
|
|
|
|
unsigned long __attribute__((weak)) get_top_of_ram(void)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
#endif /* LATE_CBMEM_INIT */
|
|
|
|
#if IS_ENABLED(CONFIG_CBMEM_TOP_BACKUP)
|
|
|
|
static void *ramtop_pointer;
|
|
|
|
void set_top_of_ram(uint64_t ramtop)
|
|
{
|
|
backup_top_of_ram(ramtop);
|
|
if (ENV_RAMSTAGE)
|
|
ramtop_pointer = (void *)(uintptr_t)ramtop;
|
|
}
|
|
|
|
void *cbmem_top(void)
|
|
{
|
|
/* Top of cbmem is at lowest usable DRAM address below 4GiB. */
|
|
uintptr_t ramtop;
|
|
|
|
if (ENV_RAMSTAGE && ramtop_pointer != NULL)
|
|
return ramtop_pointer;
|
|
|
|
ramtop = get_top_of_ram();
|
|
|
|
if (ENV_RAMSTAGE)
|
|
ramtop_pointer = (void *)ramtop;
|
|
|
|
return (void *)ramtop;
|
|
}
|
|
|
|
#endif /* CBMEM_TOP_BACKUP */
|
|
|
|
/* Something went wrong, our high memory area got wiped */
|
|
void cbmem_fail_resume(void)
|
|
{
|
|
#if !defined(__PRE_RAM__) && IS_ENABLED(CONFIG_HAVE_ACPI_RESUME)
|
|
/* ACPI resume needs to be cleared in the fail-to-recover case, but that
|
|
* condition is only handled during ramstage. */
|
|
acpi_fail_wakeup();
|
|
#endif
|
|
}
|