From 3ede231dec1c5aca94a39f995b47421301b1db0a Mon Sep 17 00:00:00 2001 From: Vladimir Ivanov Date: Thu, 11 Feb 2021 10:16:09 +0000 Subject: [PATCH] 8259430: C2: assert(in_vt->length() == out_vt->length()) failed: mismatch on number of elements Reviewed-by: kvn, thartmann --- src/hotspot/share/opto/vectornode.cpp | 35 +++++++++++++++------------ test/jdk/ProblemList-Xcomp.txt | 1 - 2 files changed, 20 insertions(+), 16 deletions(-) diff --git a/src/hotspot/share/opto/vectornode.cpp b/src/hotspot/share/opto/vectornode.cpp index 0979adce7a0..3870d1089f4 100644 --- a/src/hotspot/share/opto/vectornode.cpp +++ b/src/hotspot/share/opto/vectornode.cpp @@ -1225,25 +1225,30 @@ Node* VectorUnboxNode::Ideal(PhaseGVN* phase, bool can_reshape) { ciKlass* vbox_klass = vbox->box_type()->klass(); const TypeVect* in_vt = vbox->vec_type(); 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()); - bool is_vector_shuffle = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorShuffle_klass()); - if (is_vector_mask) { - // VectorUnbox (VectorBox vmask) ==> VectorLoadMask (VectorStoreMask vmask) - value = phase->transform(VectorStoreMaskNode::make(*phase, value, in_vt->element_basic_type(), in_vt->length())); - return new VectorLoadMaskNode(value, out_vt); - } else if (is_vector_shuffle) { - if (is_shuffle_to_vector()) { - // VectorUnbox (VectorBox vshuffle) ==> VectorCastB2X vshuffle - return new VectorCastB2XNode(value, out_vt); + if (in_vt->length() == out_vt->length()) { + Node* value = vbox->in(VectorBoxNode::Value); + + bool is_vector_mask = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorMask_klass()); + bool is_vector_shuffle = vbox_klass->is_subclass_of(ciEnv::current()->vector_VectorShuffle_klass()); + if (is_vector_mask) { + // VectorUnbox (VectorBox vmask) ==> VectorLoadMask (VectorStoreMask vmask) + value = phase->transform(VectorStoreMaskNode::make(*phase, value, in_vt->element_basic_type(), in_vt->length())); + return new VectorLoadMaskNode(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 { - // VectorUnbox (VectorBox vshuffle) ==> VectorLoadShuffle vshuffle - return new VectorLoadShuffleNode(value, out_vt); + // Vector type mismatch is only supported for masks and shuffles, but sometimes it happens in pathological cases. } } 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). } } } diff --git a/test/jdk/ProblemList-Xcomp.txt b/test/jdk/ProblemList-Xcomp.txt index 6f1f7f36b74..77b61348af5 100644 --- a/test/jdk/ProblemList-Xcomp.txt +++ b/test/jdk/ProblemList-Xcomp.txt @@ -29,4 +29,3 @@ java/lang/invoke/MethodHandles/CatchExceptionTest.java 8146623 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