summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/445-checker-licm/src/Main.java28
-rw-r--r--test/603-checker-instanceof/src/Main.java40
2 files changed, 65 insertions, 3 deletions
diff --git a/test/445-checker-licm/src/Main.java b/test/445-checker-licm/src/Main.java
index 00ce3a9f8e..9635e70278 100644
--- a/test/445-checker-licm/src/Main.java
+++ b/test/445-checker-licm/src/Main.java
@@ -15,6 +15,11 @@
*/
public class Main {
+ static class Dummy {
+ static int getValue() {
+ return 1;
+ }
+ }
/// CHECK-START: int Main.div() licm (before)
/// CHECK-DAG: Div loop:{{B\d+}}
@@ -107,6 +112,28 @@ public class Main {
return result;
}
+ /// CHECK-START: int Main.clinitCheck() licm (before)
+ /// CHECK-DAG: <<LoadClass:l\d+>> LoadClass loop:<<Loop:B\d+>>
+ /// CHECK-DAG: ClinitCheck [<<LoadClass>>] loop:<<Loop>>
+
+ /// CHECK-START: int Main.clinitCheck() licm (after)
+ /// CHECK-NOT: LoadClass loop:{{B\d+}}
+ /// CHECK-NOT: ClinitCheck loop:{{B\d+}}
+
+ /// CHECK-START: int Main.clinitCheck() licm (after)
+ /// CHECK-DAG: <<LoadClass:l\d+>> LoadClass loop:none
+ /// CHECK-DAG: ClinitCheck [<<LoadClass>>] loop:none
+
+ public static int clinitCheck() {
+ int i = 0;
+ int sum = 0;
+ do {
+ sum += Dummy.getValue();
+ i++;
+ } while (i < 10);
+ return sum;
+ }
+
/// CHECK-START: int Main.divAndIntrinsic(int[]) licm (before)
/// CHECK-DAG: Div loop:{{B\d+}}
@@ -213,6 +240,7 @@ public class Main {
assertEquals(18900, innerMul());
assertEquals(105, divByA(2, 0));
assertEquals(12, arrayLength(new int[] { 4, 8 }));
+ assertEquals(10, clinitCheck());
assertEquals(21, divAndIntrinsic(new int[] { 4, -2, 8, -3 }));
assertEquals(45, invariantBoundIntrinsic(-10));
assertEquals(30, invariantBodyIntrinsic(2, 3));
diff --git a/test/603-checker-instanceof/src/Main.java b/test/603-checker-instanceof/src/Main.java
index ddf4b92fba..1487969c03 100644
--- a/test/603-checker-instanceof/src/Main.java
+++ b/test/603-checker-instanceof/src/Main.java
@@ -22,12 +22,17 @@ class ChildClass extends SuperClass {
public class Main {
- /// CHECK-START: void Main.main(java.lang.String[]) builder (after)
+ public static void main(String[] args) {
+ test1();
+ test2();
+ }
+
+ /// CHECK-START: void Main.test1() builder (after)
/// CHECK: BoundType klass:SuperClass can_be_null:false exact:false
- /// CHECK-START: void Main.main(java.lang.String[]) builder (after)
+ /// CHECK-START: void Main.test1() builder (after)
/// CHECK-NOT: BoundType klass:SuperClass can_be_null:false exact:true
- public static void main(String[] args) {
+ public static void test1() {
Object obj = new ChildClass();
// We need a fixed point iteration to hit the bogus type update
@@ -45,4 +50,33 @@ public class Main {
}
}
}
+
+ /// CHECK-START-X86: boolean Main.$noinline$instanceOfString(java.lang.Object) disassembly (after)
+ /// CHECK: InstanceOf check_kind:exact_check
+ /// CHECK-NOT: {{.*fs:.*}}
+
+ /// CHECK-START-X86_64: boolean Main.$noinline$instanceOfString(java.lang.Object) disassembly (after)
+ /// CHECK: InstanceOf check_kind:exact_check
+ /// CHECK-NOT: {{.*gs:.*}}
+
+ /// CHECK-START-{ARM,ARM64}: boolean Main.$noinline$instanceOfString(java.lang.Object) disassembly (after)
+ /// CHECK: InstanceOf check_kind:exact_check
+ // For ARM and ARM64, the marking register (r8 and x20, respectively) can be used in
+ // non-CC configs for any other purpose, so we'd need a config-specific checker test.
+ // TODO: Add the checks when we support config-specific tests.
+ public static boolean $noinline$instanceOfString(Object o) {
+ // String is a final class, so `instanceof String` should use exact check.
+ // String is in the boot image, so we should avoid read barriers. The presence
+ // of the read barrier can be checked in the architecture-specific disassembly.
+ return o instanceof String;
+ }
+
+ public static void test2() {
+ if ($noinline$instanceOfString(new Object())) {
+ throw new Error();
+ }
+ if (!$noinline$instanceOfString(new String())) {
+ throw new Error();
+ }
+ }
}