commit - c1f950fc32d55890e0b914d9368657b23122dd59
commit + 9cf92718e9f2e82c7d1f2a896b5c93b01f1ad073
blob - /dev/null
blob + 43a4662b3107e2118f6f6f4d82324d66dbec14e3 (mode 644)
--- /dev/null
+++ src/libmp/arm/mkfile
+all:
+
+%:V:
+ # nothing to see here
blob - /dev/null
blob + 43a4662b3107e2118f6f6f4d82324d66dbec14e3 (mode 644)
--- /dev/null
+++ src/libsec/arm/mkfile
+all:
+
+%:V:
+ # nothing to see here
blob - 433588002ab9afaf25259ddf581fc87551ef39a4
blob + 907fb0c3fd4b29e0279c5de34eb0e374b2514d97
--- src/libthread/Linux-arm-swapcontext.c
+++ src/libthread/Linux-arm-swapcontext.c
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;
}
blob - 270294713673b2355f590eed14de4e0fce166f94
blob + 32600a7147f767f2bff6080218f39b0b4d1ea209
--- 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
;;
blob - f5c44f63292e8ba30743df9e57362f07ee556b69
blob + 8b931ae7597a396888c95c67ef632ce24f0bf5af
--- src/libthread/threadimpl.h
+++ src/libthread/threadimpl.h
*/
#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