aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2010-01-05 13:42:40 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2010-01-05 13:42:40 +0000
commit82aee9233b2e880723cf6aba5db1fe42000a9ef5 (patch)
treede35d790f8d69233802bd7770c31626901df9ae4 /gcc
parentbc3c12a29c67753c473b465767b2ba6b2f7e72a6 (diff)
downloadgcc-82aee9233b2e880723cf6aba5db1fe42000a9ef5.zip
gcc-82aee9233b2e880723cf6aba5db1fe42000a9ef5.tar.gz
gcc-82aee9233b2e880723cf6aba5db1fe42000a9ef5.tar.bz2
re PR tree-optimization/42614 (FRE optimizes away valid code after IPA inlining)
2010-01-05 Richard Guenther <rguenther@suse.de> PR tree-optimization/42614 * gcc.c-torture/execute/pr42614.c: New testcase. From-SVN: r155647
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/pr42614.c68
2 files changed, 73 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 42eb680..813e005 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2010-01-05 Richard Guenther <rguenther@suse.de>
+
+ PR tree-optimization/42614
+ * gcc.c-torture/execute/pr42614.c: New testcase.
+
2010-01-05 Eric Fisher <joefoxreal@gmail.com>
* gcc.dg/pr12603.c: Remove -Wunreachable-code from dg-options.
diff --git a/gcc/testsuite/gcc.c-torture/execute/pr42614.c b/gcc/testsuite/gcc.c-torture/execute/pr42614.c
new file mode 100644
index 0000000..d368053
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/execute/pr42614.c
@@ -0,0 +1,68 @@
+extern void *malloc(__SIZE_TYPE__);
+extern void abort(void);
+extern void free(void *);
+
+typedef struct SEntry
+{
+ unsigned char num;
+} TEntry;
+
+typedef struct STable
+{
+ TEntry data[2];
+} TTable;
+
+TTable *init ()
+{
+ return malloc(sizeof(TTable));
+}
+
+void
+expect_func (int a, unsigned char *b) __attribute__ ((noinline));
+
+static inline void
+inlined_wrong (TEntry *entry_p, int flag);
+
+void
+inlined_wrong (TEntry *entry_p, int flag)
+{
+ unsigned char index;
+ entry_p->num = 0;
+
+ if (flag == 0)
+ abort();
+
+ for (index = 0; index < 1; index++)
+ entry_p->num++;
+
+ if (!entry_p->num)
+ {
+ abort();
+ }
+}
+
+void
+expect_func (int a, unsigned char *b)
+{
+ if (abs ((a == 0)))
+ abort ();
+ if (abs ((b == 0)))
+ abort ();
+}
+
+int
+main ()
+{
+ unsigned char index = 0;
+ TTable *table_p = init();
+ TEntry work;
+
+ inlined_wrong (&(table_p->data[1]), 1);
+ expect_func (1, &index);
+ inlined_wrong (&work, 1);
+
+ free (table_p);
+
+ return 0;
+}
+