From: Jeff Law Date: Fri, 10 Jan 2014 22:13:18 +0000 (-0700) Subject: re PR middle-end/59743 (ICE: Segmentation fault) X-Git-Tag: releases/gcc-4.9.0~1705 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=7e41c852e38703c9a7f9ec1d4c513d781f1e46a6;p=thirdparty%2Fgcc.git re PR middle-end/59743 (ICE: Segmentation fault) PR middle-end/59743 * ree.c (combine_reaching_defs): Ensure the defining statement occurs before the extension when optimizing extensions with different source and destination hard registers. PR middle-end/59743 * gcc.c-torture/compile/pr59743.c: New test. From-SVN: r206545 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 54d62608a943..c554609e7b7d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2014-01-10 Jeff Law + + PR middle-end/59743 + * ree.c (combine_reaching_defs): Ensure the defining statement + occurs before the extension when optimizing extensions with + different source and destination hard registers. + 2014-01-10 Jan Hubicka PR ipa/58585 diff --git a/gcc/ree.c b/gcc/ree.c index 01ccd6996266..63cc8cc7c32e 100644 --- a/gcc/ree.c +++ b/gcc/ree.c @@ -723,8 +723,10 @@ combine_reaching_defs (ext_cand *cand, const_rtx set_pat, ext_state *state) /* The defining statement and candidate insn must be in the same block. This is merely to keep the test for safety and updating the insn - stream simple. */ - if (BLOCK_FOR_INSN (cand->insn) != BLOCK_FOR_INSN (def_insn)) + stream simple. Also ensure that within the block the candidate + follows the defining insn. */ + if (BLOCK_FOR_INSN (cand->insn) != BLOCK_FOR_INSN (def_insn) + || DF_INSN_LUID (def_insn) > DF_INSN_LUID (cand->insn)) return false; /* If there is an overlap between the destination of DEF_INSN and diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 4373d0ffcc29..f40d56ed2c77 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-01-10 Jeff Law + + PR middle-end/59743 + * gcc.c-torture/compile/pr59743.c: New test. + 2014-01-10 Jan Hubicka PR ipa/58585 diff --git a/gcc/testsuite/gcc.c-torture/compile/pr59743.c b/gcc/testsuite/gcc.c-torture/compile/pr59743.c new file mode 100644 index 000000000000..8dadba594e59 --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/compile/pr59743.c @@ -0,0 +1,23 @@ +/* PR middle-end/59743 */ + +typedef union { + long all; + struct { + int low; + int high; + } s; +} udwords; +int a, b, c, d; +void __udivmoddi4() { + udwords r; + d = __builtin_clz(0); + r.s.low = 0; + for (; d; --d) { + r.s.high = r.s.high << 1 | r.s.low >> a; + r.s.low = r.s.low << b >> 1; + int s = -r.all; + c = s; + r.all--; + } +} +