diff options
| author | forsyth <forsyth@vitanuova.com> | 2011-02-25 10:59:02 +0000 |
|---|---|---|
| committer | forsyth <forsyth@vitanuova.com> | 2011-02-25 10:59:02 +0000 |
| commit | 90ccc69f5be0b7e26c3607dac07340fe3e271509 (patch) | |
| tree | 97f0ca5a225bf4efc8ee8a9e7403d34a41e17412 /Linux/arm/include/emu.h | |
| parent | 54d06533f3d8d73d9369206f7f5be71351cfbcf3 (diff) | |
20110225-1058
Diffstat (limited to 'Linux/arm/include/emu.h')
| -rw-r--r-- | Linux/arm/include/emu.h | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/Linux/arm/include/emu.h b/Linux/arm/include/emu.h new file mode 100644 index 00000000..da7b786f --- /dev/null +++ b/Linux/arm/include/emu.h @@ -0,0 +1,33 @@ +/* + * system- and machine-specific declarations for emu: + * floating-point save and restore, signal handling primitive, and + * implementation of the current-process variable `up'. + */ + +/* + * This structure must agree with FPsave and FPrestore asm routines + */ +typedef struct FPU FPU; +struct FPU +{ + uchar env[28]; +}; + +#define KSTACK (16 * 1024) + +#ifndef USE_PTHREADS +static __inline Proc *getup(void) { + Proc *p; + __asm__( "mov %0, %%sp;" + : "=r" (p) + ); + return *(Proc **)((uintptr)p & ~(KSTACK - 1)); +}; +#else +extern Proc* getup(void); +#endif + +#define up (getup()) + +typedef sigjmp_buf osjmpbuf; +#define ossetjmp(buf) sigsetjmp(buf, 1) |
