aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/libmp/arm/mkfile4
-rw-r--r--src/libsec/arm/mkfile4
-rw-r--r--src/libthread/Linux-arm-swapcontext.c26
-rw-r--r--src/libthread/sysofiles.sh3
-rw-r--r--src/libthread/threadimpl.h8
5 files changed, 25 insertions, 20 deletions
diff --git a/src/libmp/arm/mkfile b/src/libmp/arm/mkfile
new file mode 100644
index 00000000..43a4662b
--- /dev/null
+++ b/src/libmp/arm/mkfile
@@ -0,0 +1,4 @@
+all:
+
+%:V:
+ # nothing to see here
diff --git a/src/libsec/arm/mkfile b/src/libsec/arm/mkfile
new file mode 100644
index 00000000..43a4662b
--- /dev/null
+++ b/src/libsec/arm/mkfile
@@ -0,0 +1,4 @@
+all:
+
+%:V:
+ # nothing to see here
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