From 496fb90b3a038f5fe76acc8a98bcd0dac4071cf9 Mon Sep 17 00:00:00 2001 From: Xiaohong Gong Date: Wed, 2 Jun 2021 07:50:46 +0000 Subject: [PATCH] 8267969: Add vectorized implementation for VectorMask.eq() Reviewed-by: psandoz, neliasso --- .../share/classes/jdk/incubator/vector/AbstractMask.java | 6 ------ .../share/classes/jdk/incubator/vector/Byte128Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Byte256Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Byte512Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Byte64Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/ByteMaxVector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Double128Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Double256Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Double512Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Double64Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/DoubleMaxVector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Float128Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Float256Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Float512Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Float64Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/FloatMaxVector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Int128Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Int256Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Int512Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Int64Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/IntMaxVector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Long128Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Long256Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Long512Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Long64Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/LongMaxVector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Short128Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Short256Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/Short512Vector.java | 8 ++++++++ .../share/classes/jdk/incubator/vector/Short64Vector.java | 8 ++++++++ .../classes/jdk/incubator/vector/ShortMaxVector.java | 8 ++++++++ .../jdk/incubator/vector/X-VectorBits.java.template | 8 ++++++++ 32 files changed, 248 insertions(+), 6 deletions(-) diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/AbstractMask.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/AbstractMask.java index 5169bad0d72..81855a4af7d 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/AbstractMask.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/AbstractMask.java @@ -114,12 +114,6 @@ abstract class AbstractMask extends VectorMask { return (VectorMask) this; } - @Override - public VectorMask eq(VectorMask m) { - // FIXME: Generate good code here. - return bOp(m, (i, a, b) -> a == b); - } - @Override public VectorMask andNot(VectorMask m) { return and(m.not()); diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte128Vector.java index a5215b785b4..bb31d1b0403 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte128Vector.java @@ -638,6 +638,14 @@ final class Byte128Vector extends ByteVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Byte128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Byte128Mask m = (Byte128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte256Vector.java index 6936059f5da..c72e72065a4 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte256Vector.java @@ -670,6 +670,14 @@ final class Byte256Vector extends ByteVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Byte256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Byte256Mask m = (Byte256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte512Vector.java index 96d852b1a80..402b35ef834 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte512Vector.java @@ -734,6 +734,14 @@ final class Byte512Vector extends ByteVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Byte512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Byte512Mask m = (Byte512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte64Vector.java index f49b43e319e..f50d980337d 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Byte64Vector.java @@ -622,6 +622,14 @@ final class Byte64Vector extends ByteVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Byte64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Byte64Mask m = (Byte64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteMaxVector.java index 502ee50f9e2..1d590d4b6c7 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ByteMaxVector.java @@ -608,6 +608,14 @@ final class ByteMaxVector extends ByteVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public ByteMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + ByteMaxMask m = (ByteMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double128Vector.java index 46c7be0eeda..a7adc2bf2ec 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double128Vector.java @@ -606,6 +606,14 @@ final class Double128Vector extends DoubleVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Double128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Double128Mask m = (Double128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double256Vector.java index 1d774b0cb0c..29a296a5832 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double256Vector.java @@ -610,6 +610,14 @@ final class Double256Vector extends DoubleVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Double256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Double256Mask m = (Double256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double512Vector.java index aec9bea4693..ed835bc49ce 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double512Vector.java @@ -618,6 +618,14 @@ final class Double512Vector extends DoubleVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Double512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Double512Mask m = (Double512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double64Vector.java index 78b9284b770..09dae24ebd4 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Double64Vector.java @@ -604,6 +604,14 @@ final class Double64Vector extends DoubleVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Double64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Double64Mask m = (Double64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleMaxVector.java index df0e6d786da..a810232da0a 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/DoubleMaxVector.java @@ -603,6 +603,14 @@ final class DoubleMaxVector extends DoubleVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public DoubleMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + DoubleMaxMask m = (DoubleMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float128Vector.java index 934605101b4..54715fbd81f 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float128Vector.java @@ -610,6 +610,14 @@ final class Float128Vector extends FloatVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Float128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Float128Mask m = (Float128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float256Vector.java index 05cc833b238..ea81890b282 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float256Vector.java @@ -618,6 +618,14 @@ final class Float256Vector extends FloatVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Float256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Float256Mask m = (Float256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float512Vector.java index 932fd6e5622..9a6ffc9dbb1 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float512Vector.java @@ -634,6 +634,14 @@ final class Float512Vector extends FloatVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Float512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Float512Mask m = (Float512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float64Vector.java index 7676544236b..81b0899bb83 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Float64Vector.java @@ -606,6 +606,14 @@ final class Float64Vector extends FloatVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Float64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Float64Mask m = (Float64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatMaxVector.java index b90a8c3cd5f..8cd8dd114ca 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/FloatMaxVector.java @@ -603,6 +603,14 @@ final class FloatMaxVector extends FloatVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public FloatMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + FloatMaxMask m = (FloatMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int128Vector.java index a83a5120eee..978cc2876b2 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int128Vector.java @@ -614,6 +614,14 @@ final class Int128Vector extends IntVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Int128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Int128Mask m = (Int128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int256Vector.java index 19d6ca4e68a..669c3181e0f 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int256Vector.java @@ -622,6 +622,14 @@ final class Int256Vector extends IntVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Int256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Int256Mask m = (Int256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int512Vector.java index f711675e10f..c29d14605f1 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int512Vector.java @@ -638,6 +638,14 @@ final class Int512Vector extends IntVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Int512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Int512Mask m = (Int512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int64Vector.java index 1cc6217b53b..5c2d884d0dd 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Int64Vector.java @@ -610,6 +610,14 @@ final class Int64Vector extends IntVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Int64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Int64Mask m = (Int64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntMaxVector.java index 3f06a7b76cf..ccdf7ea1da1 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/IntMaxVector.java @@ -608,6 +608,14 @@ final class IntMaxVector extends IntVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public IntMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + IntMaxMask m = (IntMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long128Vector.java index 78dd64147bc..0869111e87b 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long128Vector.java @@ -600,6 +600,14 @@ final class Long128Vector extends LongVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Long128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Long128Mask m = (Long128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long256Vector.java index 59a2656e361..904c405ea06 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long256Vector.java @@ -604,6 +604,14 @@ final class Long256Vector extends LongVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Long256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Long256Mask m = (Long256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long512Vector.java index 6a2a16e47b6..9d17b8dc3d5 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long512Vector.java @@ -612,6 +612,14 @@ final class Long512Vector extends LongVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Long512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Long512Mask m = (Long512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long64Vector.java index 8471e72e35d..3a7d4d6d231 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Long64Vector.java @@ -598,6 +598,14 @@ final class Long64Vector extends LongVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Long64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Long64Mask m = (Long64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongMaxVector.java index 358a33d3ae9..03f637c3f56 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/LongMaxVector.java @@ -598,6 +598,14 @@ final class LongMaxVector extends LongVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public LongMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + LongMaxMask m = (LongMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short128Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short128Vector.java index 32b1ac069a8..1144b494886 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short128Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short128Vector.java @@ -622,6 +622,14 @@ final class Short128Vector extends ShortVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Short128Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Short128Mask m = (Short128Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short256Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short256Vector.java index 3def18c1cdc..d49b1514f5c 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short256Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short256Vector.java @@ -638,6 +638,14 @@ final class Short256Vector extends ShortVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Short256Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Short256Mask m = (Short256Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short512Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short512Vector.java index a5bcc542238..d7819a8ae49 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short512Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short512Vector.java @@ -670,6 +670,14 @@ final class Short512Vector extends ShortVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Short512Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Short512Mask m = (Short512Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short64Vector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short64Vector.java index c4e9ce37234..4e4541ef4fa 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short64Vector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/Short64Vector.java @@ -614,6 +614,14 @@ final class Short64Vector extends ShortVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public Short64Mask eq(VectorMask mask) { + Objects.requireNonNull(mask); + Short64Mask m = (Short64Mask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortMaxVector.java b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortMaxVector.java index c696ed9ac95..ddfe8c8bbb8 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortMaxVector.java +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/ShortMaxVector.java @@ -608,6 +608,14 @@ final class ShortMaxVector extends ShortVector { return this.defaultMaskCast(species); } + @Override + @ForceInline + public ShortMaxMask eq(VectorMask mask) { + Objects.requireNonNull(mask); + ShortMaxMask m = (ShortMaxMask)mask; + return xor(m.not()); + } + // Unary operations @Override diff --git a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-VectorBits.java.template b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-VectorBits.java.template index 82f24c339b7..2d56bff1506 100644 --- a/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-VectorBits.java.template +++ b/src/jdk.incubator.vector/share/classes/jdk/incubator/vector/X-VectorBits.java.template @@ -881,6 +881,14 @@ final class $vectortype$ extends $abstractvectortype$ { return this.defaultMaskCast(species); } + @Override + @ForceInline + public $masktype$ eq(VectorMask<$Boxtype$> mask) { + Objects.requireNonNull(mask); + $masktype$ m = ($masktype$)mask; + return xor(m.not()); + } + // Unary operations @Override