8256585: Remove in-place conversion vector operators from Vector API

Reviewed-by: psandoz
This commit is contained in:
Sandhya Viswanathan 2020-11-23 18:48:16 +00:00
parent 18e8506412
commit 9de5d091ff
2 changed files with 3 additions and 133 deletions

View File

@ -3077,18 +3077,6 @@ public abstract class Vector<E> extends jdk.internal.vm.vector.VectorSupport.Vec
* of the output with zero bits, when there are no corresponding * of the output with zero bits, when there are no corresponding
* input bits. * input bits.
* *
* <p> As another variation of behavior, an in-place conversion
* can incorporate an expanding or contracting conversion, while
* retaining the same lane size between input and output.
*
* In the case of a contraction, the lane value is first converted
* to the smaller value, and then zero-padded (as if by a subsequent
* reinterpretation) before storing into the output lane.
*
* In the case of an expansion, the lane value is first truncated
* to the smaller value (as if by an initial reinterpretation),
* and then converted before storing into the output lane.
*
* <p> An expanding conversion such as {@code S2I} ({@code short} * <p> An expanding conversion such as {@code S2I} ({@code short}
* value to {@code int}) takes a scalar value and represents it * value to {@code int}) takes a scalar value and represents it
* in a larger format (always with some information redundancy). * in a larger format (always with some information redundancy).

View File

