From: Rich Felker Date: Sun, 18 Dec 2016 00:30:03 +0000 (-0500) Subject: make arm setjmp/longjmp asm thumb2-compatible X-Git-Tag: v1.1.16~8 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=fbbeda172d6f146067f9f57ab1498cf99c8d1007;p=oweals%2Fmusl.git make arm setjmp/longjmp asm thumb2-compatible sp cannot be used in the ldm/stm register set in thumb mode. --- diff --git a/src/setjmp/arm/longjmp.s b/src/setjmp/arm/longjmp.s index e28d8f31..6191ab26 100644 --- a/src/setjmp/arm/longjmp.s +++ b/src/setjmp/arm/longjmp.s @@ -8,7 +8,9 @@ longjmp: mov ip,r0 movs r0,r1 moveq r0,#1 - ldmia ip!, {v1,v2,v3,v4,v5,v6,sl,fp,sp,lr} + ldmia ip!, {v1,v2,v3,v4,v5,v6,sl,fp} + ldmia ip!, {r2,lr} + mov sp,r2 adr r1,1f ldr r2,1f diff --git a/src/setjmp/arm/setjmp.s b/src/setjmp/arm/setjmp.s index 87791634..c6fe1bb2 100644 --- a/src/setjmp/arm/setjmp.s +++ b/src/setjmp/arm/setjmp.s @@ -9,7 +9,9 @@ __setjmp: _setjmp: setjmp: mov ip,r0 - stmia ip!,{v1,v2,v3,v4,v5,v6,sl,fp,sp,lr} + stmia ip!,{v1,v2,v3,v4,v5,v6,sl,fp} + mov r2,sp + stmia ip!,{r2,lr} mov r0,#0 adr r1,1f