Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/openj9
Path: blob/master/doc/release-notes/0.16/0.16.md
6004 views

Eclipse OpenJ9 version 0.16 release notes

These release notes support the Eclipse OpenJ9 0.16 release plan.

Binaries and supported environments

OpenJ9 release 0.16 supports OpenJDK 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.16. Further information about these changes can be found in the user documentation.

Issue number Description Version / Platform Impact
#6271 Class data sharing for bootstrap classes is enabled by default OpenJDK8 and later Class data sharing is enabled by default for bootstrap classes, unless your application is running in a container. You can use the -Xshareclasses option to change the default behavior.
#6541 New option to share VM anonymous classes in the shared classes cache OpenJDK8 and later Anonymous classes (defined by Unsafe.defineAnonymousClass) are now stored in the shared classes cache by default so that they are available for ahead-of-time (AOT) compilation. To prevent these classes being shared, use the -XX:-ShareAnonymousClasses option.
#6536, #5480 Changes to the shared classes cache generation number OpenJDK8 and later The format of classes that are stored in the shared classes cache is changed. To save space, all existing shared caches can be removed unless they are in use by an earlier release. For more information about deleting a shared classes cache, see the -Xshareclasses option.
#6234 Performance improvements for JVMTI watched fields on IBM Power® systems OpenJDK8 and later (AIX® and Linux on POWER) In earlier releases, performance improvements were introduced for JVMTI watched fields on x86, Linux on Z, and z/OS systems. These improvements are now available for AIX and Linux on POWER systems.
#6713 Support for Transparent HugePage allocation by default OpenJDK8 and later (Linux on x86) In release 0.15, support was introduced for Transparent HugePage on Linux when the madvise (/sys/kernel/mm/transparent_hugepage/enabled) setting is set by specifying the -XX:+TransparentHugePage option on the command line. This support is now enabled by default for Linux on x86 systems.
#5164 New jcmd tool OpenJDK8 and later For compatibility, OpenJ9 includes an independent implementation of the jcmd tool, which can run diagnostic commands on a specified VM or VMs.
#3743 Automatically setting an initial heap size by default OpenJDK8 and later In release 0.15, a new feature was introduced that allowed OpenJ9 to learn and set an appropriate initial heap size for an application as an alternative to a user manually sizing and setting an -Xms value. This feature could be enabled by setting the -XX:+UseGCStartupHints option on the command line. This option is now enabled by default.
#5822 Options -Xverify:none and -noverify are deprecated OpenJDK13 and later The -Xverify:none and -noverify options are deprecated in Java 13 and might be removed in a future release. A warning message is issued when these commands are used.

Known Issues

The v0.16 release contains the following known issues and limitations:

Issue number Description Platform Impact Workaround
#2507 Restriction analyzing system (core) dumps Linux and Windows You must use a 32-bit JVM to look at a 32-bit core, and a 64-bit JVM to look at a 64-bit core. This restriction will be fixed in a later version of OpenJ9. None
#479 Non-compressed references VM builds not available AIX, Linux on Z, Linux on Power Non-compressed references VM builds, which support heaps larger than 57GB, are built on Linux on x86, Windows, and macOS. Manual builds on other platforms are possible by following our detailed build instructions.
#897 Javadoc not building some OpenJ9 extensions. All platforms Some API documentation is missing in the build/<platform>/docs directory. None
#898 Javadoc building some unsupported OpenJ9 extensions. All platforms Some API documentation in build/<platform>/docs is not supported with OpenJ9. None

Other changes

A full commit history for this release is available at Eclipse OpenJ9 v0.16.0.