]> git.baikalelectronics.ru Git - uboot.git/commit
efi_loader: PSCI reset and shutdown
authorHeinrich Schuchardt <xypron.glpk@gmx.de>
Thu, 18 Oct 2018 10:29:40 +0000 (12:29 +0200)
committerAlexander Graf <agraf@suse.de>
Sun, 2 Dec 2018 20:59:37 +0000 (21:59 +0100)
commit55103254c0ea59352494a882c9a1ae16f10aa111
tree34fae16c5c4252c09835e63f605e4be9614a24e7
parent4a236e3e1b80d21861f14aab88af364bea1875a9
efi_loader: PSCI reset and shutdown

When an operating system started via bootefi tries to reset or power off
this is done by calling the EFI runtime ResetSystem(). On most ARMv8 system
the actual reset relies on PSCI. Depending on whether the PSCI firmware
resides the hypervisor (EL2) or in the secure monitor (EL3) either an HVC
or an SMC command has to be issued.

The current implementation always uses SMC. This results in crashes on
systems where the PSCI firmware is implemented in the hypervisor, e.g.
qemu-arm64_defconfig.

The logic to decide which call is needed based on the device tree is
already implemented in the PSCI firmware driver. During the EFI runtime
the device driver model is not available. But we can minimize code
duplication by merging the EFI runtime reset and poweroff code with
the PSCI firmware driver.

As the same HVC/SMC problem is also evident for the ARMv8 do_poweroff
and reset_misc routines let's move them into the same code module.

Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Reviewed-by: Sumit Garg <sumit.garg@linaro.org>
Tested-by: Sumit Garg <sumit.garg@linaro.org>
Signed-off-by: Alexander Graf <agraf@suse.de>
arch/arm/cpu/armv7/smccc-call.S
arch/arm/cpu/armv8/Kconfig
arch/arm/cpu/armv8/fwcall.c
arch/arm/cpu/armv8/smccc-call.S
drivers/firmware/psci.c
include/linux/psci.h