aboutsummaryrefslogtreecommitdiffstats
path: root/test/regression
diff options
context:
space:
mode:
Diffstat (limited to 'test/regression')
-rw-r--r--test/regression/Makefile6
-rw-r--r--test/regression/Results/builtins-riscV12
-rwxr-xr-xtest/regression/Runtest2
-rw-r--r--test/regression/alignas.c7
-rw-r--r--test/regression/builtins-riscV.c30
-rw-r--r--test/regression/extasm.c2
-rw-r--r--test/regression/floats-basics.c3
-rw-r--r--test/regression/floats.c3
8 files changed, 58 insertions, 7 deletions
diff --git a/test/regression/Makefile b/test/regression/Makefile
index 5def966b..54745863 100644
--- a/test/regression/Makefile
+++ b/test/regression/Makefile
@@ -71,15 +71,15 @@ clean:
test:
@echo "----------- Compiled tests -------------"
@for i in $(TESTS) $(TESTS_COMP); do \
- ./Runtest $$i ./$$i.compcert; \
+ SIMU='$(SIMU)' ./Runtest $$i ./$$i.compcert; \
done
@echo "----------- Interpreted tests -------------"
@for i in $(TESTS); do \
- ./Runtest $$i $(CCOMP) -fall -interp -quiet $$i.c; \
+ SIMU='' ./Runtest $$i $(CCOMP) -fall -interp -quiet $$i.c; \
done
@for i in $(TESTS_DIFF); do \
if $(CCOMP) -fall -interp -quiet $$i.c > _cinterp.log; then \
- if ./$$i.compcert | cmp -s _cinterp.log -; \
+ if $(SIMU) ./$$i.compcert | cmp -s _cinterp.log -; \
then echo "$$i: compiler and interpreter agree"; \
else echo "$$i: compiler and interpreter DISAGREE"; \
fi; \
diff --git a/test/regression/Results/builtins-riscV b/test/regression/Results/builtins-riscV
new file mode 100644
index 00000000..1576b252
--- /dev/null
+++ b/test/regression/Results/builtins-riscV
@@ -0,0 +1,12 @@
+bswap16(1234) = 3412
+bswap32(12345678) = 78563412
+bswap64(123456789abcdef0) = f0debc9a78563412
+fmadd(3.141590, 2.718000, 1.414000) = 9.952842
+fmsub(3.141590, 2.718000, 1.414000) = 7.124842
+fnmadd(3.141590, 2.718000, 1.414000) = -9.952842
+fnmsub(3.141590, 2.718000, 1.414000) = -7.124842
+fabs(3.141590) = 3.141590
+fabs(-3.141590) = 3.141590
+fsqrt(3.141590) = 1.772453
+fmax(3.141590, 2.718000) = 3.141590
+fmin(3.141590, 2.718000) = 2.718000
diff --git a/test/regression/Runtest b/test/regression/Runtest
index 9051b5b7..ad2a58f1 100755
--- a/test/regression/Runtest
+++ b/test/regression/Runtest
@@ -27,7 +27,7 @@ else
fi
# Administer the test
-if $* > $out
+if $SIMU $* > $out
then
if test -n "$ref"; then
if cmp -s "$out" "$ref"; then
diff --git a/test/regression/alignas.c b/test/regression/alignas.c
index a6a2e690..b3754039 100644
--- a/test/regression/alignas.c
+++ b/test/regression/alignas.c
@@ -7,6 +7,13 @@
#define _Alignof(x) __alignof__(x)
#endif
+#ifdef _Alignas
+#undef _Alignas
+#endif
+#ifdef _Alignof
+#undef _Alignof
+#endif
+
/* Base type */
int _Alignas(16) a;
char filler1;
diff --git a/test/regression/builtins-riscV.c b/test/regression/builtins-riscV.c
new file mode 100644
index 00000000..a302a6c4
--- /dev/null
+++ b/test/regression/builtins-riscV.c
@@ -0,0 +1,30 @@
+/* Fun with builtins */
+
+#include <stdio.h>
+
+int main(int argc, char ** argv)
+{
+ unsigned int x = 0x12345678;
+ unsigned short s = 0x1234;
+ unsigned long long zz = 0x123456789ABCDEF0ULL;
+ double a = 3.14159;
+ double b = 2.718;
+ double c = 1.414;
+
+ printf("bswap16(%x) = %x\n", s, __builtin_bswap16(s));
+ printf("bswap32(%x) = %x\n", x, __builtin_bswap32(x));
+ printf("bswap64(%llx) = %llx\n", zz, __builtin_bswap64(zz));
+ printf("fmadd(%f, %f, %f) = %f\n", a, b, c, __builtin_fmadd(a, b, c));
+ printf("fmsub(%f, %f, %f) = %f\n", a, b, c, __builtin_fmsub(a, b, c));
+ printf("fnmadd(%f, %f, %f) = %f\n", a, b, c, __builtin_fnmadd(a, b, c));
+ printf("fnmsub(%f, %f, %f) = %f\n", a, b, c, __builtin_fnmsub(a, b, c));
+ printf("fabs(%f) = %f\n", a, __builtin_fabs(a));
+ printf("fabs(%f) = %f\n", -a, __builtin_fabs(-a));
+ printf("fsqrt(%f) = %f\n", a, __builtin_fsqrt(a));
+ printf("fmax(%f, %f) = %f\n", a, b, __builtin_fmax(a, b));
+ printf("fmin(%f, %f) = %f\n", a, b, __builtin_fmin(a, b));
+ /* Make sure that ignoring the result of a builtin
+ doesn't cause an internal error */
+ (void) __builtin_fsqrt(a);
+ return 0;
+}
diff --git a/test/regression/extasm.c b/test/regression/extasm.c
index c0534047..a41c4202 100644
--- a/test/regression/extasm.c
+++ b/test/regression/extasm.c
@@ -18,7 +18,7 @@ int clobbers(int x, int z)
return y + z;
}
-#if defined(__x86_64__)
+#if defined(__x86_64__) || __riscv_xlen == 64
#define SIXTYFOUR
#else
#undef SIXTYFOUR
diff --git a/test/regression/floats-basics.c b/test/regression/floats-basics.c
index 5aa91d14..a7ba3623 100644
--- a/test/regression/floats-basics.c
+++ b/test/regression/floats-basics.c
@@ -6,7 +6,8 @@
#if defined(__ppc__) || defined(__PPC__) || defined(__ARMEB__)
#define ARCH_BIG_ENDIAN
-#elif defined(__i386__) || defined(__x86_64__) || defined(__ARMEL__)
+#elif defined(__i386__) || defined(__x86_64__) || defined(__ARMEL__) \
+ || defined(__riscv)
#undef ARCH_BIG_ENDIAN
#else
#error "unknown endianness"
diff --git a/test/regression/floats.c b/test/regression/floats.c
index 68d60f65..84c4e062 100644
--- a/test/regression/floats.c
+++ b/test/regression/floats.c
@@ -5,7 +5,8 @@
#if defined(__ppc__) || defined(__PPC__) || defined(__ARMEB__)
#define ARCH_BIG_ENDIAN
-#elif defined(__i386__) || defined(__x86_64__) || defined(__ARMEL__)
+#elif defined(__i386__) || defined(__x86_64__) || defined(__ARMEL__) \
+ || defined(__riscv)
#undef ARCH_BIG_ENDIAN
#else
#error "unknown endianness"