summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/sparc/sparcv9/sdiv.S
diff options
context:
space:
mode:
Diffstat (limited to 'libc/sysdeps/linux/sparc/sparcv9/sdiv.S')
-rw-r--r--libc/sysdeps/linux/sparc/sparcv9/sdiv.S18
1 files changed, 18 insertions, 0 deletions
diff --git a/libc/sysdeps/linux/sparc/sparcv9/sdiv.S b/libc/sysdeps/linux/sparc/sparcv9/sdiv.S
new file mode 100644
index 000000000..45535bb68
--- /dev/null
+++ b/libc/sysdeps/linux/sparc/sparcv9/sdiv.S
@@ -0,0 +1,18 @@
+/*
+ * Sparc v9 has divide.
+ * As divx takes 68 cycles and sdivcc only 36,
+ * we use sdivcc eventhough it is deprecated.
+ */
+
+ .text
+ .align 32
+ENTRY(.div)
+
+ sra %o0, 31, %o2
+ wr %o2, 0, %y
+ sdivcc %o0, %o1, %o0
+ xnor %o0, %g0, %o2
+ retl
+ movvs %icc, %o2, %o0
+
+END(.div)