make arm setjmp/longjmp asm thumb2-compatible
authorRich Felker <dalias@aerifal.cx>
Sun, 18 Dec 2016 00:30:03 +0000 (19:30 -0500)
committerRich Felker <dalias@aerifal.cx>
Sun, 18 Dec 2016 00:30:03 +0000 (19:30 -0500)
sp cannot be used in the ldm/stm register set in thumb mode.

src/setjmp/arm/longjmp.s
src/setjmp/arm/setjmp.s

index e28d8f31c32bec17eb454560a4fbcb50a33e1887..6191ab26b8ab7109b1961479b8577fd36cb32fe6 100644 (file)
@@ -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
index 87791634b862313f69168c6742fe2e3fa35c5c15..c6fe1bb230f171a41056213b98e7355b4ce04dc7 100644 (file)
@@ -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