From d7b5cb688956ce79443ef3cd080c36028fcfb19d Mon Sep 17 00:00:00 2001 From: Vladimir Kozlov Date: Wed, 28 Jul 2021 06:58:36 +0000 Subject: [PATCH] 8271368: [BACKOUT] JDK-8266054 VectorAPI rotate operation optimization Reviewed-by: dholmes, iklam --- src/hotspot/cpu/aarch64/matcher_aarch64.hpp | 5 - src/hotspot/cpu/arm/matcher_arm.hpp | 5 - src/hotspot/cpu/ppc/matcher_ppc.hpp | 5 - src/hotspot/cpu/s390/matcher_s390.hpp | 5 - src/hotspot/cpu/x86/matcher_x86.hpp | 5 - src/hotspot/cpu/x86/x86.ad | 3 - src/hotspot/share/opto/library_call.hpp | 1 - src/hotspot/share/opto/superword.cpp | 3 +- src/hotspot/share/opto/vectorIntrinsics.cpp | 97 +------- src/hotspot/share/opto/vectornode.cpp | 90 ++------ src/hotspot/share/opto/vectornode.hpp | 2 - src/hotspot/share/prims/vectorSupport.cpp | 20 -- src/hotspot/share/prims/vectorSupport.hpp | 4 - .../jdk/internal/vm/vector/VectorSupport.java | 4 - .../jdk/incubator/vector/ByteVector.java | 32 +-- .../jdk/incubator/vector/DoubleVector.java | 1 - .../jdk/incubator/vector/FloatVector.java | 1 - .../jdk/incubator/vector/IntVector.java | 32 +-- .../jdk/incubator/vector/LongVector.java | 32 +-- .../jdk/incubator/vector/ShortVector.java | 32 +-- .../jdk/incubator/vector/VectorOperators.java | 4 +- .../incubator/vector/X-Vector.java.template | 42 +--- .../incubator/vector/Byte128VectorTests.java | 192 +--------------- .../incubator/vector/Byte256VectorTests.java | 192 +--------------- .../incubator/vector/Byte512VectorTests.java | 192 +--------------- .../incubator/vector/Byte64VectorTests.java | 192 +--------------- .../incubator/vector/ByteMaxVectorTests.java | 192 +--------------- .../vector/Double128VectorTests.java | 8 - .../vector/Double256VectorTests.java | 8 - .../vector/Double512VectorTests.java | 8 - .../incubator/vector/Double64VectorTests.java | 8 - .../vector/DoubleMaxVectorTests.java | 8 - .../incubator/vector/Float128VectorTests.java | 8 - .../incubator/vector/Float256VectorTests.java | 8 - .../incubator/vector/Float512VectorTests.java | 8 - .../incubator/vector/Float64VectorTests.java | 8 - .../incubator/vector/FloatMaxVectorTests.java | 8 - .../incubator/vector/Int128VectorTests.java | 192 +--------------- .../incubator/vector/Int256VectorTests.java | 192 +--------------- .../incubator/vector/Int512VectorTests.java | 192 +--------------- .../incubator/vector/Int64VectorTests.java | 192 +--------------- .../incubator/vector/IntMaxVectorTests.java | 192 +--------------- .../incubator/vector/Long128VectorTests.java | 192 +--------------- .../incubator/vector/Long256VectorTests.java | 192 +--------------- .../incubator/vector/Long512VectorTests.java | 192 +--------------- .../incubator/vector/Long64VectorTests.java | 192 +--------------- .../incubator/vector/LongMaxVectorTests.java | 192 +--------------- .../incubator/vector/Short128VectorTests.java | 192 +--------------- .../incubator/vector/Short256VectorTests.java | 192 +--------------- .../incubator/vector/Short512VectorTests.java | 192 +--------------- .../incubator/vector/Short64VectorTests.java | 192 +--------------- .../incubator/vector/ShortMaxVectorTests.java | 192 +--------------- test/jdk/jdk/incubator/vector/gen-template.sh | 12 +- .../templates/Unit-Shift-Masked-op.template | 2 +- .../vector/templates/Unit-Shift-op.template | 2 +- .../vector/templates/Unit-header.template | 24 -- .../jdk/incubator/vector/RotateBenchmark.java | 214 ------------------ 57 files changed, 219 insertions(+), 4380 deletions(-) delete mode 100644 test/micro/org/openjdk/bench/jdk/incubator/vector/RotateBenchmark.java diff --git a/src/hotspot/cpu/aarch64/matcher_aarch64.hpp b/src/hotspot/cpu/aarch64/matcher_aarch64.hpp index 0a7f14fa23b..f08c0d494aa 100644 --- a/src/hotspot/cpu/aarch64/matcher_aarch64.hpp +++ b/src/hotspot/cpu/aarch64/matcher_aarch64.hpp @@ -138,11 +138,6 @@ return false; } - // Does the CPU supports vector constant rotate instructions? - static constexpr bool supports_vector_constant_rotates(int shift) { - return false; - } - // Does the CPU supports vector unsigned comparison instructions? static const bool supports_vector_comparison_unsigned(int vlen, BasicType bt) { // Not supported on SVE yet. diff --git a/src/hotspot/cpu/arm/matcher_arm.hpp b/src/hotspot/cpu/arm/matcher_arm.hpp index 56f77409a89..0d011a620f9 100644 --- a/src/hotspot/cpu/arm/matcher_arm.hpp +++ b/src/hotspot/cpu/arm/matcher_arm.hpp @@ -131,11 +131,6 @@ return false; // not supported } - // Does the CPU supports vector constant rotate instructions? - static constexpr bool supports_vector_constant_rotates(int shift) { - return false; - } - // Does the CPU supports vector unsigned comparison instructions? static constexpr bool supports_vector_comparison_unsigned(int vlen, BasicType bt) { return false; diff --git a/src/hotspot/cpu/ppc/matcher_ppc.hpp b/src/hotspot/cpu/ppc/matcher_ppc.hpp index d1bb8b21dbf..cbcebc23ddc 100644 --- a/src/hotspot/cpu/ppc/matcher_ppc.hpp +++ b/src/hotspot/cpu/ppc/matcher_ppc.hpp @@ -138,11 +138,6 @@ return false; } - // Does the CPU supports vector constant rotate instructions? - static constexpr bool supports_vector_constant_rotates(int shift) { - return false; - } - // Does the CPU supports vector unsigned comparison instructions? static constexpr bool supports_vector_comparison_unsigned(int vlen, BasicType bt) { return false; diff --git a/src/hotspot/cpu/s390/matcher_s390.hpp b/src/hotspot/cpu/s390/matcher_s390.hpp index bc6956c445d..2906f584a31 100644 --- a/src/hotspot/cpu/s390/matcher_s390.hpp +++ b/src/hotspot/cpu/s390/matcher_s390.hpp @@ -128,11 +128,6 @@ return false; } - // Does the CPU supports vector constant rotate instructions? - static constexpr bool supports_vector_constant_rotates(int shift) { - return false; - } - // Does the CPU supports vector unsigned comparison instructions? static constexpr bool supports_vector_comparison_unsigned(int vlen, BasicType bt) { return false; diff --git a/src/hotspot/cpu/x86/matcher_x86.hpp b/src/hotspot/cpu/x86/matcher_x86.hpp index 44c2a5a270c..f0c7aff73f9 100644 --- a/src/hotspot/cpu/x86/matcher_x86.hpp +++ b/src/hotspot/cpu/x86/matcher_x86.hpp @@ -158,11 +158,6 @@ return true; } - // Does the CPU supports vector constant rotate instructions? - static constexpr bool supports_vector_constant_rotates(int shift) { - return -0x80 <= shift && shift < 0x80; - } - // Does the CPU supports vector unsigned comparison instructions? static const bool supports_vector_comparison_unsigned(int vlen, BasicType bt) { int vlen_in_bytes = vlen * type2aelembytes(bt); diff --git a/src/hotspot/cpu/x86/x86.ad b/src/hotspot/cpu/x86/x86.ad index 4453d01e3d5..12a11f8abdd 100644 --- a/src/hotspot/cpu/x86/x86.ad +++ b/src/hotspot/cpu/x86/x86.ad @@ -1638,9 +1638,6 @@ const bool Matcher::match_rule_supported_vector(int opcode, int vlen, BasicType break; case Op_RotateRightV: case Op_RotateLeftV: - if (bt != T_INT && bt != T_LONG) { - return false; - } // fallthrough case Op_MacroLogicV: if (!VM_Version::supports_evex() || ((size_in_bits != 512) && !VM_Version::supports_avx512vl())) { diff --git a/src/hotspot/share/opto/library_call.hpp b/src/hotspot/share/opto/library_call.hpp index 1f483219297..1d33d6f4c9b 100644 --- a/src/hotspot/share/opto/library_call.hpp +++ b/src/hotspot/share/opto/library_call.hpp @@ -336,7 +336,6 @@ class LibraryCallKit : public GraphKit { }; bool arch_supports_vector(int op, int num_elem, BasicType type, VectorMaskUseType mask_use_type, bool has_scalar_args = false); - bool arch_supports_vector_rotate(int opc, int num_elem, BasicType elem_bt, bool has_scalar_args = false); void clear_upper_avx() { #ifdef X86 diff --git a/src/hotspot/share/opto/superword.cpp b/src/hotspot/share/opto/superword.cpp index 7850e19f16d..60977b023af 100644 --- a/src/hotspot/share/opto/superword.cpp +++ b/src/hotspot/share/opto/superword.cpp @@ -2488,8 +2488,9 @@ void SuperWord::output() { } else if (VectorNode::is_scalar_rotate(n)) { Node* in1 = low_adr->in(1); Node* in2 = p->at(0)->in(2); + assert(in2->bottom_type()->isa_int(), "Shift must always be an int value"); // If rotation count is non-constant or greater than 8bit value create a vector. - if (!in2->is_Con() || !Matcher::supports_vector_constant_rotates(in2->get_int())) { + if (!in2->is_Con() || -0x80 > in2->get_int() || in2->get_int() >= 0x80) { in2 = vector_opd(p, 2); } vn = VectorNode::make(opc, in1, in2, vlen, velt_basic_type(n)); diff --git a/src/hotspot/share/opto/vectorIntrinsics.cpp b/src/hotspot/share/opto/vectorIntrinsics.cpp index c7e18796c2d..d1a8ede4f5f 100644 --- a/src/hotspot/share/opto/vectorIntrinsics.cpp +++ b/src/hotspot/share/opto/vectorIntrinsics.cpp @@ -59,48 +59,6 @@ static bool check_vbox(const TypeInstPtr* vbox_type) { } #endif -bool LibraryCallKit::arch_supports_vector_rotate(int opc, int num_elem, BasicType elem_bt, bool has_scalar_args) { - bool is_supported = true; - // has_scalar_args flag is true only for non-constant scalar shift count, - // since in this case shift needs to be broadcasted. - if (!Matcher::match_rule_supported_vector(opc, num_elem, elem_bt) || - (has_scalar_args && - !arch_supports_vector(VectorNode::replicate_opcode(elem_bt), num_elem, elem_bt, VecMaskNotUsed))) { - is_supported = false; - } - - int lshiftopc, rshiftopc; - switch(elem_bt) { - case T_BYTE: - lshiftopc = Op_LShiftI; - rshiftopc = Op_URShiftB; - break; - case T_SHORT: - lshiftopc = Op_LShiftI; - rshiftopc = Op_URShiftS; - break; - case T_INT: - lshiftopc = Op_LShiftI; - rshiftopc = Op_URShiftI; - break; - case T_LONG: - lshiftopc = Op_LShiftL; - rshiftopc = Op_URShiftL; - break; - default: - assert(false, "Unexpected type"); - } - int lshiftvopc = VectorNode::opcode(lshiftopc, elem_bt); - int rshiftvopc = VectorNode::opcode(rshiftopc, elem_bt); - if (!is_supported && - arch_supports_vector(lshiftvopc, num_elem, elem_bt, VecMaskNotUsed) && - arch_supports_vector(rshiftvopc, num_elem, elem_bt, VecMaskNotUsed) && - arch_supports_vector(Op_OrV, num_elem, elem_bt, VecMaskNotUsed)) { - is_supported = true; - } - return is_supported; -} - Node* GraphKit::box_vector(Node* vector, const TypeInstPtr* vbox_type, BasicType elem_bt, int num_elem, bool deoptimize_on_exception) { assert(EnableVectorSupport, ""); @@ -154,29 +112,17 @@ bool LibraryCallKit::arch_supports_vector(int sopc, int num_elem, BasicType type return false; } - if (VectorNode::is_vector_rotate(sopc)) { - if(!arch_supports_vector_rotate(sopc, num_elem, type, has_scalar_args)) { + // Check that architecture supports this op-size-type combination. + if (!Matcher::match_rule_supported_vector(sopc, num_elem, type)) { #ifndef PRODUCT - if (C->print_intrinsics()) { - tty->print_cr(" ** Rejected vector op (%s,%s,%d) because architecture does not support variable vector shifts", - NodeClassNames[sopc], type2name(type), num_elem); - } -#endif - return false; + if (C->print_intrinsics()) { + tty->print_cr(" ** Rejected vector op (%s,%s,%d) because architecture does not support it", + NodeClassNames[sopc], type2name(type), num_elem); } +#endif + return false; } else { - // Check that architecture supports this op-size-type combination. - if (!Matcher::match_rule_supported_vector(sopc, num_elem, type)) { -#ifndef PRODUCT - if (C->print_intrinsics()) { - tty->print_cr(" ** Rejected vector op (%s,%s,%d) because architecture does not support it", - NodeClassNames[sopc], type2name(type), num_elem); - } -#endif - return false; - } else { - assert(Matcher::match_rule_supported(sopc), "must be supported"); - } + assert(Matcher::match_rule_supported(sopc), "must be supported"); } if (num_elem == 1) { @@ -1554,9 +1500,7 @@ bool LibraryCallKit::inline_vector_broadcast_int() { BasicType elem_bt = elem_type->basic_type(); int num_elem = vlen->get_con(); int opc = VectorSupport::vop2ideal(opr->get_con(), elem_bt); - bool is_shift = VectorNode::is_shift_opcode(opc); - bool is_rotate = VectorNode::is_rotate_opcode(opc); - if (opc == 0 || (!is_shift && !is_rotate)) { + if (opc == 0 || !VectorNode::is_shift_opcode(opc)) { if (C->print_intrinsics()) { tty->print_cr(" ** operation not supported: op=%d bt=%s", opr->get_con(), type2name(elem_bt)); } @@ -1569,16 +1513,10 @@ bool LibraryCallKit::inline_vector_broadcast_int() { } return false; // operation not supported } - Node* cnt = argument(5); ciKlass* vbox_klass = vector_klass->const_oop()->as_instance()->java_lang_Class_klass(); const TypeInstPtr* vbox_type = TypeInstPtr::make_exact(TypePtr::NotNull, vbox_klass); - const TypeInt* cnt_type = cnt->bottom_type()->isa_int(); - // If CPU supports vector constant rotate instructions pass it directly - bool is_const_rotate = is_rotate && cnt_type && cnt_type->is_con() && - Matcher::supports_vector_constant_rotates(cnt_type->get_con()); - bool has_scalar_args = is_rotate ? !is_const_rotate : true; - if (!arch_supports_vector(sopc, num_elem, elem_bt, VecMaskNotUsed, has_scalar_args)) { + if (!arch_supports_vector(sopc, num_elem, elem_bt, VecMaskNotUsed, true /*has_scalar_args*/)) { if (C->print_intrinsics()) { tty->print_cr(" ** not supported: arity=0 op=int/%d vlen=%d etype=%s ismask=no", sopc, num_elem, type2name(elem_bt)); @@ -1586,20 +1524,7 @@ bool LibraryCallKit::inline_vector_broadcast_int() { return false; // not supported } Node* opd1 = unbox_vector(argument(4), vbox_type, elem_bt, num_elem); - Node* opd2 = NULL; - if (is_shift) { - opd2 = vector_shift_count(cnt, opc, elem_bt, num_elem); - } else { - assert(is_rotate, "unexpected operation"); - if (!is_const_rotate) { - const Type * type_bt = Type::get_const_basic_type(elem_bt); - cnt = elem_bt == T_LONG ? gvn().transform(new ConvI2LNode(cnt)) : cnt; - opd2 = gvn().transform(VectorNode::scalar2vector(cnt, num_elem, type_bt)); - } else { - // Constant shift value. - opd2 = cnt; - } - } + Node* opd2 = vector_shift_count(argument(5), opc, elem_bt, num_elem); if (opd1 == NULL || opd2 == NULL) { return false; } diff --git a/src/hotspot/share/opto/vectornode.cpp b/src/hotspot/share/opto/vectornode.cpp index 13d631c1879..b51b0a51680 100644 --- a/src/hotspot/share/opto/vectornode.cpp +++ b/src/hotspot/share/opto/vectornode.cpp @@ -142,9 +142,9 @@ int VectorNode::opcode(int sopc, BasicType bt) { case Op_RoundDoubleMode: return (bt == T_DOUBLE ? Op_RoundDoubleModeV : 0); case Op_RotateLeft: - return (is_integral_type(bt) ? Op_RotateLeftV : 0); + return (bt == T_LONG || bt == T_INT ? Op_RotateLeftV : 0); case Op_RotateRight: - return (is_integral_type(bt) ? Op_RotateRightV : 0); + return (bt == T_LONG || bt == T_INT ? Op_RotateRightV : 0); case Op_SqrtF: return (bt == T_FLOAT ? Op_SqrtVF : 0); case Op_SqrtD: @@ -261,7 +261,7 @@ bool VectorNode::implemented(int opc, uint vlen, BasicType bt) { // For rotate operation we will do a lazy de-generation into // OrV/LShiftV/URShiftV pattern if the target does not support // vector rotation instruction. - if (VectorNode::is_vector_rotate(vopc)) { + if (vopc == Op_RotateLeftV || vopc == Op_RotateRightV) { return is_vector_rotate_supported(vopc, vlen, bt); } return vopc > 0 && Matcher::match_rule_supported_vector(vopc, vlen, bt); @@ -295,8 +295,15 @@ bool VectorNode::is_roundopD(Node* n) { return false; } +bool VectorNode::is_scalar_rotate(Node* n) { + if (n->Opcode() == Op_RotateLeft || n->Opcode() == Op_RotateRight) { + return true; + } + return false; +} + bool VectorNode::is_vector_rotate_supported(int vopc, uint vlen, BasicType bt) { - assert(VectorNode::is_vector_rotate(vopc), "wrong opcode"); + assert(vopc == Op_RotateLeftV || vopc == Op_RotateRightV, "wrong opcode"); // If target defines vector rotation patterns then no // need for degeneration. @@ -340,23 +347,6 @@ bool VectorNode::is_shift(Node* n) { return is_shift_opcode(n->Opcode()); } -bool VectorNode::is_rotate_opcode(int opc) { - switch (opc) { - case Op_RotateRight: - case Op_RotateLeft: - return true; - default: - return false; - } -} - -bool VectorNode::is_scalar_rotate(Node* n) { - if (is_rotate_opcode(n->Opcode())) { - return true; - } - return false; -} - bool VectorNode::is_vshift_cnt(Node* n) { switch (n->Opcode()) { case Op_LShiftCntV: @@ -588,16 +578,6 @@ VectorNode* VectorNode::shift_count(int opc, Node* cnt, uint vlen, BasicType bt) } } -bool VectorNode::is_vector_rotate(int opc) { - switch (opc) { - case Op_RotateLeftV: - case Op_RotateRightV: - return true; - default: - return false; - } -} - bool VectorNode::is_vector_shift(int opc) { assert(opc > _last_machine_leaf && opc < _last_opcode, "invalid opcode"); switch (opc) { @@ -1151,35 +1131,24 @@ MacroLogicVNode* MacroLogicVNode::make(PhaseGVN& gvn, Node* in1, Node* in2, Node Node* VectorNode::degenerate_vector_rotate(Node* src, Node* cnt, bool is_rotate_left, int vlen, BasicType bt, PhaseGVN* phase) { - assert(is_integral_type(bt), "sanity"); + assert(bt == T_INT || bt == T_LONG, "sanity"); const TypeVect* vt = TypeVect::make(bt, vlen); - int shift_mask = (type2aelembytes(bt) * 8) - 1; - int shiftLOpc = (bt == T_LONG) ? Op_LShiftL : Op_LShiftI; - auto urshiftopc = [=]() { - switch(bt) { - case T_INT: return Op_URShiftI; - case T_LONG: return Op_URShiftL; - case T_BYTE: return Op_URShiftB; - case T_SHORT: return Op_URShiftS; - default: return (Opcodes)0; - } - }; - int shiftROpc = urshiftopc(); + int shift_mask = (bt == T_INT) ? 0x1F : 0x3F; + int shiftLOpc = (bt == T_INT) ? Op_LShiftI : Op_LShiftL; + int shiftROpc = (bt == T_INT) ? Op_URShiftI: Op_URShiftL; // Compute shift values for right rotation and // later swap them in case of left rotation. Node* shiftRCnt = NULL; Node* shiftLCnt = NULL; - const TypeInt* cnt_type = cnt->bottom_type()->isa_int(); - bool is_binary_vector_op = false; - if (cnt_type && cnt_type->is_con()) { - // Constant shift. - int shift = cnt_type->get_con() & shift_mask; + if (cnt->is_Con() && cnt->bottom_type()->isa_int()) { + // Constant shift case. + int shift = cnt->get_int() & shift_mask; shiftRCnt = phase->intcon(shift); shiftLCnt = phase->intcon(shift_mask + 1 - shift); - } else if (VectorNode::is_invariant_vector(cnt)) { - // Scalar variable shift, handle replicates generated by auto vectorizer. + } else { + // Variable shift case. assert(VectorNode::is_invariant_vector(cnt), "Broadcast expected"); cnt = cnt->in(1); if (bt == T_LONG) { @@ -1187,19 +1156,8 @@ Node* VectorNode::degenerate_vector_rotate(Node* src, Node* cnt, bool is_rotate_ assert(cnt->Opcode() == Op_ConvI2L, "ConvI2L expected"); cnt = cnt->in(1); } - shiftRCnt = cnt; + shiftRCnt = phase->transform(new AndINode(cnt, phase->intcon(shift_mask))); shiftLCnt = phase->transform(new SubINode(phase->intcon(shift_mask + 1), shiftRCnt)); - } else { - // Vector variable shift. - assert(cnt->bottom_type()->isa_vect(), "Unexpected shift"); - const Type* elem_ty = Type::get_const_basic_type(bt); - Node* shift_mask_node = (bt == T_LONG) ? (Node*)(phase->longcon(shift_mask + 1L)) : - (Node*)(phase->intcon(shift_mask + 1)); - Node* vector_mask = phase->transform(VectorNode::scalar2vector(shift_mask_node,vlen, elem_ty)); - int subVopc = VectorNode::opcode((bt == T_LONG) ? Op_SubL : Op_SubI, bt); - shiftRCnt = cnt; - shiftLCnt = phase->transform(VectorNode::make(subVopc, vector_mask, shiftRCnt, vt)); - is_binary_vector_op = true; } // Swap the computed left and right shift counts. @@ -1207,10 +1165,8 @@ Node* VectorNode::degenerate_vector_rotate(Node* src, Node* cnt, bool is_rotate_ swap(shiftRCnt,shiftLCnt); } - if (!is_binary_vector_op) { - shiftLCnt = phase->transform(new LShiftCntVNode(shiftLCnt, vt)); - shiftRCnt = phase->transform(new RShiftCntVNode(shiftRCnt, vt)); - } + shiftLCnt = phase->transform(new LShiftCntVNode(shiftLCnt, vt)); + shiftRCnt = phase->transform(new RShiftCntVNode(shiftRCnt, vt)); return new OrVNode(phase->transform(VectorNode::make(shiftLOpc, src, shiftLCnt, vlen, bt)), phase->transform(VectorNode::make(shiftROpc, src, shiftRCnt, vlen, bt)), diff --git a/src/hotspot/share/opto/vectornode.hpp b/src/hotspot/share/opto/vectornode.hpp index 6f8e8b9b1f0..7ba0149777f 100644 --- a/src/hotspot/share/opto/vectornode.hpp +++ b/src/hotspot/share/opto/vectornode.hpp @@ -76,7 +76,6 @@ class VectorNode : public TypeNode { static VectorNode* make(int vopc, Node* n1, Node* n2, Node* n3, const TypeVect* vt); static bool is_shift_opcode(int opc); - static bool is_rotate_opcode(int opc); static int opcode(int opc, BasicType bt); static int replicate_opcode(BasicType bt); @@ -100,7 +99,6 @@ class VectorNode : public TypeNode { static bool is_vector_shift(int opc); static bool is_vector_shift_count(int opc); - static bool is_vector_rotate(int opc); static bool is_vector_shift(Node* n) { return is_vector_shift(n->Opcode()); diff --git a/src/hotspot/share/prims/vectorSupport.cpp b/src/hotspot/share/prims/vectorSupport.cpp index 0b59f632408..be578539f4e 100644 --- a/src/hotspot/share/prims/vectorSupport.cpp +++ b/src/hotspot/share/prims/vectorSupport.cpp @@ -374,26 +374,6 @@ int VectorSupport::vop2ideal(jint id, BasicType bt) { } break; } - case VECTOR_OP_LROTATE: { - switch (bt) { - case T_BYTE: // fall-through - case T_SHORT: // fall-through - case T_INT: // fall-through - case T_LONG: return Op_RotateLeft; - default: fatal("LROTATE: %s", type2name(bt)); - } - break; - } - case VECTOR_OP_RROTATE: { - switch (bt) { - case T_BYTE: // fall-through - case T_SHORT: // fall-through - case T_INT: // fall-through - case T_LONG: return Op_RotateRight; - default: fatal("RROTATE: %s", type2name(bt)); - } - break; - } case VECTOR_OP_MASK_LASTTRUE: { switch (bt) { case T_BYTE: // fall-through diff --git a/src/hotspot/share/prims/vectorSupport.hpp b/src/hotspot/share/prims/vectorSupport.hpp index ac436a87976..7a05fb47c9f 100644 --- a/src/hotspot/share/prims/vectorSupport.hpp +++ b/src/hotspot/share/prims/vectorSupport.hpp @@ -83,10 +83,6 @@ class VectorSupport : AllStatic { VECTOR_OP_MASK_FIRSTTRUE = 20, VECTOR_OP_MASK_LASTTRUE = 21, - // Rotate operations - VECTOR_OP_LROTATE = 22, - VECTOR_OP_RROTATE = 23, - // Vector Math Library VECTOR_OP_TAN = 101, VECTOR_OP_TANH = 102, diff --git a/src/java.base/share/classes/jdk/internal/vm/vector/VectorSupport.java b/src/java.base/share/classes/jdk/internal/vm/vector/VectorSupport.java index 2c984ef427c..936a302331b 100644 --- a/src/java.base/share/classes/jdk/internal/vm/vector/VectorSupport.java +++ b/src/java.base/share/classes/jdk/internal/vm/vector/VectorSupport.java @@ -70,10 +70,6 @@ public class VectorSupport { public static final int VECTOR_OP_MASK_FIRSTTRUE = 20; public static final int VECTOR_OP_MASK_LASTTRUE = 21; - // Rotate operations - public static final int VECTOR_OP_LROTATE = 22; - public static final int VECTOR_OP_RROTATE = 23; - // Math routines public static final int VECTOR_OP_TAN = 101; public static final int VECTOR_OP_TANH = 102; diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteVector.java index 7f42edf8623..c7613b2ff14 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteVector.java @@ -380,18 +380,6 @@ public abstract class ByteVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ - @ForceInline - static byte rotateLeft(byte a, int n) { - return (byte)(((((byte)a) & Byte.toUnsignedInt((byte)-1)) << (n & Byte.SIZE-1)) | ((((byte)a) & Byte.toUnsignedInt((byte)-1)) >>> (Byte.SIZE - (n & Byte.SIZE-1)))); - } - - /*package-private*/ - @ForceInline - static byte rotateRight(byte a, int n) { - return (byte)(((((byte)a) & Byte.toUnsignedInt((byte)-1)) >>> (n & Byte.SIZE-1)) | ((((byte)a) & Byte.toUnsignedInt((byte)-1)) << (Byte.SIZE - (n & Byte.SIZE-1)))); - } - /*package-private*/ @Override abstract ByteSpecies vspecies(); @@ -612,7 +600,12 @@ public abstract class ByteVector extends AbstractVector { // This allows the JIT to ignore some ISA details. that = that.lanewise(AND, SHIFT_MASK); } - if (op == AND_NOT) { + if (op == ROR || op == ROL) { // FIXME: JIT should do this + ByteVector neg = that.lanewise(NEG); + ByteVector hi = this.lanewise(LSHL, (op == ROR) ? neg : that); + ByteVector lo = this.lanewise(LSHR, (op == ROR) ? that : neg); + return hi.lanewise(OR, lo); + } else if (op == AND_NOT) { // FIXME: Support this in the JIT. that = that.lanewise(NOT); op = AND; @@ -653,10 +646,6 @@ public abstract class ByteVector extends AbstractVector { v0.bOp(v1, (i, a, n) -> (byte)(a >> n)); case VECTOR_OP_URSHIFT: return (v0, v1) -> v0.bOp(v1, (i, a, n) -> (byte)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateRight(a, (int)n)); default: return null; }})); } @@ -803,6 +792,11 @@ public abstract class ByteVector extends AbstractVector { assert(opKind(op, VO_SHIFT)); // As per shift specification for Java, mask the shift count. e &= SHIFT_MASK; + if (op == ROR || op == ROL) { // FIXME: JIT should do this + ByteVector hi = this.lanewise(LSHL, (op == ROR) ? -e : e); + ByteVector lo = this.lanewise(LSHR, (op == ROR) ? e : -e); + return hi.lanewise(OR, lo); + } int opc = opCode(op); return VectorSupport.broadcastInt( opc, getClass(), byte.class, length(), @@ -815,10 +809,6 @@ public abstract class ByteVector extends AbstractVector { v.uOp((i, a) -> (byte)(a >> n)); case VECTOR_OP_URSHIFT: return (v, n) -> v.uOp((i, a) -> (byte)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v, n) -> - v.uOp((i, a) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v, n) -> - v.uOp((i, a) -> rotateRight(a, (int)n)); default: return null; }})); } diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleVector.java index 4c3746b745f..9dadb3f7b03 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleVector.java @@ -380,7 +380,6 @@ public abstract class DoubleVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ @Override abstract DoubleSpecies vspecies(); diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatVector.java index 7a741cd2e5e..1841b3e0dec 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatVector.java @@ -380,7 +380,6 @@ public abstract class FloatVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ @Override abstract FloatSpecies vspecies(); diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntVector.java index 6fdf612a255..f23cdfa1149 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntVector.java @@ -380,18 +380,6 @@ public abstract class IntVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ - @ForceInline - static int rotateLeft(int a, int n) { - return Integer.rotateLeft(a, n); - } - - /*package-private*/ - @ForceInline - static int rotateRight(int a, int n) { - return Integer.rotateRight(a, n); - } - /*package-private*/ @Override abstract IntSpecies vspecies(); @@ -612,7 +600,12 @@ public abstract class IntVector extends AbstractVector { // This allows the JIT to ignore some ISA details. that = that.lanewise(AND, SHIFT_MASK); } - if (op == AND_NOT) { + if (op == ROR || op == ROL) { // FIXME: JIT should do this + IntVector neg = that.lanewise(NEG); + IntVector hi = this.lanewise(LSHL, (op == ROR) ? neg : that); + IntVector lo = this.lanewise(LSHR, (op == ROR) ? that : neg); + return hi.lanewise(OR, lo); + } else if (op == AND_NOT) { // FIXME: Support this in the JIT. that = that.lanewise(NOT); op = AND; @@ -653,10 +646,6 @@ public abstract class IntVector extends AbstractVector { v0.bOp(v1, (i, a, n) -> (int)(a >> n)); case VECTOR_OP_URSHIFT: return (v0, v1) -> v0.bOp(v1, (i, a, n) -> (int)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateRight(a, (int)n)); default: return null; }})); } @@ -803,6 +792,11 @@ public abstract class IntVector extends AbstractVector { assert(opKind(op, VO_SHIFT)); // As per shift specification for Java, mask the shift count. e &= SHIFT_MASK; + if (op == ROR || op == ROL) { // FIXME: JIT should do this + IntVector hi = this.lanewise(LSHL, (op == ROR) ? -e : e); + IntVector lo = this.lanewise(LSHR, (op == ROR) ? e : -e); + return hi.lanewise(OR, lo); + } int opc = opCode(op); return VectorSupport.broadcastInt( opc, getClass(), int.class, length(), @@ -815,10 +809,6 @@ public abstract class IntVector extends AbstractVector { v.uOp((i, a) -> (int)(a >> n)); case VECTOR_OP_URSHIFT: return (v, n) -> v.uOp((i, a) -> (int)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v, n) -> - v.uOp((i, a) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v, n) -> - v.uOp((i, a) -> rotateRight(a, (int)n)); default: return null; }})); } diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongVector.java index f5069826d44..c1c1aea390a 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongVector.java @@ -380,18 +380,6 @@ public abstract class LongVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ - @ForceInline - static long rotateLeft(long a, int n) { - return Long.rotateLeft(a, n); - } - - /*package-private*/ - @ForceInline - static long rotateRight(long a, int n) { - return Long.rotateRight(a, n); - } - /*package-private*/ @Override abstract LongSpecies vspecies(); @@ -570,7 +558,12 @@ public abstract class LongVector extends AbstractVector { // This allows the JIT to ignore some ISA details. that = that.lanewise(AND, SHIFT_MASK); } - if (op == AND_NOT) { + if (op == ROR || op == ROL) { // FIXME: JIT should do this + LongVector neg = that.lanewise(NEG); + LongVector hi = this.lanewise(LSHL, (op == ROR) ? neg : that); + LongVector lo = this.lanewise(LSHR, (op == ROR) ? that : neg); + return hi.lanewise(OR, lo); + } else if (op == AND_NOT) { // FIXME: Support this in the JIT. that = that.lanewise(NOT); op = AND; @@ -611,10 +604,6 @@ public abstract class LongVector extends AbstractVector { v0.bOp(v1, (i, a, n) -> (long)(a >> n)); case VECTOR_OP_URSHIFT: return (v0, v1) -> v0.bOp(v1, (i, a, n) -> (long)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateRight(a, (int)n)); default: return null; }})); } @@ -721,6 +710,11 @@ public abstract class LongVector extends AbstractVector { assert(opKind(op, VO_SHIFT)); // As per shift specification for Java, mask the shift count. e &= SHIFT_MASK; + if (op == ROR || op == ROL) { // FIXME: JIT should do this + LongVector hi = this.lanewise(LSHL, (op == ROR) ? -e : e); + LongVector lo = this.lanewise(LSHR, (op == ROR) ? e : -e); + return hi.lanewise(OR, lo); + } int opc = opCode(op); return VectorSupport.broadcastInt( opc, getClass(), long.class, length(), @@ -733,10 +727,6 @@ public abstract class LongVector extends AbstractVector { v.uOp((i, a) -> (long)(a >> n)); case VECTOR_OP_URSHIFT: return (v, n) -> v.uOp((i, a) -> (long)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v, n) -> - v.uOp((i, a) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v, n) -> - v.uOp((i, a) -> rotateRight(a, (int)n)); default: return null; }})); } diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortVector.java index a02e981e809..a2ee13e6319 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortVector.java @@ -380,18 +380,6 @@ public abstract class ShortVector extends AbstractVector { return maskFactory(bits); } - /*package-private*/ - @ForceInline - static short rotateLeft(short a, int n) { - return (short)(((((short)a) & Short.toUnsignedInt((short)-1)) << (n & Short.SIZE-1)) | ((((short)a) & Short.toUnsignedInt((short)-1)) >>> (Short.SIZE - (n & Short.SIZE-1)))); - } - - /*package-private*/ - @ForceInline - static short rotateRight(short a, int n) { - return (short)(((((short)a) & Short.toUnsignedInt((short)-1)) >>> (n & Short.SIZE-1)) | ((((short)a) & Short.toUnsignedInt((short)-1)) << (Short.SIZE - (n & Short.SIZE-1)))); - } - /*package-private*/ @Override abstract ShortSpecies vspecies(); @@ -612,7 +600,12 @@ public abstract class ShortVector extends AbstractVector { // This allows the JIT to ignore some ISA details. that = that.lanewise(AND, SHIFT_MASK); } - if (op == AND_NOT) { + if (op == ROR || op == ROL) { // FIXME: JIT should do this + ShortVector neg = that.lanewise(NEG); + ShortVector hi = this.lanewise(LSHL, (op == ROR) ? neg : that); + ShortVector lo = this.lanewise(LSHR, (op == ROR) ? that : neg); + return hi.lanewise(OR, lo); + } else if (op == AND_NOT) { // FIXME: Support this in the JIT. that = that.lanewise(NOT); op = AND; @@ -653,10 +646,6 @@ public abstract class ShortVector extends AbstractVector { v0.bOp(v1, (i, a, n) -> (short)(a >> n)); case VECTOR_OP_URSHIFT: return (v0, v1) -> v0.bOp(v1, (i, a, n) -> (short)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateRight(a, (int)n)); default: return null; }})); } @@ -803,6 +792,11 @@ public abstract class ShortVector extends AbstractVector { assert(opKind(op, VO_SHIFT)); // As per shift specification for Java, mask the shift count. e &= SHIFT_MASK; + if (op == ROR || op == ROL) { // FIXME: JIT should do this + ShortVector hi = this.lanewise(LSHL, (op == ROR) ? -e : e); + ShortVector lo = this.lanewise(LSHR, (op == ROR) ? e : -e); + return hi.lanewise(OR, lo); + } int opc = opCode(op); return VectorSupport.broadcastInt( opc, getClass(), short.class, length(), @@ -815,10 +809,6 @@ public abstract class ShortVector extends AbstractVector { v.uOp((i, a) -> (short)(a >> n)); case VECTOR_OP_URSHIFT: return (v, n) -> v.uOp((i, a) -> (short)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v, n) -> - v.uOp((i, a) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v, n) -> - v.uOp((i, a) -> rotateRight(a, (int)n)); default: return null; }})); } diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/VectorOperators.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/VectorOperators.java index 3562a2578ef..8622449a59e 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/VectorOperators.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/VectorOperators.java @@ -551,9 +551,9 @@ public abstract class VectorOperators { /** Produce {@code a>>>(n&(ESIZE*8-1))}. Integral only. */ public static final /*bitwise*/ Binary LSHR = binary("LSHR", ">>>", VectorSupport.VECTOR_OP_URSHIFT, VO_SHIFT); /** Produce {@code rotateLeft(a,n)}. Integral only. */ - public static final /*bitwise*/ Binary ROL = binary("ROL", "rotateLeft", VectorSupport.VECTOR_OP_LROTATE, VO_SHIFT); + public static final /*bitwise*/ Binary ROL = binary("ROL", "rotateLeft", -1 /*VectorSupport.VECTOR_OP_LROTATE*/, VO_SHIFT | VO_SPECIAL); /** Produce {@code rotateRight(a,n)}. Integral only. */ - public static final /*bitwise*/ Binary ROR = binary("ROR", "rotateRight", VectorSupport.VECTOR_OP_RROTATE, VO_SHIFT); + public static final /*bitwise*/ Binary ROR = binary("ROR", "rotateRight", -1 /*VectorSupport.VECTOR_OP_RROTATE*/, VO_SHIFT | VO_SPECIAL); /** Produce {@code atan2(a,b)}. See Floating only. * Not guaranteed to be semi-monotonic. See section "Operations on floating point vectors" above diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-Vector.java.template b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-Vector.java.template index 860ef572d67..2fb3ae856cf 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-Vector.java.template +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-Vector.java.template @@ -384,28 +384,6 @@ public abstract class $abstractvectortype$ extends AbstractVector<$Boxtype$> { return maskFactory(bits); } -#if[BITWISE] - /*package-private*/ - @ForceInline - static $type$ rotateLeft($type$ a, int n) { -#if[intOrLong] - return $Boxtype$.rotateLeft(a, n); -#else[intOrLong] - return ($type$)((((($type$)a) & $Boxtype$.toUnsignedInt(($type$)-1)) << (n & $Boxtype$.SIZE-1)) | (((($type$)a) & $Boxtype$.toUnsignedInt(($type$)-1)) >>> ($Boxtype$.SIZE - (n & $Boxtype$.SIZE-1)))); -#end[intOrLong] - } - - /*package-private*/ - @ForceInline - static $type$ rotateRight($type$ a, int n) { -#if[intOrLong] - return $Boxtype$.rotateRight(a, n); -#else[intOrLong] - return ($type$)((((($type$)a) & $Boxtype$.toUnsignedInt(($type$)-1)) >>> (n & $Boxtype$.SIZE-1)) | (((($type$)a) & $Boxtype$.toUnsignedInt(($type$)-1)) << ($Boxtype$.SIZE - (n & $Boxtype$.SIZE-1)))); -#end[intOrLong] - } -#end[BITWISE] - /*package-private*/ @Override abstract $Type$Species vspecies(); @@ -679,7 +657,12 @@ public abstract class $abstractvectortype$ extends AbstractVector<$Boxtype$> { that = that.lanewise(AND, SHIFT_MASK); } #end[!FP] - if (op == AND_NOT) { + if (op == ROR || op == ROL) { // FIXME: JIT should do this + $abstractvectortype$ neg = that.lanewise(NEG); + $abstractvectortype$ hi = this.lanewise(LSHL, (op == ROR) ? neg : that); + $abstractvectortype$ lo = this.lanewise(LSHR, (op == ROR) ? that : neg); + return hi.lanewise(OR, lo); + } else if (op == AND_NOT) { // FIXME: Support this in the JIT. that = that.lanewise(NOT); op = AND; @@ -722,10 +705,6 @@ public abstract class $abstractvectortype$ extends AbstractVector<$Boxtype$> { v0.bOp(v1, (i, a, n) -> ($type$)(a >> n)); case VECTOR_OP_URSHIFT: return (v0, v1) -> v0.bOp(v1, (i, a, n) -> ($type$)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v0, v1) -> - v0.bOp(v1, (i, a, n) -> rotateRight(a, (int)n)); #end[BITWISE] #if[FP] case VECTOR_OP_ATAN2: return (v0, v1) -> @@ -890,6 +869,11 @@ public abstract class $abstractvectortype$ extends AbstractVector<$Boxtype$> { assert(opKind(op, VO_SHIFT)); // As per shift specification for Java, mask the shift count. e &= SHIFT_MASK; + if (op == ROR || op == ROL) { // FIXME: JIT should do this + $abstractvectortype$ hi = this.lanewise(LSHL, (op == ROR) ? -e : e); + $abstractvectortype$ lo = this.lanewise(LSHR, (op == ROR) ? e : -e); + return hi.lanewise(OR, lo); + } int opc = opCode(op); return VectorSupport.broadcastInt( opc, getClass(), $type$.class, length(), @@ -902,10 +886,6 @@ public abstract class $abstractvectortype$ extends AbstractVector<$Boxtype$> { v.uOp((i, a) -> ($type$)(a >> n)); case VECTOR_OP_URSHIFT: return (v, n) -> v.uOp((i, a) -> ($type$)((a & LSHR_SETUP_MASK) >>> n)); - case VECTOR_OP_LROTATE: return (v, n) -> - v.uOp((i, a) -> rotateLeft(a, (int)n)); - case VECTOR_OP_RROTATE: return (v, n) -> - v.uOp((i, a) -> rotateRight(a, (int)n)); default: return null; }})); } diff --git a/test/jdk/jdk/incubator/vector/Byte128VectorTests.java b/test/jdk/jdk/incubator/vector/Byte128VectorTests.java index db2140d223e..00ebad48021 100644 --- a/test/jdk/jdk/incubator/vector/Byte128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Byte128VectorTests.java @@ -1153,14 +1153,6 @@ public class Byte128VectorTests extends AbstractVectorTest { } } - static byte ROL_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); - } - - static byte ROR_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); - } - static boolean eq(byte a, byte b) { return a == b; } @@ -2330,7 +2322,7 @@ public class Byte128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHLByte128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLByte128VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2348,7 +2340,7 @@ public class Byte128VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHLByte128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLByte128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2376,7 +2368,7 @@ public class Byte128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHRByte128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRByte128VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2394,7 +2386,7 @@ public class Byte128VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHRByte128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRByte128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2422,7 +2414,7 @@ public class Byte128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void ASHRByte128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRByte128VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2440,7 +2432,7 @@ public class Byte128VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ASHRByte128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRByte128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2460,178 +2452,6 @@ public class Byte128VectorTests extends AbstractVectorTest { - - static byte ROR(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte128VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte128VectorTests::ROR); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte128VectorTests::ROR); - } - - - static byte ROL(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte128VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte128VectorTests::ROL); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte128VectorTests::ROL); - } - - - static byte ROR_unary(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte128VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte128VectorTests::ROR_unary); - } - - - static byte ROL_unary(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte128VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte128VectorTests::ROL_unary); - } - static byte MIN(byte a, byte b) { return (byte)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Byte256VectorTests.java b/test/jdk/jdk/incubator/vector/Byte256VectorTests.java index b980f61df8c..32c67f72e56 100644 --- a/test/jdk/jdk/incubator/vector/Byte256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Byte256VectorTests.java @@ -1153,14 +1153,6 @@ public class Byte256VectorTests extends AbstractVectorTest { } } - static byte ROL_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); - } - - static byte ROR_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); - } - static boolean eq(byte a, byte b) { return a == b; } @@ -2330,7 +2322,7 @@ public class Byte256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHLByte256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLByte256VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2348,7 +2340,7 @@ public class Byte256VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHLByte256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLByte256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2376,7 +2368,7 @@ public class Byte256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHRByte256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRByte256VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2394,7 +2386,7 @@ public class Byte256VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHRByte256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRByte256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2422,7 +2414,7 @@ public class Byte256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void ASHRByte256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRByte256VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2440,7 +2432,7 @@ public class Byte256VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ASHRByte256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRByte256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2460,178 +2452,6 @@ public class Byte256VectorTests extends AbstractVectorTest { - - static byte ROR(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte256VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte256VectorTests::ROR); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte256VectorTests::ROR); - } - - - static byte ROL(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte256VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte256VectorTests::ROL); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte256VectorTests::ROL); - } - - - static byte ROR_unary(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte256VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte256VectorTests::ROR_unary); - } - - - static byte ROL_unary(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte256VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte256VectorTests::ROL_unary); - } - static byte MIN(byte a, byte b) { return (byte)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Byte512VectorTests.java b/test/jdk/jdk/incubator/vector/Byte512VectorTests.java index 2ec4e8b2c53..eab4d8226d3 100644 --- a/test/jdk/jdk/incubator/vector/Byte512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Byte512VectorTests.java @@ -1153,14 +1153,6 @@ public class Byte512VectorTests extends AbstractVectorTest { } } - static byte ROL_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); - } - - static byte ROR_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); - } - static boolean eq(byte a, byte b) { return a == b; } @@ -2330,7 +2322,7 @@ public class Byte512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHLByte512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLByte512VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2348,7 +2340,7 @@ public class Byte512VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHLByte512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLByte512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2376,7 +2368,7 @@ public class Byte512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHRByte512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRByte512VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2394,7 +2386,7 @@ public class Byte512VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHRByte512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRByte512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2422,7 +2414,7 @@ public class Byte512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void ASHRByte512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRByte512VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2440,7 +2432,7 @@ public class Byte512VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ASHRByte512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRByte512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2460,178 +2452,6 @@ public class Byte512VectorTests extends AbstractVectorTest { - - static byte ROR(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte512VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte512VectorTests::ROR); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte512VectorTests::ROR); - } - - - static byte ROL(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte512VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte512VectorTests::ROL); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte512VectorTests::ROL); - } - - - static byte ROR_unary(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte512VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte512VectorTests::ROR_unary); - } - - - static byte ROL_unary(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte512VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte512VectorTests::ROL_unary); - } - static byte MIN(byte a, byte b) { return (byte)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Byte64VectorTests.java b/test/jdk/jdk/incubator/vector/Byte64VectorTests.java index 7ca7543a992..75aaf7b1b80 100644 --- a/test/jdk/jdk/incubator/vector/Byte64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Byte64VectorTests.java @@ -1153,14 +1153,6 @@ public class Byte64VectorTests extends AbstractVectorTest { } } - static byte ROL_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); - } - - static byte ROR_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); - } - static boolean eq(byte a, byte b) { return a == b; } @@ -2330,7 +2322,7 @@ public class Byte64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHLByte64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLByte64VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2348,7 +2340,7 @@ public class Byte64VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHLByte64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLByte64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2376,7 +2368,7 @@ public class Byte64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHRByte64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRByte64VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2394,7 +2386,7 @@ public class Byte64VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHRByte64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRByte64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2422,7 +2414,7 @@ public class Byte64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void ASHRByte64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRByte64VectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2440,7 +2432,7 @@ public class Byte64VectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ASHRByte64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRByte64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2460,178 +2452,6 @@ public class Byte64VectorTests extends AbstractVectorTest { - - static byte ROR(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte64VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte64VectorTests::ROR); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte64VectorTests::ROR); - } - - - static byte ROL(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte64VectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Byte64VectorTests::ROL); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Byte64VectorTests::ROL); - } - - - static byte ROR_unary(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByte64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte64VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByte64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte64VectorTests::ROR_unary); - } - - - static byte ROL_unary(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByte64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Byte64VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByte64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Byte64VectorTests::ROL_unary); - } - static byte MIN(byte a, byte b) { return (byte)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/ByteMaxVectorTests.java b/test/jdk/jdk/incubator/vector/ByteMaxVectorTests.java index 422dd249a8d..20a7cccfdd7 100644 --- a/test/jdk/jdk/incubator/vector/ByteMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/ByteMaxVectorTests.java @@ -1158,14 +1158,6 @@ public class ByteMaxVectorTests extends AbstractVectorTest { } } - static byte ROL_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); - } - - static byte ROR_scalar(byte a, byte b) { - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); - } - static boolean eq(byte a, byte b) { return a == b; } @@ -2335,7 +2327,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHLByteMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLByteMaxVectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2353,7 +2345,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHLByteMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLByteMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2381,7 +2373,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void LSHRByteMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRByteMaxVectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2399,7 +2391,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void LSHRByteMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRByteMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2427,7 +2419,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "byteBinaryOpProvider") - static void ASHRByteMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRByteMaxVectorTestsShift(IntFunction fa, IntFunction fb) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); byte[] r = fr.apply(SPECIES.length()); @@ -2445,7 +2437,7 @@ public class ByteMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ASHRByteMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRByteMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { byte[] a = fa.apply(SPECIES.length()); byte[] b = fb.apply(SPECIES.length()); @@ -2465,178 +2457,6 @@ public class ByteMaxVectorTests extends AbstractVectorTest { - - static byte ROR(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByteMaxVectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, ByteMaxVectorTests::ROR); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByteMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, ByteMaxVectorTests::ROR); - } - - - static byte ROL(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByteMaxVectorTests(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, ByteMaxVectorTests::ROL); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByteMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - ByteVector bv = ByteVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, ByteMaxVectorTests::ROL); - } - - - static byte ROR_unary(byte a, byte b) { - return (byte)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void RORByteMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, ByteMaxVectorTests::ROR_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void RORByteMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, ByteMaxVectorTests::ROR_unary); - } - - - static byte ROL_unary(byte a, byte b) { - return (byte)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "byteBinaryOpProvider") - static void ROLByteMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, ByteMaxVectorTests::ROL_unary); - } - - - - @Test(dataProvider = "byteBinaryOpMaskProvider") - static void ROLByteMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - byte[] a = fa.apply(SPECIES.length()); - byte[] b = fb.apply(SPECIES.length()); - byte[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ByteVector av = ByteVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, ByteMaxVectorTests::ROL_unary); - } - static byte MIN(byte a, byte b) { return (byte)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Double128VectorTests.java b/test/jdk/jdk/incubator/vector/Double128VectorTests.java index a2dd0d44720..a5f9cad0921 100644 --- a/test/jdk/jdk/incubator/vector/Double128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Double128VectorTests.java @@ -1943,14 +1943,6 @@ public class Double128VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Double256VectorTests.java b/test/jdk/jdk/incubator/vector/Double256VectorTests.java index c7be717ef5f..b27d568fc8b 100644 --- a/test/jdk/jdk/incubator/vector/Double256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Double256VectorTests.java @@ -1943,14 +1943,6 @@ public class Double256VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Double512VectorTests.java b/test/jdk/jdk/incubator/vector/Double512VectorTests.java index ed7a2e470cb..5d5d53b57e6 100644 --- a/test/jdk/jdk/incubator/vector/Double512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Double512VectorTests.java @@ -1943,14 +1943,6 @@ public class Double512VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Double64VectorTests.java b/test/jdk/jdk/incubator/vector/Double64VectorTests.java index 20e70d70cc0..d17308715bc 100644 --- a/test/jdk/jdk/incubator/vector/Double64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Double64VectorTests.java @@ -1943,14 +1943,6 @@ public class Double64VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/DoubleMaxVectorTests.java b/test/jdk/jdk/incubator/vector/DoubleMaxVectorTests.java index ee136b9b32b..7f6ae5860eb 100644 --- a/test/jdk/jdk/incubator/vector/DoubleMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/DoubleMaxVectorTests.java @@ -1948,14 +1948,6 @@ public class DoubleMaxVectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Float128VectorTests.java b/test/jdk/jdk/incubator/vector/Float128VectorTests.java index 7e01f848864..465817c6c54 100644 --- a/test/jdk/jdk/incubator/vector/Float128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Float128VectorTests.java @@ -1953,14 +1953,6 @@ public class Float128VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Float256VectorTests.java b/test/jdk/jdk/incubator/vector/Float256VectorTests.java index 3ff38daa0a8..661b9d8a590 100644 --- a/test/jdk/jdk/incubator/vector/Float256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Float256VectorTests.java @@ -1953,14 +1953,6 @@ public class Float256VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Float512VectorTests.java b/test/jdk/jdk/incubator/vector/Float512VectorTests.java index e7d9e3fa532..a2bd05921bc 100644 --- a/test/jdk/jdk/incubator/vector/Float512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Float512VectorTests.java @@ -1953,14 +1953,6 @@ public class Float512VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Float64VectorTests.java b/test/jdk/jdk/incubator/vector/Float64VectorTests.java index e4c646623bb..6d325336941 100644 --- a/test/jdk/jdk/incubator/vector/Float64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Float64VectorTests.java @@ -1953,14 +1953,6 @@ public class Float64VectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/FloatMaxVectorTests.java b/test/jdk/jdk/incubator/vector/FloatMaxVectorTests.java index 23f01dcdb95..ee8ac1ab8f0 100644 --- a/test/jdk/jdk/incubator/vector/FloatMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/FloatMaxVectorTests.java @@ -1958,14 +1958,6 @@ public class FloatMaxVectorTests extends AbstractVectorTest { - - - - - - - - diff --git a/test/jdk/jdk/incubator/vector/Int128VectorTests.java b/test/jdk/jdk/incubator/vector/Int128VectorTests.java index 0493494d1c0..c45ea61f830 100644 --- a/test/jdk/jdk/incubator/vector/Int128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Int128VectorTests.java @@ -1113,14 +1113,6 @@ public class Int128VectorTests extends AbstractVectorTest { } } - static int ROL_scalar(int a, int b) { - return Integer.rotateLeft(a, ((int)b)); - } - - static int ROR_scalar(int a, int b) { - return Integer.rotateRight(a, ((int)b)); - } - static boolean eq(int a, int b) { return a == b; } @@ -2293,7 +2285,7 @@ public class Int128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHLInt128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLInt128VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2311,7 +2303,7 @@ public class Int128VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHLInt128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLInt128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2339,7 +2331,7 @@ public class Int128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHRInt128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRInt128VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2357,7 +2349,7 @@ public class Int128VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHRInt128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRInt128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2385,7 +2377,7 @@ public class Int128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void ASHRInt128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRInt128VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2403,7 +2395,7 @@ public class Int128VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void ASHRInt128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRInt128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2425,178 +2417,6 @@ public class Int128VectorTests extends AbstractVectorTest { - - static int ROR(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt128VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int128VectorTests::ROR); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int128VectorTests::ROR); - } - - - static int ROL(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt128VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int128VectorTests::ROL); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int128VectorTests::ROL); - } - - - static int ROR_unary(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int128VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int128VectorTests::ROR_unary); - } - - - static int ROL_unary(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int128VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int128VectorTests::ROL_unary); - } - static int MIN(int a, int b) { return (int)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Int256VectorTests.java b/test/jdk/jdk/incubator/vector/Int256VectorTests.java index 9b1872f33d1..121b5c37f5f 100644 --- a/test/jdk/jdk/incubator/vector/Int256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Int256VectorTests.java @@ -1113,14 +1113,6 @@ public class Int256VectorTests extends AbstractVectorTest { } } - static int ROL_scalar(int a, int b) { - return Integer.rotateLeft(a, ((int)b)); - } - - static int ROR_scalar(int a, int b) { - return Integer.rotateRight(a, ((int)b)); - } - static boolean eq(int a, int b) { return a == b; } @@ -2293,7 +2285,7 @@ public class Int256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHLInt256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLInt256VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2311,7 +2303,7 @@ public class Int256VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHLInt256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLInt256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2339,7 +2331,7 @@ public class Int256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHRInt256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRInt256VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2357,7 +2349,7 @@ public class Int256VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHRInt256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRInt256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2385,7 +2377,7 @@ public class Int256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void ASHRInt256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRInt256VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2403,7 +2395,7 @@ public class Int256VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void ASHRInt256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRInt256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2425,178 +2417,6 @@ public class Int256VectorTests extends AbstractVectorTest { - - static int ROR(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt256VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int256VectorTests::ROR); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int256VectorTests::ROR); - } - - - static int ROL(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt256VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int256VectorTests::ROL); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int256VectorTests::ROL); - } - - - static int ROR_unary(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int256VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int256VectorTests::ROR_unary); - } - - - static int ROL_unary(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int256VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int256VectorTests::ROL_unary); - } - static int MIN(int a, int b) { return (int)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Int512VectorTests.java b/test/jdk/jdk/incubator/vector/Int512VectorTests.java index 52dcf43e31b..23dcf6464e3 100644 --- a/test/jdk/jdk/incubator/vector/Int512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Int512VectorTests.java @@ -1113,14 +1113,6 @@ public class Int512VectorTests extends AbstractVectorTest { } } - static int ROL_scalar(int a, int b) { - return Integer.rotateLeft(a, ((int)b)); - } - - static int ROR_scalar(int a, int b) { - return Integer.rotateRight(a, ((int)b)); - } - static boolean eq(int a, int b) { return a == b; } @@ -2293,7 +2285,7 @@ public class Int512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHLInt512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLInt512VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2311,7 +2303,7 @@ public class Int512VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHLInt512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLInt512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2339,7 +2331,7 @@ public class Int512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHRInt512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRInt512VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2357,7 +2349,7 @@ public class Int512VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHRInt512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRInt512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2385,7 +2377,7 @@ public class Int512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void ASHRInt512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRInt512VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2403,7 +2395,7 @@ public class Int512VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void ASHRInt512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRInt512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2425,178 +2417,6 @@ public class Int512VectorTests extends AbstractVectorTest { - - static int ROR(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt512VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int512VectorTests::ROR); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int512VectorTests::ROR); - } - - - static int ROL(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt512VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int512VectorTests::ROL); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int512VectorTests::ROL); - } - - - static int ROR_unary(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int512VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int512VectorTests::ROR_unary); - } - - - static int ROL_unary(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int512VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int512VectorTests::ROL_unary); - } - static int MIN(int a, int b) { return (int)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Int64VectorTests.java b/test/jdk/jdk/incubator/vector/Int64VectorTests.java index 9d9fffcf246..0a442077f23 100644 --- a/test/jdk/jdk/incubator/vector/Int64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Int64VectorTests.java @@ -1113,14 +1113,6 @@ public class Int64VectorTests extends AbstractVectorTest { } } - static int ROL_scalar(int a, int b) { - return Integer.rotateLeft(a, ((int)b)); - } - - static int ROR_scalar(int a, int b) { - return Integer.rotateRight(a, ((int)b)); - } - static boolean eq(int a, int b) { return a == b; } @@ -2293,7 +2285,7 @@ public class Int64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHLInt64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLInt64VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2311,7 +2303,7 @@ public class Int64VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHLInt64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLInt64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2339,7 +2331,7 @@ public class Int64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHRInt64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRInt64VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2357,7 +2349,7 @@ public class Int64VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHRInt64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRInt64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2385,7 +2377,7 @@ public class Int64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void ASHRInt64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRInt64VectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2403,7 +2395,7 @@ public class Int64VectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void ASHRInt64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRInt64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2425,178 +2417,6 @@ public class Int64VectorTests extends AbstractVectorTest { - - static int ROR(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt64VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int64VectorTests::ROR); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int64VectorTests::ROR); - } - - - static int ROL(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt64VectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Int64VectorTests::ROL); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Int64VectorTests::ROL); - } - - - static int ROR_unary(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORInt64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int64VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORInt64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int64VectorTests::ROR_unary); - } - - - static int ROL_unary(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLInt64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Int64VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLInt64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Int64VectorTests::ROL_unary); - } - static int MIN(int a, int b) { return (int)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/IntMaxVectorTests.java b/test/jdk/jdk/incubator/vector/IntMaxVectorTests.java index d226226cac2..f8257ccbf92 100644 --- a/test/jdk/jdk/incubator/vector/IntMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/IntMaxVectorTests.java @@ -1118,14 +1118,6 @@ public class IntMaxVectorTests extends AbstractVectorTest { } } - static int ROL_scalar(int a, int b) { - return Integer.rotateLeft(a, ((int)b)); - } - - static int ROR_scalar(int a, int b) { - return Integer.rotateRight(a, ((int)b)); - } - static boolean eq(int a, int b) { return a == b; } @@ -2298,7 +2290,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHLIntMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLIntMaxVectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2316,7 +2308,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHLIntMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLIntMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2344,7 +2336,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void LSHRIntMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRIntMaxVectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2362,7 +2354,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void LSHRIntMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRIntMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2390,7 +2382,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "intBinaryOpProvider") - static void ASHRIntMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRIntMaxVectorTestsShift(IntFunction fa, IntFunction fb) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); int[] r = fr.apply(SPECIES.length()); @@ -2408,7 +2400,7 @@ public class IntMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "intBinaryOpMaskProvider") - static void ASHRIntMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRIntMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { int[] a = fa.apply(SPECIES.length()); int[] b = fb.apply(SPECIES.length()); @@ -2430,178 +2422,6 @@ public class IntMaxVectorTests extends AbstractVectorTest { - - static int ROR(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORIntMaxVectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, IntMaxVectorTests::ROR); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORIntMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, IntMaxVectorTests::ROR); - } - - - static int ROL(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLIntMaxVectorTests(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, IntMaxVectorTests::ROL); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLIntMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - IntVector bv = IntVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, IntMaxVectorTests::ROL); - } - - - static int ROR_unary(int a, int b) { - return (int)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void RORIntMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, IntMaxVectorTests::ROR_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void RORIntMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, IntMaxVectorTests::ROR_unary); - } - - - static int ROL_unary(int a, int b) { - return (int)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "intBinaryOpProvider") - static void ROLIntMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, IntMaxVectorTests::ROL_unary); - } - - - - @Test(dataProvider = "intBinaryOpMaskProvider") - static void ROLIntMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - int[] a = fa.apply(SPECIES.length()); - int[] b = fb.apply(SPECIES.length()); - int[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - IntVector av = IntVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, IntMaxVectorTests::ROL_unary); - } - static int MIN(int a, int b) { return (int)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Long128VectorTests.java b/test/jdk/jdk/incubator/vector/Long128VectorTests.java index 03d163a8a4c..20a1bfe900b 100644 --- a/test/jdk/jdk/incubator/vector/Long128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Long128VectorTests.java @@ -1135,14 +1135,6 @@ public class Long128VectorTests extends AbstractVectorTest { } } - static long ROL_scalar(long a, long b) { - return Long.rotateLeft(a, ((int)b)); - } - - static long ROR_scalar(long a, long b) { - return Long.rotateRight(a, ((int)b)); - } - static boolean eq(long a, long b) { return a == b; } @@ -2315,7 +2307,7 @@ public class Long128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHLLong128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLLong128VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2333,7 +2325,7 @@ public class Long128VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHLLong128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLLong128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2361,7 +2353,7 @@ public class Long128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHRLong128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRLong128VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2379,7 +2371,7 @@ public class Long128VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHRLong128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRLong128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2407,7 +2399,7 @@ public class Long128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void ASHRLong128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRLong128VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2425,7 +2417,7 @@ public class Long128VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void ASHRLong128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRLong128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2447,178 +2439,6 @@ public class Long128VectorTests extends AbstractVectorTest { - - static long ROR(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong128VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long128VectorTests::ROR); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long128VectorTests::ROR); - } - - - static long ROL(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong128VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long128VectorTests::ROL); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long128VectorTests::ROL); - } - - - static long ROR_unary(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long128VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long128VectorTests::ROR_unary); - } - - - static long ROL_unary(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long128VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long128VectorTests::ROL_unary); - } - static long MIN(long a, long b) { return (long)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Long256VectorTests.java b/test/jdk/jdk/incubator/vector/Long256VectorTests.java index 91a41519bb4..fd8493eff22 100644 --- a/test/jdk/jdk/incubator/vector/Long256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Long256VectorTests.java @@ -1135,14 +1135,6 @@ public class Long256VectorTests extends AbstractVectorTest { } } - static long ROL_scalar(long a, long b) { - return Long.rotateLeft(a, ((int)b)); - } - - static long ROR_scalar(long a, long b) { - return Long.rotateRight(a, ((int)b)); - } - static boolean eq(long a, long b) { return a == b; } @@ -2315,7 +2307,7 @@ public class Long256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHLLong256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLLong256VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2333,7 +2325,7 @@ public class Long256VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHLLong256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLLong256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2361,7 +2353,7 @@ public class Long256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHRLong256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRLong256VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2379,7 +2371,7 @@ public class Long256VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHRLong256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRLong256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2407,7 +2399,7 @@ public class Long256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void ASHRLong256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRLong256VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2425,7 +2417,7 @@ public class Long256VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void ASHRLong256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRLong256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2447,178 +2439,6 @@ public class Long256VectorTests extends AbstractVectorTest { - - static long ROR(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong256VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long256VectorTests::ROR); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long256VectorTests::ROR); - } - - - static long ROL(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong256VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long256VectorTests::ROL); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long256VectorTests::ROL); - } - - - static long ROR_unary(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long256VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long256VectorTests::ROR_unary); - } - - - static long ROL_unary(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long256VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long256VectorTests::ROL_unary); - } - static long MIN(long a, long b) { return (long)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Long512VectorTests.java b/test/jdk/jdk/incubator/vector/Long512VectorTests.java index 53fa4592fc6..05fcf160be2 100644 --- a/test/jdk/jdk/incubator/vector/Long512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Long512VectorTests.java @@ -1135,14 +1135,6 @@ public class Long512VectorTests extends AbstractVectorTest { } } - static long ROL_scalar(long a, long b) { - return Long.rotateLeft(a, ((int)b)); - } - - static long ROR_scalar(long a, long b) { - return Long.rotateRight(a, ((int)b)); - } - static boolean eq(long a, long b) { return a == b; } @@ -2315,7 +2307,7 @@ public class Long512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHLLong512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLLong512VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2333,7 +2325,7 @@ public class Long512VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHLLong512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLLong512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2361,7 +2353,7 @@ public class Long512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHRLong512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRLong512VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2379,7 +2371,7 @@ public class Long512VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHRLong512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRLong512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2407,7 +2399,7 @@ public class Long512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void ASHRLong512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRLong512VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2425,7 +2417,7 @@ public class Long512VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void ASHRLong512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRLong512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2447,178 +2439,6 @@ public class Long512VectorTests extends AbstractVectorTest { - - static long ROR(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong512VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long512VectorTests::ROR); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long512VectorTests::ROR); - } - - - static long ROL(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong512VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long512VectorTests::ROL); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long512VectorTests::ROL); - } - - - static long ROR_unary(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long512VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long512VectorTests::ROR_unary); - } - - - static long ROL_unary(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long512VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long512VectorTests::ROL_unary); - } - static long MIN(long a, long b) { return (long)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Long64VectorTests.java b/test/jdk/jdk/incubator/vector/Long64VectorTests.java index c8f9c31e499..1ed9c4895fc 100644 --- a/test/jdk/jdk/incubator/vector/Long64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Long64VectorTests.java @@ -1135,14 +1135,6 @@ public class Long64VectorTests extends AbstractVectorTest { } } - static long ROL_scalar(long a, long b) { - return Long.rotateLeft(a, ((int)b)); - } - - static long ROR_scalar(long a, long b) { - return Long.rotateRight(a, ((int)b)); - } - static boolean eq(long a, long b) { return a == b; } @@ -2315,7 +2307,7 @@ public class Long64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHLLong64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLLong64VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2333,7 +2325,7 @@ public class Long64VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHLLong64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLLong64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2361,7 +2353,7 @@ public class Long64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHRLong64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRLong64VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2379,7 +2371,7 @@ public class Long64VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHRLong64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRLong64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2407,7 +2399,7 @@ public class Long64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void ASHRLong64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRLong64VectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2425,7 +2417,7 @@ public class Long64VectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void ASHRLong64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRLong64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2447,178 +2439,6 @@ public class Long64VectorTests extends AbstractVectorTest { - - static long ROR(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong64VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long64VectorTests::ROR); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long64VectorTests::ROR); - } - - - static long ROL(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong64VectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Long64VectorTests::ROL); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Long64VectorTests::ROL); - } - - - static long ROR_unary(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLong64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long64VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLong64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long64VectorTests::ROR_unary); - } - - - static long ROL_unary(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLong64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Long64VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLong64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Long64VectorTests::ROL_unary); - } - static long MIN(long a, long b) { return (long)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/LongMaxVectorTests.java b/test/jdk/jdk/incubator/vector/LongMaxVectorTests.java index e5cd61eca74..c3612dab831 100644 --- a/test/jdk/jdk/incubator/vector/LongMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/LongMaxVectorTests.java @@ -1140,14 +1140,6 @@ public class LongMaxVectorTests extends AbstractVectorTest { } } - static long ROL_scalar(long a, long b) { - return Long.rotateLeft(a, ((int)b)); - } - - static long ROR_scalar(long a, long b) { - return Long.rotateRight(a, ((int)b)); - } - static boolean eq(long a, long b) { return a == b; } @@ -2320,7 +2312,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHLLongMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLLongMaxVectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2338,7 +2330,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHLLongMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLLongMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2366,7 +2358,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void LSHRLongMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRLongMaxVectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2384,7 +2376,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void LSHRLongMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRLongMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2412,7 +2404,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "longBinaryOpProvider") - static void ASHRLongMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRLongMaxVectorTestsShift(IntFunction fa, IntFunction fb) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); long[] r = fr.apply(SPECIES.length()); @@ -2430,7 +2422,7 @@ public class LongMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "longBinaryOpMaskProvider") - static void ASHRLongMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRLongMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { long[] a = fa.apply(SPECIES.length()); long[] b = fb.apply(SPECIES.length()); @@ -2452,178 +2444,6 @@ public class LongMaxVectorTests extends AbstractVectorTest { - - static long ROR(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLongMaxVectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, LongMaxVectorTests::ROR); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLongMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, LongMaxVectorTests::ROR); - } - - - static long ROL(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLongMaxVectorTests(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, LongMaxVectorTests::ROL); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLongMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - LongVector bv = LongVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, LongMaxVectorTests::ROL); - } - - - static long ROR_unary(long a, long b) { - return (long)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void RORLongMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, LongMaxVectorTests::ROR_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void RORLongMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, LongMaxVectorTests::ROR_unary); - } - - - static long ROL_unary(long a, long b) { - return (long)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "longBinaryOpProvider") - static void ROLLongMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, LongMaxVectorTests::ROL_unary); - } - - - - @Test(dataProvider = "longBinaryOpMaskProvider") - static void ROLLongMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - long[] a = fa.apply(SPECIES.length()); - long[] b = fb.apply(SPECIES.length()); - long[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - LongVector av = LongVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, LongMaxVectorTests::ROL_unary); - } - static long MIN(long a, long b) { return (long)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Short128VectorTests.java b/test/jdk/jdk/incubator/vector/Short128VectorTests.java index 88eca9e1d9a..50dc41bc7db 100644 --- a/test/jdk/jdk/incubator/vector/Short128VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Short128VectorTests.java @@ -1143,14 +1143,6 @@ public class Short128VectorTests extends AbstractVectorTest { } } - static short ROL_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); - } - - static short ROR_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); - } - static boolean eq(short a, short b) { return a == b; } @@ -2322,7 +2314,7 @@ public class Short128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHLShort128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLShort128VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2340,7 +2332,7 @@ public class Short128VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHLShort128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLShort128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2368,7 +2360,7 @@ public class Short128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHRShort128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRShort128VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2386,7 +2378,7 @@ public class Short128VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHRShort128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRShort128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2414,7 +2406,7 @@ public class Short128VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void ASHRShort128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRShort128VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2432,7 +2424,7 @@ public class Short128VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ASHRShort128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRShort128VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2450,178 +2442,6 @@ public class Short128VectorTests extends AbstractVectorTest { assertShiftArraysEquals(r, a, b, mask, Short128VectorTests::ASHR_unary); } - - static short ROR(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort128VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short128VectorTests::ROR); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short128VectorTests::ROR); - } - - - static short ROL(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort128VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short128VectorTests::ROL); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort128VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short128VectorTests::ROL); - } - - - static short ROR_unary(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short128VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short128VectorTests::ROR_unary); - } - - - static short ROL_unary(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort128VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short128VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort128VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short128VectorTests::ROL_unary); - } - static short MIN(short a, short b) { return (short)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Short256VectorTests.java b/test/jdk/jdk/incubator/vector/Short256VectorTests.java index bc33a302cec..6c1d460b1a2 100644 --- a/test/jdk/jdk/incubator/vector/Short256VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Short256VectorTests.java @@ -1143,14 +1143,6 @@ public class Short256VectorTests extends AbstractVectorTest { } } - static short ROL_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); - } - - static short ROR_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); - } - static boolean eq(short a, short b) { return a == b; } @@ -2322,7 +2314,7 @@ public class Short256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHLShort256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLShort256VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2340,7 +2332,7 @@ public class Short256VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHLShort256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLShort256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2368,7 +2360,7 @@ public class Short256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHRShort256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRShort256VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2386,7 +2378,7 @@ public class Short256VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHRShort256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRShort256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2414,7 +2406,7 @@ public class Short256VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void ASHRShort256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRShort256VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2432,7 +2424,7 @@ public class Short256VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ASHRShort256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRShort256VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2450,178 +2442,6 @@ public class Short256VectorTests extends AbstractVectorTest { assertShiftArraysEquals(r, a, b, mask, Short256VectorTests::ASHR_unary); } - - static short ROR(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort256VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short256VectorTests::ROR); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short256VectorTests::ROR); - } - - - static short ROL(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort256VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short256VectorTests::ROL); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort256VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short256VectorTests::ROL); - } - - - static short ROR_unary(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short256VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short256VectorTests::ROR_unary); - } - - - static short ROL_unary(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort256VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short256VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort256VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short256VectorTests::ROL_unary); - } - static short MIN(short a, short b) { return (short)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Short512VectorTests.java b/test/jdk/jdk/incubator/vector/Short512VectorTests.java index b33134d6225..9410b3c8579 100644 --- a/test/jdk/jdk/incubator/vector/Short512VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Short512VectorTests.java @@ -1143,14 +1143,6 @@ public class Short512VectorTests extends AbstractVectorTest { } } - static short ROL_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); - } - - static short ROR_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); - } - static boolean eq(short a, short b) { return a == b; } @@ -2322,7 +2314,7 @@ public class Short512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHLShort512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLShort512VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2340,7 +2332,7 @@ public class Short512VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHLShort512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLShort512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2368,7 +2360,7 @@ public class Short512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHRShort512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRShort512VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2386,7 +2378,7 @@ public class Short512VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHRShort512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRShort512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2414,7 +2406,7 @@ public class Short512VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void ASHRShort512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRShort512VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2432,7 +2424,7 @@ public class Short512VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ASHRShort512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRShort512VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2450,178 +2442,6 @@ public class Short512VectorTests extends AbstractVectorTest { assertShiftArraysEquals(r, a, b, mask, Short512VectorTests::ASHR_unary); } - - static short ROR(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort512VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short512VectorTests::ROR); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short512VectorTests::ROR); - } - - - static short ROL(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort512VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short512VectorTests::ROL); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort512VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short512VectorTests::ROL); - } - - - static short ROR_unary(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short512VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short512VectorTests::ROR_unary); - } - - - static short ROL_unary(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort512VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short512VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort512VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short512VectorTests::ROL_unary); - } - static short MIN(short a, short b) { return (short)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/Short64VectorTests.java b/test/jdk/jdk/incubator/vector/Short64VectorTests.java index af7dd74ac0e..a6fc3dd3e03 100644 --- a/test/jdk/jdk/incubator/vector/Short64VectorTests.java +++ b/test/jdk/jdk/incubator/vector/Short64VectorTests.java @@ -1143,14 +1143,6 @@ public class Short64VectorTests extends AbstractVectorTest { } } - static short ROL_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); - } - - static short ROR_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); - } - static boolean eq(short a, short b) { return a == b; } @@ -2322,7 +2314,7 @@ public class Short64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHLShort64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLShort64VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2340,7 +2332,7 @@ public class Short64VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHLShort64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLShort64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2368,7 +2360,7 @@ public class Short64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHRShort64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRShort64VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2386,7 +2378,7 @@ public class Short64VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHRShort64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRShort64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2414,7 +2406,7 @@ public class Short64VectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void ASHRShort64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRShort64VectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2432,7 +2424,7 @@ public class Short64VectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ASHRShort64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRShort64VectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2450,178 +2442,6 @@ public class Short64VectorTests extends AbstractVectorTest { assertShiftArraysEquals(r, a, b, mask, Short64VectorTests::ASHR_unary); } - - static short ROR(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort64VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short64VectorTests::ROR); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short64VectorTests::ROR); - } - - - static short ROL(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort64VectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, Short64VectorTests::ROL); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort64VectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, Short64VectorTests::ROL); - } - - - static short ROR_unary(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShort64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short64VectorTests::ROR_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShort64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short64VectorTests::ROR_unary); - } - - - static short ROL_unary(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShort64VectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, Short64VectorTests::ROL_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShort64VectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, Short64VectorTests::ROL_unary); - } - static short MIN(short a, short b) { return (short)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/ShortMaxVectorTests.java b/test/jdk/jdk/incubator/vector/ShortMaxVectorTests.java index 04681e6985d..4653a8fb32a 100644 --- a/test/jdk/jdk/incubator/vector/ShortMaxVectorTests.java +++ b/test/jdk/jdk/incubator/vector/ShortMaxVectorTests.java @@ -1148,14 +1148,6 @@ public class ShortMaxVectorTests extends AbstractVectorTest { } } - static short ROL_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); - } - - static short ROR_scalar(short a, short b) { - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); - } - static boolean eq(short a, short b) { return a == b; } @@ -2327,7 +2319,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHLShortMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHLShortMaxVectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2345,7 +2337,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHLShortMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHLShortMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2373,7 +2365,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void LSHRShortMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void LSHRShortMaxVectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2391,7 +2383,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void LSHRShortMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void LSHRShortMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2419,7 +2411,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { } @Test(dataProvider = "shortBinaryOpProvider") - static void ASHRShortMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { + static void ASHRShortMaxVectorTestsShift(IntFunction fa, IntFunction fb) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); short[] r = fr.apply(SPECIES.length()); @@ -2437,7 +2429,7 @@ public class ShortMaxVectorTests extends AbstractVectorTest { @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ASHRShortMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, + static void ASHRShortMaxVectorTestsShift(IntFunction fa, IntFunction fb, IntFunction fm) { short[] a = fa.apply(SPECIES.length()); short[] b = fb.apply(SPECIES.length()); @@ -2455,178 +2447,6 @@ public class ShortMaxVectorTests extends AbstractVectorTest { assertShiftArraysEquals(r, a, b, mask, ShortMaxVectorTests::ASHR_unary); } - - static short ROR(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShortMaxVectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, ShortMaxVectorTests::ROR); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShortMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROR, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, ShortMaxVectorTests::ROR); - } - - - static short ROL(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShortMaxVectorTests(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, ShortMaxVectorTests::ROL); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShortMaxVectorTestsMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - ShortVector bv = ShortVector.fromArray(SPECIES, b, i); - av.lanewise(VectorOperators.ROL, bv, vmask).intoArray(r, i); - } - } - - assertArraysEquals(r, a, b, mask, ShortMaxVectorTests::ROL); - } - - - static short ROR_unary(short a, short b) { - return (short)(ROR_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void RORShortMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, ShortMaxVectorTests::ROR_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void RORShortMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROR, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, ShortMaxVectorTests::ROR_unary); - } - - - static short ROL_unary(short a, short b) { - return (short)(ROL_scalar(a,b)); - } - - @Test(dataProvider = "shortBinaryOpProvider") - static void ROLShortMaxVectorTestsScalarShift(IntFunction fa, IntFunction fb) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i]).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, ShortMaxVectorTests::ROL_unary); - } - - - - @Test(dataProvider = "shortBinaryOpMaskProvider") - static void ROLShortMaxVectorTestsScalarShiftMasked(IntFunction fa, IntFunction fb, - IntFunction fm) { - short[] a = fa.apply(SPECIES.length()); - short[] b = fb.apply(SPECIES.length()); - short[] r = fr.apply(SPECIES.length()); - boolean[] mask = fm.apply(SPECIES.length()); - VectorMask vmask = VectorMask.fromArray(SPECIES, mask, 0); - - for (int ic = 0; ic < INVOC_COUNT; ic++) { - for (int i = 0; i < a.length; i += SPECIES.length()) { - ShortVector av = ShortVector.fromArray(SPECIES, a, i); - av.lanewise(VectorOperators.ROL, (int)b[i], vmask).intoArray(r, i); - } - } - - assertShiftArraysEquals(r, a, b, mask, ShortMaxVectorTests::ROL_unary); - } - static short MIN(short a, short b) { return (short)(Math.min(a, b)); } diff --git a/test/jdk/jdk/incubator/vector/gen-template.sh b/test/jdk/jdk/incubator/vector/gen-template.sh index 544cd0dc317..2f69f7d08af 100644 --- a/test/jdk/jdk/incubator/vector/gen-template.sh +++ b/test/jdk/jdk/incubator/vector/gen-template.sh @@ -99,9 +99,9 @@ function replace_variables { local kernel_smoke=${10} if [ "x${kernel}" != "x" ]; then - local kernel_escaped=$(echo -e "$kernel" | tr '\n' '`') + local kernel_escaped=$(echo -e "$kernel" | tr '\n' '|') sed "s/\[\[KERNEL\]\]/${kernel_escaped}/g" $filename > ${filename}.current1 - cat ${filename}.current1 | tr '`' "\n" > ${filename}.current + cat ${filename}.current1 | tr '|' "\n" > ${filename}.current rm -f "${filename}.current1" else cp $filename ${filename}.current @@ -156,9 +156,9 @@ function replace_variables { if [[ "$filename" == *"Unit"* ]] && [ "$test_func" != "" ]; then if [ "$masked" == "" ] || [ "$withMask" != "" ]; then if [ ! -z "$kernel_smoke" ]; then - local kernel_smoke_escaped=$(echo -e "$kernel_smoke" | tr '\n' '`') + local kernel_smoke_escaped=$(echo -e "$kernel_smoke" | tr '\n' '|') sed "s/\[\[KERNEL\]\]/${kernel_smoke_escaped}/g" $filename > ${filename}.scurrent1 - cat ${filename}.scurrent1 | tr '`' "\n" > ${filename}.scurrent + cat ${filename}.scurrent1 | tr '|' "\n" > ${filename}.scurrent rm -f "${filename}.scurrent1" else cp $filename.current ${filename}.scurrent @@ -445,10 +445,6 @@ gen_shift_cst_op "LSHR" "((a \& 0xFFFF) >>> (b \& 15))" "short" gen_shift_cst_op "ASHR" "(a >> b)" "intOrLong" gen_shift_cst_op "ASHR" "(a >> (b \& 7))" "byte" gen_shift_cst_op "ASHR" "(a >> (b \& 15))" "short" -gen_binary_alu_op "ROR" "ROR_scalar(a,b)" "BITWISE" -gen_binary_alu_op "ROL" "ROL_scalar(a,b)" "BITWISE" -gen_shift_cst_op "ROR" "ROR_scalar(a,b)" "BITWISE" -gen_shift_cst_op "ROL" "ROL_scalar(a,b)" "BITWISE" # Masked reductions. gen_binary_op_no_masked "MIN+min" "Math.min(a, b)" diff --git a/test/jdk/jdk/incubator/vector/templates/Unit-Shift-Masked-op.template b/test/jdk/jdk/incubator/vector/templates/Unit-Shift-Masked-op.template index 78d7c468eda..608217c3571 100644 --- a/test/jdk/jdk/incubator/vector/templates/Unit-Shift-Masked-op.template +++ b/test/jdk/jdk/incubator/vector/templates/Unit-Shift-Masked-op.template @@ -1,6 +1,6 @@ @Test(dataProvider = "$type$BinaryOpMaskProvider") - static void [[TEST]]$vectorteststype$ScalarShiftMasked(IntFunction<$type$[]> fa, IntFunction<$type$[]> fb, + static void [[TEST]]$vectorteststype$Shift(IntFunction<$type$[]> fa, IntFunction<$type$[]> fb, IntFunction fm) { [[KERNEL]] assertShiftArraysEquals(r, a, b, mask, $vectorteststype$::[[TEST]]_unary); diff --git a/test/jdk/jdk/incubator/vector/templates/Unit-Shift-op.template b/test/jdk/jdk/incubator/vector/templates/Unit-Shift-op.template index bee542c2586..b225da4b22b 100644 --- a/test/jdk/jdk/incubator/vector/templates/Unit-Shift-op.template +++ b/test/jdk/jdk/incubator/vector/templates/Unit-Shift-op.template @@ -3,7 +3,7 @@ } @Test(dataProvider = "$type$BinaryOpProvider") - static void [[TEST]]$vectorteststype$ScalarShift(IntFunction<$type$[]> fa, IntFunction<$type$[]> fb) { + static void [[TEST]]$vectorteststype$Shift(IntFunction<$type$[]> fa, IntFunction<$type$[]> fb) { [[KERNEL]] assertShiftArraysEquals(r, a, b, $vectorteststype$::[[TEST]]_unary); } diff --git a/test/jdk/jdk/incubator/vector/templates/Unit-header.template b/test/jdk/jdk/incubator/vector/templates/Unit-header.template index 0cbb3447340..4c0fd5bdfb9 100644 --- a/test/jdk/jdk/incubator/vector/templates/Unit-header.template +++ b/test/jdk/jdk/incubator/vector/templates/Unit-header.template @@ -1383,30 +1383,6 @@ public class $vectorteststype$ extends AbstractVectorTest { } } } - - static $type$ ROL_scalar($type$ a, $type$ b) { -#if[intOrLong] - return $Wideboxtype$.rotateLeft(a, ((int)b)); -#else[intOrLong] -#if[short] - return (short)(((((short)a) & 0xFFFF) << (b & 15)) | ((((short)a) & 0xFFFF) >>> (16 - (b & 15)))); -#else[short] - return (byte)(((((byte)a) & 0xFF) << (b & 7)) | ((((byte)a) & 0xFF) >>> (8 - (b & 7)))); -#end[short] -#end[intOrLong] - } - - static $type$ ROR_scalar($type$ a, $type$ b) { -#if[intOrLong] - return $Wideboxtype$.rotateRight(a, ((int)b)); -#else[intOrLong] -#if[short] - return (short)(((((short)a) & 0xFFFF) >>> (b & 15)) | ((((short)a) & 0xFFFF) << (16 - (b & 15)))); -#else[short] - return (byte)(((((byte)a) & 0xFF) >>> (b & 7)) | ((((byte)a) & 0xFF) << (8 - (b & 7)))); -#end[short] -#end[intOrLong] - } #end[BITWISE] static boolean eq($type$ a, $type$ b) { diff --git a/test/micro/org/openjdk/bench/jdk/incubator/vector/RotateBenchmark.java b/test/micro/org/openjdk/bench/jdk/incubator/vector/RotateBenchmark.java deleted file mode 100644 index cb898f82795..00000000000 --- a/test/micro/org/openjdk/bench/jdk/incubator/vector/RotateBenchmark.java +++ /dev/null @@ -1,214 +0,0 @@ -// -// Copyright (c) 2021 Oracle and/or its affiliates. All rights reserved. -// DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. -// -// This code is free software; you can redistribute it and/or modify it -// under the terms of the GNU General Public License version 2 only, as -// published by the Free Software Foundation. -// -// This code is distributed in the hope that it will be useful, but WITHOUT -// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or -// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License -// version 2 for more details (a copy is included in the LICENSE file that -// accompanied this code). -// -// You should have received a copy of the GNU General Public License version -// 2 along with this work; if not, write to the Free Software Foundation, -// Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. -// -// Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA -// or visit www.oracle.com if you need additional information or have any -// questions. -// -// -package org.openjdk.bench.jdk.incubator.vector; - -import java.util.Random; -import jdk.incubator.vector.*; -import java.util.concurrent.TimeUnit; -import org.openjdk.jmh.annotations.*; -import org.openjdk.jmh.infra.Blackhole; - -@OutputTimeUnit(TimeUnit.MILLISECONDS) -@State(Scope.Thread) -public class RotateBenchmark { - @Param({"256","512"}) - int size; - - @Param({"128","256", "512"}) - int bits; - - @Param({"7","15","31"}) - int shift; - - byte[] byteinp; - byte[] byteres; - - short[] shortinp; - short[] shortres; - - int[] intinp; - int[] intres; - - long[] longinp; - long[] longres; - - VectorSpecies bspecies; - VectorSpecies sspecies; - VectorSpecies ispecies; - VectorSpecies lspecies; - - static final byte[] specialvalsbyte = {0, -0, Byte.MIN_VALUE, Byte.MAX_VALUE}; - static final short[] specialvalsshort = {0, -0, Short.MIN_VALUE, Short.MAX_VALUE}; - static final int[] specialvalsint = {0, -0, Integer.MIN_VALUE, Integer.MAX_VALUE}; - static final long[] specialvalslong = {0L, -0L, Long.MIN_VALUE, Long.MAX_VALUE}; - - @Setup(Level.Trial) - public void BmSetup() { - Random r = new Random(1024); - byteinp = new byte[size]; - byteres = new byte[size]; - shortinp = new short[size]; - shortres = new short[size]; - intinp = new int[size]; - intres = new int[size]; - longinp = new long[size]; - longres = new long[size]; - - bspecies = VectorSpecies.of(byte.class, VectorShape.forBitSize(bits)); - sspecies = VectorSpecies.of(short.class, VectorShape.forBitSize(bits)); - ispecies = VectorSpecies.of(int.class, VectorShape.forBitSize(bits)); - lspecies = VectorSpecies.of(long.class, VectorShape.forBitSize(bits)); - - for (int i = 4; i < size; i++) { - byteinp[i] = (byte)i; - shortinp[i] = (short)i; - intinp[i] = i; - longinp[i] = i; - } - for (int i = 0; i < specialvalsbyte.length; i++) { - byteinp[i] = specialvalsbyte[i]; - } - for (int i = 0; i < specialvalsshort.length; i++) { - shortinp[i] = specialvalsshort[i]; - } - for (int i = 0; i < specialvalsint.length; i++) { - intinp[i] = specialvalsint[i]; - } - for (int i = 0; i < specialvalslong.length; i++) { - longinp[i] = specialvalslong[i]; - } - } - - @Benchmark - public void testRotateLeftB() { - for (int j = 0; j < size; j += bspecies.length()) { - ByteVector.fromArray(bspecies, byteinp, j) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift).intoArray(byteres, j); - } - } - - @Benchmark - public void testRotateRightB() { - for (int j = 0; j < size; j += bspecies.length()) { - ByteVector.fromArray(bspecies, byteinp, j) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift).intoArray(byteres, j); - } - } - - @Benchmark - public void testRotateLeftS() { - for (int j = 0; j < size; j += sspecies.length()) { - ShortVector.fromArray(sspecies, shortinp, j) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift).intoArray(shortres, j); - } - } - - @Benchmark - public void testRotateRightS() { - for (int j = 0; j < size; j += sspecies.length()) { - ShortVector.fromArray(sspecies, shortinp, j) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift).intoArray(shortres, j); - } - } - - @Benchmark - public void testRotateLeftI() { - for (int j = 0; j < size; j += ispecies.length()) { - IntVector.fromArray(ispecies, intinp, j) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift).intoArray(intres, j); - } - } - - @Benchmark - public void testRotateRightI() { - for (int j = 0; j < size; j += ispecies.length()) { - IntVector.fromArray(ispecies, intinp, j) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift).intoArray(intres, j); - } - } - - @Benchmark - public void testRotateLeftL() { - for (int j = 0; j < size; j += lspecies.length()) { - LongVector.fromArray(lspecies, longinp, j) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift) - .lanewise(VectorOperators.ROL, shift).intoArray(longres, j); - } - } - - @Benchmark - public void testRotateRightL() { - for (int j = 0; j < size; j += lspecies.length()) { - LongVector.fromArray(lspecies, longinp, j) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift) - .lanewise(VectorOperators.ROR, shift).intoArray(longres, j); - } - } -}