From: Andreas Krebbel Date: Wed, 24 Jun 2015 06:50:53 +0000 (+0000) Subject: PR66306: Fix match_dups on swapped operands. X-Git-Tag: basepoints/gcc-7~6148 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f303100baaf48a54f07e9abd25ac37ebc95b641e;p=thirdparty%2Fgcc.git PR66306: Fix match_dups on swapped operands. 2015-06-24 Andreas Krebbel PR rtl-optimization/66306 * reload.c (find_reloads): Swap the match_dup info for commutative operands. 2015-06-24 Andreas Krebbel PR rtl-optimization/66306 * gcc.target/s390/pr66306.c: New test. From-SVN: r224875 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index be625c5b06b3..d1f82b29f53d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2015-06-24 Andreas Krebbel + + PR rtl-optimization/66306 + * reload.c (find_reloads): Swap the match_dup info for + commutative operands. + 2015-06-24 Andreas Krebbel * config/s390/vx-builtins.md diff --git a/gcc/reload.c b/gcc/reload.c index 03354deb6059..1dc04bf0eb96 100644 --- a/gcc/reload.c +++ b/gcc/reload.c @@ -3872,6 +3872,12 @@ find_reloads (rtx_insn *insn, int replace, int ind_levels, int live_known, std::swap (*recog_data.operand_loc[commutative], *recog_data.operand_loc[commutative + 1]); + for (i = 0; i < recog_data.n_dups; i++) + if (recog_data.dup_num[i] == commutative + || recog_data.dup_num[i] == commutative + 1) + *recog_data.dup_loc[i] + = recog_data.operand[(int) recog_data.dup_num[i]]; + for (i = 0; i < n_reloads; i++) { if (rld[i].opnum == commutative) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d1431575ae8c..8e28edc2aea7 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2015-06-24 Andreas Krebbel + + PR rtl-optimization/66306 + * gcc.target/s390/pr66306.c: New test. + 2015-06-24 Andreas Krebbel * gcc.target/s390/vector/vec-abi-1.c: Add gnu attribute check. diff --git a/gcc/testsuite/gcc.target/s390/pr66306.c b/gcc/testsuite/gcc.target/s390/pr66306.c new file mode 100644 index 000000000000..73903cb3b430 --- /dev/null +++ b/gcc/testsuite/gcc.target/s390/pr66306.c @@ -0,0 +1,26 @@ +/* This caused an ICE on s390x due to a reload bug handling + commutative constraints. */ + +/* { dg-do compile } */ +/* { dg-options "-O1" } */ + +struct line_map +{ + unsigned start_location; + unsigned ordinary; +}; +unsigned +linemap_resolve_location (struct line_map **loc_map); + +unsigned +linemap_position_for_loc_and_offset (unsigned h, unsigned loc) +{ + struct line_map *map = 0; + linemap_resolve_location (&map); + + if (map->ordinary <= loc + map->start_location + map->ordinary) + __builtin_abort (); + + if (h >= loc + map->start_location) + __builtin_abort (); +}