summaryrefslogtreecommitdiff
path: root/emu/Irix/asm-mips.s
diff options
context:
space:
mode:
Diffstat (limited to 'emu/Irix/asm-mips.s')
-rw-r--r--emu/Irix/asm-mips.s31
1 files changed, 31 insertions, 0 deletions
diff --git a/emu/Irix/asm-mips.s b/emu/Irix/asm-mips.s
new file mode 100644
index 00000000..394baa36
--- /dev/null
+++ b/emu/Irix/asm-mips.s
@@ -0,0 +1,31 @@
+#include <sys/regdef.h>
+#include <sys/asm.h>
+
+LEAF(FPsave)
+ cfc1 t0, $31
+ sw t0, 0(a0) /* a0 is argument */
+ j $31
+ END(FPsave)
+
+LEAF(FPrestore)
+ lw t0, 0(a0) /* a0 is argument */
+ ctc1 t0, $31
+ j $31
+ END(FPrestore)
+
+
+/*
+ * lock from r4000 book
+ */
+LEAF(_tas)
+ .set noreorder
+1:
+ ll v0,0(a0) /* a0 is argument */
+ or t1, v0, 1
+ sc t1,0(a0)
+ beq t1,zero,1b
+ nop
+ j $31 /* lock held */
+ nop
+ .set reorder
+ END(_tas)