diff options
author | Richard Miller <millerresearch@gmail.com> | 2011-05-18 13:20:56 -0400 |
---|---|---|
committer | Russ Cox <rsc@swtch.com> | 2011-05-18 13:20:56 -0400 |
commit | 9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073 (patch) | |
tree | 392f2d1c712a4eb2dde49163678ec2fedad6b848 /src/libthread | |
parent | c1f950fc32d55890e0b914d9368657b23122dd59 (diff) | |
download | plan9port-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.c | 26 | ||||
-rw-r--r-- | src/libthread/sysofiles.sh | 3 | ||||
-rw-r--r-- | src/libthread/threadimpl.h | 8 |
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 |