提交 051c5843 编写于 作者: O ohair

Merge

...@@ -57,7 +57,10 @@ public class JavaStatic { ...@@ -57,7 +57,10 @@ public class JavaStatic {
id = ((JavaObjectRef)value).getId(); id = ((JavaObjectRef)value).getId();
} }
value = value.dereference(snapshot, field); value = value.dereference(snapshot, field);
if (value.isHeapAllocated()) { if (value.isHeapAllocated() &&
clazz.getLoader() == snapshot.getNullThing()) {
// static fields are only roots if they are in classes
// loaded by the root classloader.
JavaHeapObject ho = (JavaHeapObject) value; JavaHeapObject ho = (JavaHeapObject) value;
String s = "Static reference from " + clazz.getName() String s = "Static reference from " + clazz.getName()
+ "." + field.getName(); + "." + field.getName();
......
...@@ -1117,9 +1117,6 @@ sun/jvmstat/monitor/MonitoredVm/CR6672135.java generic-all ...@@ -1117,9 +1117,6 @@ sun/jvmstat/monitor/MonitoredVm/CR6672135.java generic-all
# Unexpected Monitor Exception, solaris sparc -client # Unexpected Monitor Exception, solaris sparc -client
sun/jvmstat/monitor/MonitoredVm/MonitorVmStartTerminate.sh generic-all sun/jvmstat/monitor/MonitoredVm/MonitorVmStartTerminate.sh generic-all
# Probably should be samevm, but seem to cause errors even in othervm at times
sun/tools/jhat/HatHeapDump1Test.java generic-all
# Problems on windows, jmap.exe hangs? (these run jmap) # Problems on windows, jmap.exe hangs? (these run jmap)
sun/tools/jmap/Basic.sh windows-all sun/tools/jmap/Basic.sh windows-all
...@@ -1129,9 +1126,6 @@ sun/tools/jstatd/jstatdDefaults.sh solaris-all ...@@ -1129,9 +1126,6 @@ sun/tools/jstatd/jstatdDefaults.sh solaris-all
# Solaris sparcv9, jps output does not match, x64 different # Solaris sparcv9, jps output does not match, x64 different
sun/tools/jstatd/jstatdExternalRegistry.sh solaris-all sun/tools/jstatd/jstatdExternalRegistry.sh solaris-all
# Probably should be samevm, but seem to cause errors even in othervm at times
sun/tools/native2ascii/NativeErrors.java generic-all
# Solaris 10 sparc 32bit -client, java.lang.AssertionError: Some tests failed # Solaris 10 sparc 32bit -client, java.lang.AssertionError: Some tests failed
tools/jar/JarEntryTime.java generic-all tools/jar/JarEntryTime.java generic-all
......
...@@ -186,11 +186,13 @@ public class HatRun { ...@@ -186,11 +186,13 @@ public class HatRun {
*/ */
int nvm_options = 0; int nvm_options = 0;
if ( vm_options != null ) nvm_options = vm_options.length; if ( vm_options != null ) nvm_options = vm_options.length;
String cmd[] = new String[1 + (d64?1:0) + 5 + nvm_options]; String cmd[] = new String[1 + (d64?1:0) + 7 + nvm_options];
int i,j; int i,j;
i = 0; i = 0;
cmd[i++] = java; cmd[i++] = java;
cmd[i++] = "-cp";
cmd[i++] = cdir;
cmd[i++] = "-Dtest.classes=" + cdir; cmd[i++] = "-Dtest.classes=" + cdir;
if ( d64 ) { if ( d64 ) {
cmd[i++] = "-d64"; cmd[i++] = "-d64";
......
...@@ -59,15 +59,28 @@ public class NativeErrors { ...@@ -59,15 +59,28 @@ public class NativeErrors {
in = new BufferedReader(new InputStreamReader(p.getInputStream())); in = new BufferedReader(new InputStreamReader(p.getInputStream()));
checkResult(in, "err.bad.arg"); checkResult(in, "err.bad.arg");
command = getComString("test123"); File f0 = new File(System.getProperty("test.src", "."), "test123");
String path0 = f0.getPath();
if ( f0.exists() ) {
throw new Error("Input file should not exist: " + path0);
}
command = getComString(path0);
p = Runtime.getRuntime().exec(command); p = Runtime.getRuntime().exec(command);
in = new BufferedReader(new InputStreamReader(p.getInputStream())); in = new BufferedReader(new InputStreamReader(p.getInputStream()));
checkResult(in, "err.cannot.read"); checkResult(in, "err.cannot.read");
File f1 = new File(System.getProperty("test.src", "."), "test1"); File f1 = new File(System.getProperty("test.src", "."), "test1");
File f2 = new File(System.getProperty("test.src", "."), "test2"); File f2 = File.createTempFile("test2", ".tmp");
String path1 = f1.getPath(); String path1 = f1.getPath();
String path2 = f2.getPath(); String path2 = f2.getPath();
if ( !f1.exists() ) {
throw new Error("Missing input file: " + path1);
}
if ( !f2.setWritable(false) ) {
throw new Error("Output file cannot be made read only: " + path2);
}
f2.deleteOnExit();
command = getComString(path1, path2); command = getComString(path1, path2);
p = Runtime.getRuntime().exec(command); p = Runtime.getRuntime().exec(command);
...@@ -80,7 +93,9 @@ public class NativeErrors { ...@@ -80,7 +93,9 @@ public class NativeErrors {
throws Exception { throws Exception {
String errorReceived; String errorReceived;
errorReceived = in.readLine(); errorReceived = in.readLine();
assert errorReceived != null : "First readline cannot be null";
errorExpected = rsrc.getString(errorExpected); errorExpected = rsrc.getString(errorExpected);
assert errorExpected != null : "Expected message cannot be null";
StringBuffer error = new StringBuffer(errorExpected); StringBuffer error = new StringBuffer(errorExpected);
int start = errorExpected.indexOf("{0}"); int start = errorExpected.indexOf("{0}");
if (start >= 0) { if (start >= 0) {
...@@ -128,6 +143,7 @@ public class NativeErrors { ...@@ -128,6 +143,7 @@ public class NativeErrors {
f = new File(path); f = new File(path);
if (!f.exists()) if (!f.exists())
throw new RuntimeException("Cannot find native2ascii at "+path); throw new RuntimeException("Cannot find native2ascii at "+path);
System.out.println("Using native2ascii at "+path);
} }
return path; return path;
} }
......
This file exists as a non-writable placeholder for NativeErrors.java
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册