xref: /aosp_15_r20/art/test/455-checker-gvn/src/Main.java (revision 795d594fd825385562da6b089ea9b2033f3abf5a)
1*795d594fSAndroid Build Coastguard Worker /*
2*795d594fSAndroid Build Coastguard Worker  * Copyright (C) 2014 The Android Open Source Project
3*795d594fSAndroid Build Coastguard Worker  *
4*795d594fSAndroid Build Coastguard Worker  * Licensed under the Apache License, Version 2.0 (the "License");
5*795d594fSAndroid Build Coastguard Worker  * you may not use this file except in compliance with the License.
6*795d594fSAndroid Build Coastguard Worker  * You may obtain a copy of the License at
7*795d594fSAndroid Build Coastguard Worker  *
8*795d594fSAndroid Build Coastguard Worker  *      http://www.apache.org/licenses/LICENSE-2.0
9*795d594fSAndroid Build Coastguard Worker  *
10*795d594fSAndroid Build Coastguard Worker  * Unless required by applicable law or agreed to in writing, software
11*795d594fSAndroid Build Coastguard Worker  * distributed under the License is distributed on an "AS IS" BASIS,
12*795d594fSAndroid Build Coastguard Worker  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*795d594fSAndroid Build Coastguard Worker  * See the License for the specific language governing permissions and
14*795d594fSAndroid Build Coastguard Worker  * limitations under the License.
15*795d594fSAndroid Build Coastguard Worker  */
16*795d594fSAndroid Build Coastguard Worker import java.lang.reflect.Method;
17*795d594fSAndroid Build Coastguard Worker 
18*795d594fSAndroid Build Coastguard Worker public class Main {
19*795d594fSAndroid Build Coastguard Worker 
20*795d594fSAndroid Build Coastguard Worker   private static int mX = 2;
21*795d594fSAndroid Build Coastguard Worker   private static int mY = -3;
22*795d594fSAndroid Build Coastguard Worker 
main(String[] args)23*795d594fSAndroid Build Coastguard Worker   public static void main(String[] args) {
24*795d594fSAndroid Build Coastguard Worker     System.out.println($noinline$foo(3, 4));
25*795d594fSAndroid Build Coastguard Worker     System.out.println($noinline$mulAndIntrinsic());
26*795d594fSAndroid Build Coastguard Worker     System.out.println($noinline$directIntrinsic(-5));
27*795d594fSAndroid Build Coastguard Worker     System.out.println($noinline$deoptimizeArray(new int[100]));
28*795d594fSAndroid Build Coastguard Worker   }
29*795d594fSAndroid Build Coastguard Worker 
$inline$add(int a, int b)30*795d594fSAndroid Build Coastguard Worker   private static int $inline$add(int a, int b) {
31*795d594fSAndroid Build Coastguard Worker     return a + b;
32*795d594fSAndroid Build Coastguard Worker   }
33*795d594fSAndroid Build Coastguard Worker 
34*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$foo(int, int) GVN (before)
35*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
36*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
37*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
38*795d594fSAndroid Build Coastguard Worker 
39*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$foo(int, int) GVN (after)
40*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
41*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
42*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: Add
$noinline$foo(int x, int y)43*795d594fSAndroid Build Coastguard Worker   public static int $noinline$foo(int x, int y) {
44*795d594fSAndroid Build Coastguard Worker     int sum1 = $inline$add(x, y);
45*795d594fSAndroid Build Coastguard Worker     int sum2 = $inline$add(y, x);
46*795d594fSAndroid Build Coastguard Worker     return sum1 + sum2;
47*795d594fSAndroid Build Coastguard Worker   }
48*795d594fSAndroid Build Coastguard Worker 
49*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$mulAndIntrinsic() GVN (before)
50*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
51*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
52*795d594fSAndroid Build Coastguard Worker   /// CHECK: Mul
53*795d594fSAndroid Build Coastguard Worker   /// CHECK: Abs
54*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
55*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
56*795d594fSAndroid Build Coastguard Worker   /// CHECK: Mul
57*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
58*795d594fSAndroid Build Coastguard Worker 
59*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$mulAndIntrinsic() GVN (after)
60*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
61*795d594fSAndroid Build Coastguard Worker   /// CHECK: StaticFieldGet
62*795d594fSAndroid Build Coastguard Worker   /// CHECK: Mul
63*795d594fSAndroid Build Coastguard Worker   /// CHECK: Abs
64*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: StaticFieldGet
65*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: StaticFieldGet
66*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: Mul
67*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
68*795d594fSAndroid Build Coastguard Worker 
$noinline$mulAndIntrinsic()69*795d594fSAndroid Build Coastguard Worker   public static int $noinline$mulAndIntrinsic() {
70*795d594fSAndroid Build Coastguard Worker     // The intermediate call to abs() does not kill
71*795d594fSAndroid Build Coastguard Worker     // the common subexpression on the multiplication.
72*795d594fSAndroid Build Coastguard Worker     int mul1 = mX * mY;
73*795d594fSAndroid Build Coastguard Worker     int abs  = Math.abs(mul1);
74*795d594fSAndroid Build Coastguard Worker     int mul2 = mY * mX;
75*795d594fSAndroid Build Coastguard Worker     return abs + mul2;
76*795d594fSAndroid Build Coastguard Worker   }
77*795d594fSAndroid Build Coastguard Worker 
78*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$directIntrinsic(int) GVN (before)
79*795d594fSAndroid Build Coastguard Worker   /// CHECK: Abs
80*795d594fSAndroid Build Coastguard Worker   /// CHECK: Abs
81*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
82*795d594fSAndroid Build Coastguard Worker 
83*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$directIntrinsic(int) GVN (after)
84*795d594fSAndroid Build Coastguard Worker   /// CHECK: Abs
85*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: Abs
86*795d594fSAndroid Build Coastguard Worker   /// CHECK: Add
87*795d594fSAndroid Build Coastguard Worker 
$noinline$directIntrinsic(int x)88*795d594fSAndroid Build Coastguard Worker   public static int $noinline$directIntrinsic(int x) {
89*795d594fSAndroid Build Coastguard Worker     // Here, the two calls to abs() themselves can be replaced with just one.
90*795d594fSAndroid Build Coastguard Worker     int abs1 = Math.abs(x);
91*795d594fSAndroid Build Coastguard Worker     int abs2 = Math.abs(x);
92*795d594fSAndroid Build Coastguard Worker     return abs1 + abs2;
93*795d594fSAndroid Build Coastguard Worker   }
94*795d594fSAndroid Build Coastguard Worker 
95*795d594fSAndroid Build Coastguard Worker   public static class MyList {
96*795d594fSAndroid Build Coastguard Worker     public int[] arr;
97*795d594fSAndroid Build Coastguard Worker   }
98*795d594fSAndroid Build Coastguard Worker 
99*795d594fSAndroid Build Coastguard Worker   // The 4 deoptimize are pairs of checking for null and array-length. The
100*795d594fSAndroid Build Coastguard Worker   // repetition is due to the two loops.
101*795d594fSAndroid Build Coastguard Worker   // NB This is a very degenerate example and improvements to our analysis could
102*795d594fSAndroid Build Coastguard Worker   // allow for this entire function to be removed.
103*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$deoptimizeArray(int[]) GVN$after_arch (before)
104*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
105*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
106*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
107*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
108*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: Deoptimize
109*795d594fSAndroid Build Coastguard Worker   // Get rid of redundant deoptimizes
110*795d594fSAndroid Build Coastguard Worker   /// CHECK-START: int Main.$noinline$deoptimizeArray(int[]) GVN$after_arch (after)
111*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
112*795d594fSAndroid Build Coastguard Worker   /// CHECK: Deoptimize
113*795d594fSAndroid Build Coastguard Worker   /// CHECK-NOT: Deoptimize
$noinline$deoptimizeArray(int[] arr)114*795d594fSAndroid Build Coastguard Worker   public static int $noinline$deoptimizeArray(int[] arr) {
115*795d594fSAndroid Build Coastguard Worker     if (arr == null) {
116*795d594fSAndroid Build Coastguard Worker       arr = new int[100];
117*795d594fSAndroid Build Coastguard Worker     }
118*795d594fSAndroid Build Coastguard Worker     for (int i = 0; i < 10; i++) {
119*795d594fSAndroid Build Coastguard Worker       arr[i] = i;
120*795d594fSAndroid Build Coastguard Worker     }
121*795d594fSAndroid Build Coastguard Worker     int sum = 0;
122*795d594fSAndroid Build Coastguard Worker     for (int i = 0; i < 10; i++) {
123*795d594fSAndroid Build Coastguard Worker       sum += arr[i];
124*795d594fSAndroid Build Coastguard Worker     }
125*795d594fSAndroid Build Coastguard Worker     return sum;
126*795d594fSAndroid Build Coastguard Worker   }
127*795d594fSAndroid Build Coastguard Worker }
128