diff options
author | Heinrich Schuchardt <xypron.glpk@gmx.de> | 2020-09-26 07:50:36 +0200 |
---|---|---|
committer | Heinrich Schuchardt <xypron.glpk@gmx.de> | 2020-09-28 12:20:19 +0200 |
commit | c48e9f310b950e39a91cea74b6708dd4fe2eb39c (patch) | |
tree | 6d32a1601de2a11a4fd3f8b2152ebd42a431171e /board/nvidia/beaver | |
parent | b59c13d42f42811912fd08f32f11e68a8e708c00 (diff) |
riscv: restore global data pointer in trap handler
The gp register is used to store U-Boot's global data pointer. We should
not assume that an UEFI application leaves the gp register unchanged as
the UEFI specifications does not define who is the owner of the gp and tp
registers.
So the following sequence should be followed in the trap handler:
* save the caller's gp register
* restore the global data pointer
* serve interrupts or print crash dump and reset
* restore the caller's gp register
Cc: Abner Chang <abner.chang@hpe.com>
Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Reviewed-by: Bin Meng <bin.meng@windriver.com>
Reviewed-by: Rick Chen <rick@andestech.com>
Diffstat (limited to 'board/nvidia/beaver')
0 files changed, 0 insertions, 0 deletions