commit - 778ec84c9c817be65404193e2156c8fdb90b846a
commit + ba940ae61c4c33766e385b63ecf49bec25f301d7
blob - /dev/null
blob + 9bd54f8af2cab24ea03c783413b7c41f260bf252 (mode 644)
--- /dev/null
+++ src/libthread/Linux-arm-context.s
+.globl mygetmcontext
+mygetmcontext:
+ 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 mysetmcontext
+mysetmcontext:
+ 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 - /dev/null
blob + 433588002ab9afaf25259ddf581fc87551ef39a4 (mode 644)
--- /dev/null
+++ src/libthread/Linux-arm-swapcontext.c
+#include "threadimpl.h"
+
+void
+makecontext(ucontext_t *uc, void (*fn)(void), int argc, ...)
+{
+ int i, *sp;
+ va_list arg;
+
+ 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[i] = va_arg(arg, uint);
+ va_end(arg);
+ uc->uc_mcontext.gregs[13] = (uint)sp;
+ uc->uc_mcontext.gregs[14] = (uint)fn;
+}
+
+int
+swapcontext(ucontext_t *oucp, const ucontext_t *ucp)
+{
+ if(getcontext(oucp) == 0)
+ setcontext(ucp);
+ return 0;
+}
+
+
blob - cdc1ad029312d1649a806a7804bd5313475fecb8
blob + 270294713673b2355f590eed14de4e0fce166f94
--- src/libthread/sysofiles.sh
+++ src/libthread/sysofiles.sh
tag="$OBJTYPE-$SYSNAME-${SYSVERSION:-`uname -r`}-${CC9:-cc}"
case "$tag" in
+arm-Linux-*)
+ echo ${SYSNAME}-${OBJTYPE}-asm.o $SYSNAME.o
+ ;;
*-Linux-2.6.*)
echo pthread.o
;;
# so we supply our own copy from the latest glibc.
echo Linux-sparc64-context.o Linux-sparc64-swapcontext.o
;;
+arm-Linux)
+ # ARM doesn't supply them either.
+ echo Linux-arm-context.o Linux-arm-swapcontext.o
+ ;;
esac
blob - 8b00694e3be7b3e2ffe4a354c2f8993275c682b8
blob + f5c44f63292e8ba30743df9e57362f07ee556b69
--- src/libthread/threadimpl.h
+++ src/libthread/threadimpl.h
*/
#if defined(__arm__)
-int getmcontext(mcontext_t*);
-void setmcontext(const mcontext_t*);
-#define setcontext(u) setmcontext(&(u)->uc_mcontext)
-#define getcontext(u) getmcontext(&(u)->uc_mcontext)
+int mygetmcontext(mcontext_t*);
+void mysetmcontext(const mcontext_t*);
+#define setcontext(u) mysetmcontext(&(u)->uc_mcontext)
+#define getcontext(u) mygetmcontext(&(u)->uc_mcontext)
#endif