From c69ac54b7c9fc39e870c508f2c4a9b5c6452c7b5 Mon Sep 17 00:00:00 2001 From: aoliva <aoliva@138bc75d-0d04-0410-961f-82ee72b054a4> Date: Tue, 4 Mar 2003 05:55:20 +0000 Subject: [PATCH] * gcc.c-torture/execute/20030222-1.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@63767 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/testsuite/ChangeLog | 4 +++ .../gcc.c-torture/execute/20030222-1.c | 27 +++++++++++++++++++ 2 files changed, 31 insertions(+) create mode 100644 gcc/testsuite/gcc.c-torture/execute/20030222-1.c diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 22470c3b0967..5f34024a2fde 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2003-03-04 Alexandre Oliva <aoliva@redhat.com> + + * gcc.c-torture/execute/20030222-1.c: New test. + 2003-03-03 James E Wilson <wilson@tuliptree.org> * gcc.dg/m68k-slp-ice.c: New test for PR c/7872. diff --git a/gcc/testsuite/gcc.c-torture/execute/20030222-1.c b/gcc/testsuite/gcc.c-torture/execute/20030222-1.c new file mode 100644 index 000000000000..93d1e3c4e800 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/20030222-1.c @@ -0,0 +1,27 @@ +/* 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. */ + +#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); +} -- GitLab