Eclipse OpenJ9 version 0.18.0 release notes
These release notes support the Eclipse OpenJ9 0.18.0 release plan.
Binaries and supported environments
OpenJ9 release 0.18.0 supports OpenJDK 8, 11, and 13.
Binaries are available at the AdoptOpenJDK project:
All builds are tested against the OpenJ9 functional verification (FV) test suite, the OpenJDK test suites, and additional tests at AdoptOpenJDK.
To learn more about support for OpenJ9 releases, including OpenJDK levels and platform support, see Supported environments.
Notable changes in this release
The following table covers notable changes in v0.18.0. Further information about these changes can be found in the user documentation.
Issue number |
Description |
Version / Platform |
Impact |
#7841 |
JITServer technology preview available |
OpenJDK8 and 11 (Linux x86-64 only) |
JITServer decouples the JIT compiler from the OpenJ9 VM, freeing up CPU and memory for an application. JITServer then runs in its own process, either locally or on a remote machine where resources can be separately managed. |
#7197 |
jextract is now available on macOS systems |
OpenJDK8 and later |
Support for the jextract tool is now available on macOS platforms in addition to AIX and Linux. |
#7575 |
Timestamp checking of shared classes can be turned off |
OpenJDK8 and later |
The -Xshareclasses:noTimestampChecks suboption instructs the VM not to check the timestamps of shared classes, which can improve performance. This option is previously undocumented. |
#7304 |
New minimum value for the -Xmso option |
OpenJDK8 and later (64-bit z/OS only) |
To match the minimum stack space provided by z/OS, the minimum value for the -Xmso option is now 1 MB. A value lower than 1 MB is ignored. |
#7240 |
New jstat tool for monitoring Java statistics |
OpenJDK8 and later |
For compatibility with the HotSpot implementation, OpenJ9 now includes an independent implementation of the jstat tool for retrieving statistics on a VM. |
#7665 |
Extended platform support for the -XX:+TransparentHugePage option |
OpenJDK8 and later (Linux on POWER and IBM Z) |
Platform support for the -XX:+TransparentHugePage option is now extended to Linux on POWER and Linux on IBM Z. This option takes affect only when Transparent Huge Pages (THP) is set to madvise on your system and might increase your application footprint. |
#7406 |
New exit dump agent and -XX:[+|-]ExitOnOutOfMemoryError option |
OpenJDK8 and later |
The new exit dump agent saves information on the state of the VM when the VM shuts down, which can help you diagnose problems. For compatibility, OpenJ9 also supports the HotSpot option -XX:[+|-]ExitOnOutOfMemoryError. This option shuts down the VM when a java.lang.OutOfMemory error occurs by calling the exit dump agent. |
#7332 |
LUDCL caching enabled by default |
OpenJDK8 and later |
This feature was disabled by default in Eclipse OpenJ9 0.17.0 due to issue #7332. This issue is resolved and the option is reenabled. |
#7427 |
Support for Terabyte suffixes for -X and -XX options |
OpenJDK8 and later |
OpenJ9 now supports 't' and 'T' suffixes (indicating terabytes) for -X and -XX options that take a <size> parameter. |
#7728 |
Extended platform support for pause-less garbage collection |
OpenJDK8 and later (macOS) |
Support for pause-less garbage collection (-Xgc:concurrentScavenge) is now extended to macOS systems. |
#7955 |
Remove restriction on multi-layer shared cache |
OpenJDK8 and later |
In the previous release, there is a restriction that the jvmtiSharedCacheInfo.isCorrupt field and the SharedClassCacheInfo.isCacheCorrupt() method cannot detect a corrupted cache that has a layer number other than zero. This restriction is now removed. |
#7723 |
Support for OpenJDK HotSpot Garbage Collection options |
OpenJDK8 and later |
For compatibility, the following HotSpot options are now supported by OpenJ9: -XX:ParallelGCThreads, -XX:ConcGCThreads, and -XX:ParallelCMSThreads. |
Known Issues
The v0.18.0 release contains the following known issues and limitations:
Issue number |
Description |
Platform |
Impact |
Workaround |
#479 |
Non-compressed references VM builds not available |
AIX |
Non-compressed references VM builds, which support heaps larger than 57GB, are built on Linux, Windows, and macOS. |
Manual builds on other platforms are possible by following our detailed build instructions. |
Other changes
A full commit history for this release is available at Eclipse OpenJ9 v0.18.0.