From ae72b5283b5b5eee0fbb6c9121494a4e65fb381c Mon Sep 17 00:00:00 2001 From: Stefan Karlsson Date: Thu, 22 Oct 2020 08:24:51 +0000 Subject: [PATCH] 8255047: Add HotSpot UseDebuggerErgo flags Reviewed-by: dcubed, dholmes --- src/hotspot/os/linux/globals_linux.hpp | 2 +- src/hotspot/os/linux/os_linux.cpp | 23 +++++++++++++++++++++-- src/hotspot/share/runtime/arguments.cpp | 18 ++++++++++++++++++ src/hotspot/share/runtime/globals.hpp | 11 +++++++++++ 4 files changed, 51 insertions(+), 3 deletions(-) diff --git a/src/hotspot/os/linux/globals_linux.hpp b/src/hotspot/os/linux/globals_linux.hpp index f2a889285af..0e5c209c940 100644 --- a/src/hotspot/os/linux/globals_linux.hpp +++ b/src/hotspot/os/linux/globals_linux.hpp @@ -79,7 +79,7 @@ "be dumped into the corefile.") \ \ product(bool, UseCpuAllocPath, false, DIAGNOSTIC, \ - "Use CPU_ALLOC code path in os::active_processor_count ") + "Use CPU_ALLOC code path in os::active_processor_count ") // end of RUNTIME_OS_FLAGS diff --git a/src/hotspot/os/linux/os_linux.cpp b/src/hotspot/os/linux/os_linux.cpp index 395bfa359f7..8536a161e64 100644 --- a/src/hotspot/os/linux/os_linux.cpp +++ b/src/hotspot/os/linux/os_linux.cpp @@ -3217,7 +3217,17 @@ void os::Linux::rebuild_cpu_to_node_map() { if (cpu_map[j] != 0) { for (size_t k = 0; k < BitsPerCLong; k++) { if (cpu_map[j] & (1UL << k)) { - cpu_to_node()->at_put(j * BitsPerCLong + k, closest_node); + int cpu_index = j * BitsPerCLong + k; + +#ifndef PRODUCT + if (UseDebuggerErgo1 && cpu_index >= (int)cpu_num) { + // Some debuggers limit the processor count without + // intercepting the NUMA APIs. Just fake the values. + cpu_index = 0; + } +#endif + + cpu_to_node()->at_put(cpu_index, closest_node); } } } @@ -4762,7 +4772,16 @@ int os::active_processor_count() { uint os::processor_id() { const int id = Linux::sched_getcpu(); - assert(id >= 0 && id < _processor_count, "Invalid processor id"); + +#ifndef PRODUCT + if (UseDebuggerErgo1 && id >= _processor_count) { + // Some debuggers limit the processor count without limiting + // the returned processor ids. Fake the processor id. + return 0; + } +#endif + + assert(id >= 0 && id < _processor_count, "Invalid processor id [%d]", id); return (uint)id; } diff --git a/src/hotspot/share/runtime/arguments.cpp b/src/hotspot/share/runtime/arguments.cpp index fc070e417f1..43a505d7676 100644 --- a/src/hotspot/share/runtime/arguments.cpp +++ b/src/hotspot/share/runtime/arguments.cpp @@ -3901,6 +3901,22 @@ bool Arguments::handle_deprecated_print_gc_flags() { return true; } +static void apply_debugger_ergo() { + if (UseDebuggerErgo) { + // Turn on sub-flags + FLAG_SET_ERGO_IF_DEFAULT(UseDebuggerErgo1, true); + FLAG_SET_ERGO_IF_DEFAULT(UseDebuggerErgo2, true); + } + + if (UseDebuggerErgo2) { + // Debugging with limited number of CPUs + FLAG_SET_ERGO_IF_DEFAULT(UseNUMA, false); + FLAG_SET_ERGO_IF_DEFAULT(ConcGCThreads, 1); + FLAG_SET_ERGO_IF_DEFAULT(ParallelGCThreads, 1); + FLAG_SET_ERGO_IF_DEFAULT(CICompilerCount, 2); + } +} + // Parse entry point called from JNI_CreateJavaVM jint Arguments::parse(const JavaVMInitArgs* initial_cmd_args) { @@ -4097,6 +4113,8 @@ jint Arguments::parse(const JavaVMInitArgs* initial_cmd_args) { } #endif + apply_debugger_ergo(); + return JNI_OK; } diff --git a/src/hotspot/share/runtime/globals.hpp b/src/hotspot/share/runtime/globals.hpp index c19960c310f..4b77de98941 100644 --- a/src/hotspot/share/runtime/globals.hpp +++ b/src/hotspot/share/runtime/globals.hpp @@ -2207,6 +2207,17 @@ const intx ObjectAlignmentInBytes = 8; product(bool, UseNewCode3, false, DIAGNOSTIC, \ "Testing Only: Use the new version while testing") \ \ + notproduct(bool, UseDebuggerErgo, false, \ + "Debugging Only: Adjust the VM to be more debugger-friendly. " \ + "Turns on the other UseDebuggerErgo* flags") \ + \ + notproduct(bool, UseDebuggerErgo1, false, \ + "Debugging Only: Enable workarounds for debugger induced " \ + "os::processor_id() >= os::processor_count() problems") \ + \ + notproduct(bool, UseDebuggerErgo2, false, \ + "Debugging Only: Limit the number of spawned JVM threads") \ + \ /* flags for performance data collection */ \ \ product(bool, UsePerfData, true, \