8259430: C2: assert(in_vt->length() == out_vt->length()) failed: mismatch on number of elements
Reviewed-by: kvn, thartmann
This commit is contained in:
parent
1662373400
commit
3ede231dec
@ -1225,25 +1225,30 @@ Node* VectorUnboxNode::Ideal(PhaseGVN* phase, bool can_reshape) {
|
|||||||
ciKlass* vbox_klass = vbox->box_type()->klass();
|
ciKlass* vbox_klass = vbox->box_type()->klass();
|
||||||
const TypeVect* in_vt = vbox->vec_type();
|
const TypeVect* in_vt = vbox->vec_type();
|
||||||
const TypeVect* out_vt = type()->is_vect();
|
const TypeVect* out_vt = type()->is_vect();
|
||||||
assert(in_vt->length() == out_vt->length(), "mismatch on number of elements");
|
|
||||||
Node* value = vbox->in(VectorBoxNode::Value);
|
|
||||||
|
|
||||||
bool is_vector_mask = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorMask_klass());
|
if (in_vt->length() == out_vt->length()) {
|
||||||
bool is_vector_shuffle = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorShuffle_klass());
|
Node* value = vbox->in(VectorBoxNode::Value);
|
||||||
if (is_vector_mask) {
|
|
||||||
// VectorUnbox (VectorBox vmask) ==> VectorLoadMask (VectorStoreMask vmask)
|
bool is_vector_mask = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorMask_klass());
|
||||||
value = phase->transform(VectorStoreMaskNode::make(*phase, value, in_vt->element_basic_type(), in_vt->length()));
|
bool is_vector_shuffle = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorShuffle_klass());
|
||||||
return new VectorLoadMaskNode(value, out_vt);
|
if (is_vector_mask) {
|
||||||
} else if (is_vector_shuffle) {
|
// VectorUnbox (VectorBox vmask) ==> VectorLoadMask (VectorStoreMask vmask)
|
||||||
if (is_shuffle_to_vector()) {
|
value = phase->transform(VectorStoreMaskNode::make(*phase, value, in_vt->element_basic_type(), in_vt->length()));
|
||||||
// VectorUnbox (VectorBox vshuffle) ==> VectorCastB2X vshuffle
|
return new VectorLoadMaskNode(value, out_vt);
|
||||||
return new VectorCastB2XNode(value, out_vt);
|
} else if (is_vector_shuffle) {
|
||||||
|
if (is_shuffle_to_vector()) {
|
||||||
|
// VectorUnbox (VectorBox vshuffle) ==> VectorCastB2X vshuffle
|
||||||
|
return new VectorCastB2XNode(value, out_vt);
|
||||||
|
} else {
|
||||||
|
// VectorUnbox (VectorBox vshuffle) ==> VectorLoadShuffle vshuffle
|
||||||
|
return new VectorLoadShuffleNode(value, out_vt);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// VectorUnbox (VectorBox vshuffle) ==> VectorLoadShuffle vshuffle
|
// Vector type mismatch is only supported for masks and shuffles, but sometimes it happens in pathological cases.
|
||||||
return new VectorLoadShuffleNode(value, out_vt);
|
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
assert(false, "type mismatch on vector: %s", vbox_klass->name()->as_utf8());
|
// Vector length mismatch.
|
||||||
|
// Sometimes happen in pathological cases (e.g., when unboxing happens in effectively dead code).
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -29,4 +29,3 @@
|
|||||||
|
|
||||||
java/lang/invoke/MethodHandles/CatchExceptionTest.java 8146623 generic-all
|
java/lang/invoke/MethodHandles/CatchExceptionTest.java 8146623 generic-all
|
||||||
java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorTest.java 8256368 generic-all
|
java/util/stream/test/org/openjdk/tests/java/util/stream/SpliteratorTest.java 8256368 generic-all
|
||||||
jdk/incubator/vector/VectorHash.java 8259430 generic-all
|
|
||||||
|
Loading…
Reference in New Issue
Block a user