From 82bcbebce43f0227f506d75a5b764b6847041bae Mon Sep 17 00:00:00 2001 From: Ben Cheng Date: Mon, 1 Oct 2012 10:30:31 -0700 Subject: Initial check-in of gcc 4.7.2. Change-Id: I4a2f5a921c21741a0e18bda986d77e5f1bef0365 --- gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c | 31 ++++++++++++++++++++++ 1 file changed, 31 insertions(+) create mode 100644 gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c (limited to 'gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c') diff --git a/gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c b/gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c new file mode 100644 index 000000000..35941405d --- /dev/null +++ b/gcc-4.7/gcc/testsuite/gcc.target/i386/movsi-sm-1.c @@ -0,0 +1,31 @@ +/* { dg-do run } */ +/* { dg-options "-O2 -fgcse-sm -minline-all-stringops" } */ + +/* Store motion used to fail to recognize killed expressions within + parallels such as those generated for memory copying. */ + +static const char s[1024] __attribute__ ((__aligned__ (32))) + = "This is what we should get!"; + +int bug (int arg) { + char str[sizeof(s) > 4 ? sizeof(s) : 4] __attribute__ ((__aligned__ (32))); + + __builtin_memcpy (str, "Bug", 4); + + if (arg <= 2) + __builtin_memcpy (str, s, sizeof (s)); + + if (arg <= 1) + __builtin_memcpy (str, "Err", 4); + + __builtin_puts (str); + + return str[0] != s[0]; +} + +int main () { + if (bug (2)) + __builtin_abort (); + + return 0; +} -- cgit v1.2.3