@ -395,42 +395,6 @@ public abstract class VectorOperators {
return ConversionImpl.ofReinterpret(dom, ran).check(from, to); return ConversionImpl.ofReinterpret(dom, ran).check(from, to);
} }
/**
* An in-place version of a narrowing
* conversion between two types.
* The output of the conversion must be no larger
* than the type {@code E}.
* Any unused lane bits are ignored and
* overwritten by zero bits (not a copied sign bit).
* @param <E> the domain and range type (boxed version of a lane type)
* @param conv the narrowing conversion to treat in-place
* @return a Java narrowing conversion,
* stored back to the original lane of type {@code E}
*/
@ForceInline
static <E> Conversion<E,E> ofNarrowing(Conversion<E,?> conv) {
Class<E> lt = conv.domainType();
return ConversionImpl.ofInplace((ConversionImpl<?,?>) conv, false).check(lt, lt);
}
/**
* An in-place version of a widening
* conversion between two types.
* The input of the conversion must be no larger
* than the type {@code E}.
* Any unused lane bits are ignored and
* overwritten by the result.
* @param <E> the domain and range type (boxed version of a lane type)
* @param conv the widening conversion to treat in-place
* @return a Java widening conversion,
* loading its input from same lane of type {@code E}
*/
@ForceInline
static <E> Conversion<E,E> ofWidening(Conversion<?,E> conv) {
Class<E> lt = conv.rangeType();
return ConversionImpl.ofInplace((ConversionImpl<?,?>) conv, true).check(lt, lt);
}
} }
/*package-private*/ /*package-private*/
@ -467,8 +431,7 @@ public abstract class VectorOperators {
VO_DOM_SHIFT = 4, VO_DOM_SHIFT = 4,
VO_DOM_RAN_MASK = 0x0FF, VO_DOM_RAN_MASK = 0x0FF,
VO_KIND_CAST = 0x000, VO_KIND_CAST = 0x000,
VO_KIND_BITWISE = 0x100, VO_KIND_BITWISE = 0x100;
VO_KIND_INPLACE = 0x200;
private static final HashMap<Integer, String> OPC_NAME private static final HashMap<Integer, String> OPC_NAME
= new HashMap<>(); = new HashMap<>();
@ -666,58 +629,6 @@ public abstract class VectorOperators {
public static final Conversion<Short,Integer> S2I = convert("S2I", 'C', short.class, int.class, VO_KIND_CAST, VO_ALL); public static final Conversion<Short,Integer> S2I = convert("S2I", 'C', short.class, int.class, VO_KIND_CAST, VO_ALL);
/** Convert {@code shortVal} to {@code (long)shortVal}. */ /** Convert {@code shortVal} to {@code (long)shortVal}. */
public static final Conversion<Short,Long> S2L = convert("S2L", 'C', short.class, long.class, VO_KIND_CAST, VO_ALL); public static final Conversion<Short,Long> S2L = convert("S2L", 'C', short.class, long.class, VO_KIND_CAST, VO_ALL);
/** In-place narrow {@code doubleVal} to {@code (byte)doubleVal} inside double. */
public static final Conversion<Double,Double> INPLACE_D2B = convert("INPLACE_D2B", 'N', double.class, double.class, VO_KIND_INPLACE + 0x78, VO_ALL);
/** In-place narrow {@code doubleVal} to {@code (float)doubleVal} inside double. */
public static final Conversion<Double,Double> INPLACE_D2F = convert("INPLACE_D2F", 'N', double.class, double.class, VO_KIND_INPLACE + 0x76, VO_ALL);
/** In-place narrow {@code doubleVal} to {@code (int)doubleVal} inside double. */
public static final Conversion<Double,Double> INPLACE_D2I = convert("INPLACE_D2I", 'N', double.class, double.class, VO_KIND_INPLACE + 0x7a, VO_ALL);
/** In-place narrow {@code doubleVal} to {@code (short)doubleVal} inside double. */
public static final Conversion<Double,Double> INPLACE_D2S = convert("INPLACE_D2S", 'N', double.class, double.class, VO_KIND_INPLACE + 0x79, VO_ALL);
/** In-place narrow {@code floatVal} to {@code (byte)floatVal} inside float. */
public static final Conversion<Float,Float> INPLACE_F2B = convert("INPLACE_F2B", 'N', float.class, float.class, VO_KIND_INPLACE + 0x68, VO_ALL);
/** In-place narrow {@code floatVal} to {@code (short)floatVal} inside float. */
public static final Conversion<Float,Float> INPLACE_F2S = convert("INPLACE_F2S", 'N', float.class, float.class, VO_KIND_INPLACE + 0x69, VO_ALL);
/** In-place narrow {@code intVal} to {@code (byte)intVal} inside int. */
public static final Conversion<Integer,Integer> INPLACE_I2B = convert("INPLACE_I2B", 'N', int.class, int.class, VO_KIND_INPLACE + 0xa8, VO_ALL);
/** In-place narrow {@code intVal} to {@code (short)intVal} inside int. */
public static final Conversion<Integer,Integer> INPLACE_I2S = convert("INPLACE_I2S", 'N', int.class, int.class, VO_KIND_INPLACE + 0xa9, VO_ALL);
/** In-place narrow {@code longVal} to {@code (byte)longVal} inside long. */
public static final Conversion<Long,Long> INPLACE_L2B = convert("INPLACE_L2B", 'N', long.class, long.class, VO_KIND_INPLACE + 0xb8, VO_ALL);
/** In-place narrow {@code longVal} to {@code (float)longVal} inside long. */
public static final Conversion<Long,Long> INPLACE_L2F = convert("INPLACE_L2F", 'N', long.class, long.class, VO_KIND_INPLACE + 0xb6, VO_ALL);
/** In-place narrow {@code longVal} to {@code (int)longVal} inside long. */
public static final Conversion<Long,Long> INPLACE_L2I = convert("INPLACE_L2I", 'N', long.class, long.class, VO_KIND_INPLACE + 0xba, VO_ALL);
/** In-place narrow {@code longVal} to {@code (short)longVal} inside long. */
public static final Conversion<Long,Long> INPLACE_L2S = convert("INPLACE_L2S", 'N', long.class, long.class, VO_KIND_INPLACE + 0xb9, VO_ALL);
/** In-place narrow {@code shortVal} to {@code (byte)shortVal} inside short. */
public static final Conversion<Short,Short> INPLACE_S2B = convert("INPLACE_S2B", 'N', short.class, short.class, VO_KIND_INPLACE + 0x98, VO_ALL);
/** In-place widen {@code byteVal} inside double to {@code (double)byteVal}. */
public static final Conversion<Double,Double> INPLACE_B2D = convert("INPLACE_B2D", 'W', double.class, double.class, VO_KIND_INPLACE + 0x87, VO_ALL);
/** In-place widen {@code byteVal} inside float to {@code (float)byteVal}. */
public static final Conversion<Float,Float> INPLACE_B2F = convert("INPLACE_B2F", 'W', float.class, float.class, VO_KIND_INPLACE + 0x86, VO_ALL);
/** In-place widen {@code byteVal} inside int to {@code (int)byteVal}. */
public static final Conversion<Integer,Integer> INPLACE_B2I = convert("INPLACE_B2I", 'W', int.class, int.class, VO_KIND_INPLACE + 0x8a, VO_ALL);
/** In-place widen {@code byteVal} inside long to {@code (long)byteVal}. */
public static final Conversion<Long,Long> INPLACE_B2L = convert("INPLACE_B2L", 'W', long.class, long.class, VO_KIND_INPLACE + 0x8b, VO_ALL);
/** In-place widen {@code byteVal} inside short to {@code (short)byteVal}. */
public static final Conversion<Short,Short> INPLACE_B2S = convert("INPLACE_B2S", 'W', short.class, short.class, VO_KIND_INPLACE + 0x89, VO_ALL);
/** In-place widen {@code floatVal} inside double to {@code (double)floatVal}. */
public static final Conversion<Double,Double> INPLACE_F2D = convert("INPLACE_F2D", 'W', double.class, double.class, VO_KIND_INPLACE + 0x67, VO_ALL);
/** In-place widen {@code floatVal} inside long to {@code (long)floatVal}. */
public static final Conversion<Long,Long> INPLACE_F2L = convert("INPLACE_F2L", 'W', long.class, long.class, VO_KIND_INPLACE + 0x6b, VO_ALL);
/** In-place widen {@code intVal} inside double to {@code (double)intVal}. */
public static final Conversion<Double,Double> INPLACE_I2D = convert("INPLACE_I2D", 'W', double.class, double.class, VO_KIND_INPLACE + 0xa7, VO_ALL);
/** In-place widen {@code intVal} inside long to {@code (long)intVal}. */
public static final Conversion<Long,Long> INPLACE_I2L = convert("INPLACE_I2L", 'W', long.class, long.class, VO_KIND_INPLACE + 0xab, VO_ALL);
/** In-place widen {@code shortVal} inside double to {@code (double)shortVal}. */
public static final Conversion<Double,Double> INPLACE_S2D = convert("INPLACE_S2D", 'W', double.class, double.class, VO_KIND_INPLACE + 0x97, VO_ALL);
/** In-place widen {@code shortVal} inside float to {@code (float)shortVal}. */
public static final Conversion<Float,Float> INPLACE_S2F = convert("INPLACE_S2F", 'W', float.class, float.class, VO_KIND_INPLACE + 0x96, VO_ALL);
/** In-place widen {@code shortVal} inside int to {@code (int)shortVal}. */
public static final Conversion<Integer,Integer> INPLACE_S2I = convert("INPLACE_S2I", 'W', int.class, int.class, VO_KIND_INPLACE + 0x9a, VO_ALL);
/** In-place widen {@code shortVal} inside long to {@code (long)shortVal}. */
public static final Conversion<Long,Long> INPLACE_S2L = convert("INPLACE_S2L", 'W', long.class, long.class, VO_KIND_INPLACE + 0x9b, VO_ALL);
/** Reinterpret bits of {@code doubleVal} as {@code long}. As if by {@link Double#doubleToRawLongBits(double)} */ /** Reinterpret bits of {@code doubleVal} as {@code long}. As if by {@link Double#doubleToRawLongBits(double)} */
public static final Conversion<Double,Long> REINTERPRET_D2L = convert("REINTERPRET_D2L", 'R', double.class, long.class, VO_KIND_BITWISE, VO_ALL); public static final Conversion<Double,Long> REINTERPRET_D2L = convert("REINTERPRET_D2L", 'R', double.class, long.class, VO_KIND_BITWISE, VO_ALL);
/** Reinterpret bits of {@code floatVal} as {@code int}. As if by {@link Float#floatToRawIntBits(float)} */ /** Reinterpret bits of {@code floatVal} as {@code int}. As if by {@link Float#floatToRawIntBits(float)} */
@ -796,9 +707,6 @@ public abstract class VectorOperators {
if (opCode >= 0) { if (opCode >= 0) {
if ((opCode & VO_DOM_RAN_MASK) == 0) { if ((opCode & VO_DOM_RAN_MASK) == 0) {
opCode += domran; opCode += domran;
} else {
// only the widening or narrowing guys specify their own opcode dom/ran
assert(dom == ran && "WN".indexOf(kind) >= 0);
} }
if ((flags & VO_PRIVATE) == 0) if ((flags & VO_PRIVATE) == 0)
CONV_OPC_NAME.put(opCode, name); CONV_OPC_NAME.put(opCode, name);
@ -1032,19 +940,6 @@ public abstract class VectorOperators {
// } // }
return findConv('R', dom, ran); return findConv('R', dom, ran);
} }
static ConversionImpl<?,?> ofInplace(ConversionImpl<?,?> conv,
boolean widening) {
int domSize = conv.dom.elementSize;
int ranSize = conv.ran.elementSize;
if (domSize >= ranSize && widening)
throw new IllegalArgumentException(conv + ": must be a widening conversion");
if (domSize <= ranSize && !widening)
throw new IllegalArgumentException(conv + ": must be a narrowing conversion");
if (conv.kind != 'C')
throw new IllegalArgumentException(conv + ": must be a standard Java conversion");
char kind = (widening ? 'W' : 'N');
return findConv(kind, conv.dom, conv.ran);
}
@ForceInline @ForceInline
private static ConversionImpl<?,?> private static ConversionImpl<?,?>
@ -1088,16 +983,6 @@ public abstract class VectorOperators {
name = "ZERO_EXTEND_"+a2b(dom, ran); name = "ZERO_EXTEND_"+a2b(dom, ran);
opCode = VO_KIND_BITWISE; opCode = VO_KIND_BITWISE;
break; break;
case 'W':
name = "INPLACE_"+a2b(dom, ran);
opCode += VO_KIND_INPLACE;
domType = ranType; // slice narrow domain from range
break;
case 'N':
name = "INPLACE_"+a2b(dom, ran);
opCode += VO_KIND_INPLACE;
ranType = domType; // zero-fill narrow range
break;
default: throw new AssertionError(); default: throw new AssertionError();
} }
ConversionImpl<?,?> conv = convert(name, kind, domType, ranType, opCode, VO_ALL); ConversionImpl<?,?> conv = convert(name, kind, domType, ranType, opCode, VO_ALL);
@ -1184,12 +1069,10 @@ public abstract class VectorOperators {
ArrayList<String> defs = new ArrayList<>(); ArrayList<String> defs = new ArrayList<>();
for (LaneType l1 : LaneType.values()) { for (LaneType l1 : LaneType.values()) {
for (LaneType l2 : LaneType.values()) { for (LaneType l2 : LaneType.values()) {
for (int i = 0; i <= 2; i++) { for (int i = 0; i <= 1; i++) {
ConversionImpl<?,?> c; ConversionImpl<?,?> c;
try { try {
c = ((i == 0) ? ofCast(l1, l2) : c = ((i == 0) ? ofCast(l1, l2) : ofReinterpret(l1, l2));
(i == 1) ? ofReinterpret(l1, l2) :
ofInplace(ofCast(l1, l2), (l1.elementSize < l2.elementSize)));
} catch (IllegalArgumentException ex) { } catch (IllegalArgumentException ex) {
assert((i == 1 && l1.elementSize != l2.elementSize) || assert((i == 1 && l1.elementSize != l2.elementSize) ||
(i == 2 && l1.elementSize == l2.elementSize)); (i == 2 && l1.elementSize == l2.elementSize));
@ -1206,7 +1089,6 @@ public abstract class VectorOperators {
switch (opc & ~VO_DOM_RAN_MASK) { switch (opc & ~VO_DOM_RAN_MASK) {
case VO_KIND_CAST: opcs = "VO_KIND_CAST"; break; case VO_KIND_CAST: opcs = "VO_KIND_CAST"; break;
case VO_KIND_BITWISE: opcs = "VO_KIND_BITWISE"; break; case VO_KIND_BITWISE: opcs = "VO_KIND_BITWISE"; break;
case VO_KIND_INPLACE: opcs = "VO_KIND_INPLACE"; break;
default: opcs = Integer.toHexString(opc); default: opcs = Integer.toHexString(opc);
} }
String code = c.genCode(opcs); String code = c.genCode(opcs);