--- a/test/hotspot/jtreg/compiler/c2/aarch64/TestUnsafeVolatileCAS.java Thu Oct 04 09:24:27 2018 +0200
+++ b/test/hotspot/jtreg/compiler/c2/aarch64/TestUnsafeVolatileCAS.java Mon Nov 05 12:53:55 2018 +0100
@@ -30,19 +30,34 @@
{
public volatile int f_int = 0;
public volatile Integer f_obj = Integer.valueOf(0);
+ public volatile long f_long = 0;
+ public volatile byte f_byte = 0;
+ public volatile short f_short = 0;
public static Unsafe unsafe = Unsafe.getUnsafe();
public static Field f_int_field;
public static Field f_obj_field;
+ public static Field f_long_field;
+ public static Field f_byte_field;
+ public static Field f_short_field;
public static long f_int_off;
public static long f_obj_off;
+ public static long f_long_off;
+ public static long f_byte_off;
+ public static long f_short_off;
static {
try {
f_int_field = TestUnsafeVolatileCAS.class.getField("f_int");
f_obj_field = TestUnsafeVolatileCAS.class.getField("f_obj");
+ f_long_field = TestUnsafeVolatileCAS.class.getField("f_long");
+ f_byte_field = TestUnsafeVolatileCAS.class.getField("f_byte");
+ f_short_field = TestUnsafeVolatileCAS.class.getField("f_short");
f_int_off = unsafe.objectFieldOffset(f_int_field);
f_obj_off = unsafe.objectFieldOffset(f_obj_field);
+ f_long_off = unsafe.objectFieldOffset(f_long_field);
+ f_byte_off = unsafe.objectFieldOffset(f_byte_field);
+ f_short_off = unsafe.objectFieldOffset(f_short_field);
} catch (Exception e) {
System.out.println("reflection failed " + e);
e.printStackTrace();
@@ -59,6 +74,29 @@
throw new RuntimeException("bad result!");
}
}
+ for (int i = 0; i < 100_000; i++) {
+ t.f_long = -1;
+ t.testLong(-1, i);
+ if (t.f_long != i) {
+ throw new RuntimeException("bad result!");
+ }
+ }
+ for (int i = 0; i < 100_000; i++) {
+ t.f_byte = -1;
+ byte i_b = (byte)i;
+ t.testByte((byte)-1, i_b);
+ if (t.f_byte != i_b) {
+ throw new RuntimeException("bad result!");
+ }
+ }
+ for (int i = 0; i < 100_000; i++) {
+ t.f_short = -1;
+ short i_s = (short)i;
+ t.testShort((byte)-1, i_s);
+ if (t.f_short != i_s) {
+ throw new RuntimeException("bad result!");
+ }
+ }
Integer minusOne = Integer.valueOf(-1);
for (int i = 0; i < 100_000; i++) {
t.f_obj = minusOne;
@@ -68,6 +106,7 @@
}
}
}
+
public void testInt(int x, int i)
{
unsafe.compareAndSetInt(this, f_int_off, x, i);
@@ -77,4 +116,19 @@
{
unsafe.compareAndSetReference(this, f_obj_off, x, o);
}
+
+ public void testLong(long x, long i)
+ {
+ unsafe.compareAndSetLong(this, f_long_off, x, i);
+ }
+
+ public void testByte(byte x, byte i)
+ {
+ unsafe.compareAndSetByte(this, f_byte_off, x, i);
+ }
+
+ public void testShort(short x, short i)
+ {
+ unsafe.compareAndSetShort(this, f_short_off, x, i);
+ }
}