Commit Diff


commit - 6912efc49c6362c46536d79c56dbfa0af1ba944e
commit + 9aa463c541d03ce5389e7015b9a19358a5796e63
blob - 95c8aaac419a003e9e82e6e194d7ba7db593653d
blob + 5a285bf20bcf53bbcbaee9f7a018e54f5be76dc4
--- src/libthread/Linux-arm-asm.s
+++ src/libthread/Linux-arm-asm.s
@@ -11,43 +11,43 @@ _tas:
 
 .globl getmcontext
 getmcontext:
-	/* r0 will be overwritten */
-	str	r1, [r0,#4]!
-	str	r2, [r0,#4]!
-	str	r3, [r0,#4]!
-	str	r4, [r0,#4]!
-	str	r5, [r0,#4]!
-	str	r6, [r0,#4]!
-	str	r7, [r0,#4]!
-	str	r8, [r0,#4]!
-	str	r9, [r0,#4]!
-	str	r10, [r0,#4]!
-	str	r11, [r0,#4]!
-	str	r12, [r0,#4]!
-	str	r13, [r0,#4]!
-	str	r14, [r0,#4]!
-	/* r15 is pc */
+	str	r1, [r0,#4]
+	str	r2, [r0,#8]
+	str	r3, [r0,#12]
+	str	r4, [r0,#16]
+	str	r5, [r0,#20]
+	str	r6, [r0,#24]
+	str	r7, [r0,#28]
+	str	r8, [r0,#32]
+	str	r9, [r0,#36]
+	str	r10, [r0,#40]
+	str	r11, [r0,#44]
+	str	r12, [r0,#48]
+	str	r13, [r0,#52]
+	str	r14, [r0,#56]
+	/* store 1 as r0-to-restore */
+	mov	r1, #1
+	str	r1, [r0]
+	/* return 0 */
 	mov	r0, #0
 	mov	pc, lr
 
 .globl setmcontext
 setmcontext:
-	/* r0 will be overwritten */
-	ldr	r1, [r0,#4]!
-	ldr	r2, [r0,#4]!
-	ldr	r3, [r0,#4]!
-	ldr	r4, [r0,#4]!
-	ldr	r5, [r0,#4]!
-	ldr	r6, [r0,#4]!
-	ldr	r7, [r0,#4]!
-	ldr	r8, [r0,#4]!
-	ldr	r9, [r0,#4]!
-	ldr	r10, [r0,#4]!
-	ldr	r11, [r0,#4]!
-	ldr	r12, [r0,#4]!
-	ldr	r13, [r0,#4]!
-	ldr	r14, [r0,#4]!
-	/* r15 is pc */
-	mov	r0, #1
+	ldr	r1, [r0,#4]
+	ldr	r2, [r0,#8]
+	ldr	r3, [r0,#12]
+	ldr	r4, [r0,#16]
+	ldr	r5, [r0,#20]
+	ldr	r6, [r0,#24]
+	ldr	r7, [r0,#28]
+	ldr	r8, [r0,#32]
+	ldr	r9, [r0,#36]
+	ldr	r10, [r0,#40]
+	ldr	r11, [r0,#44]
+	ldr	r12, [r0,#48]
+	ldr	r13, [r0,#52]
+	ldr	r14, [r0,#56]
+	ldr	r0, [r0]
 	mov	pc, lr
 
blob - 5d033248f45bd1c4be0bd6ec112f396fc2e5d686
blob + 73cb28e0731f12afcc9a082a5d008fffc5684f41
--- src/libthread/Linux.c
+++ src/libthread/Linux.c
@@ -449,7 +449,8 @@ makecontext(ucontext_t *uc, void (*fn)(void), int argc
 	sp = (int*)uc->uc_stack.ss_sp+uc->uc_stack.ss_size/4;
 	va_start(arg, argc);
 	for(i=0; i<4 && i<argc; i++)
-		uc->uc_mcontext.gregs[0] = va_arg(arg, uint);
+		uc->uc_mcontext.gregs[i] = va_arg(arg, uint);
+	va_end(arg);
 	uc->uc_mcontext.gregs[13] = (uint)sp;
 	uc->uc_mcontext.gregs[14] = (uint)fn;
 }