From e707f486c525bd4cf106e408b0a6ee1b3a3e9fd0 Mon Sep 17 00:00:00 2001 From: Greg Hackmann Date: Fri, 2 Mar 2018 13:22:46 -0800 Subject: [PATCH] ANDROID: arm-smccc: fix clang build The SMCCC 1.1 helpers rely on an undocumented(?) gcc extension, where obsolete AArch32 register names are accepted in AArch64 mode and silently changed to X[n] or W[n] based on context. There's ongoing discussion upstream about how to move forward on this (https://lkml.org/lkml/2018/2/28/1175, https://lkml.org/lkml/2018/3/16/876). In the meantime, to unbreak the android-4.14 build on clang, we'll temporary switch to using X[n] instead of R[n] on ARM64: these helpers were introduced to 4.14.y for two specific callers, and both cases should use the full 64-bit register width. Bug: 74579705 Fixes: ac63fdb4a2b2 ("arm/arm64: smccc: Implement SMCCC v1.1 inline primitive") Change-Id: I1eb14f7b6674f7dffcad9572e409f6bcdba69610 Signed-off-by: Greg Hackmann --- include/linux/arm-smccc.h | 42 ++++++++++++++++++++------------------- 1 file changed, 22 insertions(+), 20 deletions(-) diff --git a/include/linux/arm-smccc.h b/include/linux/arm-smccc.h index a031897fca76..43690f501712 100644 --- a/include/linux/arm-smccc.h +++ b/include/linux/arm-smccc.h @@ -155,6 +155,7 @@ asmlinkage void __arm_smccc_hvc(unsigned long a0, unsigned long a1, #define SMCCC_SMC_INST "smc #0" #define SMCCC_HVC_INST "hvc #0" +#define SMCCC_REG(n) asm("x" # n) #elif defined(CONFIG_ARM) #include @@ -162,6 +163,7 @@ asmlinkage void __arm_smccc_hvc(unsigned long a0, unsigned long a1, #define SMCCC_SMC_INST __SMC(0) #define SMCCC_HVC_INST __HVC(0) +#define SMCCC_REG(n) asm("r" # n) #endif @@ -194,47 +196,47 @@ asmlinkage void __arm_smccc_hvc(unsigned long a0, unsigned long a1, #define __declare_arg_0(a0, res) \ struct arm_smccc_res *___res = res; \ - register u32 r0 asm("r0") = a0; \ - register unsigned long r1 asm("r1"); \ - register unsigned long r2 asm("r2"); \ - register unsigned long r3 asm("r3") + register u32 r0 SMCCC_REG(0) = a0; \ + register unsigned long r1 SMCCC_REG(1); \ + register unsigned long r2 SMCCC_REG(2); \ + register unsigned long r3 SMCCC_REG(3) #define __declare_arg_1(a0, a1, res) \ struct arm_smccc_res *___res = res; \ - register u32 r0 asm("r0") = a0; \ - register typeof(a1) r1 asm("r1") = a1; \ - register unsigned long r2 asm("r2"); \ - register unsigned long r3 asm("r3") + register u32 r0 SMCCC_REG(0) = a0; \ + register typeof(a1) r1 SMCCC_REG(1) = a1; \ + register unsigned long r2 SMCCC_REG(2); \ + register unsigned long r3 SMCCC_REG(3) #define __declare_arg_2(a0, a1, a2, res) \ struct arm_smccc_res *___res = res; \ - register u32 r0 asm("r0") = a0; \ - register typeof(a1) r1 asm("r1") = a1; \ - register typeof(a2) r2 asm("r2") = a2; \ - register unsigned long r3 asm("r3") + register u32 r0 SMCCC_REG(0) = a0; \ + register typeof(a1) r1 SMCCC_REG(1) = a1; \ + register typeof(a2) r2 SMCCC_REG(2) = a2; \ + register unsigned long r3 SMCCC_REG(3) #define __declare_arg_3(a0, a1, a2, a3, res) \ struct arm_smccc_res *___res = res; \ - register u32 r0 asm("r0") = a0; \ - register typeof(a1) r1 asm("r1") = a1; \ - register typeof(a2) r2 asm("r2") = a2; \ - register typeof(a3) r3 asm("r3") = a3 + register u32 r0 SMCCC_REG(0) = a0; \ + register typeof(a1) r1 SMCCC_REG(1) = a1; \ + register typeof(a2) r2 SMCCC_REG(2) = a2; \ + register typeof(a3) r3 SMCCC_REG(3) = a3 #define __declare_arg_4(a0, a1, a2, a3, a4, res) \ __declare_arg_3(a0, a1, a2, a3, res); \ - register typeof(a4) r4 asm("r4") = a4 + register typeof(a4) r4 SMCCC_REG(4) = a4 #define __declare_arg_5(a0, a1, a2, a3, a4, a5, res) \ __declare_arg_4(a0, a1, a2, a3, a4, res); \ - register typeof(a5) r5 asm("r5") = a5 + register typeof(a5) r5 SMCCC_REG(5) = a5 #define __declare_arg_6(a0, a1, a2, a3, a4, a5, a6, res) \ __declare_arg_5(a0, a1, a2, a3, a4, a5, res); \ - register typeof(a6) r6 asm("r6") = a6 + register typeof(a6) r6 SMCCC_REG(6) = a6 #define __declare_arg_7(a0, a1, a2, a3, a4, a5, a6, a7, res) \ __declare_arg_6(a0, a1, a2, a3, a4, a5, a6, res); \ - register typeof(a7) r7 asm("r7") = a7 + register typeof(a7) r7 SMCCC_REG(7) = a7 #define ___declare_args(count, ...) __declare_arg_ ## count(__VA_ARGS__) #define __declare_args(count, ...) ___declare_args(count, __VA_ARGS__) -- 2.20.1