6982533: Crash in ~StubRoutines::jbyte_fill with AggressiveOpts enabled
Reviewed-by: kvn
This commit is contained in:
parent
34b016cb42
commit
cf8bea660b
@ -2417,6 +2417,8 @@ bool PhaseIdealLoop::match_fill_loop(IdealLoopTree* lpt, Node*& store, Node*& st
|
|||||||
Node* value = n->in(MemNode::ValueIn);
|
Node* value = n->in(MemNode::ValueIn);
|
||||||
if (!lpt->is_invariant(value)) {
|
if (!lpt->is_invariant(value)) {
|
||||||
msg = "variant store value";
|
msg = "variant store value";
|
||||||
|
} else if (!_igvn.type(n->in(MemNode::Address))->isa_aryptr()) {
|
||||||
|
msg = "not array address";
|
||||||
}
|
}
|
||||||
store = n;
|
store = n;
|
||||||
store_value = value;
|
store_value = value;
|
||||||
@ -2468,6 +2470,7 @@ bool PhaseIdealLoop::match_fill_loop(IdealLoopTree* lpt, Node*& store, Node*& st
|
|||||||
// head->phi * elsize + con. head->phi might have a ConvI2L.
|
// head->phi * elsize + con. head->phi might have a ConvI2L.
|
||||||
Node* elements[4];
|
Node* elements[4];
|
||||||
Node* conv = NULL;
|
Node* conv = NULL;
|
||||||
|
bool found_index = false;
|
||||||
int count = store->in(MemNode::Address)->as_AddP()->unpack_offsets(elements, ARRAY_SIZE(elements));
|
int count = store->in(MemNode::Address)->as_AddP()->unpack_offsets(elements, ARRAY_SIZE(elements));
|
||||||
for (int e = 0; e < count; e++) {
|
for (int e = 0; e < count; e++) {
|
||||||
Node* n = elements[e];
|
Node* n = elements[e];
|
||||||
@ -2484,17 +2487,20 @@ bool PhaseIdealLoop::match_fill_loop(IdealLoopTree* lpt, Node*& store, Node*& st
|
|||||||
if (value != head->phi()) {
|
if (value != head->phi()) {
|
||||||
msg = "unhandled shift in address";
|
msg = "unhandled shift in address";
|
||||||
} else {
|
} else {
|
||||||
|
found_index = true;
|
||||||
shift = n;
|
shift = n;
|
||||||
assert(type2aelembytes(store->as_Mem()->memory_type(), true) == 1 << shift->in(2)->get_int(), "scale should match");
|
assert(type2aelembytes(store->as_Mem()->memory_type(), true) == 1 << shift->in(2)->get_int(), "scale should match");
|
||||||
}
|
}
|
||||||
} else if (n->Opcode() == Op_ConvI2L && conv == NULL) {
|
} else if (n->Opcode() == Op_ConvI2L && conv == NULL) {
|
||||||
if (n->in(1) == head->phi()) {
|
if (n->in(1) == head->phi()) {
|
||||||
|
found_index = true;
|
||||||
conv = n;
|
conv = n;
|
||||||
} else {
|
} else {
|
||||||
msg = "unhandled input to ConvI2L";
|
msg = "unhandled input to ConvI2L";
|
||||||
}
|
}
|
||||||
} else if (n == head->phi()) {
|
} else if (n == head->phi()) {
|
||||||
// no shift, check below for allowed cases
|
// no shift, check below for allowed cases
|
||||||
|
found_index = true;
|
||||||
} else {
|
} else {
|
||||||
msg = "unhandled node in address";
|
msg = "unhandled node in address";
|
||||||
msg_node = n;
|
msg_node = n;
|
||||||
@ -2506,6 +2512,10 @@ bool PhaseIdealLoop::match_fill_loop(IdealLoopTree* lpt, Node*& store, Node*& st
|
|||||||
msg_node = store;
|
msg_node = store;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!found_index) {
|
||||||
|
msg = "missing use of index";
|
||||||
|
}
|
||||||
|
|
||||||
// byte sized items won't have a shift
|
// byte sized items won't have a shift
|
||||||
if (msg == NULL && shift == NULL && t != T_BYTE && t != T_BOOLEAN) {
|
if (msg == NULL && shift == NULL && t != T_BYTE && t != T_BOOLEAN) {
|
||||||
msg = "can't find shift";
|
msg = "can't find shift";
|
||||||
|
Loading…
x
Reference in New Issue
Block a user