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:
Sergii Dmytruk 2021-08-21 16:24:02 +03:00 committed by Felix Held
parent dba9b54731
commit 3a96074441
4 changed files with 32 additions and 0 deletions

View file

@ -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

View file

@ -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

View file

@ -2,3 +2,5 @@
romstage-y += cbmem.c
romstage-y += romstage.c
ramstage-y += ramstage.c

View 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");
}