2023-10-14 05:56:52 +00:00
|
|
|
/*
|
2024-05-08 10:38:09 +00:00
|
|
|
* Copyright (c) 2023, 2024, Red Hat, Inc. All rights reserved.
|
|
|
|
* Copyright (c) 2023, 2024, Oracle and/or its affiliates. All rights reserved.
|
2023-10-14 05:56:52 +00:00
|
|
|
* 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
|
|
|
|
* @summary Checks that -XX:CompileCommand=PrintMemStat,... works
|
2023-11-22 16:03:45 +00:00
|
|
|
* @requires vm.compiler1.enabled | vm.compiler2.enabled
|
2023-10-14 05:56:52 +00:00
|
|
|
* @library /test/lib
|
|
|
|
* @run driver compiler.print.CompileCommandPrintMemStat
|
|
|
|
*/
|
|
|
|
|
|
|
|
package compiler.print;
|
|
|
|
|
2024-05-08 10:38:09 +00:00
|
|
|
import jdk.test.lib.Platform;
|
2023-10-14 05:56:52 +00:00
|
|
|
import jdk.test.lib.process.OutputAnalyzer;
|
|
|
|
import jdk.test.lib.process.ProcessTools;
|
|
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
public class CompileCommandPrintMemStat {
|
|
|
|
|
|
|
|
final static String METHOD1 = "method1";
|
|
|
|
final static String METHOD2 = "method2";
|
|
|
|
|
|
|
|
public static void main(String[] args) throws Exception {
|
|
|
|
test(METHOD1, METHOD2);
|
|
|
|
test(METHOD2, METHOD1);
|
|
|
|
}
|
|
|
|
|
|
|
|
private static void test(String include, String exclude) throws Exception {
|
|
|
|
List<String> options = new ArrayList<String>();
|
|
|
|
options.add("-Xcomp");
|
|
|
|
options.add("-XX:-Inline");
|
|
|
|
options.add("-XX:CompileCommand=compileonly," + getTestClass() + "::*");
|
|
|
|
options.add("-XX:CompileCommand=MemStat," + getTestMethod(include) + ",print");
|
|
|
|
options.add(getTestClass());
|
|
|
|
|
2024-01-03 08:53:01 +00:00
|
|
|
OutputAnalyzer oa = ProcessTools.executeTestJava(options);
|
2023-10-14 05:56:52 +00:00
|
|
|
|
|
|
|
// We expect two printouts for "PrintMemStat". A line at compilation time, and a line in a summary report
|
|
|
|
// that is printed when we exit. Both use the typical <class>::name format but use / as separator and also
|
|
|
|
// print the signature.
|
|
|
|
String expectedNameIncl = getTestMethod(include)
|
|
|
|
.replace('.', '/')
|
|
|
|
.replace("$", "\\$");
|
|
|
|
String expectedNameExcl = getTestMethod(exclude)
|
|
|
|
.replace('.', '/')
|
|
|
|
.replace("$", "\\$");
|
|
|
|
|
|
|
|
// Should see trace output when methods are compiled
|
2024-05-08 10:38:09 +00:00
|
|
|
oa.shouldHaveExitValue(0).
|
|
|
|
shouldMatch("Arena usage.*" + expectedNameIncl + ".*").
|
|
|
|
shouldNotMatch("Arena usage.*" + expectedNameExcl + ".*");
|
|
|
|
|
2023-10-14 05:56:52 +00:00
|
|
|
|
|
|
|
// Should see final report
|
|
|
|
// Looks like this:
|
2024-05-08 10:38:09 +00:00
|
|
|
// total NA RA result #nodes limit time type #rc thread method
|
|
|
|
// 2149912 0 1986272 ok - - 0.101 c1 1 0x000000015180a600 jdk/internal/org/objectweb/asm/Frame::execute((IILjdk/internal/org/objectweb/asm/Symbol;Ljdk/internal/org/objectweb/asm/SymbolTable;)V) oa.shouldMatch("total.*method");
|
|
|
|
// or
|
|
|
|
// 537784 98184 208536 ok 267 - 0.096 c2 1 0x0000000153019c00 jdk/internal/classfile/impl/BufWriterImpl::writeU1((I)V) 4521912 0 1986272 ok - - 0.101 c1 1 0x000000015180a600 jdk/internal/org/objectweb/asm/Frame::execute((IILjdk/internal/org/objectweb/asm/Symbol;Ljdk/internal/org/objectweb/asm/SymbolTable;)V) oa.shouldMatch("total.*method");
|
|
|
|
oa.shouldMatch("\\d+ +\\d+ +\\d+ +ok +(\\d+|-) +.*" + expectedNameIncl + ".*");
|
|
|
|
|
|
|
|
// In debug builds, we have a default memory limit enabled. That implies MemStat. Therefore we
|
|
|
|
// expect to see all methods, not just the one we specified on the command line.
|
|
|
|
if (Platform.isDebugBuild()) {
|
|
|
|
oa.shouldMatch("\\d+ +\\d+ +\\d+ +ok +(\\d+|-) +.*" + expectedNameExcl + ".*");
|
|
|
|
} else {
|
|
|
|
oa.shouldNotMatch(".*" + expectedNameExcl + ".*");
|
|
|
|
}
|
2023-10-14 05:56:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Test class that is invoked by the sub process
|
|
|
|
public static String getTestClass() {
|
|
|
|
return TestMain.class.getName();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static String getTestMethod(String method) {
|
|
|
|
return getTestClass() + "::" + method;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class TestMain {
|
|
|
|
public static void main(String[] args) {
|
|
|
|
method1();
|
|
|
|
method2();
|
|
|
|
}
|
|
|
|
|
|
|
|
static void method1() {}
|
|
|
|
static void method2() {}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|