aboutsummaryrefslogtreecommitdiff
path: root/SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c
diff options
context:
space:
mode:
Diffstat (limited to 'SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c')
-rw-r--r--SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c b/SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c
new file mode 100644
index 00000000..be087850
--- /dev/null
+++ b/SingleSource/Regression/C/gcc-c-torture/execute/20030222-1.c
@@ -0,0 +1,28 @@
+/* Verify that we get the low part of the long long as an int. We
+ used to get it wrong on big-endian machines, if register allocation
+ succeeded at all. We use volatile to make sure the long long is
+ actually truncated to int, in case a single register is wide enough
+ for a long long. */
+/* { dg-skip-if "asm would require extra shift-left-4-byte" { spu-*-* } } */
+/* { dg-skip-if "asm requires register allocation" { nvptx-*-* } } */
+#include <limits.h>
+
+void
+ll_to_int (long long x, volatile int *p)
+{
+ int i;
+ asm ("" : "=r" (i) : "0" (x));
+ *p = i;
+}
+
+int val = INT_MIN + 1;
+
+int main() {
+ volatile int i;
+
+ ll_to_int ((long long)val, &i);
+ if (i != val)
+ abort ();
+
+ exit (0);
+}