Commit d05e38ce authored by Marc Zyngier's avatar Marc Zyngier Committed by Stefan Bader

arm/arm64: smccc-1.1: Make return values unsigned long

BugLink: https://bugs.launchpad.net/bugs/1852110

[ Upstream commit 1d8f5747 ]

An unfortunate consequence of having a strong typing for the input
values to the SMC call is that it also affects the type of the
return values, limiting r0 to 32 bits and r{1,2,3} to whatever
was passed as an input.

Let's turn everything into "unsigned long", which satisfies the
requirements of both architectures, and allows for the full
range of return values.
Reported-by: default avatarJulien Grall <julien.grall@arm.com>
Signed-off-by: default avatarMarc Zyngier <marc.zyngier@arm.com>
Signed-off-by: default avatarWill Deacon <will.deacon@arm.com>
Signed-off-by: default avatarSasha Levin <alexander.levin@microsoft.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarConnor Kuehl <connor.kuehl@canonical.com>
Signed-off-by: default avatarKhalid Elmously <khalid.elmously@canonical.com>
parent 14fb2ed0
...@@ -167,31 +167,31 @@ asmlinkage void arm_smccc_hvc(unsigned long a0, unsigned long a1, ...@@ -167,31 +167,31 @@ asmlinkage void arm_smccc_hvc(unsigned long a0, unsigned long a1,
#define __declare_arg_0(a0, res) \ #define __declare_arg_0(a0, res) \
struct arm_smccc_res *___res = res; \ struct arm_smccc_res *___res = res; \
register u32 r0 asm("r0") = a0; \ register unsigned long r0 asm("r0") = (u32)a0; \
register unsigned long r1 asm("r1"); \ register unsigned long r1 asm("r1"); \
register unsigned long r2 asm("r2"); \ register unsigned long r2 asm("r2"); \
register unsigned long r3 asm("r3") register unsigned long r3 asm("r3")
#define __declare_arg_1(a0, a1, res) \ #define __declare_arg_1(a0, a1, res) \
struct arm_smccc_res *___res = res; \ struct arm_smccc_res *___res = res; \
register u32 r0 asm("r0") = a0; \ register unsigned long r0 asm("r0") = (u32)a0; \
register typeof(a1) r1 asm("r1") = a1; \ register unsigned long r1 asm("r1") = a1; \
register unsigned long r2 asm("r2"); \ register unsigned long r2 asm("r2"); \
register unsigned long r3 asm("r3") register unsigned long r3 asm("r3")
#define __declare_arg_2(a0, a1, a2, res) \ #define __declare_arg_2(a0, a1, a2, res) \
struct arm_smccc_res *___res = res; \ struct arm_smccc_res *___res = res; \
register u32 r0 asm("r0") = a0; \ register unsigned long r0 asm("r0") = (u32)a0; \
register typeof(a1) r1 asm("r1") = a1; \ register unsigned long r1 asm("r1") = a1; \
register typeof(a2) r2 asm("r2") = a2; \ register unsigned long r2 asm("r2") = a2; \
register unsigned long r3 asm("r3") register unsigned long r3 asm("r3")
#define __declare_arg_3(a0, a1, a2, a3, res) \ #define __declare_arg_3(a0, a1, a2, a3, res) \
struct arm_smccc_res *___res = res; \ struct arm_smccc_res *___res = res; \
register u32 r0 asm("r0") = a0; \ register unsigned long r0 asm("r0") = (u32)a0; \
register typeof(a1) r1 asm("r1") = a1; \ register unsigned long r1 asm("r1") = a1; \
register typeof(a2) r2 asm("r2") = a2; \ register unsigned long r2 asm("r2") = a2; \
register typeof(a3) r3 asm("r3") = a3 register unsigned long r3 asm("r3") = a3
#define __declare_arg_4(a0, a1, a2, a3, a4, res) \ #define __declare_arg_4(a0, a1, a2, a3, a4, res) \
__declare_arg_3(a0, a1, a2, a3, res); \ __declare_arg_3(a0, a1, a2, a3, res); \
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment