1*795d594fSAndroid Build Coastguard Worker /* 2*795d594fSAndroid Build Coastguard Worker * Copyright (C) 2011 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 /* 18*795d594fSAndroid Build Coastguard Worker * Create two versions of loops where the unresolved field is on either the 19*795d594fSAndroid Build Coastguard Worker * taken or the non-taken path to make sure that the loop detection code bails 20*795d594fSAndroid Build Coastguard Worker * on unresolved fields. 21*795d594fSAndroid Build Coastguard Worker */ 22*795d594fSAndroid Build Coastguard Worker public class Main { 23*795d594fSAndroid Build Coastguard Worker static int counter1; 24*795d594fSAndroid Build Coastguard Worker static int counter2; 25*795d594fSAndroid Build Coastguard Worker static int counter3; 26*795d594fSAndroid Build Coastguard Worker static int counter4; 27*795d594fSAndroid Build Coastguard Worker static int counter5; 28*795d594fSAndroid Build Coastguard Worker main(String[] args)29*795d594fSAndroid Build Coastguard Worker public static void main(String[] args) { 30*795d594fSAndroid Build Coastguard Worker /* counter1 is not resolved */ 31*795d594fSAndroid Build Coastguard Worker for (int i = 0; i < 32767; i++) { 32*795d594fSAndroid Build Coastguard Worker if (i < 0) { 33*795d594fSAndroid Build Coastguard Worker counter1++; 34*795d594fSAndroid Build Coastguard Worker } else { 35*795d594fSAndroid Build Coastguard Worker counter2++; 36*795d594fSAndroid Build Coastguard Worker } 37*795d594fSAndroid Build Coastguard Worker counter5++; 38*795d594fSAndroid Build Coastguard Worker } 39*795d594fSAndroid Build Coastguard Worker 40*795d594fSAndroid Build Coastguard Worker /* counter4 is not resolved */ 41*795d594fSAndroid Build Coastguard Worker for (int i = 0; i < 32767; i++) { 42*795d594fSAndroid Build Coastguard Worker if (i >= 0) { 43*795d594fSAndroid Build Coastguard Worker counter3++; 44*795d594fSAndroid Build Coastguard Worker } else { 45*795d594fSAndroid Build Coastguard Worker counter4++; 46*795d594fSAndroid Build Coastguard Worker } 47*795d594fSAndroid Build Coastguard Worker counter5++; 48*795d594fSAndroid Build Coastguard Worker } 49*795d594fSAndroid Build Coastguard Worker 50*795d594fSAndroid Build Coastguard Worker System.out.println("counter1 is " + counter1); 51*795d594fSAndroid Build Coastguard Worker System.out.println("counter2 is " + counter2); 52*795d594fSAndroid Build Coastguard Worker System.out.println("counter3 is " + counter3); 53*795d594fSAndroid Build Coastguard Worker System.out.println("counter4 is " + counter4); 54*795d594fSAndroid Build Coastguard Worker System.out.println("counter5 is " + counter5); 55*795d594fSAndroid Build Coastguard Worker 56*795d594fSAndroid Build Coastguard Worker deeplyNested(); 57*795d594fSAndroid Build Coastguard Worker } 58*795d594fSAndroid Build Coastguard Worker 59*795d594fSAndroid Build Coastguard Worker // GVN is limited to a maximum loop depth of 6. To track whether dependent passes are 60*795d594fSAndroid Build Coastguard Worker // correctly turned off, test some very simple, but deeply nested loops. deeplyNested()61*795d594fSAndroid Build Coastguard Worker private static void deeplyNested() { 62*795d594fSAndroid Build Coastguard Worker int sum = 0; 63*795d594fSAndroid Build Coastguard Worker for (int i = 0; i < 2; i++) { 64*795d594fSAndroid Build Coastguard Worker for (int j = 0; j < 2; j++) { 65*795d594fSAndroid Build Coastguard Worker for (int k = 0; k < 2; k++) { 66*795d594fSAndroid Build Coastguard Worker for (int l = 0; l < 2; l++) { 67*795d594fSAndroid Build Coastguard Worker for (int m = 0; m < 2; m++) { 68*795d594fSAndroid Build Coastguard Worker for (int n = 0; n < 2; n++) { 69*795d594fSAndroid Build Coastguard Worker for (int o = 0; o < 2; o++) { 70*795d594fSAndroid Build Coastguard Worker for (int p = 0; p < 2; p++) { 71*795d594fSAndroid Build Coastguard Worker sum++; 72*795d594fSAndroid Build Coastguard Worker } 73*795d594fSAndroid Build Coastguard Worker } 74*795d594fSAndroid Build Coastguard Worker } 75*795d594fSAndroid Build Coastguard Worker } 76*795d594fSAndroid Build Coastguard Worker } 77*795d594fSAndroid Build Coastguard Worker } 78*795d594fSAndroid Build Coastguard Worker } 79*795d594fSAndroid Build Coastguard Worker } 80*795d594fSAndroid Build Coastguard Worker System.out.println(sum); 81*795d594fSAndroid Build Coastguard Worker } 82*795d594fSAndroid Build Coastguard Worker } 83