diff options
Diffstat (limited to 'lib9')
| -rw-r--r-- | lib9/getcallerpc-FreeRTOS-riscv64.c | 12 | ||||
| -rw-r--r-- | lib9/setfcr-FreeRTOS-riscv64.c | 64 |
2 files changed, 76 insertions, 0 deletions
diff --git a/lib9/getcallerpc-FreeRTOS-riscv64.c b/lib9/getcallerpc-FreeRTOS-riscv64.c new file mode 100644 index 0000000..4a4e4fb --- /dev/null +++ b/lib9/getcallerpc-FreeRTOS-riscv64.c @@ -0,0 +1,12 @@ +#include <lib9.h> + +ulong +getcallerpc(void *x) +{ +ulong *lp; + + lp = x; + + return lp[-1]; +} + diff --git a/lib9/setfcr-FreeRTOS-riscv64.c b/lib9/setfcr-FreeRTOS-riscv64.c new file mode 100644 index 0000000..0ed32c6 --- /dev/null +++ b/lib9/setfcr-FreeRTOS-riscv64.c @@ -0,0 +1,64 @@ +/* + * Linux 386 fpu support + * Mimic Plan9 floating point support + */ + +#include "lib9.h" + +void +setfcr(ulong fcr) +{ +#if 0 + __asm__( "xorb $0x3f, %%al\n\t" + "pushw %%ax\n\t" + "fwait\n\t" + "fldcw (%%esp)\n\t" + "popw %%ax\n\t" + : /* no output */ + : "al" (fcr) + ); +#endif +} + +ulong +getfcr(void) +{ + ulong fcr = 0; + +#if 0 + __asm__( "pushl %%eax\n\t" + "fwait\n\t" + "fstcw (%%esp)\n\t" + "popl %%eax\n\t" + "xorb $0x3f, %%al\n\t" + : "=a" (fcr) + : "eax" (fcr) + ); +#endif + return fcr; +} + +ulong +getfsr(void) +{ + ulong fsr = -1; + +#if 0 + __asm__( "fwait\n\t" + "fstsw (%%eax)\n\t" + "movl (%%eax), %%eax\n\t" + "andl $0xffff, %%eax\n\t" + : "=a" (fsr) + : "eax" (&fsr) + ); +#endif + return fsr; +} + +void +setfsr(ulong fsr) +{ +#if 0 + __asm__("fclex\n\t"); +#endif +} |
