OSDN Git Service

powerpc: add single instruction fabs, fabsf, fma, fmaf, sqrt, sqrtf
authorSzabolcs Nagy <nsz@port70.net>
Thu, 20 Sep 2018 23:14:11 +0000 (23:14 +0000)
committerRich Felker <dalias@aerifal.cx>
Mon, 15 Oct 2018 18:41:59 +0000 (14:41 -0400)
These are only available on hard float target and sqrt is not available
in the base ISA, so further check is used.

src/math/powerpc/fabs.c [new file with mode: 0644]
src/math/powerpc/fabsf.c [new file with mode: 0644]
src/math/powerpc/fma.c [new file with mode: 0644]
src/math/powerpc/fmaf.c [new file with mode: 0644]
src/math/powerpc/sqrt.c [new file with mode: 0644]
src/math/powerpc/sqrtf.c [new file with mode: 0644]

diff --git a/src/math/powerpc/fabs.c b/src/math/powerpc/fabs.c
new file mode 100644 (file)
index 0000000..f6ec443
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#ifdef _SOFT_FLOAT
+
+#include "../fabs.c"
+
+#else
+
+double fabs(double x)
+{
+       __asm__ ("fabs %0, %1" : "=d"(x) : "d"(x));
+       return x;
+}
+
+#endif
diff --git a/src/math/powerpc/fabsf.c b/src/math/powerpc/fabsf.c
new file mode 100644 (file)
index 0000000..d88b591
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#ifdef _SOFT_FLOAT
+
+#include "../fabsf.c"
+
+#else
+
+float fabsf(float x)
+{
+       __asm__ ("fabs %0, %1" : "=f"(x) : "f"(x));
+       return x;
+}
+
+#endif
diff --git a/src/math/powerpc/fma.c b/src/math/powerpc/fma.c
new file mode 100644 (file)
index 0000000..fd268f5
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#ifdef _SOFT_FLOAT
+
+#include "../fma.c"
+
+#else
+
+double fma(double x, double y, double z)
+{
+       __asm__("fmadd %0, %1, %2, %3" : "=d"(x) : "d"(x), "d"(y), "d"(z));
+       return x;
+}
+
+#endif
diff --git a/src/math/powerpc/fmaf.c b/src/math/powerpc/fmaf.c
new file mode 100644 (file)
index 0000000..a99a2a3
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#ifdef _SOFT_FLOAT
+
+#include "../fmaf.c"
+
+#else
+
+float fmaf(float x, float y, float z)
+{
+       __asm__("fmadds %0, %1, %2, %3" : "=f"(x) : "f"(x), "f"(y), "f"(z));
+       return x;
+}
+
+#endif
diff --git a/src/math/powerpc/sqrt.c b/src/math/powerpc/sqrt.c
new file mode 100644 (file)
index 0000000..8718dbd
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#if !defined _SOFT_FLOAT && defined _ARCH_PPCSQ
+
+double sqrt(double x)
+{
+       __asm__ ("fsqrt %0, %1\n" : "=d" (x) : "d" (x));
+       return x;
+}
+
+#else
+
+#include "../sqrt.c"
+
+#endif
diff --git a/src/math/powerpc/sqrtf.c b/src/math/powerpc/sqrtf.c
new file mode 100644 (file)
index 0000000..3431b67
--- /dev/null
@@ -0,0 +1,15 @@
+#include <math.h>
+
+#if !defined _SOFT_FLOAT && defined _ARCH_PPCSQ
+
+float sqrtf(float x)
+{
+       __asm__ ("fsqrts %0, %1\n" : "=f" (x) : "f" (x));
+       return x;
+}
+
+#else
+
+#include "../sqrtf.c"
+
+#endif