src/arch/ppc64/*: pass FDT address to payload
It's available in %r3 in bootblock and needs to be passed to payload in %r27. We use one of two hypervisor's special registers as a buffer, which aren't used for anything by the code. Change-Id: I0911f4b534c6f8cacfa057a5bad7576fec711637 Signed-off-by: Sergii Dmytruk <sergii.dmytruk@3mdeb.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/57084 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Michał Żygowski <michal.zygowski@3mdeb.com> Reviewed-by: Krystian Hebel <krystian.hebel@3mdeb.com>
This commit is contained in:
parent
dba9b54731
commit
3a96074441
4 changed files with 32 additions and 0 deletions
|
@ -3,6 +3,8 @@
|
|||
* Early initialization code for POWER8/POWER9.
|
||||
*/
|
||||
|
||||
#include <cpu/power/spr.h>
|
||||
|
||||
#define FIXUP_ENDIAN \
|
||||
tdi 0,0,0x48; /* Reverse endian of b . + 8 */ \
|
||||
b $+44; /* Skip trampoline if endian is good */ \
|
||||
|
@ -35,6 +37,10 @@ _start:
|
|||
nop
|
||||
FIXUP_ENDIAN
|
||||
|
||||
/* Store FDT address provided by QEMU in %r3 to pass it later to
|
||||
* payload */
|
||||
mtspr SPR_HSPRG0, %r3
|
||||
|
||||
/* Set program priority to medium */
|
||||
or %r2, %r2, %r2
|
||||
|
||||
|
|
|
@ -9,6 +9,9 @@
|
|||
#define SPR_PVR_REV_MASK (PPC_BITMASK(52, 55) | PPC_BITMASK(60, 63))
|
||||
#define SPR_PVR_REV(maj, min) (PPC_SHIFT((maj), 55) | PPC_SHIFT((min), 63))
|
||||
|
||||
#define SPR_HSPRG0 0x130
|
||||
#define SPR_HSPRG1 0x131
|
||||
|
||||
#define SPR_HRMOR 0x139
|
||||
|
||||
#define SPR_HMER 0x150
|
||||
|
|
|
@ -2,3 +2,5 @@
|
|||
|
||||
romstage-y += cbmem.c
|
||||
romstage-y += romstage.c
|
||||
|
||||
ramstage-y += ramstage.c
|
||||
|
|
21
src/mainboard/emulation/qemu-power9/ramstage.c
Normal file
21
src/mainboard/emulation/qemu-power9/ramstage.c
Normal file
|
@ -0,0 +1,21 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||
|
||||
#include <cpu/power/spr.h>
|
||||
#include <program_loading.h>
|
||||
|
||||
/*
|
||||
* Payload's entry point is an offset to the real entry point, not to OPD
|
||||
* (Official Procedure Descriptor) for entry point.
|
||||
*
|
||||
* Also pass FDT address to payload stored in SPR_HSPRG0 by bootblock.
|
||||
*/
|
||||
void platform_prog_run(struct prog *prog)
|
||||
{
|
||||
asm volatile(
|
||||
"mfspr %%r27, %0\n" /* pass pointer to FDT */
|
||||
"mtctr %2\n"
|
||||
"mr 3, %1\n"
|
||||
"bctr\n"
|
||||
:: "i"(SPR_HSPRG0), "r"(prog_entry_arg(prog)), "r"(prog_entry(prog))
|
||||
: "memory");
|
||||
}
|
Loading…
Reference in a new issue