RFR (S): 8222534: VerifyBeforeExit is not honored when System.exit is called
David Holmes
david.holmes at oracle.com
Tue Apr 30 03:54:42 UTC 2019
Bug: https://bugs.openjdk.java.net/browse/JDK-8222534
Webrev: http://cr.openjdk.java.net/~dholmes/8222534/webrev/
Stefan noticed that VerifyBeforeExit was not honoured when a Java
application terminates via System.exit.
Examination of the exit code sequences revealed four differences between
an exit due to the last non-daemon thread terminating (handled via
jni_DestroyJavaVM) and a call to System.exit() (handled via JVM_Halt()).
There are four missing actions on the System.exit() path:
- No processing of VerifyBeforeExit
- No XML logging before exit
- No LogConfiguration::finalize()
- No IdealGraphPrinter::clean_up()
The first three have now been added at the appropriate point.
VerifyBefore exit was the main omission. The compiler team (i.e.
Vladimir K.) indicated they'd also like the XML logging. And the
LogConfiguration::finalize while possibly not essential avoids any doubt
as to whether buffered log output may get lost.
The IdealGraphPrinter::cleanup was deemed unnecessary due to the fact
the process is being blown away anyway.
The bug report contains a lot of details on the exit sequences including
a side-by-side comparison in the attached pdf, showing the relative
positioning of each action and that the correct order has been maintained.
The vm_exit() code affects a number of "abrupt" exit paths in the VM,
not just JVM_Halt, and this is discussed in the bug report as well. In
short the addition of the missing actions should not cause any issues.
Testing:
- some manual checking of exit paths and whether new code was executed
- all hotspot/jtreg/gc tests with -XX:+VerifyBeforeExit added
- mach5 tiers 1-3
Thanks,
David
More information about the hotspot-dev
mailing list