mirror of
https://github.com/openjdk/jdk.git
synced 2025-09-22 20:14:43 +02:00
8027230: Overflow in java.lang.instrument.Instrumentation.getObjectSize() method
Reviewed-by: dholmes, sspitsyn
This commit is contained in:
parent
ead7a2760b
commit
09afb7b210
4 changed files with 112 additions and 2 deletions
|
@ -307,9 +307,9 @@ JvmtiEnv::GetObjectSize(jobject object, jlong* size_ptr) {
|
||||||
!java_lang_Class::is_primitive(mirror)) {
|
!java_lang_Class::is_primitive(mirror)) {
|
||||||
Klass* k = java_lang_Class::as_Klass(mirror);
|
Klass* k = java_lang_Class::as_Klass(mirror);
|
||||||
assert(k != NULL, "class for non-primitive mirror must exist");
|
assert(k != NULL, "class for non-primitive mirror must exist");
|
||||||
*size_ptr = k->size() * wordSize;
|
*size_ptr = (jlong)k->size() * wordSize;
|
||||||
} else {
|
} else {
|
||||||
*size_ptr = mirror->size() * wordSize;
|
*size_ptr = (jlong)mirror->size() * wordSize;
|
||||||
}
|
}
|
||||||
return JVMTI_ERROR_NONE;
|
return JVMTI_ERROR_NONE;
|
||||||
} /* end GetObjectSize */
|
} /* end GetObjectSize */
|
||||||
|
|
|
@ -83,6 +83,7 @@ needs_jdk = \
|
||||||
runtime/RedefineObject/TestRedefineObject.java \
|
runtime/RedefineObject/TestRedefineObject.java \
|
||||||
runtime/XCheckJniJsig/XCheckJSig.java \
|
runtime/XCheckJniJsig/XCheckJSig.java \
|
||||||
serviceability/attach/AttachWithStalePidFile.java \
|
serviceability/attach/AttachWithStalePidFile.java \
|
||||||
|
serviceability/jvmti/8036666/GetObjectLockCount.java \
|
||||||
serviceability/sa/jmap-hprof/JMapHProfLargeHeapTest.java \
|
serviceability/sa/jmap-hprof/JMapHProfLargeHeapTest.java \
|
||||||
serviceability/dcmd/DynLibDcmdTest.java
|
serviceability/dcmd/DynLibDcmdTest.java
|
||||||
|
|
||||||
|
@ -134,6 +135,8 @@ needs_compact3 = \
|
||||||
gc/parallelScavenge/TestDynShrinkHeap.java \
|
gc/parallelScavenge/TestDynShrinkHeap.java \
|
||||||
runtime/InternalApi/ThreadCpuTimesDeadlock.java \
|
runtime/InternalApi/ThreadCpuTimesDeadlock.java \
|
||||||
serviceability/threads/TestFalseDeadLock.java \
|
serviceability/threads/TestFalseDeadLock.java \
|
||||||
|
serviceability/jvmti/GetObjectSizeOverflow.java \
|
||||||
|
serviceability/jvmti/TestRedefineWithUnresolvedClass.java \
|
||||||
compiler/tiered/NonTieredLevelsTest.java \
|
compiler/tiered/NonTieredLevelsTest.java \
|
||||||
compiler/tiered/TieredLevelsTest.java \
|
compiler/tiered/TieredLevelsTest.java \
|
||||||
compiler/intrinsics/bmi/verifycode
|
compiler/intrinsics/bmi/verifycode
|
||||||
|
|
64
hotspot/test/serviceability/jvmti/GetObjectSizeOverflow.java
Normal file
64
hotspot/test/serviceability/jvmti/GetObjectSizeOverflow.java
Normal file
|
@ -0,0 +1,64 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2014 Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
import java.io.PrintWriter;
|
||||||
|
import com.oracle.java.testlibrary.*;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Test to verify GetObjectSize does not overflow on a 600M element int[]
|
||||||
|
*
|
||||||
|
* @test
|
||||||
|
* @bug 8027230
|
||||||
|
* @library /testlibrary
|
||||||
|
* @build GetObjectSizeOverflowAgent
|
||||||
|
* @run main ClassFileInstaller GetObjectSizeOverflowAgent
|
||||||
|
* @run main GetObjectSizeOverflow
|
||||||
|
*/
|
||||||
|
public class GetObjectSizeOverflow {
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
|
||||||
|
if (!Platform.is64bit()) {
|
||||||
|
System.out.println("Test needs a 4GB heap and can only be run as a 64bit process, skipping.");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
PrintWriter pw = new PrintWriter("MANIFEST.MF");
|
||||||
|
pw.println("Premain-Class: GetObjectSizeOverflowAgent");
|
||||||
|
pw.close();
|
||||||
|
|
||||||
|
ProcessBuilder pb = new ProcessBuilder();
|
||||||
|
pb.command(new String[] { JDKToolFinder.getJDKTool("jar"), "cmf", "MANIFEST.MF", "agent.jar", "GetObjectSizeOverflowAgent.class"});
|
||||||
|
pb.start().waitFor();
|
||||||
|
|
||||||
|
ProcessBuilder pt = ProcessTools.createJavaProcessBuilder(true, "-Xmx4000m", "-javaagent:agent.jar", "GetObjectSizeOverflowAgent");
|
||||||
|
OutputAnalyzer output = new OutputAnalyzer(pt.start());
|
||||||
|
|
||||||
|
if (output.getStdout().contains("Could not reserve enough space") || output.getStderr().contains("java.lang.OutOfMemoryError")) {
|
||||||
|
System.out.println("stdout: " + output.getStdout());
|
||||||
|
System.out.println("stderr: " + output.getStderr());
|
||||||
|
System.out.println("Test could not reserve or allocate enough space, skipping");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
output.stdoutShouldContain("GetObjectSizeOverflow passed");
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,43 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2014, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
import java.lang.instrument.*;
|
||||||
|
|
||||||
|
public class GetObjectSizeOverflowAgent {
|
||||||
|
|
||||||
|
static Instrumentation instrumentation;
|
||||||
|
|
||||||
|
public static void premain(String agentArgs, Instrumentation instrumentation) {
|
||||||
|
GetObjectSizeOverflowAgent.instrumentation = instrumentation;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String[] args) throws Exception {
|
||||||
|
int[] a = new int[600_000_000];
|
||||||
|
long size = instrumentation.getObjectSize(a);
|
||||||
|
|
||||||
|
if (size < 2_400_000_000L) {
|
||||||
|
throw new RuntimeException("Invalid size of array, expected >= 2400000000, got " + size);
|
||||||
|
}
|
||||||
|
|
||||||
|
System.out.println("GetObjectSizeOverflow passed");
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue