Uploaded image for project: 'JDK'
  1. JDK
  2. JDK-8078399

Obsolete -Xoss, -Xsqnopause, -Xoptimize and -Xboundthreads options in JDK 9



    • b74



        HotSpot contains 4 "-X" options that silently ignored: -Xoss, -Xsqnopause, -Xoptimize, -Xboundthreads. These options can be deprecated and removed in future releases. This will remove 4 "if" tests from very long "if" in Arguments::parse_each_vm_init_arg function in hotspot/src/share/vm/runtime/arguments.cpp module.

        Here are description of these options:
        "-Xoss", "-Xsqnopause", "-Xoptimize" - EVM option leaved for compatibility. From Java 2 SDK for Solaris Developer's Guide: "Prior to version 1.3.0, the production releases of the Java 2 SDK for the Solaris Operating Environment shipped with a virtual-machine implementation known as the Exact VM (EVM). Beginning with version 1.3.0, the Exact VM is replaced by the Java HotSpot VM.". So, from Java 1.4 EVM is not used as VM for JDK on Solaris and these very old flags just silently ignored by HotSpot.
        "-Xboundthreads" - was used to bind user level threads to kernel threads on Solaris in case when new thread library is not available. But old T1 libthread has been removed from Solaris in release 10. JDK9 requires Solaris 10u9 or higher. So, this flag become useless.

        I search these options in sourcecs of several Java projects(I took latest version) and none of these options are mentioned. Here a list of the projects: NetBeans, Jetty, Hadoop, TomCat, GlassFish, Intellij Idea Community Edition, Ant, Maven.

        Suggested fix: In JDK 9 print warning that option is deprecated and probably will be removed in future release(similar to the deprecated "-XX" options). E.g. "Java HotSpot(TM) 64-Bit Server VM warning: Option -Xoss was deprecated in version 9.0 and will likely be removed in a future release.".


          Issue Links



                ddmitriev Dmitry Dmitriev
                ddmitriev Dmitry Dmitriev
                1 Vote for this issue
                3 Start watching this issue