On Fri, 8 Sep 2023 09:46:00 GMT, Aleksey Shipilev <sh...@openjdk.org> wrote:

>> 8315770: serviceability/sa/TestJmapCoreMetaspace.java should run with 
>> -XX:-VerifyDependencies
>> 
>> serviceability/sa/TestJmapCoreMetaspace.java runs in hotspot:tier2, and 
>> takes about 330 seconds out of 670 seconds of the entire run on x86_64 
>> fastdebug. The tier2 completion usually waits on it. Profiling shows we are 
>> spending time during classloading, checking dependencies. Since we load lots 
>> of classes, we do it many times, and each time the cost grows linearly to 
>> the number of classes. Some other tests that target metaspace explicitly 
>> disable `VerifyDependencies` to avoid this.
>> 
>> The commit includes adding "-XX:-VerifyDependencies" along with 
>> "-XX:+IgnoreUnrecognizedVMOptions" in TestJmapCore.java to make sure that 
>> release builds work with the test, as VerifyDependencies is a develop option 
>> and not available in release builds. The changes in the commit are resulting 
>> in considerable improvement for the test in fastdebug mode as can be seen 
>> below:
>> 
>> * before: **130.41s user 14.11s system 118% cpu 2:01.85 total**
>> * after: **27.52s user 13.64s system 213% cpu 19.249 total**
>
> test/hotspot/jtreg/serviceability/sa/TestJmapCore.java line 76:
> 
>> 74:         ProcessBuilder pb = 
>> ProcessTools.createTestJvm("-XX:+CreateCoredumpOnCrash",
>> 75:                 "-Xmx512m", "-XX:MaxMetaspaceSize=64m", 
>> "-XX:+CrashOnOutOfMemoryError",
>> 76:                 "-XX:-VerifyDependencies", 
>> "-XX:+IgnoreUnrecognizedVMOptions",
> 
> Have you tried this test with `release`? I think 
> `IgnoreUnrecognizedVMOptions` is positional, and should go before 
> `VerifyDependencies` to actually work.

I will try it and raise another commit if that is required

-------------

PR Review Comment: https://git.openjdk.org/jdk/pull/15631#discussion_r1319640639

Reply via email to