Test case for PR middle-end/13779.
authorFariborz Jahanian <fjahanian@gcc.gnu.org>
Mon, 26 Jan 2004 17:48:49 +0000 (17:48 +0000)
committerFariborz Jahanian <fjahanian@gcc.gnu.org>
Mon, 26 Jan 2004 17:48:49 +0000 (17:48 +0000)
From-SVN: r76652

gcc/testsuite/gcc.dg/darwin-longlong.c [new file with mode: 0644]

diff --git a/gcc/testsuite/gcc.dg/darwin-longlong.c b/gcc/testsuite/gcc.dg/darwin-longlong.c
new file mode 100644 (file)
index 0000000..ef925d6
--- /dev/null
@@ -0,0 +1,34 @@
+/* { dg-do run { target powerpc*-*-* } } */
+/* { dg-options "-mcpu=G5" } */
+
+#include <signal.h>
+
+void
+sig_ill_handler (int sig)
+{
+    exit(0);
+}
+
+
+int  msw(long long in)
+{
+  union {
+    long long ll;
+    int  i[2];
+  } ud;
+  ud.ll = in;
+  return ud.i[0];
+}
+
+int main()
+{
+
+  /* Exit on systems without 64bit instructions.  */
+  signal (SIGILL, sig_ill_handler);
+  asm volatile ("extsw r0,r0");
+  signal (SIGILL, SIG_DFL);
+
+  if (msw(1) != 0)
+    abort();
+  exit(0);
+}