1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2023 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 17*795d594fSAndroid Build Coastguard Worker public class Main { main(String[] args)18*795d594fSAndroid Build Coastguard Worker public static void main(String[] args) { 19*795d594fSAndroid Build Coastguard Worker $noinline$assertEquals(0, $noinline$pathologicalCase()); 20*795d594fSAndroid Build Coastguard Worker } 21*795d594fSAndroid Build Coastguard Worker $noinline$assertEquals(int expected, int result)22*795d594fSAndroid Build Coastguard Worker public static void $noinline$assertEquals(int expected, int result) { 23*795d594fSAndroid Build Coastguard Worker if (expected != result) { 24*795d594fSAndroid Build Coastguard Worker throw new Error("Expected: " + expected + ", found: " + result); 25*795d594fSAndroid Build Coastguard Worker } 26*795d594fSAndroid Build Coastguard Worker } 27*795d594fSAndroid Build Coastguard Worker 28*795d594fSAndroid Build Coastguard Worker // Empty $noinline$ method so that it doesn't get removed. $noinline$emptyMethod(int val)29*795d594fSAndroid Build Coastguard Worker private static void $noinline$emptyMethod(int val) {} 30*795d594fSAndroid Build Coastguard Worker 31*795d594fSAndroid Build Coastguard Worker // A pathological case which has > 15 loop header phis in a row. 32*795d594fSAndroid Build Coastguard Worker /// CHECK-START: int Main.$noinline$pathologicalCase() induction_var_analysis (before) 33*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Const0:i\d+>> IntConstant 0 34*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi1:i\d+>> Phi [<<Const0>>,<<Add1:i\d+>>] 35*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi2:i\d+>> Phi [<<Phi1>>,<<Add2:i\d+>>] 36*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi3:i\d+>> Phi [<<Phi2>>,<<Add3:i\d+>>] 37*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi4:i\d+>> Phi [<<Phi3>>,<<Add4:i\d+>>] 38*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi5:i\d+>> Phi [<<Phi4>>,<<Add5:i\d+>>] 39*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi6:i\d+>> Phi [<<Phi5>>,<<Add6:i\d+>>] 40*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi7:i\d+>> Phi [<<Phi6>>,<<Add7:i\d+>>] 41*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi8:i\d+>> Phi [<<Phi7>>,<<Add8:i\d+>>] 42*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi9:i\d+>> Phi [<<Phi8>>,<<Add9:i\d+>>] 43*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi10:i\d+>> Phi [<<Phi9>>,<<Add10:i\d+>>] 44*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi11:i\d+>> Phi [<<Phi10>>,<<Add11:i\d+>>] 45*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi12:i\d+>> Phi [<<Phi11>>,<<Add12:i\d+>>] 46*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi13:i\d+>> Phi [<<Phi12>>,<<Add13:i\d+>>] 47*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi14:i\d+>> Phi [<<Phi13>>,<<Add14:i\d+>>] 48*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi15:i\d+>> Phi [<<Phi14>>,<<Add15:i\d+>>] 49*795d594fSAndroid Build Coastguard Worker /// CHECK: <<Phi16:i\d+>> Phi [<<Phi15>>,<<Add16:i\d+>>] $noinline$pathologicalCase()50*795d594fSAndroid Build Coastguard Worker private static int $noinline$pathologicalCase() { 51*795d594fSAndroid Build Coastguard Worker int value = 0; 52*795d594fSAndroid Build Coastguard Worker for (; value < 3; value++) { 53*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 54*795d594fSAndroid Build Coastguard Worker } 55*795d594fSAndroid Build Coastguard Worker 56*795d594fSAndroid Build Coastguard Worker for (; value < 5; value++) { 57*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 58*795d594fSAndroid Build Coastguard Worker } 59*795d594fSAndroid Build Coastguard Worker 60*795d594fSAndroid Build Coastguard Worker for (; value < 7; value++) { 61*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 62*795d594fSAndroid Build Coastguard Worker } 63*795d594fSAndroid Build Coastguard Worker 64*795d594fSAndroid Build Coastguard Worker for (; value < 9; value++) { 65*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 66*795d594fSAndroid Build Coastguard Worker } 67*795d594fSAndroid Build Coastguard Worker 68*795d594fSAndroid Build Coastguard Worker for (; value < 11; value++) { 69*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 70*795d594fSAndroid Build Coastguard Worker } 71*795d594fSAndroid Build Coastguard Worker 72*795d594fSAndroid Build Coastguard Worker for (; value < 13; value++) { 73*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 74*795d594fSAndroid Build Coastguard Worker } 75*795d594fSAndroid Build Coastguard Worker 76*795d594fSAndroid Build Coastguard Worker for (; value < 15; value++) { 77*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 78*795d594fSAndroid Build Coastguard Worker } 79*795d594fSAndroid Build Coastguard Worker 80*795d594fSAndroid Build Coastguard Worker for (; value < 17; value++) { 81*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 82*795d594fSAndroid Build Coastguard Worker } 83*795d594fSAndroid Build Coastguard Worker 84*795d594fSAndroid Build Coastguard Worker for (; value < 19; value++) { 85*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 86*795d594fSAndroid Build Coastguard Worker } 87*795d594fSAndroid Build Coastguard Worker 88*795d594fSAndroid Build Coastguard Worker for (; value < 21; value++) { 89*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 90*795d594fSAndroid Build Coastguard Worker } 91*795d594fSAndroid Build Coastguard Worker 92*795d594fSAndroid Build Coastguard Worker for (; value < 23; value++) { 93*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 94*795d594fSAndroid Build Coastguard Worker } 95*795d594fSAndroid Build Coastguard Worker 96*795d594fSAndroid Build Coastguard Worker for (; value < 25; value++) { 97*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 98*795d594fSAndroid Build Coastguard Worker } 99*795d594fSAndroid Build Coastguard Worker 100*795d594fSAndroid Build Coastguard Worker for (; value < 27; value++) { 101*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 102*795d594fSAndroid Build Coastguard Worker } 103*795d594fSAndroid Build Coastguard Worker 104*795d594fSAndroid Build Coastguard Worker for (; value < 29; value++) { 105*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 106*795d594fSAndroid Build Coastguard Worker } 107*795d594fSAndroid Build Coastguard Worker 108*795d594fSAndroid Build Coastguard Worker for (; value < 31; value++) { 109*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 110*795d594fSAndroid Build Coastguard Worker } 111*795d594fSAndroid Build Coastguard Worker 112*795d594fSAndroid Build Coastguard Worker for (; value < 33; value++) { 113*795d594fSAndroid Build Coastguard Worker $noinline$emptyMethod(value); 114*795d594fSAndroid Build Coastguard Worker } 115*795d594fSAndroid Build Coastguard Worker 116*795d594fSAndroid Build Coastguard Worker return 0; 117*795d594fSAndroid Build Coastguard Worker } 118*795d594fSAndroid Build Coastguard Worker } 119