From 99546049b3a3f901376938368afaf3499eb1a701 Mon Sep 17 00:00:00 2001 From: Matthias Neugschwandtner Date: Wed, 18 Mar 2020 15:59:07 -0700 Subject: [PATCH] 8235908: omit ThreadPriorityPolicy warning when value is set from image Reviewed-by: dholmes, clanger, kvn --- src/hotspot/os/aix/os_aix.cpp | 2 +- src/hotspot/os/bsd/os_bsd.cpp | 2 +- src/hotspot/os/linux/os_linux.cpp | 2 +- src/hotspot/share/runtime/flags/jvmFlag.cpp | 10 ++++++++++ src/hotspot/share/runtime/flags/jvmFlag.hpp | 1 + src/hotspot/share/runtime/globals_extension.hpp | 2 ++ 6 files changed, 16 insertions(+), 3 deletions(-) diff --git a/src/hotspot/os/aix/os_aix.cpp b/src/hotspot/os/aix/os_aix.cpp index 5b30fc7affa..a0ca00601e0 100644 --- a/src/hotspot/os/aix/os_aix.cpp +++ b/src/hotspot/os/aix/os_aix.cpp @@ -2649,7 +2649,7 @@ int os::java_to_os_priority[CriticalPriority + 1] = { static int prio_init() { if (ThreadPriorityPolicy == 1) { if (geteuid() != 0) { - if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy)) { + if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy) && !FLAG_IS_JIMAGE_RESOURCE(ThreadPriorityPolicy)) { warning("-XX:ThreadPriorityPolicy=1 may require system level permission, " \ "e.g., being the root user. If the necessary permission is not " \ "possessed, changes to priority will be silently ignored."); diff --git a/src/hotspot/os/bsd/os_bsd.cpp b/src/hotspot/os/bsd/os_bsd.cpp index 314566cd241..01e239d8630 100644 --- a/src/hotspot/os/bsd/os_bsd.cpp +++ b/src/hotspot/os/bsd/os_bsd.cpp @@ -2277,7 +2277,7 @@ int os::java_to_os_priority[CriticalPriority + 1] = { static int prio_init() { if (ThreadPriorityPolicy == 1) { if (geteuid() != 0) { - if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy)) { + if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy) && !FLAG_IS_JIMAGE_RESOURCE(ThreadPriorityPolicy)) { warning("-XX:ThreadPriorityPolicy=1 may require system level permission, " \ "e.g., being the root user. If the necessary permission is not " \ "possessed, changes to priority will be silently ignored."); diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index e58894f1793..7ac4670d9ae 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -4332,7 +4332,7 @@ int os::java_to_os_priority[CriticalPriority + 1] = { static int prio_init() { if (ThreadPriorityPolicy == 1) { if (geteuid() != 0) { - if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy)) { + if (!FLAG_IS_DEFAULT(ThreadPriorityPolicy) && !FLAG_IS_JIMAGE_RESOURCE(ThreadPriorityPolicy)) { warning("-XX:ThreadPriorityPolicy=1 may require system level permission, " \ "e.g., being the root user. If the necessary permission is not " \ "possessed, changes to priority will be silently ignored."); diff --git a/src/hotspot/share/runtime/flags/jvmFlag.cpp b/src/hotspot/share/runtime/flags/jvmFlag.cpp index a32c4f94269..81210d3d7d1 100644 --- a/src/hotspot/share/runtime/flags/jvmFlag.cpp +++ b/src/hotspot/share/runtime/flags/jvmFlag.cpp @@ -153,6 +153,10 @@ bool JVMFlag::is_command_line() { return (_flags & ORIG_COMMAND_LINE) != 0; } +bool JVMFlag::is_jimage_resource() { + return (get_origin() == JIMAGE_RESOURCE); +} + void JVMFlag::set_command_line() { _flags = Flags(_flags | ORIG_COMMAND_LINE); } @@ -839,6 +843,12 @@ bool JVMFlagEx::is_cmdline(JVMFlagsEnum flag) { return flag_from_enum(flag)->is_command_line(); } +bool JVMFlagEx::is_jimage_resource(JVMFlagsEnum flag) { + assert((size_t)flag < JVMFlag::numFlags, "bad command line flag index"); + JVMFlag* f = &JVMFlag::flags[flag]; + return f->is_jimage_resource(); +} + void JVMFlagEx::setOnCmdLine(JVMFlagsEnum flag) { JVMFlag* faddr = flag_from_enum(flag); assert(faddr != NULL, "Unknown flag"); diff --git a/src/hotspot/share/runtime/flags/jvmFlag.hpp b/src/hotspot/share/runtime/flags/jvmFlag.hpp index 4bf7bf2faab..1c84920896d 100644 --- a/src/hotspot/share/runtime/flags/jvmFlag.hpp +++ b/src/hotspot/share/runtime/flags/jvmFlag.hpp @@ -187,6 +187,7 @@ public: bool is_default(); bool is_ergonomic(); + bool is_jimage_resource(); bool is_command_line(); void set_command_line(); diff --git a/src/hotspot/share/runtime/globals_extension.hpp b/src/hotspot/share/runtime/globals_extension.hpp index c1b692968bd..1116a6a023a 100644 --- a/src/hotspot/share/runtime/globals_extension.hpp +++ b/src/hotspot/share/runtime/globals_extension.hpp @@ -88,6 +88,7 @@ class JVMFlagEx : JVMFlag { static bool is_default(JVMFlagsEnum flag); static bool is_ergo(JVMFlagsEnum flag); static bool is_cmdline(JVMFlagsEnum flag); + static bool is_jimage_resource(JVMFlagsEnum flag); static void setOnCmdLine(JVMFlagsEnum flag); @@ -132,6 +133,7 @@ ALL_FLAGS(FLAG_MEMBER_SET_DEVELOP, #define FLAG_IS_DEFAULT(name) (JVMFlagEx::is_default(FLAG_MEMBER_ENUM(name))) #define FLAG_IS_ERGO(name) (JVMFlagEx::is_ergo(FLAG_MEMBER_ENUM(name))) #define FLAG_IS_CMDLINE(name) (JVMFlagEx::is_cmdline(FLAG_MEMBER_ENUM(name))) +#define FLAG_IS_JIMAGE_RESOURCE(name) (JVMFlagEx::is_jimage_resource(FLAG_MEMBER_ENUM(name))) #define FLAG_SET_DEFAULT(name, value) ((name) = (value))