diff options
| author | Kai Backman <kaib@golang.org> | 2009-06-10 11:53:07 -0700 |
|---|---|---|
| committer | Kai Backman <kaib@golang.org> | 2009-06-10 11:53:07 -0700 |
| commit | 528919520d6d1561187afe0ee454e413849e46f1 (patch) | |
| tree | a41cf5f698184c45b9bde064ce58969dfb048b35 /src/pkg/runtime/linux | |
| parent | f2201185ab8d441b997588112fb0388adf315dc9 (diff) | |
| download | go-528919520d6d1561187afe0ee454e413849e46f1.tar.xz | |
Adding a batch of missing system calls.
R=rsc
APPROVED=rsc
DELTA=1329 (1264 added, 1 deleted, 64 changed)
OCL=30040
CL=30158
Diffstat (limited to 'src/pkg/runtime/linux')
| -rw-r--r-- | src/pkg/runtime/linux/arm/signal.c | 100 | ||||
| -rw-r--r-- | src/pkg/runtime/linux/arm/sys.s | 24 |
2 files changed, 123 insertions, 1 deletions
diff --git a/src/pkg/runtime/linux/arm/signal.c b/src/pkg/runtime/linux/arm/signal.c index 024018d5a4..f14dcbf912 100644 --- a/src/pkg/runtime/linux/arm/signal.c +++ b/src/pkg/runtime/linux/arm/signal.c @@ -2,3 +2,103 @@ // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. +#include "runtime.h" +#include "defs.h" +#include "signals.h" +#include "os.h" + +void dumpregs(void) {} +// void +// dumpregs(Sigcontext *r) +// { +// printf("eax %X\n", r->eax); +// printf("ebx %X\n", r->ebx); +// printf("ecx %X\n", r->ecx); +// printf("edx %X\n", r->edx); +// printf("edi %X\n", r->edi); +// printf("esi %X\n", r->esi); +// printf("ebp %X\n", r->ebp); +// printf("esp %X\n", r->esp); +// printf("eip %X\n", r->eip); +// printf("eflags %X\n", r->eflags); +// printf("cs %X\n", r->cs); +// printf("fs %X\n", r->fs); +// printf("gs %X\n", r->gs); +// } + + +/* + * This assembler routine takes the args from registers, puts them on the stack, + * and calls sighandler(). + */ +extern void sigtramp(void); +extern void sigignore(void); // just returns +extern void sigreturn(void); // calls sigreturn + +void sighandler(void) {} +// void +// sighandler(int32 sig, Siginfo* info, void* context) +// { +// Ucontext *uc; +// Sigcontext *sc; + +// if(panicking) // traceback already printed +// exit(2); +// panicking = 1; + +// uc = context; +// sc = &uc->uc_mcontext; + +// if(sig < 0 || sig >= NSIG) +// printf("Signal %d\n", sig); +// else +// printf("%s\n", sigtab[sig].name); + +// printf("Faulting address: %p\n", *(void**)info->_sifields); +// printf("pc=%X\n", sc->eip); +// printf("\n"); + +// if(gotraceback()){ +// traceback((void*)sc->eip, (void*)sc->esp, m->curg); +// tracebackothers(m->curg); +// dumpregs(sc); +// } + +// breakpoint(); +// exit(2); +// } + +void +signalstack(byte *p, int32 n) +{ +// Sigaltstack st; + +// st.ss_sp = p; +// st.ss_size = n; +// st.ss_flags = 0; +// sigaltstack(&st, nil); +} + +void +initsig(void) +{ +// static Sigaction sa; + +// int32 i; +// sa.sa_flags = SA_ONSTACK | SA_SIGINFO | SA_RESTORER; +// sa.sa_mask = 0xFFFFFFFFFFFFFFFFULL; +// sa.sa_restorer = (void*)sigreturn; +// for(i = 0; i<NSIG; i++) { +// if(sigtab[i].flags) { +// if(sigtab[i].flags & SigCatch) +// *(void**)sa._u = (void*)sigtramp; // handler +// else +// *(void**)sa._u = (void*)sigignore; // handler +// if(sigtab[i].flags & SigRestart) +// sa.sa_flags |= SA_RESTART; +// else +// sa.sa_flags &= ~SA_RESTART; +// rt_sigaction(i, &sa, nil, 8); +// } +// } +} diff --git a/src/pkg/runtime/linux/arm/sys.s b/src/pkg/runtime/linux/arm/sys.s index f5db32305b..25e64a3587 100644 --- a/src/pkg/runtime/linux/arm/sys.s +++ b/src/pkg/runtime/linux/arm/sys.s @@ -7,9 +7,31 @@ // TEXT write(SB),7,$0 - MOVW 4(SP), R0 MOVW 8(SP), R1 MOVW 12(SP), R2 SWI $0x00900004 // syscall write RET +TEXT exit(SB),7,$0 + SWI $0x00900001 // exit value in R0 + +TEXT sys·write(SB),7,$0 + MOVW 8(SP), R1 + MOVW 12(SP), R2 + SWI $0x00900004 // syscall write + RET + +TEXT sys·mmap(SB),7,$0 + BL abort(SB) + RET + +// int64 futex(int32 *uaddr, int32 op, int32 val, +// struct timespec *timeout, int32 *uaddr2, int32 val2); +TEXT futex(SB),7,$0 + BL abort(SB) + RET + +// int64 clone(int32 flags, void *stack, M *m, G *g, void (*fn)(void)); +TEXT clone(SB),7,$0 + BL abort(SB) + RET |
