提交 7c47f93b 编写于 作者: R roland

8011771: runThese crashed with EAV

Summary: Array bound check elimination's in block motion doesn't always reset its data structures from one step to the other.
Reviewed-by: kvn, twisti
上级 e47ccc4b
...@@ -459,7 +459,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList ...@@ -459,7 +459,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList
// Iterate over all different indices // Iterate over all different indices
if (_optimistic) { if (_optimistic) {
for (int i=0; i<indices.length(); i++) { for (int i = 0; i < indices.length(); i++) {
Instruction *index_instruction = indices.at(i); Instruction *index_instruction = indices.at(i);
AccessIndexedInfo *info = _access_indexed_info[index_instruction->id()]; AccessIndexedInfo *info = _access_indexed_info[index_instruction->id()];
assert(info != NULL, "Info must not be null"); assert(info != NULL, "Info must not be null");
...@@ -531,9 +531,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList ...@@ -531,9 +531,7 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList
remove_range_check(ai); remove_range_check(ai);
} }
} }
_access_indexed_info[index_instruction->id()] = NULL;
} }
indices.clear();
if (list_constant.length() > 1) { if (list_constant.length() > 1) {
AccessIndexed *first = list_constant.at(0); AccessIndexed *first = list_constant.at(0);
...@@ -560,6 +558,13 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList ...@@ -560,6 +558,13 @@ void RangeCheckEliminator::in_block_motion(BlockBegin *block, AccessIndexedList
} }
} }
} }
// Clear data structures for next array
for (int i = 0; i < indices.length(); i++) {
Instruction *index_instruction = indices.at(i);
_access_indexed_info[index_instruction->id()] = NULL;
}
indices.clear();
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册