summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/regression/Makefile2
-rw-r--r--test/regression/Results/volatile214
-rw-r--r--test/regression/volatile2.c30
3 files changed, 45 insertions, 1 deletions
diff --git a/test/regression/Makefile b/test/regression/Makefile
index cc8684c..a86f7d9 100644
--- a/test/regression/Makefile
+++ b/test/regression/Makefile
@@ -7,7 +7,7 @@ CCOMPFLAGS=-stdlib ../../runtime -dparse -dclight -dasm \
LIBS=$(LIBMATH)
# Can run and have reference output in Results
-TESTS=bitfields1 expr1 initializers
+TESTS=bitfields1 expr1 initializers volatile2
# Other tests: should compile to .s without errors (but expect warnings)
EXTRAS=commaprec expr2 expr3 expr4 extern1 funct2 funptr1 init1 \
diff --git a/test/regression/Results/volatile2 b/test/regression/Results/volatile2
new file mode 100644
index 0000000..5f88874
--- /dev/null
+++ b/test/regression/Results/volatile2
@@ -0,0 +1,14 @@
+signed char 1: OK
+signed char 2: OK
+unsigned char 1: OK
+unsigned char 2: OK
+signed short 1: OK
+signed short 2: OK
+unsigned short 1: OK
+unsigned short 2: OK
+int 1: OK
+int 2: OK
+float 1: OK
+float 2: OK
+double 1: OK
+double 2: OK
diff --git a/test/regression/volatile2.c b/test/regression/volatile2.c
new file mode 100644
index 0000000..d83927b
--- /dev/null
+++ b/test/regression/volatile2.c
@@ -0,0 +1,30 @@
+/* Checking that __builtin_volatile_xxx functions are correctly compiled */
+
+#include <stdio.h>
+
+#define TEST(msg,ty,x,v1,v2) \
+ *((volatile ty *) &x) = v1; \
+ printf("%s 1: %s\n", msg, *((ty *) &x) == v1 ? "OK" : "FAILED"); \
+ *((ty *) &x) = v2; \
+ printf("%s 2: %s\n", msg, *((volatile ty *) &x) == v2 ? "OK" : "FAILED");
+
+int main(int argc, char ** argv)
+{
+ signed char sc;
+ unsigned char uc;
+ signed short ss;
+ unsigned short us;
+ int i;
+ float f;
+ double d;
+
+ TEST("signed char", signed char, sc, 12, 34);
+ TEST("unsigned char", unsigned char, uc, 56, 78);
+ TEST("signed short", signed short, ss, 1234, 5678);
+ TEST("unsigned short", unsigned short, us, 1357, 2468);
+ TEST("int", int, i, 0x123456, 0x7890AB);
+ TEST("float", float, f, 0.5, 256.0);
+ TEST("double", double, d, 3.1415, 2.718);
+ return 0;
+}
+