aboutsummaryrefslogtreecommitdiff
path: root/gcc/ipa-inline-analysis.c
diff options
context:
space:
mode:
authorMartin Jambor <mjambor@suse.cz>2012-08-31 16:05:45 +0200
committerMartin Jambor <jamborm@gcc.gnu.org>2012-08-31 16:05:45 +0200
commit0336096575e3cf4dd0ac43d65097976631c609df (patch)
tree602afe45f5e892491199bff66bc6cf3c3be7a5f6 /gcc/ipa-inline-analysis.c
parent48679f6e244fdfb273d669ff02095ef0ffe3265f (diff)
downloadgcc-0336096575e3cf4dd0ac43d65097976631c609df.zip
gcc-0336096575e3cf4dd0ac43d65097976631c609df.tar.gz
gcc-0336096575e3cf4dd0ac43d65097976631c609df.tar.bz2
re PR middle-end/54409 (internal compiler error: in remap_predicate, at ipa-inline-analysis.c:2710)
2012-08-31 Martin Jambor <mjambor@suse.cz> PR middle-end/54409 * ipa-inline-analysis.c (remap_predicate): Fix the offset_map checking condition. * gcc/testsuite/gcc.dg/torture/pr54409.c: New test. From-SVN: r190833
Diffstat (limited to 'gcc/ipa-inline-analysis.c')
-rw-r--r--gcc/ipa-inline-analysis.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/gcc/ipa-inline-analysis.c b/gcc/ipa-inline-analysis.c
index 6da256a..5b31b6d 100644
--- a/gcc/ipa-inline-analysis.c
+++ b/gcc/ipa-inline-analysis.c
@@ -2811,8 +2811,11 @@ remap_predicate (struct inline_summary *info,
if (!operand_map
|| (int)VEC_length (int, operand_map) <= c->operand_num
|| VEC_index (int, operand_map, c->operand_num) == -1
- || (!c->agg_contents
- && VEC_index (int, offset_map, c->operand_num) != 0)
+ /* TODO: For non-aggregate conditions, adding an offset is
+ basically an arithmetic jump function processing which
+ we should support in future. */
+ || ((!c->agg_contents || !c->by_ref)
+ && VEC_index (int, offset_map, c->operand_num) > 0)
|| (c->agg_contents && c->by_ref
&& VEC_index (int, offset_map, c->operand_num) < 0))
cond_predicate = true_predicate ();