From 144d81caf69d0e624aa9ccebcf081b7ede126c69 Mon Sep 17 00:00:00 2001 From: Lin Zang Date: Mon, 11 Mar 2019 21:26:19 -0400 Subject: [PATCH] 8219721: jcmd from earlier release will hang attaching to VM with JDK-8215622 applied Fix compatibility issue caused by jmap update of 8215622 Reviewed-by: dholmes, ysuenaga, phh, sspitsyn --- src/hotspot/share/services/attachListener.cpp | 24 ++++++++++--------- src/hotspot/share/services/attachListener.hpp | 2 +- .../sun/tools/attach/VirtualMachineImpl.java | 4 ++-- .../sun/tools/attach/VirtualMachineImpl.java | 4 ++-- .../sun/tools/attach/VirtualMachineImpl.java | 4 ++-- .../sun/tools/attach/VirtualMachineImpl.java | 2 +- .../sun/tools/attach/VirtualMachineImpl.java | 2 +- .../share/classes/sun/tools/jmap/JMap.java | 2 +- .../util/logging/TestLoggerWeakRefLeak.java | 4 ++-- 9 files changed, 25 insertions(+), 23 deletions(-) diff --git a/src/hotspot/share/services/attachListener.cpp b/src/hotspot/share/services/attachListener.cpp index fe296b22d04..b2c001e2014 100644 --- a/src/hotspot/share/services/attachListener.cpp +++ b/src/hotspot/share/services/attachListener.cpp @@ -257,13 +257,22 @@ jint dump_heap(AttachOperation* op, outputStream* out) { // See also: ClassHistogramDCmd class // // Input arguments :- -// arg0: Name of the dump file or NULL -// arg1: "-live" or "-all" +// arg0: "-live" or "-all" +// arg1: Name of the dump file or NULL static jint heap_inspection(AttachOperation* op, outputStream* out) { bool live_objects_only = true; // default is true to retain the behavior before this change is made outputStream* os = out; // if path not specified or path is NULL, use out fileStream* fs = NULL; - const char* path = op->arg(0); + const char* arg0 = op->arg(0); + if (arg0 != NULL && (strlen(arg0) > 0)) { + if (strcmp(arg0, "-all") != 0 && strcmp(arg0, "-live") != 0) { + out->print_cr("Invalid argument to inspectheap operation: %s", arg0); + return JNI_ERR; + } + live_objects_only = strcmp(arg0, "-live") == 0; + } + + const char* path = op->arg(1); if (path != NULL) { if (path[0] == '\0') { out->print_cr("No dump file specified"); @@ -277,14 +286,7 @@ static jint heap_inspection(AttachOperation* op, outputStream* out) { os = fs; } } - const char* arg1 = op->arg(1); - if (arg1 != NULL && (strlen(arg1) > 0)) { - if (strcmp(arg1, "-all") != 0 && strcmp(arg1, "-live") != 0) { - out->print_cr("Invalid argument to inspectheap operation: %s", arg1); - return JNI_ERR; - } - live_objects_only = strcmp(arg1, "-live") == 0; - } + VM_GC_HeapInspection heapop(os, live_objects_only /* request full gc */); VMThread::execute(&heapop); if (os != NULL && os != out) { diff --git a/src/hotspot/share/services/attachListener.hpp b/src/hotspot/share/services/attachListener.hpp index 2b653639689..c59ac76981b 100644 --- a/src/hotspot/share/services/attachListener.hpp +++ b/src/hotspot/share/services/attachListener.hpp @@ -106,7 +106,7 @@ class AttachOperation: public CHeapObj { enum { name_length_max = 16, // maximum length of name arg_length_max = 1024, // maximum length of argument - arg_count_max = 4 // maximum number of arguments + arg_count_max = 3 // maximum number of arguments }; // name of special operation that can be enqueued when all diff --git a/src/jdk.attach/aix/classes/sun/tools/attach/VirtualMachineImpl.java b/src/jdk.attach/aix/classes/sun/tools/attach/VirtualMachineImpl.java index 8541bf88186..7aaabab1824 100644 --- a/src/jdk.attach/aix/classes/sun/tools/attach/VirtualMachineImpl.java +++ b/src/jdk.attach/aix/classes/sun/tools/attach/VirtualMachineImpl.java @@ -138,7 +138,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { * Execute the given command in the target VM. */ InputStream execute(String cmd, Object ... args) throws AgentLoadException, IOException { - assert args.length <= 4; // includes null + assert args.length <= 3; // includes null // did we detach? synchronized (this) { @@ -166,7 +166,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { writeString(s, PROTOCOL_VERSION); writeString(s, cmd); - for (int i = 0; i < 4; i++) { + for (int i = 0; i < 3; i++) { if (i < args.length && args[i] != null) { writeString(s, (String)args[i]); } else { diff --git a/src/jdk.attach/linux/classes/sun/tools/attach/VirtualMachineImpl.java b/src/jdk.attach/linux/classes/sun/tools/attach/VirtualMachineImpl.java index 0966f182dfd..8b963206f38 100644 --- a/src/jdk.attach/linux/classes/sun/tools/attach/VirtualMachineImpl.java +++ b/src/jdk.attach/linux/classes/sun/tools/attach/VirtualMachineImpl.java @@ -143,7 +143,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { * Execute the given command in the target VM. */ InputStream execute(String cmd, Object ... args) throws AgentLoadException, IOException { - assert args.length <= 4; // includes null + assert args.length <= 3; // includes null // did we detach? synchronized (this) { @@ -171,7 +171,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { writeString(s, PROTOCOL_VERSION); writeString(s, cmd); - for (int i = 0; i < 4; i++) { + for (int i = 0; i < 3; i++) { if (i < args.length && args[i] != null) { writeString(s, (String)args[i]); } else { diff --git a/src/jdk.attach/macosx/classes/sun/tools/attach/VirtualMachineImpl.java b/src/jdk.attach/macosx/classes/sun/tools/attach/VirtualMachineImpl.java index 64beabcba64..777b1eb94ae 100644 --- a/src/jdk.attach/macosx/classes/sun/tools/attach/VirtualMachineImpl.java +++ b/src/jdk.attach/macosx/classes/sun/tools/attach/VirtualMachineImpl.java @@ -139,7 +139,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { * Execute the given command in the target VM. */ InputStream execute(String cmd, Object ... args) throws AgentLoadException, IOException { - assert args.length <= 4; // includes null + assert args.length <= 3; // includes null // did we detach? synchronized (this) { @@ -167,7 +167,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { writeString(s, PROTOCOL_VERSION); writeString(s, cmd); - for (int i = 0; i < 4; i++) { + for (int i = 0; i < 3; i++) { if (i < args.length && args[i] != null) { writeString(s, (String)args[i]); } else { diff --git a/src/jdk.attach/solaris/classes/sun/tools/attach/VirtualMachineImpl.java b/src/jdk.attach/solaris/classes/sun/tools/attach/VirtualMachineImpl.java index 6948a969504..2e6bfdb0956 100644 --- a/src/jdk.attach/solaris/classes/sun/tools/attach/VirtualMachineImpl.java +++ b/src/jdk.attach/solaris/classes/sun/tools/attach/VirtualMachineImpl.java @@ -126,7 +126,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { * Execute the given command in the target VM. */ InputStream execute(String cmd, Object ... args) throws AgentLoadException, IOException { - assert args.length <= 4; // includes null + assert args.length <= 3; // includes null // first check that we are still attached int door; diff --git a/src/jdk.attach/windows/classes/sun/tools/attach/VirtualMachineImpl.java b/src/jdk.attach/windows/classes/sun/tools/attach/VirtualMachineImpl.java index 7e839a7a64a..1ed78264c4c 100644 --- a/src/jdk.attach/windows/classes/sun/tools/attach/VirtualMachineImpl.java +++ b/src/jdk.attach/windows/classes/sun/tools/attach/VirtualMachineImpl.java @@ -77,7 +77,7 @@ public class VirtualMachineImpl extends HotSpotVirtualMachine { InputStream execute(String cmd, Object ... args) throws AgentLoadException, IOException { - assert args.length <= 4; // includes null + assert args.length <= 3; // includes null // create a pipe using a random name Random rnd = new Random(); diff --git a/src/jdk.jcmd/share/classes/sun/tools/jmap/JMap.java b/src/jdk.jcmd/share/classes/sun/tools/jmap/JMap.java index 8611a335506..09af1af538e 100644 --- a/src/jdk.jcmd/share/classes/sun/tools/jmap/JMap.java +++ b/src/jdk.jcmd/share/classes/sun/tools/jmap/JMap.java @@ -190,7 +190,7 @@ public class JMap { System.out.flush(); // inspectHeap is not the same as jcmd GC.class_histogram - executeCommandForPid(pid, "inspectheap", filename, liveopt); + executeCommandForPid(pid, "inspectheap", liveopt, filename); } private static void dump(String pid, String options) diff --git a/test/jdk/java/util/logging/TestLoggerWeakRefLeak.java b/test/jdk/java/util/logging/TestLoggerWeakRefLeak.java index 0929b5341ff..f9d05af6cd2 100644 --- a/test/jdk/java/util/logging/TestLoggerWeakRefLeak.java +++ b/test/jdk/java/util/logging/TestLoggerWeakRefLeak.java @@ -123,7 +123,7 @@ public class TestLoggerWeakRefLeak { } /** - * 'vm.heapHisto("", "-live")' will request a full GC + * 'vm.heapHisto("-live")' will request a full GC */ private static int getInstanceCountFromHeapHisto() throws AttachNotSupportedException, Exception { int instanceCount = 0; @@ -131,7 +131,7 @@ public class TestLoggerWeakRefLeak { HotSpotVirtualMachine vm = (HotSpotVirtualMachine) VirtualMachine .attach(Long.toString(ProcessTools.getProcessId())); try { - try (InputStream heapHistoStream = vm.heapHisto("", "-live"); + try (InputStream heapHistoStream = vm.heapHisto("-live"); BufferedReader in = new BufferedReader(new InputStreamReader(heapHistoStream))) { String inputLine; while ((inputLine = in.readLine()) != null) {