coreboot-kgpe-d16/src/include/ramdetect.h
Asami Doi 06993ee729 lib: ramdetect: Register exception handlers for ARMv8
Register exception handlers to avoid a Synchronous External Abort
that is raised when you try to access a non-memory address on ARMv8.
An exception handler can jump over the faulting instruction.
This is the feature only for QEMU/AArch64.

Signed-off-by: Asami Doi <d0iasm.pub@gmail.com>
Change-Id: I09a306ca307ba4027d9758c3debc2e7c844c66b8
Reviewed-on: https://review.coreboot.org/c/coreboot/+/34774
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Raul Rangel <rrangel@chromium.org>
2019-08-26 07:14:03 +00:00

28 lines
1 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.
*/
/*
* Used in probe_ramsize(). This is a weak function and it's overridden for
* ARMv8. Return 1 when DRAM exists at the address, otherwise return 0.
*/
int probe_mb(const uintptr_t dram_start, const uintptr_t size);
/*
* Probe an area if it's read/writable.
* Primary use case is the detection of DRAM amount on emulators.
*
* @param dram_start Physical address of DRAM start
* @param probe_size Maximum size in MiB to probe for
* @return The detected DRAM size in MiB
*/
size_t probe_ramsize(const uintptr_t dram_start, const size_t probe_size);