aboutsummaryrefslogtreecommitdiff
path: root/src/libthread
diff options
context:
space:
mode:
authorRichard Miller <millerresearch@gmail.com>2011-05-18 13:20:56 -0400
committerRuss Cox <rsc@swtch.com>2011-05-18 13:20:56 -0400
commit9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073 (patch)
tree392f2d1c712a4eb2dde49163678ec2fedad6b848 /src/libthread
parentc1f950fc32d55890e0b914d9368657b23122dd59 (diff)
downloadplan9port-9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073.tar.gz
plan9port-9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073.tar.bz2
plan9port-9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073.zip
arm: build fixes
Get p9p to build cleanly for ARM - based on suggestions from rsc and eekee, plus a final tweak from me. Tested (a bit) on sheevaplug (ubuntu jaunty), Nokia N800 (maemo 4) and Nokia N900 (maemo 5). R=rsc CC=plan9port.codebot http://codereview.appspot.com/4524056
Diffstat (limited to 'src/libthread')
-rw-r--r--src/libthread/Linux-arm-swapcontext.c26
-rw-r--r--src/libthread/sysofiles.sh3
-rw-r--r--src/libthread/threadimpl.h8
3 files changed, 17 insertions, 20 deletions
diff --git a/src/libthread/Linux-arm-swapcontext.c b/src/libthread/Linux-arm-swapcontext.c
index 43358800..907fb0c3 100644
--- a/src/libthread/Linux-arm-swapcontext.c
+++ b/src/libthread/Linux-arm-swapcontext.c
@@ -3,24 +3,24 @@
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 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.arm_r0)[i] = va_arg(arg, uint);
+ va_end(arg);
+ uc->uc_mcontext.arm_sp = (uint)sp;
+ uc->uc_mcontext.arm_lr = (uint)fn;
}
int
swapcontext(ucontext_t *oucp, const ucontext_t *ucp)
{
- if(getcontext(oucp) == 0)
- setcontext(ucp);
- return 0;
+ if(getcontext(oucp) == 0)
+ setcontext(ucp);
+ return 0;
}
diff --git a/src/libthread/sysofiles.sh b/src/libthread/sysofiles.sh
index 27029471..32600a71 100644
--- a/src/libthread/sysofiles.sh
+++ b/src/libthread/sysofiles.sh
@@ -4,9 +4,6 @@ test -f $PLAN9/config && . $PLAN9/config
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
;;
diff --git a/src/libthread/threadimpl.h b/src/libthread/threadimpl.h
index f5c44f63..8b931ae7 100644
--- a/src/libthread/threadimpl.h
+++ b/src/libthread/threadimpl.h
@@ -73,10 +73,10 @@ but surely the latter would be defined(__sparc__).
*/
#if defined(__arm__)
-int mygetmcontext(mcontext_t*);
-void mysetmcontext(const mcontext_t*);
-#define setcontext(u) mysetmcontext(&(u)->uc_mcontext)
-#define getcontext(u) mygetmcontext(&(u)->uc_mcontext)
+int mygetmcontext(ulong*);
+void mysetmcontext(const ulong*);
+#define setcontext(u) mysetmcontext(&(u)->uc_mcontext.arm_r0)
+#define getcontext(u) mygetmcontext(&(u)->uc_mcontext.arm_r0)
#endif