arm64: smccc: Support SMCCC v1.3 SVE register saving hint
authorMark Brown <broonie@kernel.org>
Thu, 3 Jun 2021 18:41:18 +0000 (19:41 +0100)
committerWill Deacon <will@kernel.org>
Tue, 8 Jun 2021 13:00:12 +0000 (14:00 +0100)
commitcfa7ff959a789a953eac40c8ac793e2cfc2db931
tree121241b7f3a9dfb8d374a06c9c4659f46d8f654f
parent57ad4fe0859ec6dd15776cae6ee8a139492334fd
arm64: smccc: Support SMCCC v1.3 SVE register saving hint

SMCCC v1.2 requires that all SVE state be preserved over SMC calls which
introduces substantial overhead in the common case where there is no SVE
state in the registers. To avoid this SMCCC v1.3 introduces a flag which
allows the caller to say that there is no state that needs to be preserved
in the registers. Make use of this flag, setting it if the SMCCC version
indicates support for it and the TIF_ flags indicate that there is no live
SVE state in the registers, this avoids placing any constraints on when
SMCCC calls can be done or triggering extra saving and reloading of SVE
register state in the kernel.

This would be straightforward enough except for the rather entertaining
inline assembly we use to do SMCCC v1.1 calls to allow us to take advantage
of the limited number of registers it clobbers. Deal with this by having a
function which we call immediately before issuing the SMCCC call to make
our checks and set the flag. Using alternatives the overhead if SVE is
supported but not detected at runtime can be reduced to a single NOP.

Signed-off-by: Mark Brown <broonie@kernel.org>
Reviewed-by: Ard Biesheuvel <ardb@kernel.org>
Reviewed-by: Marc Zyngier <maz@kernel.org>
Link: https://lore.kernel.org/r/20210603184118.15090-1-broonie@kernel.org
Signed-off-by: Will Deacon <will@kernel.org>
arch/arm64/kernel/smccc-call.S
drivers/firmware/smccc/smccc.c
include/linux/arm-smccc.h