67d1ef1479
Reviewed-by: roland, chagedorn
168 lines
7.1 KiB
Java
168 lines
7.1 KiB
Java
/*
|
|
* Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved.
|
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
*
|
|
* This code is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License version 2 only, as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
* version 2 for more details (a copy is included in the LICENSE file that
|
|
* accompanied this code).
|
|
*
|
|
* You should have received a copy of the GNU General Public License version
|
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
*
|
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
* or visit www.oracle.com if you need additional information or have any
|
|
* questions.
|
|
*/
|
|
|
|
/*
|
|
* @test
|
|
* @bug 8331736
|
|
* @summary Check that C2 does not exceed max live node limit when splitting unique types of large allocation merge.
|
|
* @library /test/lib /
|
|
* @requires vm.debug & vm.compiler2.enabled
|
|
* @compile -XDstringConcat=inline TestScalarReplacementMaxLiveNodes.java
|
|
* @run main/othervm compiler.c2.TestScalarReplacementMaxLiveNodes
|
|
* @run main/othervm -Xbatch -XX:-OptimizeStringConcat -XX:-TieredCompilation
|
|
* -XX:+UnlockDiagnosticVMOptions -XX:+ReduceAllocationMerges
|
|
* -XX:CompileCommand=dontinline,compiler.c2.TestScalarReplacementMaxLiveNodes::test
|
|
* -XX:CompileCommand=compileonly,*TestScalarReplacementMaxLiveNodes*::*test*
|
|
* -XX:CompileCommand=inline,*String*::*
|
|
* -XX:CompileCommand=dontinline,*StringBuilder*::ensureCapacityInternal
|
|
* -XX:CompileCommand=dontinline,*String*::substring
|
|
* -XX:NodeCountInliningCutoff=220000
|
|
* -XX:DesiredMethodLimit=100000
|
|
* compiler.c2.TestScalarReplacementMaxLiveNodes
|
|
*/
|
|
package compiler.c2;
|
|
|
|
public class TestScalarReplacementMaxLiveNodes {
|
|
public static void main(String[] args) {
|
|
TestScalarReplacementMaxLiveNodes obj = new TestScalarReplacementMaxLiveNodes();
|
|
|
|
int result = 0;
|
|
for (int i = 0; i < 100; i++) {
|
|
for (int val = 0; val < 50; val++) {
|
|
result += obj.test(val, val+10, val+20, val+30, val+40).length();
|
|
}
|
|
}
|
|
|
|
System.out.println("Result is: " + result);
|
|
}
|
|
|
|
public String test(int param1, int param2, int param3, int param4, int param5) {
|
|
String a = null, b = null, c = null, d = null, e = null;
|
|
|
|
if (param1 == 0) {
|
|
a = new String("first" + param1);
|
|
param1 = (int) Math.cos(param1);
|
|
} else if (param1 == 1) {
|
|
a = new String("second" + param2);
|
|
param1 = (int) Math.cos(param1);
|
|
} else if (param1 == 2) {
|
|
a = "";
|
|
param1 = (int) Math.cos(param1);
|
|
} else if (param1 == 3) {
|
|
b = new String("third" + param2);
|
|
param2 = (int) Math.sin(param2);
|
|
} else if (param1 == 4) {
|
|
b = new String("fourth" + param1);
|
|
param2 = (int) Math.sin(param2);
|
|
} else if (param1 == 5) {
|
|
b = new String("fifth" + param2);
|
|
param2 = (int) Math.sin(param2);
|
|
} else if (param1 == 6) {
|
|
c = new String("sixth" + param2);
|
|
param2 = (int) Math.sin(param2);
|
|
} else if (param1 == 7) {
|
|
c = new String("seventh" + param2);
|
|
param3 = (int) Math.tan(param3);
|
|
} else if (param1 == 8) {
|
|
c = new String("eighth" + param3);
|
|
param3 = (int) Math.tan(param3);
|
|
} else if (param1 == 9) {
|
|
d = new String("nineth" + param2);
|
|
param3 = (int) Math.tan(param3);
|
|
} else if (param1 == 10) {
|
|
d = "";
|
|
param3 = (int) Math.tan(param3);
|
|
} else if (param1 == 11) {
|
|
d = new String("tenth" + param2);
|
|
param4 = (int) Math.atan(param1 + param2);
|
|
} else if (param1 == 12) {
|
|
e = new String("eleventh" + param3);
|
|
param4 = (int) Math.atan(param1 + param2);
|
|
} else if (param1 == 13) {
|
|
e = "";
|
|
param4 = (int) Math.atan(param1 + param2);
|
|
} else if (param1 == 14) {
|
|
e = new String("twelveth" + param1);
|
|
b = e;
|
|
} else if (param1 == 15) {
|
|
a = new String("thirteenth" + param2);
|
|
param4 = (int) Math.atan(param1 + param2);
|
|
} else if (param1 == 16) {
|
|
b = "";
|
|
param5 = (int) Math.abs(Math.sqrt(param1*param2));
|
|
} else if (param1 == 17) {
|
|
c = new String("fourteenth" + param2);
|
|
param5 = (int) Math.abs(Math.sqrt(param1*param2));
|
|
} else if (param1 == 18) {
|
|
e = new String("fifteenth" + param3);
|
|
param5 = (int) Math.abs(Math.sqrt(param1*param2));
|
|
} else if (param1 == 19) {
|
|
e = new String("sixteenth" + param2);
|
|
a = e;
|
|
} else if (param1 == 20) {
|
|
a = new String("seventeenth" + param2);
|
|
param1 = param2 + param3;
|
|
} else if (param1 == 21) {
|
|
b = new String("eighteenth" + param2);
|
|
c = b;
|
|
} else if (param1 == 22) {
|
|
c = "";
|
|
param3 = param4 + param5;
|
|
} else if (param1 == 23) {
|
|
e = new String("nineteenth" + param3);
|
|
param4 = param5 + param1;
|
|
} else if (param1 == 24) {
|
|
e = new String("tweenth" + param2);
|
|
} else if (param1 == 25) {
|
|
c = "";
|
|
param3 = param4 + param5;
|
|
}
|
|
|
|
int val1 = (a != null ? a.length() : 10) + param1;
|
|
int val2 = (b != null ? b.length() : 20) + param2;
|
|
int val3 = (c != null ? c.length() : 20) + param3;
|
|
int val4 = (d != null ? d.length() : 20) + param4;
|
|
int val5 = (e != null ? e.length() : 20) + param5;
|
|
|
|
String result = "Really Really Long String";
|
|
for (int i=0; i<16; i++) {
|
|
for (int j=0; j<4; j++) {
|
|
val1 += (int) (val1 >= 10 ? Math.sqrt(val1*val2*val3*val4 / 10) : i * j * Math.sin(Math.cos(val1)));
|
|
val2 += (int) (val2 >= 10 ? Math.sqrt(val1*val2*val3*val4 / 20) : i * j * Math.sin(Math.cos(val2)));
|
|
val3 += (int) (val3 >= 10 ? Math.sqrt(val1*val2*val3*val4 / 30) : i * j * Math.sin(Math.cos(val3)));
|
|
val4 += (int) (val4 >= 10 ? Math.sqrt(val1*val2*val3*val4 / 40) : i * j * Math.sin(Math.cos(val4)));
|
|
val5 += (int) (val5 >= 10 ? Math.sqrt(val1*val2*val3*val4 / 50) : i * j * Math.sin(Math.cos(val5)));
|
|
int val6 = (int) (val1 + val2 + val3 + val4 + val5);
|
|
|
|
try {
|
|
result += "Result is: " + result.substring(10, 20) + val1;
|
|
} catch (IndexOutOfBoundsException except) {
|
|
result += "Reaally Long String" + val6;
|
|
}
|
|
}
|
|
}
|
|
|
|
return result;
|
|
}
|
|
}
|