From c4992978998d37cb6a386992e5250873d691908b Mon Sep 17 00:00:00 2001 From: Gregory Nutt Date: Fri, 29 Aug 2014 10:07:11 -0600 Subject: [PATCH] Fix ARM7/9 and Cortex-A SYSCALLs: For threads in SVC mode, the SVC instructions clobbers R14. This must be taken account in the inline assembly --- arch/arm/include/arm/syscall.h | 17 +++++++++-------- arch/arm/include/armv7-a/syscall.h | 14 +++++++------- 2 files changed, 16 insertions(+), 15 deletions(-) diff --git a/arch/arm/include/arm/syscall.h b/arch/arm/include/arm/syscall.h index 3fc36c3db0..08b6ce0033 100644 --- a/arch/arm/include/arm/syscall.h +++ b/arch/arm/include/arm/syscall.h @@ -77,7 +77,7 @@ static inline uintptr_t sys_call0(unsigned int nbr) "swi %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0) - : "memory" + : "memory", "r14" ); return reg0; @@ -95,7 +95,7 @@ static inline uintptr_t sys_call1(unsigned int nbr, uintptr_t parm1) "swi %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1) - : "memory" + : "memory", "r14" ); return reg0; @@ -115,7 +115,7 @@ static inline uintptr_t sys_call2(unsigned int nbr, uintptr_t parm1, "swi %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2) - : "memory" + : "memory", "r14" ); return reg0; @@ -136,7 +136,7 @@ static inline uintptr_t sys_call3(unsigned int nbr, uintptr_t parm1, "swi %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3) - : "memory" + : "memory", "r14" ); return reg0; @@ -160,7 +160,7 @@ static inline uintptr_t sys_call4(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4) - : "memory" + : "memory", "r14" ); return reg0; @@ -185,7 +185,7 @@ static inline uintptr_t sys_call5(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4), "r"(reg5) - : "memory" + : "memory", "r14" ); return reg0; @@ -212,7 +212,7 @@ static inline uintptr_t sys_call6(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4), "r"(reg5), "r"(reg6) - : "memory" + : "memory", "r14" ); return reg0; @@ -228,7 +228,8 @@ static inline uintptr_t sys_call6(unsigned int nbr, uintptr_t parm1, #ifdef __cplusplus #define EXTERN extern "C" -extern "C" { +extern "C" +{ #else #define EXTERN extern #endif diff --git a/arch/arm/include/armv7-a/syscall.h b/arch/arm/include/armv7-a/syscall.h index f28952d1c6..e1c3228e76 100644 --- a/arch/arm/include/armv7-a/syscall.h +++ b/arch/arm/include/armv7-a/syscall.h @@ -77,7 +77,7 @@ static inline uintptr_t sys_call0(unsigned int nbr) "svc %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0) - : "memory" + : "memory", "r14" ); return reg0; @@ -95,7 +95,7 @@ static inline uintptr_t sys_call1(unsigned int nbr, uintptr_t parm1) "svc %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1) - : "memory" + : "memory", "r14" ); return reg0; @@ -115,7 +115,7 @@ static inline uintptr_t sys_call2(unsigned int nbr, uintptr_t parm1, "svc %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2) - : "memory" + : "memory", "r14" ); return reg0; @@ -136,7 +136,7 @@ static inline uintptr_t sys_call3(unsigned int nbr, uintptr_t parm1, "svc %1" : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3) - : "memory" + : "memory", "r14" ); return reg0; @@ -160,7 +160,7 @@ static inline uintptr_t sys_call4(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4) - : "memory" + : "memory", "r14" ); return reg0; @@ -185,7 +185,7 @@ static inline uintptr_t sys_call5(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4), "r"(reg5) - : "memory" + : "memory", "r14" ); return reg0; @@ -212,7 +212,7 @@ static inline uintptr_t sys_call6(unsigned int nbr, uintptr_t parm1, : "=r"(reg0) : "i"(SYS_syscall), "r"(reg0), "r"(reg1), "r"(reg2), "r"(reg3), "r"(reg4), "r"(reg5), "r"(reg6) - : "memory" + : "memory", "r14" ); return reg0;