Merge
This commit is contained in:
commit
0c0fa1460a
1
.hgtags
1
.hgtags
@ -102,3 +102,4 @@ aa894c225b1a517b665ac2a58295217ea2245134 jdk7-b124
|
||||
f658ec2730fa29323c36d23c27e54c7219ef5e16 jdk7-b125
|
||||
f1df068076986679ea1105532a65529d63a89060 jdk7-b126
|
||||
f83cd8bd35c678f94e526990e03dc838d0ec2717 jdk7-b127
|
||||
7da3f5f30855dec6bf3a86529e87dee883b90c72 jdk7-b128
|
||||
|
@ -102,3 +102,4 @@ ed6950da30cf1e8904b4bdb034d471647942271f jdk7-b123
|
||||
5c4df7e992775c102f08e9f1c0a124b324641b70 jdk7-b125
|
||||
b566d490905691787f8931f69947a92c67c6d5e4 jdk7-b126
|
||||
bd70f76b0309068f157ae759c36eac8f2c6d098e jdk7-b127
|
||||
57d702105b23fb90e40beaf00f8f8aeae5e249e7 jdk7-b128
|
||||
|
@ -921,7 +921,7 @@
|
||||
<!-- ------------------------------------------------------ -->
|
||||
<h4><a name="ant">Ant</a></h4>
|
||||
<blockquote>
|
||||
All OpenJDK builds require access to least Ant 1.6.5.
|
||||
All OpenJDK builds require access to least Ant 1.7.1.
|
||||
The Ant tool is available from the
|
||||
<a href="http://ant.apache.org" target="_blank">
|
||||
Ant download site</a>.
|
||||
|
@ -102,3 +102,4 @@ f90b3e014e831eb4f32ef035a1dad2b8ba87949f jdk7-b124
|
||||
1ce58c72b7892cb813eb920276c7e7f17a1b79fe jdk7-b125
|
||||
d7532bcd3742f1576dd07ff9fbb535c9c9a276e9 jdk7-b126
|
||||
64775e83f4df894355f45555f50c410de6727b4e jdk7-b127
|
||||
9baa8f94a11d6c5cab3f9f0e5a20106326d0932e jdk7-b128
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 2004, 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
|
||||
|
@ -1,6 +1,6 @@
|
||||
;
|
||||
|
||||
; Copyright 2003-2009 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 2009, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 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
|
||||
|
@ -1,5 +1,5 @@
|
||||
;
|
||||
; Copyright 2003-2004 Sun Microsystems, Inc. All Rights Reserved.
|
||||
; Copyright (c) 2003, 2004, 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
|
||||
|
@ -143,4 +143,6 @@ f5603a6e50422046ebc0d2f1671d55cb8f1bf1e9 jdk7-b120
|
||||
e24ab3fa6aafad3efabbe7dba9918c5f461a20b1 jdk7-b125
|
||||
4c851c931d001a882cab809aaf3a55371b919244 jdk7-b126
|
||||
e24ab3fa6aafad3efabbe7dba9918c5f461a20b1 hs20-b06
|
||||
d535bf4c12355a2897e918da9f8910c0aceec4fb hs20-b07
|
||||
102466e70debc4b907afbd7624e34ddb1aafee9f jdk7-b127
|
||||
9a5762f448595794d449a8e17342abd81a3fadaf jdk7-b128
|
||||
|
@ -428,6 +428,36 @@ public class CommandProcessor {
|
||||
}
|
||||
}
|
||||
},
|
||||
new Command("symbol", "symbol address", false) {
|
||||
public void doit(Tokens t) {
|
||||
if (t.countTokens() != 1) {
|
||||
usage();
|
||||
} else {
|
||||
Address a = VM.getVM().getDebugger().parseAddress(t.nextToken());
|
||||
Symbol.create(a).printValueOn(out);
|
||||
out.println();
|
||||
}
|
||||
}
|
||||
},
|
||||
new Command("symboltable", "symboltable name", false) {
|
||||
public void doit(Tokens t) {
|
||||
if (t.countTokens() != 1) {
|
||||
usage();
|
||||
} else {
|
||||
out.println(SymbolTable.getTheTable().probe(t.nextToken()));
|
||||
}
|
||||
}
|
||||
},
|
||||
new Command("symboldump", "symboldump", false) {
|
||||
public void doit(Tokens t) {
|
||||
SymbolTable.getTheTable().symbolsDo(new SymbolTable.SymbolVisitor() {
|
||||
public void visit(Symbol sym) {
|
||||
sym.printValueOn(out);
|
||||
out.println();
|
||||
}
|
||||
});
|
||||
}
|
||||
},
|
||||
new Command("flags", "flags [ flag ]", false) {
|
||||
public void doit(Tokens t) {
|
||||
int tokens = t.countTokens();
|
||||
@ -629,17 +659,6 @@ public class CommandProcessor {
|
||||
}
|
||||
}
|
||||
},
|
||||
new Command("symbol", "symbol name", false) {
|
||||
public void doit(Tokens t) {
|
||||
if (t.countTokens() != 1) {
|
||||
usage();
|
||||
} else {
|
||||
String symbol = t.nextToken();
|
||||
Address a = lookup(symbol);
|
||||
out.println(symbol + " = " + a);
|
||||
}
|
||||
}
|
||||
},
|
||||
new Command("printstatics", "printstatics [ type ]", false) {
|
||||
public void doit(Tokens t) {
|
||||
if (t.countTokens() > 1) {
|
||||
@ -1262,6 +1281,9 @@ public class CommandProcessor {
|
||||
this.err = err;
|
||||
for (int i = 0; i < commandList.length; i++) {
|
||||
Command c = commandList[i];
|
||||
if (commands.get(c.name) != null) {
|
||||
throw new InternalError(c.name + " has multiple definitions");
|
||||
}
|
||||
commands.put(c.name, c);
|
||||
}
|
||||
if (debugger.isAttached()) {
|
||||
|
@ -89,6 +89,37 @@ public class HotSpotTypeDataBase extends BasicTypeDataBase {
|
||||
readVMLongConstants();
|
||||
}
|
||||
|
||||
public Type lookupType(String cTypeName, boolean throwException) {
|
||||
Type fieldType = super.lookupType(cTypeName, false);
|
||||
if (fieldType == null && cTypeName.startsWith("const ")) {
|
||||
fieldType = (BasicType)lookupType(cTypeName.substring(6), false);
|
||||
}
|
||||
if (fieldType == null && cTypeName.endsWith(" const")) {
|
||||
fieldType = (BasicType)lookupType(cTypeName.substring(0, cTypeName.length() - 6), false);
|
||||
}
|
||||
if (fieldType == null) {
|
||||
if (cTypeName.startsWith("GrowableArray<") && cTypeName.endsWith(">*")) {
|
||||
String ttype = cTypeName.substring("GrowableArray<".length(),
|
||||
cTypeName.length() - 2);
|
||||
Type templateType = lookupType(ttype, false);
|
||||
if (templateType == null && typeNameIsPointerType(ttype)) {
|
||||
templateType = recursiveCreateBasicPointerType(ttype);
|
||||
}
|
||||
if (templateType == null) {
|
||||
lookupOrFail(ttype);
|
||||
}
|
||||
fieldType = recursiveCreateBasicPointerType(cTypeName);
|
||||
}
|
||||
}
|
||||
if (fieldType == null && typeNameIsPointerType(cTypeName)) {
|
||||
fieldType = recursiveCreateBasicPointerType(cTypeName);
|
||||
}
|
||||
if (fieldType == null && throwException) {
|
||||
super.lookupType(cTypeName, true);
|
||||
}
|
||||
return fieldType;
|
||||
}
|
||||
|
||||
private void readVMTypes() {
|
||||
// Get the variables we need in order to traverse the VMTypeEntry[]
|
||||
long typeEntryTypeNameOffset;
|
||||
@ -250,7 +281,7 @@ public class HotSpotTypeDataBase extends BasicTypeDataBase {
|
||||
BasicType containingType = lookupOrFail(typeName);
|
||||
|
||||
// The field's Type must already be in the database -- no exceptions
|
||||
BasicType fieldType = lookupOrFail(typeString);
|
||||
BasicType fieldType = (BasicType)lookupType(typeString);
|
||||
|
||||
// Create field by type
|
||||
createField(containingType, fieldName, fieldType,
|
||||
@ -442,10 +473,17 @@ public class HotSpotTypeDataBase extends BasicTypeDataBase {
|
||||
workarounds due to incomplete information in the VMStructs
|
||||
database. */
|
||||
private BasicPointerType recursiveCreateBasicPointerType(String typeName) {
|
||||
BasicPointerType result = (BasicPointerType)super.lookupType(typeName, false);
|
||||
if (result != null) {
|
||||
return result;
|
||||
}
|
||||
String targetTypeName = typeName.substring(0, typeName.lastIndexOf('*')).trim();
|
||||
Type targetType = null;
|
||||
if (typeNameIsPointerType(targetTypeName)) {
|
||||
targetType = recursiveCreateBasicPointerType(targetTypeName);
|
||||
targetType = lookupType(targetTypeName, false);
|
||||
if (targetType == null) {
|
||||
targetType = recursiveCreateBasicPointerType(targetTypeName);
|
||||
}
|
||||
} else {
|
||||
targetType = lookupType(targetTypeName, false);
|
||||
if (targetType == null) {
|
||||
@ -466,6 +504,20 @@ public class HotSpotTypeDataBase extends BasicTypeDataBase {
|
||||
BasicType basicTargetType = createBasicType(targetTypeName, false, true, true);
|
||||
basicTargetType.setSize(1);
|
||||
targetType = basicTargetType;
|
||||
} else if (targetTypeName.startsWith("GrowableArray<")) {
|
||||
BasicType basicTargetType = createBasicType(targetTypeName, false, false, false);
|
||||
|
||||
// transfer fields from GenericGrowableArray to template instance
|
||||
BasicType generic = lookupOrFail("GenericGrowableArray");
|
||||
basicTargetType.setSize(generic.getSize());
|
||||
Iterator fields = generic.getFields();
|
||||
while (fields.hasNext()) {
|
||||
Field f = (Field)fields.next();
|
||||
basicTargetType.addField(internalCreateField(basicTargetType, f.getName(),
|
||||
f.getType(), f.isStatic(),
|
||||
f.getOffset(), null));
|
||||
}
|
||||
targetType = basicTargetType;
|
||||
} else {
|
||||
if (DEBUG) {
|
||||
System.err.println("WARNING: missing target type \"" + targetTypeName + "\" for pointer type \"" + typeName + "\"");
|
||||
@ -474,7 +526,10 @@ public class HotSpotTypeDataBase extends BasicTypeDataBase {
|
||||
}
|
||||
}
|
||||
}
|
||||
return new BasicPointerType(this, typeName, targetType);
|
||||
result = new BasicPointerType(this, typeName, targetType);
|
||||
result.setSize(UNINITIALIZED_SIZE);
|
||||
addType(result);
|
||||
return result;
|
||||
}
|
||||
|
||||
private boolean typeNameIsPointerType(String typeName) {
|
||||
|
@ -112,7 +112,7 @@ public class BytecodeLoadConstant extends BytecodeWithCPIndex {
|
||||
}
|
||||
|
||||
// return Symbol (if unresolved) or Klass (if resolved)
|
||||
public Oop getKlass() {
|
||||
public Object getKlass() {
|
||||
if (Assert.ASSERTS_ENABLED) {
|
||||
Assert.that(isKlassConstant(), "not a klass literal");
|
||||
}
|
||||
@ -121,11 +121,11 @@ public class BytecodeLoadConstant extends BytecodeWithCPIndex {
|
||||
// decide based on the oop type.
|
||||
ConstantPool cpool = method().getConstants();
|
||||
int cpIndex = index();
|
||||
Oop oop = cpool.getObjAt(cpIndex);
|
||||
if (oop.isKlass()) {
|
||||
return (Klass) oop;
|
||||
} else if (oop.isSymbol()) {
|
||||
return (Symbol) oop;
|
||||
ConstantPool.CPSlot oop = cpool.getSlotAt(cpIndex);
|
||||
if (oop.isOop()) {
|
||||
return (Klass) oop.getOop();
|
||||
} else if (oop.isMetaData()) {
|
||||
return oop.getSymbol();
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
@ -165,12 +165,12 @@ public class BytecodeLoadConstant extends BytecodeWithCPIndex {
|
||||
// tag change from 'unresolved' to 'string' does not happen atomically.
|
||||
// We just look at the object at the corresponding index and
|
||||
// decide based on the oop type.
|
||||
Oop obj = cpool.getObjAt(cpIndex);
|
||||
if (obj.isSymbol()) {
|
||||
Symbol sym = (Symbol) obj;
|
||||
return "<String \"" + sym.asString() + "\">";
|
||||
} else if (obj.isInstance()) {
|
||||
return "<String \"" + OopUtilities.stringOopToString(obj) + "\">";
|
||||
ConstantPool.CPSlot obj = cpool.getSlotAt(cpIndex);
|
||||
if (obj.isMetaData()) {
|
||||
Symbol sym = obj.getSymbol();
|
||||
return "<String \"" + sym.asString() + "\">";
|
||||
} else if (obj.isOop()) {
|
||||
return "<String \"" + OopUtilities.stringOopToString(obj.getOop()) + "\">";
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
@ -178,13 +178,13 @@ public class BytecodeLoadConstant extends BytecodeWithCPIndex {
|
||||
// tag change from 'unresolved' to 'klass' does not happen atomically.
|
||||
// We just look at the object at the corresponding index and
|
||||
// decide based on the oop type.
|
||||
Oop obj = cpool.getObjAt(cpIndex);
|
||||
if (obj.isKlass()) {
|
||||
Klass k = (Klass) obj;
|
||||
return "<Class " + k.getName().asString() + "@" + k.getHandle() + ">";
|
||||
} else if (obj.isSymbol()) {
|
||||
Symbol sym = (Symbol) obj;
|
||||
return "<Class " + sym.asString() + ">";
|
||||
ConstantPool.CPSlot obj = cpool.getSlotAt(cpIndex);
|
||||
if (obj.isOop()) {
|
||||
Klass k = (Klass) obj.getOop();
|
||||
return "<Class " + k.getName().asString() + "@" + k.getHandle() + ">";
|
||||
} else if (obj.isMetaData()) {
|
||||
Symbol sym = obj.getSymbol();
|
||||
return "<Class " + sym.asString() + ">";
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
|
@ -37,11 +37,11 @@ public class BytecodeWithKlass extends BytecodeWithCPIndex {
|
||||
}
|
||||
|
||||
public Symbol getClassName() {
|
||||
Oop obj = method().getConstants().getObjAt(index());
|
||||
if (obj instanceof Symbol) {
|
||||
return (Symbol)obj;
|
||||
ConstantPool.CPSlot obj = method().getConstants().getSlotAt(index());
|
||||
if (obj.isMetaData()) {
|
||||
return obj.getSymbol();
|
||||
} else {
|
||||
return ((Klass)obj).getName();
|
||||
return ((Klass)obj.getOop()).getName();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -63,7 +63,7 @@ public class DictionaryEntry extends sun.jvm.hotspot.utilities.HashtableEntry {
|
||||
}
|
||||
|
||||
public Klass klass() {
|
||||
return (Klass) literal();
|
||||
return (Klass)VM.getVM().getObjectHeap().newOop(literalValue().addOffsetToAsOopHandle(0));
|
||||
}
|
||||
|
||||
public DictionaryEntry(Address addr) {
|
||||
|
@ -42,14 +42,14 @@ public class LoaderConstraintEntry extends sun.jvm.hotspot.utilities.HashtableEn
|
||||
|
||||
private static synchronized void initialize(TypeDataBase db) {
|
||||
Type type = db.lookupType("LoaderConstraintEntry");
|
||||
nameField = type.getOopField("_name");
|
||||
nameField = type.getAddressField("_name");
|
||||
numLoadersField = type.getCIntegerField("_num_loaders");
|
||||
maxLoadersField = type.getCIntegerField("_max_loaders");
|
||||
loadersField = type.getAddressField("_loaders");
|
||||
}
|
||||
|
||||
// Fields
|
||||
private static sun.jvm.hotspot.types.OopField nameField;
|
||||
private static AddressField nameField;
|
||||
private static CIntegerField numLoadersField;
|
||||
private static CIntegerField maxLoadersField;
|
||||
private static AddressField loadersField;
|
||||
@ -57,7 +57,7 @@ public class LoaderConstraintEntry extends sun.jvm.hotspot.utilities.HashtableEn
|
||||
// Accessors
|
||||
|
||||
public Symbol name() {
|
||||
return (Symbol) VM.getVM().getObjectHeap().newOop(nameField.getValue(addr));
|
||||
return Symbol.create(nameField.getValue(addr));
|
||||
}
|
||||
|
||||
public int numLoaders() {
|
||||
|
@ -58,7 +58,7 @@ public class PlaceholderEntry extends sun.jvm.hotspot.utilities.HashtableEntry {
|
||||
}
|
||||
|
||||
public Symbol klass() {
|
||||
return (Symbol) literal();
|
||||
return Symbol.create(literalValue());
|
||||
}
|
||||
|
||||
/* covariant return type :-(
|
||||
|
@ -70,11 +70,13 @@ public class StringTable extends sun.jvm.hotspot.utilities.Hashtable {
|
||||
}
|
||||
|
||||
public void stringsDo(StringVisitor visitor) {
|
||||
ObjectHeap oh = VM.getVM().getObjectHeap();
|
||||
int numBuckets = tableSize();
|
||||
for (int i = 0; i < numBuckets; i++) {
|
||||
for (HashtableEntry e = (HashtableEntry) bucket(i); e != null;
|
||||
e = (HashtableEntry) e.next()) {
|
||||
visitor.visit((Instance) e.literal());
|
||||
Instance s = (Instance)oh.newOop(e.literalValue().addOffsetToAsOopHandle(0));
|
||||
visitor.visit(s);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -85,7 +85,7 @@ public class SymbolTable extends sun.jvm.hotspot.utilities.Hashtable {
|
||||
long hashValue = hashSymbol(name);
|
||||
for (HashtableEntry e = (HashtableEntry) bucket(hashToIndex(hashValue)); e != null; e = (HashtableEntry) e.next()) {
|
||||
if (e.hash() == hashValue) {
|
||||
Symbol sym = (Symbol) e.literal();
|
||||
Symbol sym = Symbol.create(e.literalValue());
|
||||
if (sym.equals(name)) {
|
||||
return sym;
|
||||
}
|
||||
@ -103,7 +103,7 @@ public class SymbolTable extends sun.jvm.hotspot.utilities.Hashtable {
|
||||
for (int i = 0; i < numBuckets; i++) {
|
||||
for (HashtableEntry e = (HashtableEntry) bucket(i); e != null;
|
||||
e = (HashtableEntry) e.next()) {
|
||||
visitor.visit((Symbol) e.literal());
|
||||
visitor.visit(Symbol.create(e.literalValue()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -35,6 +35,38 @@ import sun.jvm.hotspot.utilities.*;
|
||||
// as described in the class file
|
||||
|
||||
public class ConstantPool extends Oop implements ClassConstants {
|
||||
|
||||
public class CPSlot {
|
||||
private Address ptr;
|
||||
|
||||
CPSlot(Address ptr) {
|
||||
this.ptr = ptr;
|
||||
}
|
||||
CPSlot(Symbol sym) {
|
||||
this.ptr = sym.getAddress().orWithMask(1);
|
||||
}
|
||||
|
||||
public boolean isOop() {
|
||||
return (ptr.minus(null) & 1) == 0;
|
||||
}
|
||||
public boolean isMetaData() {
|
||||
return (ptr.minus(null) & 1) == 1;
|
||||
}
|
||||
|
||||
public Symbol getSymbol() {
|
||||
if (isMetaData()) {
|
||||
return Symbol.create(ptr.xorWithMask(1));
|
||||
}
|
||||
throw new InternalError("not a symbol");
|
||||
}
|
||||
public Oop getOop() {
|
||||
if (isOop()) {
|
||||
return VM.getVM().getObjectHeap().newOop(ptr.addOffsetToAsOopHandle(0));
|
||||
}
|
||||
throw new InternalError("not an oop");
|
||||
}
|
||||
}
|
||||
|
||||
// Used for debugging this code
|
||||
private static final boolean DEBUG = false;
|
||||
|
||||
@ -110,12 +142,17 @@ public class ConstantPool extends Oop implements ClassConstants {
|
||||
return new ConstantTag(getTags().getByteAt((int) index));
|
||||
}
|
||||
|
||||
public Oop getObjAt(long index){
|
||||
public CPSlot getSlotAt(long index) {
|
||||
return new CPSlot(getHandle().getAddressAt(indexOffset(index)));
|
||||
}
|
||||
|
||||
public Oop getObjAtRaw(long index){
|
||||
return getHeap().newOop(getHandle().getOopHandleAt(indexOffset(index)));
|
||||
}
|
||||
|
||||
public Symbol getSymbolAt(long index) {
|
||||
return (Symbol) getObjAt(index);
|
||||
CPSlot slot = getSlotAt(index);
|
||||
return slot.getSymbol();
|
||||
}
|
||||
|
||||
public int getIntAt(long index){
|
||||
@ -187,7 +224,7 @@ public class ConstantPool extends Oop implements ClassConstants {
|
||||
// returns null, if not resolved.
|
||||
public Klass getKlassRefAt(int which) {
|
||||
if( ! getTagAt(which).isKlass()) return null;
|
||||
return (Klass) getObjAt(which);
|
||||
return (Klass) getObjAtRaw(which);
|
||||
}
|
||||
|
||||
// returns null, if not resolved.
|
||||
@ -477,7 +514,7 @@ public class ConstantPool extends Oop implements ClassConstants {
|
||||
case JVM_CONSTANT_Class: {
|
||||
dos.writeByte(cpConstType);
|
||||
// Klass already resolved. ConstantPool constains klassOop.
|
||||
Klass refKls = (Klass) getObjAt(ci);
|
||||
Klass refKls = (Klass) getObjAtRaw(ci);
|
||||
String klassName = refKls.getName().asString();
|
||||
Short s = (Short) utf8ToIndex.get(klassName);
|
||||
dos.writeShort(s.shortValue());
|
||||
@ -498,7 +535,7 @@ public class ConstantPool extends Oop implements ClassConstants {
|
||||
|
||||
case JVM_CONSTANT_String: {
|
||||
dos.writeByte(cpConstType);
|
||||
String str = OopUtilities.stringOopToString(getObjAt(ci));
|
||||
String str = OopUtilities.stringOopToString(getObjAtRaw(ci));
|
||||
Short s = (Short) utf8ToIndex.get(str);
|
||||
dos.writeShort(s.shortValue());
|
||||
if (DEBUG) debugMessage("CP[" + ci + "] = string " + s);
|
||||
|
@ -576,7 +576,7 @@ public class GenerateOopMap {
|
||||
ConstantPool cp = method().getConstants();
|
||||
int nameAndTypeIdx = cp.name_and_type_ref_index_at(idx);
|
||||
int signatureIdx = cp.signature_ref_index_at(nameAndTypeIdx);
|
||||
symbolOop signature = cp.symbol_at(signatureIdx);
|
||||
Symbol* signature = cp.symbol_at(signatureIdx);
|
||||
tty.print("%s", signature.as_C_string());
|
||||
*/
|
||||
}
|
||||
@ -616,7 +616,7 @@ public class GenerateOopMap {
|
||||
constantPoolOop cp = method().constants();
|
||||
int nameAndTypeIdx = cp.name_and_type_ref_index_at(idx);
|
||||
int signatureIdx = cp.signature_ref_index_at(nameAndTypeIdx);
|
||||
symbolOop signature = cp.symbol_at(signatureIdx);
|
||||
Symbol* signature = cp.symbol_at(signatureIdx);
|
||||
tty.print("%s", signature.as_C_string());
|
||||
*/
|
||||
}
|
||||
|
@ -82,8 +82,8 @@ public class InstanceKlass extends Klass {
|
||||
classLoader = new OopField(type.getOopField("_class_loader"), Oop.getHeaderSize());
|
||||
protectionDomain = new OopField(type.getOopField("_protection_domain"), Oop.getHeaderSize());
|
||||
signers = new OopField(type.getOopField("_signers"), Oop.getHeaderSize());
|
||||
sourceFileName = new OopField(type.getOopField("_source_file_name"), Oop.getHeaderSize());
|
||||
sourceDebugExtension = new OopField(type.getOopField("_source_debug_extension"), Oop.getHeaderSize());
|
||||
sourceFileName = type.getAddressField("_source_file_name");
|
||||
sourceDebugExtension = type.getAddressField("_source_debug_extension");
|
||||
innerClasses = new OopField(type.getOopField("_inner_classes"), Oop.getHeaderSize());
|
||||
nonstaticFieldSize = new CIntField(type.getCIntegerField("_nonstatic_field_size"), Oop.getHeaderSize());
|
||||
staticFieldSize = new CIntField(type.getCIntegerField("_static_field_size"), Oop.getHeaderSize());
|
||||
@ -94,7 +94,7 @@ public class InstanceKlass extends Klass {
|
||||
vtableLen = new CIntField(type.getCIntegerField("_vtable_len"), Oop.getHeaderSize());
|
||||
itableLen = new CIntField(type.getCIntegerField("_itable_len"), Oop.getHeaderSize());
|
||||
breakpoints = type.getAddressField("_breakpoints");
|
||||
genericSignature = new OopField(type.getOopField("_generic_signature"), Oop.getHeaderSize());
|
||||
genericSignature = type.getAddressField("_generic_signature");
|
||||
majorVersion = new CIntField(type.getCIntegerField("_major_version"), Oop.getHeaderSize());
|
||||
minorVersion = new CIntField(type.getCIntegerField("_minor_version"), Oop.getHeaderSize());
|
||||
headerSize = alignObjectOffset(Oop.getHeaderSize() + type.getSize());
|
||||
@ -135,8 +135,8 @@ public class InstanceKlass extends Klass {
|
||||
private static OopField classLoader;
|
||||
private static OopField protectionDomain;
|
||||
private static OopField signers;
|
||||
private static OopField sourceFileName;
|
||||
private static OopField sourceDebugExtension;
|
||||
private static AddressField sourceFileName;
|
||||
private static AddressField sourceDebugExtension;
|
||||
private static OopField innerClasses;
|
||||
private static CIntField nonstaticFieldSize;
|
||||
private static CIntField staticFieldSize;
|
||||
@ -147,7 +147,7 @@ public class InstanceKlass extends Klass {
|
||||
private static CIntField vtableLen;
|
||||
private static CIntField itableLen;
|
||||
private static AddressField breakpoints;
|
||||
private static OopField genericSignature;
|
||||
private static AddressField genericSignature;
|
||||
private static CIntField majorVersion;
|
||||
private static CIntField minorVersion;
|
||||
|
||||
@ -257,8 +257,8 @@ public class InstanceKlass extends Klass {
|
||||
public Oop getClassLoader() { return classLoader.getValue(this); }
|
||||
public Oop getProtectionDomain() { return protectionDomain.getValue(this); }
|
||||
public ObjArray getSigners() { return (ObjArray) signers.getValue(this); }
|
||||
public Symbol getSourceFileName() { return (Symbol) sourceFileName.getValue(this); }
|
||||
public Symbol getSourceDebugExtension(){ return (Symbol) sourceDebugExtension.getValue(this); }
|
||||
public Symbol getSourceFileName() { return getSymbol(sourceFileName); }
|
||||
public Symbol getSourceDebugExtension(){ return getSymbol(sourceDebugExtension); }
|
||||
public TypeArray getInnerClasses() { return (TypeArray) innerClasses.getValue(this); }
|
||||
public long getNonstaticFieldSize() { return nonstaticFieldSize.getValue(this); }
|
||||
public long getStaticFieldSize() { return staticFieldSize.getValue(this); }
|
||||
@ -267,7 +267,7 @@ public class InstanceKlass extends Klass {
|
||||
public boolean getIsMarkedDependent() { return isMarkedDependent.getValue(this) != 0; }
|
||||
public long getVtableLen() { return vtableLen.getValue(this); }
|
||||
public long getItableLen() { return itableLen.getValue(this); }
|
||||
public Symbol getGenericSignature() { return (Symbol) genericSignature.getValue(this); }
|
||||
public Symbol getGenericSignature() { return getSymbol(genericSignature); }
|
||||
public long majorVersion() { return majorVersion.getValue(this); }
|
||||
public long minorVersion() { return minorVersion.getValue(this); }
|
||||
|
||||
@ -308,12 +308,12 @@ public class InstanceKlass extends Klass {
|
||||
if (ioff != 0) {
|
||||
// only look at classes that are already loaded
|
||||
// since we are looking for the flags for our self.
|
||||
Oop classInfo = getConstants().getObjAt(ioff);
|
||||
ConstantPool.CPSlot classInfo = getConstants().getSlotAt(ioff);
|
||||
Symbol name = null;
|
||||
if (classInfo instanceof Klass) {
|
||||
name = ((Klass) classInfo).getName();
|
||||
} else if (classInfo instanceof Symbol) {
|
||||
name = (Symbol) classInfo;
|
||||
if (classInfo.isOop()) {
|
||||
name = ((Klass) classInfo.getOop()).getName();
|
||||
} else if (classInfo.isMetaData()) {
|
||||
name = classInfo.getSymbol();
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
@ -358,12 +358,12 @@ public class InstanceKlass extends Klass {
|
||||
// 'ioff' can be zero.
|
||||
// refer to JVM spec. section 4.7.5.
|
||||
if (ioff != 0) {
|
||||
Oop iclassInfo = getConstants().getObjAt(ioff);
|
||||
ConstantPool.CPSlot iclassInfo = getConstants().getSlotAt(ioff);
|
||||
Symbol innerName = null;
|
||||
if (iclassInfo instanceof Klass) {
|
||||
innerName = ((Klass) iclassInfo).getName();
|
||||
} else if (iclassInfo instanceof Symbol) {
|
||||
innerName = (Symbol) iclassInfo;
|
||||
if (iclassInfo.isOop()) {
|
||||
innerName = ((Klass) iclassInfo.getOop()).getName();
|
||||
} else if (iclassInfo.isMetaData()) {
|
||||
innerName = iclassInfo.getSymbol();
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
@ -387,12 +387,12 @@ public class InstanceKlass extends Klass {
|
||||
}
|
||||
}
|
||||
} else {
|
||||
Oop oclassInfo = getConstants().getObjAt(ooff);
|
||||
ConstantPool.CPSlot oclassInfo = getConstants().getSlotAt(ooff);
|
||||
Symbol outerName = null;
|
||||
if (oclassInfo instanceof Klass) {
|
||||
outerName = ((Klass) oclassInfo).getName();
|
||||
} else if (oclassInfo instanceof Symbol) {
|
||||
outerName = (Symbol) oclassInfo;
|
||||
if (oclassInfo.isOop()) {
|
||||
outerName = ((Klass) oclassInfo.getOop()).getName();
|
||||
} else if (oclassInfo.isMetaData()) {
|
||||
outerName = oclassInfo.getSymbol();
|
||||
} else {
|
||||
throw new RuntimeException("should not reach here");
|
||||
}
|
||||
@ -450,7 +450,6 @@ public class InstanceKlass extends Klass {
|
||||
visitor.doOop(classLoader, true);
|
||||
visitor.doOop(protectionDomain, true);
|
||||
visitor.doOop(signers, true);
|
||||
visitor.doOop(sourceFileName, true);
|
||||
visitor.doOop(innerClasses, true);
|
||||
visitor.doCInt(nonstaticFieldSize, true);
|
||||
visitor.doCInt(staticFieldSize, true);
|
||||
@ -467,7 +466,7 @@ public class InstanceKlass extends Klass {
|
||||
for (int index = 0; index < length; index += NEXT_OFFSET) {
|
||||
short accessFlags = fields.getShortAt(index + ACCESS_FLAGS_OFFSET);
|
||||
short signatureIndex = fields.getShortAt(index + SIGNATURE_INDEX_OFFSET);
|
||||
FieldType type = new FieldType((Symbol) getConstants().getObjAt(signatureIndex));
|
||||
FieldType type = new FieldType(getConstants().getSymbolAt(signatureIndex));
|
||||
AccessFlags access = new AccessFlags(accessFlags);
|
||||
if (access.isStatic()) {
|
||||
visitField(visitor, type, index);
|
||||
@ -490,7 +489,7 @@ public class InstanceKlass extends Klass {
|
||||
short accessFlags = fields.getShortAt(index + ACCESS_FLAGS_OFFSET);
|
||||
short signatureIndex = fields.getShortAt(index + SIGNATURE_INDEX_OFFSET);
|
||||
|
||||
FieldType type = new FieldType((Symbol) getConstants().getObjAt(signatureIndex));
|
||||
FieldType type = new FieldType(getConstants().getSymbolAt(signatureIndex));
|
||||
AccessFlags access = new AccessFlags(accessFlags);
|
||||
if (!access.isStatic()) {
|
||||
visitField(visitor, type, index);
|
||||
@ -787,7 +786,7 @@ public class InstanceKlass extends Klass {
|
||||
private Field newField(int index) {
|
||||
TypeArray fields = getFields();
|
||||
short signatureIndex = fields.getShortAt(index + SIGNATURE_INDEX_OFFSET);
|
||||
FieldType type = new FieldType((Symbol) getConstants().getObjAt(signatureIndex));
|
||||
FieldType type = new FieldType(getConstants().getSymbolAt(signatureIndex));
|
||||
if (type.isOop()) {
|
||||
if (VM.getVM().isCompressedOopsEnabled()) {
|
||||
return new NarrowOopField(this, index);
|
||||
|
@ -53,7 +53,7 @@ public class Klass extends Oop implements ClassConstants {
|
||||
javaMirror = new OopField(type.getOopField("_java_mirror"), Oop.getHeaderSize());
|
||||
superField = new OopField(type.getOopField("_super"), Oop.getHeaderSize());
|
||||
layoutHelper = new IntField(type.getJIntField("_layout_helper"), Oop.getHeaderSize());
|
||||
name = new OopField(type.getOopField("_name"), Oop.getHeaderSize());
|
||||
name = type.getAddressField("_name");
|
||||
accessFlags = new CIntField(type.getCIntegerField("_access_flags"), Oop.getHeaderSize());
|
||||
subklass = new OopField(type.getOopField("_subklass"), Oop.getHeaderSize());
|
||||
nextSibling = new OopField(type.getOopField("_next_sibling"), Oop.getHeaderSize());
|
||||
@ -83,18 +83,26 @@ public class Klass extends Oop implements ClassConstants {
|
||||
private static OopField javaMirror;
|
||||
private static OopField superField;
|
||||
private static IntField layoutHelper;
|
||||
private static OopField name;
|
||||
private static AddressField name;
|
||||
private static CIntField accessFlags;
|
||||
private static OopField subklass;
|
||||
private static OopField nextSibling;
|
||||
private static CIntField allocCount;
|
||||
|
||||
private Address getValue(AddressField field) {
|
||||
return getHandle().getAddressAt(field.getOffset() + Oop.getHeaderSize());
|
||||
}
|
||||
|
||||
protected Symbol getSymbol(AddressField field) {
|
||||
return Symbol.create(getHandle().getAddressAt(field.getOffset() + Oop.getHeaderSize()));
|
||||
}
|
||||
|
||||
// Accessors for declared fields
|
||||
public Instance getJavaMirror() { return (Instance) javaMirror.getValue(this); }
|
||||
public Klass getSuper() { return (Klass) superField.getValue(this); }
|
||||
public Klass getJavaSuper() { return null; }
|
||||
public int getLayoutHelper() { return (int) layoutHelper.getValue(this); }
|
||||
public Symbol getName() { return (Symbol) name.getValue(this); }
|
||||
public Symbol getName() { return getSymbol(name); }
|
||||
public long getAccessFlags() { return accessFlags.getValue(this); }
|
||||
// Convenience routine
|
||||
public AccessFlags getAccessFlagsObj(){ return new AccessFlags(getAccessFlags()); }
|
||||
@ -162,7 +170,7 @@ public class Klass extends Oop implements ClassConstants {
|
||||
visitor.doOop(javaMirror, true);
|
||||
visitor.doOop(superField, true);
|
||||
visitor.doInt(layoutHelper, true);
|
||||
visitor.doOop(name, true);
|
||||
// visitor.doOop(name, true);
|
||||
visitor.doCInt(accessFlags, true);
|
||||
visitor.doOop(subklass, true);
|
||||
visitor.doOop(nextSibling, true);
|
||||
|
@ -196,11 +196,11 @@ public class Method extends Oop {
|
||||
public Address getFromCompiledCodeEntryPoint() { return fromCompiledCodeEntryPointField.getValue(this); }
|
||||
*/
|
||||
// Accessors
|
||||
public Symbol getName() { return (Symbol) getConstants().getObjAt(getNameIndex()); }
|
||||
public Symbol getSignature() { return (Symbol) getConstants().getObjAt(getSignatureIndex()); }
|
||||
public Symbol getName() { return getConstants().getSymbolAt(getNameIndex()); }
|
||||
public Symbol getSignature() { return getConstants().getSymbolAt(getSignatureIndex()); }
|
||||
public Symbol getGenericSignature() {
|
||||
long index = getGenericSignatureIndex();
|
||||
return (index != 0L) ? (Symbol) getConstants().getObjAt(index) : null;
|
||||
return (index != 0L) ? getConstants().getSymbolAt(index) : null;
|
||||
}
|
||||
|
||||
// Method holder (the Klass holding this method)
|
||||
|
@ -47,7 +47,6 @@ public class ObjectHeap {
|
||||
DEBUG = System.getProperty("sun.jvm.hotspot.oops.ObjectHeap.DEBUG") != null;
|
||||
}
|
||||
|
||||
private OopHandle symbolKlassHandle;
|
||||
private OopHandle methodKlassHandle;
|
||||
private OopHandle constMethodKlassHandle;
|
||||
private OopHandle methodDataKlassHandle;
|
||||
@ -68,7 +67,6 @@ public class ObjectHeap {
|
||||
private OopHandle arrayKlassKlassHandle;
|
||||
private OopHandle compiledICHolderKlassHandle;
|
||||
|
||||
private SymbolKlass symbolKlassObj;
|
||||
private MethodKlass methodKlassObj;
|
||||
private ConstMethodKlass constMethodKlassObj;
|
||||
private MethodDataKlass methodDataKlassObj;
|
||||
@ -93,9 +91,6 @@ public class ObjectHeap {
|
||||
// Lookup the roots in the object hierarchy.
|
||||
Type universeType = db.lookupType("Universe");
|
||||
|
||||
symbolKlassHandle = universeType.getOopField("_symbolKlassObj").getValue();
|
||||
symbolKlassObj = new SymbolKlass(symbolKlassHandle, this);
|
||||
|
||||
methodKlassHandle = universeType.getOopField("_methodKlassObj").getValue();
|
||||
methodKlassObj = new MethodKlass(methodKlassHandle, this);
|
||||
|
||||
@ -199,7 +194,6 @@ public class ObjectHeap {
|
||||
public long getDoubleSize() { return doubleSize; }
|
||||
|
||||
// Accessors for well-known system classes (from Universe)
|
||||
public SymbolKlass getSymbolKlassObj() { return symbolKlassObj; }
|
||||
public MethodKlass getMethodKlassObj() { return methodKlassObj; }
|
||||
public ConstMethodKlass getConstMethodKlassObj() { return constMethodKlassObj; }
|
||||
public MethodDataKlass getMethodDataKlassObj() { return methodDataKlassObj; }
|
||||
@ -337,7 +331,6 @@ public class ObjectHeap {
|
||||
// First check if handle is one of the root objects
|
||||
if (handle.equals(methodKlassHandle)) return getMethodKlassObj();
|
||||
if (handle.equals(constMethodKlassHandle)) return getConstMethodKlassObj();
|
||||
if (handle.equals(symbolKlassHandle)) return getSymbolKlassObj();
|
||||
if (handle.equals(constantPoolKlassHandle)) return getConstantPoolKlassObj();
|
||||
if (handle.equals(constantPoolCacheKlassHandle)) return getConstantPoolCacheKlassObj();
|
||||
if (handle.equals(instanceKlassKlassHandle)) return getInstanceKlassKlassObj();
|
||||
@ -363,7 +356,6 @@ public class ObjectHeap {
|
||||
if (klass != null) {
|
||||
if (klass.equals(methodKlassHandle)) return new Method(handle, this);
|
||||
if (klass.equals(constMethodKlassHandle)) return new ConstMethod(handle, this);
|
||||
if (klass.equals(symbolKlassHandle)) return new Symbol(handle, this);
|
||||
if (klass.equals(constantPoolKlassHandle)) return new ConstantPool(handle, this);
|
||||
if (klass.equals(constantPoolCacheKlassHandle)) return new ConstantPoolCache(handle, this);
|
||||
if (!VM.getVM().isCore()) {
|
||||
|
@ -34,7 +34,7 @@ import sun.jvm.hotspot.utilities.*;
|
||||
// A Symbol is a canonicalized string.
|
||||
// All Symbols reside in global symbolTable.
|
||||
|
||||
public class Symbol extends Oop {
|
||||
public class Symbol extends VMObject {
|
||||
static {
|
||||
VM.registerVMInitializedObserver(new Observer() {
|
||||
public void update(Observable o, Object data) {
|
||||
@ -44,9 +44,10 @@ public class Symbol extends Oop {
|
||||
}
|
||||
|
||||
private static synchronized void initialize(TypeDataBase db) throws WrongTypeException {
|
||||
Type type = db.lookupType("symbolOopDesc");
|
||||
length = new CIntField(type.getCIntegerField("_length"), 0);
|
||||
Type type = db.lookupType("Symbol");
|
||||
length = type.getCIntegerField("_length");
|
||||
baseOffset = type.getField("_body").getOffset();
|
||||
idHash = type.getCIntegerField("_identity_hash");
|
||||
}
|
||||
|
||||
// Format:
|
||||
@ -55,8 +56,15 @@ public class Symbol extends Oop {
|
||||
// [length] byte size of uft8 string
|
||||
// ..body..
|
||||
|
||||
Symbol(OopHandle handle, ObjectHeap heap) {
|
||||
super(handle, heap);
|
||||
public static Symbol create(Address addr) {
|
||||
if (addr == null) {
|
||||
return null;
|
||||
}
|
||||
return new Symbol(addr);
|
||||
}
|
||||
|
||||
Symbol(Address addr) {
|
||||
super(addr);
|
||||
}
|
||||
|
||||
public boolean isSymbol() { return true; }
|
||||
@ -64,15 +72,19 @@ public class Symbol extends Oop {
|
||||
private static long baseOffset; // tells where the array part starts
|
||||
|
||||
// Fields
|
||||
private static CIntField length;
|
||||
private static CIntegerField length;
|
||||
|
||||
// Accessors for declared fields
|
||||
public long getLength() { return length.getValue(this); }
|
||||
public long getLength() { return length.getValue(this.addr); }
|
||||
|
||||
public byte getByteAt(long index) {
|
||||
return getHandle().getJByteAt(baseOffset + index);
|
||||
return addr.getJByteAt(baseOffset + index);
|
||||
}
|
||||
|
||||
private static CIntegerField idHash;
|
||||
|
||||
public int identityHash() { return (int)idHash.getValue(this.addr); }
|
||||
|
||||
public boolean equals(byte[] modUTF8Chars) {
|
||||
int l = (int) getLength();
|
||||
if (l != modUTF8Chars.length) return false;
|
||||
@ -98,7 +110,9 @@ public class Symbol extends Oop {
|
||||
// Decode the byte array and return the string.
|
||||
try {
|
||||
return readModifiedUTF8(asByteArray());
|
||||
} catch(IOException e) {
|
||||
} catch(Exception e) {
|
||||
System.err.println(addr);
|
||||
e.printStackTrace();
|
||||
return null;
|
||||
}
|
||||
}
|
||||
@ -111,28 +125,13 @@ public class Symbol extends Oop {
|
||||
tty.print("#" + asString());
|
||||
}
|
||||
|
||||
public long getObjectSize() {
|
||||
return alignObjectSize(baseOffset + getLength());
|
||||
}
|
||||
|
||||
void iterateFields(OopVisitor visitor, boolean doVMFields) {
|
||||
super.iterateFields(visitor, doVMFields);
|
||||
if (doVMFields) {
|
||||
visitor.doCInt(length, true);
|
||||
int length = (int) getLength();
|
||||
for (int index = 0; index < length; index++) {
|
||||
visitor.doByte(new ByteField(new IndexableFieldIdentifier(index), baseOffset + index, false), true);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/** Note: this comparison is used for vtable sorting only; it
|
||||
doesn't matter what order it defines, as long as it is a total,
|
||||
time-invariant order Since symbolOops are in permSpace, their
|
||||
time-invariant order Since Symbol* are in C_HEAP, their
|
||||
relative order in memory never changes, so use address
|
||||
comparison for speed. */
|
||||
public int fastCompare(Symbol other) {
|
||||
return (int) getHandle().minus(other.getHandle());
|
||||
return (int) addr.minus(other.addr);
|
||||
}
|
||||
|
||||
private static String readModifiedUTF8(byte[] buf) throws IOException {
|
||||
|
@ -1,60 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 2000, 2001, 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.
|
||||
*
|
||||
*/
|
||||
|
||||
package sun.jvm.hotspot.oops;
|
||||
|
||||
import java.io.*;
|
||||
import java.util.*;
|
||||
import sun.jvm.hotspot.debugger.*;
|
||||
import sun.jvm.hotspot.runtime.*;
|
||||
import sun.jvm.hotspot.types.*;
|
||||
|
||||
// A SymbolKlass is the klass for all Symbols
|
||||
|
||||
public class SymbolKlass extends Klass {
|
||||
static {
|
||||
VM.registerVMInitializedObserver(new Observer() {
|
||||
public void update(Observable o, Object data) {
|
||||
initialize(VM.getVM().getTypeDataBase());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private static synchronized void initialize(TypeDataBase db) throws WrongTypeException {
|
||||
Type type = db.lookupType("symbolKlass");
|
||||
headerSize = type.getSize() + Oop.getHeaderSize();
|
||||
}
|
||||
|
||||
SymbolKlass(OopHandle handle, ObjectHeap heap) {
|
||||
super(handle, heap);
|
||||
}
|
||||
|
||||
private static long headerSize;
|
||||
|
||||
public long getObjectSize() { return alignObjectSize(headerSize); }
|
||||
|
||||
public void printValueOn(PrintStream tty) {
|
||||
tty.print("SymbolKlass");
|
||||
}
|
||||
}
|
@ -229,7 +229,7 @@ public class ClassWriter implements /* imports */ ClassConstants
|
||||
case JVM_CONSTANT_Class: {
|
||||
dos.writeByte(cpConstType);
|
||||
// Klass already resolved. ConstantPool constains klassOop.
|
||||
Klass refKls = (Klass) cpool.getObjAt(ci);
|
||||
Klass refKls = (Klass) cpool.getObjAtRaw(ci);
|
||||
String klassName = refKls.getName().asString();
|
||||
|
||||
Short s = (Short) utf8ToIndex.get(klassName);
|
||||
@ -255,7 +255,7 @@ public class ClassWriter implements /* imports */ ClassConstants
|
||||
|
||||
case JVM_CONSTANT_String: {
|
||||
dos.writeByte(cpConstType);
|
||||
String str = OopUtilities.stringOopToString(cpool.getObjAt(ci));
|
||||
String str = OopUtilities.stringOopToString(cpool.getObjAtRaw(ci));
|
||||
Short s = (Short) utf8ToIndex.get(str);
|
||||
dos.writeShort(s.shortValue());
|
||||
if (DEBUG) debugMessage("CP[" + ci + "] = string " + s);
|
||||
|
@ -56,7 +56,7 @@ import sun.jvm.hotspot.debugger.*;
|
||||
</PRE>
|
||||
|
||||
FIXME: among other things, this interface is not sufficient to
|
||||
describe fields which are themselves arrays (like symbolOop's
|
||||
describe fields which are themselves arrays (like Symbol's
|
||||
jbyte _body[1]). */
|
||||
public interface Field {
|
||||
/** Get the name of this field */
|
||||
|
@ -530,7 +530,7 @@ public class HTMLGenerator implements /* imports */ ClassConstants {
|
||||
|
||||
case JVM_CONSTANT_Class:
|
||||
buf.cell("JVM_CONSTANT_Class");
|
||||
Klass klass = (Klass) cpool.getObjAt(index);
|
||||
Klass klass = (Klass) cpool.getObjAtRaw(index);
|
||||
if (klass instanceof InstanceKlass) {
|
||||
buf.cell(genKlassLink((InstanceKlass) klass));
|
||||
} else {
|
||||
@ -555,7 +555,7 @@ public class HTMLGenerator implements /* imports */ ClassConstants {
|
||||
case JVM_CONSTANT_String:
|
||||
buf.cell("JVM_CONSTANT_String");
|
||||
buf.cell("\"" +
|
||||
escapeHTMLSpecialChars(OopUtilities.stringOopToString(cpool.getObjAt(index))) + "\"");
|
||||
escapeHTMLSpecialChars(OopUtilities.stringOopToString(cpool.getObjAtRaw(index))) + "\"");
|
||||
break;
|
||||
|
||||
case JVM_CONSTANT_Fieldref:
|
||||
@ -672,11 +672,11 @@ public class HTMLGenerator implements /* imports */ ClassConstants {
|
||||
buf.beginTag("ul");
|
||||
for (int exp = 0; exp < exceptions.length; exp++) {
|
||||
short cpIndex = (short) exceptions[exp].getClassCPIndex();
|
||||
Oop obj = cpool.getObjAt(cpIndex);
|
||||
if (obj instanceof Symbol) {
|
||||
buf.li(((Symbol)obj).asString().replace('/', '.'));
|
||||
ConstantPool.CPSlot obj = cpool.getSlotAt(cpIndex);
|
||||
if (obj.isMetaData()) {
|
||||
buf.li((obj.getSymbol()).asString().replace('/', '.'));
|
||||
} else {
|
||||
buf.li(genKlassLink((InstanceKlass)obj));
|
||||
buf.li(genKlassLink((InstanceKlass)obj.getOop()));
|
||||
}
|
||||
}
|
||||
buf.endTag("ul");
|
||||
@ -756,7 +756,7 @@ public class HTMLGenerator implements /* imports */ ClassConstants {
|
||||
} else if (instr instanceof BytecodeLoadConstant) {
|
||||
BytecodeLoadConstant ldc = (BytecodeLoadConstant) instr;
|
||||
if (ldc.isKlassConstant()) {
|
||||
Oop oop = ldc.getKlass();
|
||||
Object oop = ldc.getKlass();
|
||||
if (oop instanceof Klass) {
|
||||
buf.append("<a href='");
|
||||
buf.append(genKlassHref((InstanceKlass) oop));
|
||||
@ -803,13 +803,13 @@ public class HTMLGenerator implements /* imports */ ClassConstants {
|
||||
buf.cell(Integer.toString(exceptionTable.getIntAt(e + 1)));
|
||||
buf.cell(Integer.toString(exceptionTable.getIntAt(e + 2)));
|
||||
short cpIndex = (short) exceptionTable.getIntAt(e + 3);
|
||||
Oop obj = cpIndex == 0? null : cpool.getObjAt(cpIndex);
|
||||
ConstantPool.CPSlot obj = cpIndex == 0? null : cpool.getSlotAt(cpIndex);
|
||||
if (obj == null) {
|
||||
buf.cell("Any");
|
||||
} else if (obj instanceof Symbol) {
|
||||
buf.cell(((Symbol)obj).asString().replace('/', '.'));
|
||||
} else if (obj.isMetaData()) {
|
||||
buf.cell(obj.getSymbol().asString().replace('/', '.'));
|
||||
} else {
|
||||
buf.cell(genKlassLink((InstanceKlass)obj));
|
||||
buf.cell(genKlassLink((InstanceKlass)obj.getOop()));
|
||||
}
|
||||
buf.endTag("tr");
|
||||
}
|
||||
|
@ -40,7 +40,7 @@ public class Hashtable extends BasicHashtable {
|
||||
|
||||
private static synchronized void initialize(TypeDataBase db) {
|
||||
// just to confirm that type exists
|
||||
Type type = db.lookupType("Hashtable");
|
||||
Type type = db.lookupType("Hashtable<intptr_t>");
|
||||
}
|
||||
|
||||
// derived class may return Class<? extends HashtableEntry>
|
||||
|
@ -41,16 +41,16 @@ public class HashtableEntry extends BasicHashtableEntry {
|
||||
}
|
||||
|
||||
private static synchronized void initialize(TypeDataBase db) {
|
||||
Type type = db.lookupType("HashtableEntry");
|
||||
literalField = type.getOopField("_literal");
|
||||
Type type = db.lookupType("HashtableEntry<intptr_t>");
|
||||
literalField = type.getAddressField("_literal");
|
||||
}
|
||||
|
||||
// Fields
|
||||
private static OopField literalField;
|
||||
private static AddressField literalField;
|
||||
|
||||
// Accessors
|
||||
public Oop literal() {
|
||||
return VM.getVM().getObjectHeap().newOop(literalField.getValue(addr));
|
||||
public Address literalValue() {
|
||||
return literalField.getValue(addr);
|
||||
}
|
||||
|
||||
public HashtableEntry(Address addr) {
|
||||
|
@ -740,7 +740,7 @@ public class HeapHprofBinWriter extends AbstractHeapGraphWriter {
|
||||
for (Iterator itr = fields.iterator(); itr.hasNext();) {
|
||||
Field field = (Field) itr.next();
|
||||
Symbol name = symTbl.probe(field.getID().getName());
|
||||
writeObjectID(name);
|
||||
writeSymbolID(name);
|
||||
char typeCode = (char) field.getSignature().getByteAt(0);
|
||||
int kind = signatureToHprofKind(typeCode);
|
||||
out.writeByte((byte)kind);
|
||||
@ -852,7 +852,7 @@ public class HeapHprofBinWriter extends AbstractHeapGraphWriter {
|
||||
private void writeSymbol(Symbol sym) throws IOException {
|
||||
byte[] buf = sym.asString().getBytes("UTF-8");
|
||||
writeHeader(HPROF_UTF8, buf.length + OBJ_ID_SIZE);
|
||||
writeObjectID(sym);
|
||||
writeSymbolID(sym);
|
||||
out.write(buf);
|
||||
}
|
||||
|
||||
@ -869,7 +869,7 @@ public class HeapHprofBinWriter extends AbstractHeapGraphWriter {
|
||||
out.writeInt(serialNum);
|
||||
writeObjectID(clazz);
|
||||
out.writeInt(DUMMY_STACK_TRACE_ID);
|
||||
writeObjectID(k.getName());
|
||||
writeSymbolID(k.getName());
|
||||
serialNum++;
|
||||
} catch (IOException exp) {
|
||||
throw new RuntimeException(exp);
|
||||
@ -901,6 +901,10 @@ public class HeapHprofBinWriter extends AbstractHeapGraphWriter {
|
||||
writeObjectID(address);
|
||||
}
|
||||
|
||||
private void writeSymbolID(Symbol sym) throws IOException {
|
||||
writeObjectID(getAddressValue(sym.getAddress()));
|
||||
}
|
||||
|
||||
private void writeObjectID(long address) throws IOException {
|
||||
if (OBJ_ID_SIZE == 4) {
|
||||
out.writeInt((int) address);
|
||||
|
@ -33,9 +33,9 @@
|
||||
# Don't put quotes (fail windows build).
|
||||
HOTSPOT_VM_COPYRIGHT=Copyright 2011
|
||||
|
||||
HS_MAJOR_VER=20
|
||||
HS_MAJOR_VER=21
|
||||
HS_MINOR_VER=0
|
||||
HS_BUILD_NUMBER=07
|
||||
HS_BUILD_NUMBER=01
|
||||
|
||||
JDK_MAJOR_VER=1
|
||||
JDK_MINOR_VER=7
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -129,27 +129,6 @@ void SimpleExceptionStub::emit_code(LIR_Assembler* ce) {
|
||||
}
|
||||
|
||||
|
||||
// Implementation of ArrayStoreExceptionStub
|
||||
|
||||
ArrayStoreExceptionStub::ArrayStoreExceptionStub(CodeEmitInfo* info):
|
||||
_info(info) {
|
||||
}
|
||||
|
||||
|
||||
void ArrayStoreExceptionStub::emit_code(LIR_Assembler* ce) {
|
||||
__ bind(_entry);
|
||||
__ call(Runtime1::entry_for(Runtime1::throw_array_store_exception_id), relocInfo::runtime_call_type);
|
||||
__ delayed()->nop();
|
||||
ce->add_call_info_here(_info);
|
||||
ce->verify_oop_map(_info);
|
||||
#ifdef ASSERT
|
||||
__ should_not_reach_here();
|
||||
#endif
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
// Implementation of NewInstanceStub
|
||||
|
||||
NewInstanceStub::NewInstanceStub(LIR_Opr klass_reg, LIR_Opr result, ciInstanceKlass* klass, CodeEmitInfo* info, Runtime1::StubID stub_id) {
|
||||
|
@ -710,7 +710,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
||||
case throw_array_store_exception_id:
|
||||
{
|
||||
__ set_info("throw_array_store_exception", dont_gc_arguments);
|
||||
oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_array_store_exception), false);
|
||||
oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_array_store_exception), true);
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -2541,7 +2541,7 @@ nmethod *SharedRuntime::generate_dtrace_nmethod(
|
||||
in_sig_bt[i++] = bt; // Collect remaining bits of signature
|
||||
out_sig_bt[total_c_args++] = bt;
|
||||
if( bt == T_OBJECT) {
|
||||
symbolOop s = ss.as_symbol_or_null();
|
||||
Symbol* s = ss.as_symbol_or_null();
|
||||
if (s == vmSymbols::java_lang_String()) {
|
||||
total_strings++;
|
||||
out_sig_bt[total_c_args-1] = T_ADDRESS;
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -411,20 +411,6 @@ void SimpleExceptionStub::emit_code(LIR_Assembler* ce) {
|
||||
}
|
||||
|
||||
|
||||
ArrayStoreExceptionStub::ArrayStoreExceptionStub(CodeEmitInfo* info):
|
||||
_info(info) {
|
||||
}
|
||||
|
||||
|
||||
void ArrayStoreExceptionStub::emit_code(LIR_Assembler* ce) {
|
||||
assert(__ rsp_offset() == 0, "frame size should be fixed");
|
||||
__ bind(_entry);
|
||||
__ call(RuntimeAddress(Runtime1::entry_for(Runtime1::throw_array_store_exception_id)));
|
||||
ce->add_call_info_here(_info);
|
||||
debug_only(__ should_not_reach_here());
|
||||
}
|
||||
|
||||
|
||||
void ArrayCopyStub::emit_code(LIR_Assembler* ce) {
|
||||
//---------------slow case: call to native-----------------
|
||||
__ bind(_entry);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 2011, 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
|
||||
@ -733,8 +733,8 @@ void LIRGenerator::do_AttemptUpdate(Intrinsic* x) {
|
||||
|
||||
// generate compare-and-swap; produces zero condition if swap occurs
|
||||
int value_offset = sun_misc_AtomicLongCSImpl::value_offset();
|
||||
LIR_Opr addr = obj.result();
|
||||
__ add(addr, LIR_OprFact::intConst(value_offset), addr);
|
||||
LIR_Opr addr = new_pointer_register();
|
||||
__ leal(LIR_OprFact::address(new LIR_Address(obj.result(), value_offset, T_LONG)), addr);
|
||||
LIR_Opr t1 = LIR_OprFact::illegalOpr; // no temp needed
|
||||
LIR_Opr t2 = LIR_OprFact::illegalOpr; // no temp needed
|
||||
__ cas_long(addr, cmp_value.result(), new_value.result(), t1, t2);
|
||||
|
@ -1337,7 +1337,7 @@ OopMapSet* Runtime1::generate_code_for(StubID id, StubAssembler* sasm) {
|
||||
{ StubFrame f(sasm, "throw_array_store_exception", dont_gc_arguments);
|
||||
// tos + 0: link
|
||||
// + 1: return address
|
||||
oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_array_store_exception), false);
|
||||
oop_maps = generate_exception_throw(sasm, CAST_FROM_FN_PTR(address, throw_array_store_exception), true);
|
||||
}
|
||||
break;
|
||||
|
||||
|
@ -1974,7 +1974,7 @@ nmethod *SharedRuntime::generate_dtrace_nmethod(
|
||||
in_sig_bt[i++] = bt; // Collect remaining bits of signature
|
||||
out_sig_bt[total_c_args++] = bt;
|
||||
if( bt == T_OBJECT) {
|
||||
symbolOop s = ss.as_symbol_or_null();
|
||||
Symbol* s = ss.as_symbol_or_null(); // symbol is created
|
||||
if (s == vmSymbols::java_lang_String()) {
|
||||
total_strings++;
|
||||
out_sig_bt[total_c_args-1] = T_ADDRESS;
|
||||
|
@ -1980,7 +1980,7 @@ nmethod *SharedRuntime::generate_dtrace_nmethod(MacroAssembler *masm,
|
||||
in_sig_bt[i++] = bt; // Collect remaining bits of signature
|
||||
out_sig_bt[total_c_args++] = bt;
|
||||
if( bt == T_OBJECT) {
|
||||
symbolOop s = ss.as_symbol_or_null();
|
||||
Symbol* s = ss.as_symbol_or_null(); // symbol is created
|
||||
if (s == vmSymbols::java_lang_String()) {
|
||||
total_strings++;
|
||||
out_sig_bt[total_c_args-1] = T_ADDRESS;
|
||||
|
@ -49,7 +49,7 @@
|
||||
#include "oops/klass.hpp"
|
||||
#include "oops/methodOop.hpp"
|
||||
#include "oops/oop.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
#include "runtime/virtualspace.hpp"
|
||||
#include "runtime/vmStructs.hpp"
|
||||
#include "utilities/accessFlags.hpp"
|
||||
@ -215,8 +215,8 @@ int generateJvmOffsets(GEN_variant gen_variant) {
|
||||
GEN_VALUE(AccessFlags_NATIVE, JVM_ACC_NATIVE);
|
||||
GEN_VALUE(constMethodOopDesc_has_linenumber_table, constMethodOopDesc::_has_linenumber_table);
|
||||
GEN_OFFS(AccessFlags, _flags);
|
||||
GEN_OFFS(symbolOopDesc, _length);
|
||||
GEN_OFFS(symbolOopDesc, _body);
|
||||
GEN_OFFS(Symbol, _length);
|
||||
GEN_OFFS(Symbol, _body);
|
||||
printf("\n");
|
||||
|
||||
GEN_OFFS(methodOopDesc, _constMethod);
|
||||
|
@ -114,8 +114,8 @@ dtrace:helper:ustack:
|
||||
copyin_offset(OFFSET_HeapBlockHeader_used);
|
||||
copyin_offset(OFFSET_oopDesc_metadata);
|
||||
|
||||
copyin_offset(OFFSET_symbolOopDesc_length);
|
||||
copyin_offset(OFFSET_symbolOopDesc_body);
|
||||
copyin_offset(OFFSET_Symbol_length);
|
||||
copyin_offset(OFFSET_Symbol_body);
|
||||
|
||||
copyin_offset(OFFSET_methodOopDesc_constMethod);
|
||||
copyin_offset(OFFSET_methodOopDesc_constants);
|
||||
@ -366,13 +366,13 @@ dtrace:helper:ustack:
|
||||
this->nameIndex * sizeof (pointer) + SIZE_constantPoolOopDesc);
|
||||
|
||||
this->nameSymbolLength = copyin_uint16(this->nameSymbol +
|
||||
OFFSET_symbolOopDesc_length);
|
||||
OFFSET_Symbol_length);
|
||||
|
||||
this->signatureSymbol = copyin_ptr(this->constantPool +
|
||||
this->signatureIndex * sizeof (pointer) + SIZE_constantPoolOopDesc);
|
||||
|
||||
this->signatureSymbolLength = copyin_uint16(this->signatureSymbol +
|
||||
OFFSET_symbolOopDesc_length);
|
||||
OFFSET_Symbol_length);
|
||||
|
||||
this->klassPtr = copyin_ptr(this->constantPool +
|
||||
OFFSET_constantPoolOopDesc_pool_holder);
|
||||
@ -381,7 +381,7 @@ dtrace:helper:ustack:
|
||||
OFFSET_Klass_name + SIZE_oopDesc);
|
||||
|
||||
this->klassSymbolLength = copyin_uint16(this->klassSymbol +
|
||||
OFFSET_symbolOopDesc_length);
|
||||
OFFSET_Symbol_length);
|
||||
|
||||
/*
|
||||
* Enough for three strings, plus the '.', plus the trailing '\0'.
|
||||
@ -390,7 +390,7 @@ dtrace:helper:ustack:
|
||||
this->nameSymbolLength +
|
||||
this->signatureSymbolLength + 2 + 1);
|
||||
|
||||
copyinto(this->klassSymbol + OFFSET_symbolOopDesc_body,
|
||||
copyinto(this->klassSymbol + OFFSET_Symbol_body,
|
||||
this->klassSymbolLength, this->result);
|
||||
|
||||
/*
|
||||
@ -398,11 +398,11 @@ dtrace:helper:ustack:
|
||||
*/
|
||||
this->result[this->klassSymbolLength] = '.';
|
||||
|
||||
copyinto(this->nameSymbol + OFFSET_symbolOopDesc_body,
|
||||
copyinto(this->nameSymbol + OFFSET_Symbol_body,
|
||||
this->nameSymbolLength,
|
||||
this->result + this->klassSymbolLength + 1);
|
||||
|
||||
copyinto(this->signatureSymbol + OFFSET_symbolOopDesc_body,
|
||||
copyinto(this->signatureSymbol + OFFSET_Symbol_body,
|
||||
this->signatureSymbolLength,
|
||||
this->result + this->klassSymbolLength +
|
||||
this->nameSymbolLength + 1);
|
||||
|
@ -524,10 +524,10 @@ name_for_methodOop(jvm_agent_t* J, uint64_t methodOopPtr, char * result, size_t
|
||||
CHECK_FAIL(err);
|
||||
err = read_pointer(J, constantPool + nameIndex * POINTER_SIZE + SIZE_constantPoolOopDesc, &nameSymbol);
|
||||
CHECK_FAIL(err);
|
||||
err = ps_pread(J->P, nameSymbol + OFFSET_symbolOopDesc_length, &nameSymbolLength, 2);
|
||||
err = ps_pread(J->P, nameSymbol + OFFSET_Symbol_length, &nameSymbolLength, 2);
|
||||
CHECK_FAIL(err);
|
||||
nameString = (char*)calloc(nameSymbolLength + 1, 1);
|
||||
err = ps_pread(J->P, nameSymbol + OFFSET_symbolOopDesc_body, nameString, nameSymbolLength);
|
||||
err = ps_pread(J->P, nameSymbol + OFFSET_Symbol_body, nameString, nameSymbolLength);
|
||||
CHECK_FAIL(err);
|
||||
|
||||
/* To get signature string */
|
||||
@ -535,10 +535,10 @@ name_for_methodOop(jvm_agent_t* J, uint64_t methodOopPtr, char * result, size_t
|
||||
CHECK_FAIL(err);
|
||||
err = read_pointer(J, constantPool + signatureIndex * POINTER_SIZE + SIZE_constantPoolOopDesc, &signatureSymbol);
|
||||
CHECK_FAIL(err);
|
||||
err = ps_pread(J->P, signatureSymbol + OFFSET_symbolOopDesc_length, &signatureSymbolLength, 2);
|
||||
err = ps_pread(J->P, signatureSymbol + OFFSET_Symbol_length, &signatureSymbolLength, 2);
|
||||
CHECK_FAIL(err);
|
||||
signatureString = (char*)calloc(signatureSymbolLength + 1, 1);
|
||||
err = ps_pread(J->P, signatureSymbol + OFFSET_symbolOopDesc_body, signatureString, signatureSymbolLength);
|
||||
err = ps_pread(J->P, signatureSymbol + OFFSET_Symbol_body, signatureString, signatureSymbolLength);
|
||||
CHECK_FAIL(err);
|
||||
|
||||
/* To get klass string */
|
||||
@ -546,10 +546,10 @@ name_for_methodOop(jvm_agent_t* J, uint64_t methodOopPtr, char * result, size_t
|
||||
CHECK_FAIL(err);
|
||||
err = read_pointer(J, klassPtr + OFFSET_Klass_name + SIZE_oopDesc, &klassSymbol);
|
||||
CHECK_FAIL(err);
|
||||
err = ps_pread(J->P, klassSymbol + OFFSET_symbolOopDesc_length, &klassSymbolLength, 2);
|
||||
err = ps_pread(J->P, klassSymbol + OFFSET_Symbol_length, &klassSymbolLength, 2);
|
||||
CHECK_FAIL(err);
|
||||
klassString = (char*)calloc(klassSymbolLength + 1, 1);
|
||||
err = ps_pread(J->P, klassSymbol + OFFSET_symbolOopDesc_body, klassString, klassSymbolLength);
|
||||
err = ps_pread(J->P, klassSymbol + OFFSET_Symbol_body, klassString, klassSymbolLength);
|
||||
CHECK_FAIL(err);
|
||||
|
||||
result[0] = '\0';
|
||||
|
@ -142,7 +142,7 @@ int DTraceJSDT::pd_activate(
|
||||
++strcount;
|
||||
for(int prbc = 0; prbc < provider->probe_count; ++prbc) {
|
||||
JVM_DTraceProbe* p = &(provider->probes[prbc]);
|
||||
symbolOop sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
Symbol* sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
// function + name + one per argument
|
||||
strcount += 2 + ArgumentCount(sig).size();
|
||||
}
|
||||
@ -178,7 +178,7 @@ int DTraceJSDT::pd_activate(
|
||||
stroffs[curstr++] = string_index;
|
||||
string_index += strlen(name) + 1;
|
||||
|
||||
symbolOop sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
Symbol* sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
SignatureStream ss(sig);
|
||||
for ( ; !ss.at_return_type(); ss.next()) {
|
||||
BasicType bt = ss.type();
|
||||
@ -227,7 +227,7 @@ int DTraceJSDT::pd_activate(
|
||||
uint32_t argscount = 0;
|
||||
for(int prbc = 0; prbc < provider->probe_count; ++prbc) {
|
||||
JVM_DTraceProbe* p = &(provider->probes[prbc]);
|
||||
symbolOop sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
Symbol* sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
argscount += ArgumentCount(sig).size();
|
||||
}
|
||||
secoffs[argoffs_sec] = align_size_up(offset, alignment_for[ARG_OFFSETS]);
|
||||
@ -298,7 +298,7 @@ int DTraceJSDT::pd_activate(
|
||||
strcpy(str, name);
|
||||
str += strlen(name) + 1;
|
||||
|
||||
symbolOop sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
Symbol* sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
SignatureStream ss(sig);
|
||||
for ( ; !ss.at_return_type(); ss.next()) {
|
||||
BasicType bt = ss.type();
|
||||
@ -433,7 +433,7 @@ int DTraceJSDT::pd_activate(
|
||||
uint8_t* par = (uint8_t*)(dof + sec->dofs_offset);
|
||||
for (int prbc = 0; prbc < provider->probe_count; ++prbc) {
|
||||
JVM_DTraceProbe* p = &(provider->probes[prbc]);
|
||||
symbolOop sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
Symbol* sig = JNIHandles::resolve_jmethod_id(p->method)->signature();
|
||||
uint8_t count = (uint8_t)ArgumentCount(sig).size();
|
||||
for (uint8_t i = 0; i < count; ++i) {
|
||||
*par++ = i;
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -898,4 +898,4 @@ void Canonicalizer::do_UnsafePrefetchRead (UnsafePrefetchRead* x) {}
|
||||
void Canonicalizer::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) {}
|
||||
void Canonicalizer::do_ProfileCall(ProfileCall* x) {}
|
||||
void Canonicalizer::do_ProfileInvoke(ProfileInvoke* x) {}
|
||||
|
||||
void Canonicalizer::do_RuntimeCall(RuntimeCall* x) {}
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -102,6 +102,7 @@ class Canonicalizer: InstructionVisitor {
|
||||
virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x);
|
||||
virtual void do_ProfileCall (ProfileCall* x);
|
||||
virtual void do_ProfileInvoke (ProfileInvoke* x);
|
||||
virtual void do_RuntimeCall (RuntimeCall* x);
|
||||
};
|
||||
|
||||
#endif // SHARE_VM_C1_C1_CANONICALIZER_HPP
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -476,18 +476,12 @@ class SimpleExceptionStub: public CodeStub {
|
||||
|
||||
|
||||
|
||||
class ArrayStoreExceptionStub: public CodeStub {
|
||||
class ArrayStoreExceptionStub: public SimpleExceptionStub {
|
||||
private:
|
||||
CodeEmitInfo* _info;
|
||||
|
||||
public:
|
||||
ArrayStoreExceptionStub(CodeEmitInfo* info);
|
||||
virtual void emit_code(LIR_Assembler* emit);
|
||||
virtual CodeEmitInfo* info() const { return _info; }
|
||||
virtual bool is_exception_throw_stub() const { return true; }
|
||||
virtual void visit(LIR_OpVisitState* visitor) {
|
||||
visitor->do_slow_case(_info);
|
||||
}
|
||||
ArrayStoreExceptionStub(LIR_Opr obj, CodeEmitInfo* info): SimpleExceptionStub(Runtime1::throw_array_store_exception_id, obj, info) {}
|
||||
#ifndef PRODUCT
|
||||
virtual void print_name(outputStream* out) const { out->print("ArrayStoreExceptionStub"); }
|
||||
#endif // PRODUCT
|
||||
|
@ -1396,6 +1396,13 @@ void GraphBuilder::method_return(Value x) {
|
||||
if (continuation() != NULL) {
|
||||
assert(!method()->is_synchronized() || InlineSynchronizedMethods, "can not inline synchronized methods yet");
|
||||
|
||||
if (compilation()->env()->dtrace_method_probes()) {
|
||||
// Report exit from inline methods
|
||||
Values* args = new Values(1);
|
||||
args->push(append(new Constant(new ObjectConstant(method()))));
|
||||
append(new RuntimeCall(voidType, "dtrace_method_exit", CAST_FROM_FN_PTR(address, SharedRuntime::dtrace_method_exit), args));
|
||||
}
|
||||
|
||||
// If the inlined method is synchronized, the monitor must be
|
||||
// released before we jump to the continuation block.
|
||||
if (method()->is_synchronized()) {
|
||||
@ -3301,6 +3308,13 @@ void GraphBuilder::fill_sync_handler(Value lock, BlockBegin* sync_handler, bool
|
||||
Value exception = append_with_bci(new ExceptionObject(), SynchronizationEntryBCI);
|
||||
assert(exception->is_pinned(), "must be");
|
||||
|
||||
if (compilation()->env()->dtrace_method_probes()) {
|
||||
// Report exit from inline methods
|
||||
Values* args = new Values(1);
|
||||
args->push(append(new Constant(new ObjectConstant(method()))));
|
||||
append(new RuntimeCall(voidType, "dtrace_method_exit", CAST_FROM_FN_PTR(address, SharedRuntime::dtrace_method_exit), args));
|
||||
}
|
||||
|
||||
int bci = SynchronizationEntryBCI;
|
||||
if (lock) {
|
||||
assert(state()->locks_size() > 0 && state()->lock_at(state()->locks_size() - 1) == lock, "lock is missing");
|
||||
@ -3486,6 +3500,11 @@ bool GraphBuilder::try_inline_full(ciMethod* callee, bool holder_known) {
|
||||
inline_sync_entry(lock, sync_handler);
|
||||
}
|
||||
|
||||
if (compilation()->env()->dtrace_method_probes()) {
|
||||
Values* args = new Values(1);
|
||||
args->push(append(new Constant(new ObjectConstant(method()))));
|
||||
append(new RuntimeCall(voidType, "dtrace_method_entry", CAST_FROM_FN_PTR(address, SharedRuntime::dtrace_method_entry), args));
|
||||
}
|
||||
|
||||
BlockBegin* callee_start_block = block_at(0);
|
||||
if (callee_start_block != NULL) {
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -106,6 +106,7 @@ class UnsafePrefetchRead;
|
||||
class UnsafePrefetchWrite;
|
||||
class ProfileCall;
|
||||
class ProfileInvoke;
|
||||
class RuntimeCall;
|
||||
|
||||
// A Value is a reference to the instruction creating the value
|
||||
typedef Instruction* Value;
|
||||
@ -202,6 +203,7 @@ class InstructionVisitor: public StackObj {
|
||||
virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) = 0;
|
||||
virtual void do_ProfileCall (ProfileCall* x) = 0;
|
||||
virtual void do_ProfileInvoke (ProfileInvoke* x) = 0;
|
||||
virtual void do_RuntimeCall (RuntimeCall* x) = 0;
|
||||
};
|
||||
|
||||
|
||||
@ -2267,6 +2269,38 @@ LEAF(ProfileCall, Instruction)
|
||||
virtual void input_values_do(ValueVisitor* f) { if (_recv != NULL) f->visit(&_recv); }
|
||||
};
|
||||
|
||||
|
||||
// Call some C runtime function that doesn't safepoint,
|
||||
// optionally passing the current thread as the first argument.
|
||||
LEAF(RuntimeCall, Instruction)
|
||||
private:
|
||||
const char* _entry_name;
|
||||
address _entry;
|
||||
Values* _args;
|
||||
bool _pass_thread; // Pass the JavaThread* as an implicit first argument
|
||||
|
||||
public:
|
||||
RuntimeCall(ValueType* type, const char* entry_name, address entry, Values* args, bool pass_thread = true)
|
||||
: Instruction(type)
|
||||
, _entry(entry)
|
||||
, _args(args)
|
||||
, _entry_name(entry_name)
|
||||
, _pass_thread(pass_thread) {
|
||||
ASSERT_VALUES
|
||||
pin();
|
||||
}
|
||||
|
||||
const char* entry_name() const { return _entry_name; }
|
||||
address entry() const { return _entry; }
|
||||
int number_of_arguments() const { return _args->length(); }
|
||||
Value argument_at(int i) const { return _args->at(i); }
|
||||
bool pass_thread() const { return _pass_thread; }
|
||||
|
||||
virtual void input_values_do(ValueVisitor* f) {
|
||||
for (int i = 0; i < _args->length(); i++) f->visit(_args->adr_at(i));
|
||||
}
|
||||
};
|
||||
|
||||
// Use to trip invocation counter of an inlined method
|
||||
|
||||
LEAF(ProfileInvoke, Instruction)
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -841,4 +841,13 @@ void InstructionPrinter::do_ProfileInvoke(ProfileInvoke* x) {
|
||||
|
||||
}
|
||||
|
||||
void InstructionPrinter::do_RuntimeCall(RuntimeCall* x) {
|
||||
output()->print("call_rt %s(", x->entry_name());
|
||||
for (int i = 0; i < x->number_of_arguments(); i++) {
|
||||
if (i > 0) output()->print(", ");
|
||||
print_value(x->argument_at(i));
|
||||
}
|
||||
output()->put(')');
|
||||
}
|
||||
|
||||
#endif // PRODUCT
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -131,6 +131,7 @@ class InstructionPrinter: public InstructionVisitor {
|
||||
virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x);
|
||||
virtual void do_ProfileCall (ProfileCall* x);
|
||||
virtual void do_ProfileInvoke (ProfileInvoke* x);
|
||||
virtual void do_RuntimeCall (RuntimeCall* x);
|
||||
};
|
||||
#endif // PRODUCT
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2000, 2011, 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
|
||||
@ -396,7 +396,7 @@ LIR_OpTypeCheck::LIR_OpTypeCheck(LIR_Code code, LIR_Opr object, LIR_Opr array, L
|
||||
, _should_profile(false)
|
||||
{
|
||||
if (code == lir_store_check) {
|
||||
_stub = new ArrayStoreExceptionStub(info_for_exception);
|
||||
_stub = new ArrayStoreExceptionStub(object, info_for_exception);
|
||||
assert(info_for_exception != NULL, "store_check throws exceptions");
|
||||
} else {
|
||||
ShouldNotReachHere();
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 2011, 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
|
||||
@ -2741,6 +2741,31 @@ void LIRGenerator::increment_event_counter_impl(CodeEmitInfo* info,
|
||||
}
|
||||
}
|
||||
|
||||
void LIRGenerator::do_RuntimeCall(RuntimeCall* x) {
|
||||
LIR_OprList* args = new LIR_OprList(x->number_of_arguments());
|
||||
BasicTypeList* signature = new BasicTypeList(x->number_of_arguments());
|
||||
|
||||
if (x->pass_thread()) {
|
||||
signature->append(T_ADDRESS);
|
||||
args->append(getThreadPointer());
|
||||
}
|
||||
|
||||
for (int i = 0; i < x->number_of_arguments(); i++) {
|
||||
Value a = x->argument_at(i);
|
||||
LIRItem* item = new LIRItem(a, this);
|
||||
item->load_item();
|
||||
args->append(item->result());
|
||||
signature->append(as_BasicType(a->type()));
|
||||
}
|
||||
|
||||
LIR_Opr result = call_runtime(signature, args, x->entry(), x->type(), NULL);
|
||||
if (x->type() == voidType) {
|
||||
set_no_result(x);
|
||||
} else {
|
||||
__ move(result, rlock_result(x));
|
||||
}
|
||||
}
|
||||
|
||||
LIR_Opr LIRGenerator::call_runtime(Value arg1, address entry, ValueType* result_type, CodeEmitInfo* info) {
|
||||
LIRItemList args(1);
|
||||
LIRItem value(arg1, this);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 2005, 2011, 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
|
||||
@ -522,6 +522,7 @@ class LIRGenerator: public InstructionVisitor, public BlockClosure {
|
||||
virtual void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x);
|
||||
virtual void do_ProfileCall (ProfileCall* x);
|
||||
virtual void do_ProfileInvoke (ProfileInvoke* x);
|
||||
virtual void do_RuntimeCall (RuntimeCall* x);
|
||||
};
|
||||
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -496,6 +496,7 @@ public:
|
||||
void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x);
|
||||
void do_ProfileCall (ProfileCall* x);
|
||||
void do_ProfileInvoke (ProfileInvoke* x);
|
||||
void do_RuntimeCall (RuntimeCall* x);
|
||||
};
|
||||
|
||||
|
||||
@ -664,6 +665,7 @@ void NullCheckVisitor::do_UnsafePrefetchRead (UnsafePrefetchRead* x) {}
|
||||
void NullCheckVisitor::do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) {}
|
||||
void NullCheckVisitor::do_ProfileCall (ProfileCall* x) { nce()->clear_last_explicit_null_check(); }
|
||||
void NullCheckVisitor::do_ProfileInvoke (ProfileInvoke* x) {}
|
||||
void NullCheckVisitor::do_RuntimeCall (RuntimeCall* x) {}
|
||||
|
||||
|
||||
void NullCheckEliminator::visit(Value* p) {
|
||||
|
@ -339,8 +339,10 @@ JRT_ENTRY(void, Runtime1::unimplemented_entry(JavaThread* thread, StubID id))
|
||||
JRT_END
|
||||
|
||||
|
||||
JRT_ENTRY(void, Runtime1::throw_array_store_exception(JavaThread* thread))
|
||||
THROW(vmSymbolHandles::java_lang_ArrayStoreException());
|
||||
JRT_ENTRY(void, Runtime1::throw_array_store_exception(JavaThread* thread, oopDesc* obj))
|
||||
ResourceMark rm(thread);
|
||||
const char* klass_name = Klass::cast(obj->klass())->external_name();
|
||||
SharedRuntime::throw_and_post_jvmti_exception(thread, vmSymbols::java_lang_ArrayStoreException(), klass_name);
|
||||
JRT_END
|
||||
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -143,9 +143,9 @@ class Runtime1: public AllStatic {
|
||||
static void throw_index_exception(JavaThread* thread, int index);
|
||||
static void throw_div0_exception(JavaThread* thread);
|
||||
static void throw_null_pointer_exception(JavaThread* thread);
|
||||
static void throw_class_cast_exception(JavaThread* thread, oopDesc* obect);
|
||||
static void throw_class_cast_exception(JavaThread* thread, oopDesc* object);
|
||||
static void throw_incompatible_class_change_error(JavaThread* thread);
|
||||
static void throw_array_store_exception(JavaThread* thread);
|
||||
static void throw_array_store_exception(JavaThread* thread, oopDesc* object);
|
||||
|
||||
static void monitorenter(JavaThread* thread, oopDesc* obj, BasicObjectLock* lock);
|
||||
static void monitorexit (JavaThread* thread, BasicObjectLock* lock);
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, Oracle and/or its affiliates. All rights reserved.
|
||||
* Copyright (c) 1999, 2011, 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
|
||||
@ -192,11 +192,12 @@ class ValueNumberingVisitor: public InstructionVisitor {
|
||||
void do_ExceptionObject(ExceptionObject* x) { /* nothing to do */ }
|
||||
void do_RoundFP (RoundFP* x) { /* nothing to do */ }
|
||||
void do_UnsafeGetRaw (UnsafeGetRaw* x) { /* nothing to do */ }
|
||||
void do_ProfileInvoke (ProfileInvoke* x) { /* nothing to do */ };
|
||||
void do_UnsafeGetObject(UnsafeGetObject* x) { /* nothing to do */ }
|
||||
void do_UnsafePrefetchRead (UnsafePrefetchRead* x) { /* nothing to do */ }
|
||||
void do_UnsafePrefetchWrite(UnsafePrefetchWrite* x) { /* nothing to do */ }
|
||||
void do_ProfileCall (ProfileCall* x) { /* nothing to do */ }
|
||||
void do_ProfileInvoke (ProfileInvoke* x) { /* nothing to do */ };
|
||||
void do_RuntimeCall (RuntimeCall* x) { /* nothing to do */ };
|
||||
};
|
||||
|
||||
|
||||
|
@ -233,6 +233,10 @@ void BCEscapeAnalyzer::invoke(StateInfo &state, Bytecodes::Code code, ciMethod*
|
||||
|
||||
// compute size of arguments
|
||||
int arg_size = target->arg_size();
|
||||
if (code == Bytecodes::_invokedynamic) {
|
||||
assert(!target->is_static(), "receiver explicit in method");
|
||||
arg_size--; // implicit, not really on stack
|
||||
}
|
||||
if (!target->is_loaded() && code == Bytecodes::_invokestatic) {
|
||||
arg_size--;
|
||||
}
|
||||
@ -250,6 +254,10 @@ void BCEscapeAnalyzer::invoke(StateInfo &state, Bytecodes::Code code, ciMethod*
|
||||
ArgumentMap arg = state._stack[i];
|
||||
skip_callee = !is_argument(arg) || !is_arg_stack(arg) || (directly_recursive && arg.is_singleton(i - arg_base));
|
||||
}
|
||||
// For now we conservatively skip invokedynamic.
|
||||
if (code == Bytecodes::_invokedynamic) {
|
||||
skip_callee = true;
|
||||
}
|
||||
if (skip_callee) {
|
||||
TRACE_BCEA(3, tty->print_cr("[EA] skipping method %s::%s", holder->name()->as_utf8(), target->name()->as_utf8()));
|
||||
for (i = 0; i < arg_size; i++) {
|
||||
|
@ -60,7 +60,6 @@ class ciReturnAddress;
|
||||
class ciKlass;
|
||||
class ciInstanceKlass;
|
||||
class ciMethodKlass;
|
||||
class ciSymbolKlass;
|
||||
class ciArrayKlass;
|
||||
class ciObjArrayKlass;
|
||||
class ciTypeArrayKlass;
|
||||
@ -112,7 +111,6 @@ friend class ciReturnAddress; \
|
||||
friend class ciKlass; \
|
||||
friend class ciInstanceKlass; \
|
||||
friend class ciMethodKlass; \
|
||||
friend class ciSymbolKlass; \
|
||||
friend class ciArrayKlass; \
|
||||
friend class ciObjArrayKlass; \
|
||||
friend class ciTypeArrayKlass; \
|
||||
|
@ -68,7 +68,6 @@
|
||||
|
||||
ciObject* ciEnv::_null_object_instance;
|
||||
ciMethodKlass* ciEnv::_method_klass_instance;
|
||||
ciSymbolKlass* ciEnv::_symbol_klass_instance;
|
||||
ciKlassKlass* ciEnv::_klass_klass_instance;
|
||||
ciInstanceKlassKlass* ciEnv::_instance_klass_klass_instance;
|
||||
ciTypeArrayKlassKlass* ciEnv::_type_array_klass_klass_instance;
|
||||
@ -202,6 +201,7 @@ ciEnv::ciEnv(Arena* arena) {
|
||||
|
||||
ciEnv::~ciEnv() {
|
||||
CompilerThread* current_thread = CompilerThread::current();
|
||||
_factory->remove_symbols();
|
||||
current_thread->set_env(NULL);
|
||||
}
|
||||
|
||||
@ -234,7 +234,7 @@ void ciEnv::cache_dtrace_flags() {
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// helper for lazy exception creation
|
||||
ciInstance* ciEnv::get_or_create_exception(jobject& handle, symbolHandle name) {
|
||||
ciInstance* ciEnv::get_or_create_exception(jobject& handle, Symbol* name) {
|
||||
VM_ENTRY_MARK;
|
||||
if (handle == NULL) {
|
||||
// Cf. universe.cpp, creation of Universe::_null_ptr_exception_instance.
|
||||
@ -261,7 +261,7 @@ ciInstance* ciEnv::ArrayIndexOutOfBoundsException_instance() {
|
||||
if (_ArrayIndexOutOfBoundsException_instance == NULL) {
|
||||
_ArrayIndexOutOfBoundsException_instance
|
||||
= get_or_create_exception(_ArrayIndexOutOfBoundsException_handle,
|
||||
vmSymbolHandles::java_lang_ArrayIndexOutOfBoundsException());
|
||||
vmSymbols::java_lang_ArrayIndexOutOfBoundsException());
|
||||
}
|
||||
return _ArrayIndexOutOfBoundsException_instance;
|
||||
}
|
||||
@ -269,7 +269,7 @@ ciInstance* ciEnv::ArrayStoreException_instance() {
|
||||
if (_ArrayStoreException_instance == NULL) {
|
||||
_ArrayStoreException_instance
|
||||
= get_or_create_exception(_ArrayStoreException_handle,
|
||||
vmSymbolHandles::java_lang_ArrayStoreException());
|
||||
vmSymbols::java_lang_ArrayStoreException());
|
||||
}
|
||||
return _ArrayStoreException_instance;
|
||||
}
|
||||
@ -277,7 +277,7 @@ ciInstance* ciEnv::ClassCastException_instance() {
|
||||
if (_ClassCastException_instance == NULL) {
|
||||
_ClassCastException_instance
|
||||
= get_or_create_exception(_ClassCastException_handle,
|
||||
vmSymbolHandles::java_lang_ClassCastException());
|
||||
vmSymbols::java_lang_ClassCastException());
|
||||
}
|
||||
return _ClassCastException_instance;
|
||||
}
|
||||
@ -377,14 +377,16 @@ ciKlass* ciEnv::get_klass_by_name_impl(ciKlass* accessing_klass,
|
||||
EXCEPTION_CONTEXT;
|
||||
|
||||
// Now we need to check the SystemDictionary
|
||||
symbolHandle sym(THREAD, name->get_symbolOop());
|
||||
Symbol* sym = name->get_symbol();
|
||||
if (sym->byte_at(0) == 'L' &&
|
||||
sym->byte_at(sym->utf8_length()-1) == ';') {
|
||||
// This is a name from a signature. Strip off the trimmings.
|
||||
sym = oopFactory::new_symbol_handle(sym->as_utf8()+1,
|
||||
sym->utf8_length()-2,
|
||||
KILL_COMPILE_ON_FATAL_(_unloaded_ciinstance_klass));
|
||||
name = get_object(sym())->as_symbol();
|
||||
// Call recursive to keep scope of strippedsym.
|
||||
TempNewSymbol strippedsym = SymbolTable::new_symbol(sym->as_utf8()+1,
|
||||
sym->utf8_length()-2,
|
||||
KILL_COMPILE_ON_FATAL_(_unloaded_ciinstance_klass));
|
||||
ciSymbol* strippedname = get_symbol(strippedsym);
|
||||
return get_klass_by_name_impl(accessing_klass, strippedname, require_local);
|
||||
}
|
||||
|
||||
// Check for prior unloaded klass. The SystemDictionary's answers
|
||||
@ -430,13 +432,14 @@ ciKlass* ciEnv::get_klass_by_name_impl(ciKlass* accessing_klass,
|
||||
(sym->byte_at(1) == '[' || sym->byte_at(1) == 'L')) {
|
||||
// We have an unloaded array.
|
||||
// Build it on the fly if the element class exists.
|
||||
symbolOop elem_sym = oopFactory::new_symbol(sym->as_utf8()+1,
|
||||
sym->utf8_length()-1,
|
||||
KILL_COMPILE_ON_FATAL_(fail_type));
|
||||
TempNewSymbol elem_sym = SymbolTable::new_symbol(sym->as_utf8()+1,
|
||||
sym->utf8_length()-1,
|
||||
KILL_COMPILE_ON_FATAL_(fail_type));
|
||||
|
||||
// Get element ciKlass recursively.
|
||||
ciKlass* elem_klass =
|
||||
get_klass_by_name_impl(accessing_klass,
|
||||
get_object(elem_sym)->as_symbol(),
|
||||
get_symbol(elem_sym),
|
||||
require_local);
|
||||
if (elem_klass != NULL && elem_klass->is_loaded()) {
|
||||
// Now make an array for it
|
||||
@ -475,7 +478,7 @@ ciKlass* ciEnv::get_klass_by_index_impl(constantPoolHandle cpool,
|
||||
ciInstanceKlass* accessor) {
|
||||
EXCEPTION_CONTEXT;
|
||||
KlassHandle klass (THREAD, constantPoolOopDesc::klass_at_if_loaded(cpool, index));
|
||||
symbolHandle klass_name;
|
||||
Symbol* klass_name = NULL;
|
||||
if (klass.is_null()) {
|
||||
// The klass has not been inserted into the constant pool.
|
||||
// Try to look it up by name.
|
||||
@ -490,10 +493,10 @@ ciKlass* ciEnv::get_klass_by_index_impl(constantPoolHandle cpool,
|
||||
// very recently.
|
||||
klass = KlassHandle(THREAD, cpool->resolved_klass_at(index));
|
||||
} else if (tag.is_symbol()) {
|
||||
klass_name = symbolHandle(THREAD, cpool->symbol_at(index));
|
||||
klass_name = cpool->symbol_at(index);
|
||||
} else {
|
||||
assert(cpool->tag_at(index).is_unresolved_klass(), "wrong tag");
|
||||
klass_name = symbolHandle(THREAD, cpool->unresolved_klass_at(index));
|
||||
klass_name = cpool->unresolved_klass_at(index);
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -501,7 +504,7 @@ ciKlass* ciEnv::get_klass_by_index_impl(constantPoolHandle cpool,
|
||||
if (klass.is_null()) {
|
||||
// Not found in constant pool. Use the name to do the lookup.
|
||||
ciKlass* k = get_klass_by_name_impl(accessor,
|
||||
get_object(klass_name())->as_symbol(),
|
||||
get_symbol(klass_name),
|
||||
false);
|
||||
// Calculate accessibility the hard way.
|
||||
if (!k->is_loaded()) {
|
||||
@ -519,7 +522,7 @@ ciKlass* ciEnv::get_klass_by_index_impl(constantPoolHandle cpool,
|
||||
|
||||
// Check for prior unloaded klass. The SystemDictionary's answers
|
||||
// can vary over time but the compiler needs consistency.
|
||||
ciSymbol* name = get_object(klass()->klass_part()->name())->as_symbol();
|
||||
ciSymbol* name = get_symbol(klass()->klass_part()->name());
|
||||
ciKlass* unloaded_klass = check_get_unloaded_klass(accessor, name);
|
||||
if (unloaded_klass != NULL) {
|
||||
is_accessible = false;
|
||||
@ -605,7 +608,7 @@ ciConstant ciEnv::get_constant_by_index_impl(constantPoolHandle cpool,
|
||||
return ciConstant(T_OBJECT, ciobj);
|
||||
} else if (tag.is_method_type()) {
|
||||
// must execute Java code to link this CP entry into cache[i].f1
|
||||
ciSymbol* signature = get_object(cpool->method_type_signature_at(index))->as_symbol();
|
||||
ciSymbol* signature = get_symbol(cpool->method_type_signature_at(index));
|
||||
ciObject* ciobj = get_unloaded_method_type_constant(signature);
|
||||
return ciConstant(T_OBJECT, ciobj);
|
||||
} else if (tag.is_method_handle()) {
|
||||
@ -613,8 +616,8 @@ ciConstant ciEnv::get_constant_by_index_impl(constantPoolHandle cpool,
|
||||
int ref_kind = cpool->method_handle_ref_kind_at(index);
|
||||
int callee_index = cpool->method_handle_klass_index_at(index);
|
||||
ciKlass* callee = get_klass_by_index_impl(cpool, callee_index, ignore_will_link, accessor);
|
||||
ciSymbol* name = get_object(cpool->method_handle_name_ref_at(index))->as_symbol();
|
||||
ciSymbol* signature = get_object(cpool->method_handle_signature_ref_at(index))->as_symbol();
|
||||
ciSymbol* name = get_symbol(cpool->method_handle_name_ref_at(index));
|
||||
ciSymbol* signature = get_symbol(cpool->method_handle_signature_ref_at(index));
|
||||
ciObject* ciobj = get_unloaded_method_handle_constant(callee, name, signature, ref_kind);
|
||||
return ciConstant(T_OBJECT, ciobj);
|
||||
} else {
|
||||
@ -674,33 +677,31 @@ ciField* ciEnv::get_field_by_index(ciInstanceKlass* accessor,
|
||||
// name, signature, and bytecode.
|
||||
methodOop ciEnv::lookup_method(instanceKlass* accessor,
|
||||
instanceKlass* holder,
|
||||
symbolOop name,
|
||||
symbolOop sig,
|
||||
Symbol* name,
|
||||
Symbol* sig,
|
||||
Bytecodes::Code bc) {
|
||||
EXCEPTION_CONTEXT;
|
||||
KlassHandle h_accessor(THREAD, accessor);
|
||||
KlassHandle h_holder(THREAD, holder);
|
||||
symbolHandle h_name(THREAD, name);
|
||||
symbolHandle h_sig(THREAD, sig);
|
||||
LinkResolver::check_klass_accessability(h_accessor, h_holder, KILL_COMPILE_ON_FATAL_(NULL));
|
||||
methodHandle dest_method;
|
||||
switch (bc) {
|
||||
case Bytecodes::_invokestatic:
|
||||
dest_method =
|
||||
LinkResolver::resolve_static_call_or_null(h_holder, h_name, h_sig, h_accessor);
|
||||
LinkResolver::resolve_static_call_or_null(h_holder, name, sig, h_accessor);
|
||||
break;
|
||||
case Bytecodes::_invokespecial:
|
||||
dest_method =
|
||||
LinkResolver::resolve_special_call_or_null(h_holder, h_name, h_sig, h_accessor);
|
||||
LinkResolver::resolve_special_call_or_null(h_holder, name, sig, h_accessor);
|
||||
break;
|
||||
case Bytecodes::_invokeinterface:
|
||||
dest_method =
|
||||
LinkResolver::linktime_resolve_interface_method_or_null(h_holder, h_name, h_sig,
|
||||
LinkResolver::linktime_resolve_interface_method_or_null(h_holder, name, sig,
|
||||
h_accessor, true);
|
||||
break;
|
||||
case Bytecodes::_invokevirtual:
|
||||
dest_method =
|
||||
LinkResolver::linktime_resolve_virtual_method_or_null(h_holder, h_name, h_sig,
|
||||
LinkResolver::linktime_resolve_virtual_method_or_null(h_holder, name, sig,
|
||||
h_accessor, true);
|
||||
break;
|
||||
default: ShouldNotReachHere();
|
||||
@ -721,8 +722,8 @@ ciMethod* ciEnv::get_method_by_index_impl(constantPoolHandle cpool,
|
||||
ciInstanceKlass* declared_holder = get_instance_klass_for_declared_method_holder(holder);
|
||||
|
||||
// Get the method's name and signature.
|
||||
symbolOop name_sym = cpool->name_ref_at(index);
|
||||
symbolOop sig_sym = cpool->signature_ref_at(index);
|
||||
Symbol* name_sym = cpool->name_ref_at(index);
|
||||
Symbol* sig_sym = cpool->signature_ref_at(index);
|
||||
|
||||
if (holder_is_accessible) { // Our declared holder is loaded.
|
||||
instanceKlass* lookup = declared_holder->get_instanceKlass();
|
||||
@ -738,8 +739,8 @@ ciMethod* ciEnv::get_method_by_index_impl(constantPoolHandle cpool,
|
||||
// lookup.
|
||||
|
||||
return get_unloaded_method(declared_holder,
|
||||
get_object(name_sym)->as_symbol(),
|
||||
get_object(sig_sym)->as_symbol());
|
||||
get_symbol(name_sym),
|
||||
get_symbol(sig_sym));
|
||||
}
|
||||
|
||||
|
||||
@ -759,7 +760,7 @@ ciMethod* ciEnv::get_fake_invokedynamic_method_impl(constantPoolHandle cpool,
|
||||
// compiler, but it is simpler to stop the code path here with an unlinked method.
|
||||
if (!is_resolved) {
|
||||
ciInstanceKlass* mh_klass = get_object(SystemDictionary::MethodHandle_klass())->as_instance_klass();
|
||||
ciSymbol* sig_sym = get_object(cpool->signature_ref_at(index))->as_symbol();
|
||||
ciSymbol* sig_sym = get_symbol(cpool->signature_ref_at(index));
|
||||
return get_unloaded_method(mh_klass, ciSymbol::invokeExact_name(), sig_sym);
|
||||
}
|
||||
|
||||
|
@ -79,7 +79,6 @@ private:
|
||||
// Distinguished instances of certain ciObjects..
|
||||
static ciObject* _null_object_instance;
|
||||
static ciMethodKlass* _method_klass_instance;
|
||||
static ciSymbolKlass* _symbol_klass_instance;
|
||||
static ciKlassKlass* _klass_klass_instance;
|
||||
static ciInstanceKlassKlass* _instance_klass_klass_instance;
|
||||
static ciTypeArrayKlassKlass* _type_array_klass_klass_instance;
|
||||
@ -160,8 +159,8 @@ private:
|
||||
klassOop resolved_klassOop);
|
||||
methodOop lookup_method(instanceKlass* accessor,
|
||||
instanceKlass* holder,
|
||||
symbolOop name,
|
||||
symbolOop sig,
|
||||
Symbol* name,
|
||||
Symbol* sig,
|
||||
Bytecodes::Code bc);
|
||||
|
||||
// Get a ciObject from the object factory. Ensures uniqueness
|
||||
@ -174,9 +173,18 @@ private:
|
||||
}
|
||||
}
|
||||
|
||||
ciSymbol* get_symbol(Symbol* o) {
|
||||
if (o == NULL) {
|
||||
ShouldNotReachHere();
|
||||
return NULL;
|
||||
} else {
|
||||
return _factory->get_symbol(o);
|
||||
}
|
||||
}
|
||||
|
||||
ciMethod* get_method_from_handle(jobject method);
|
||||
|
||||
ciInstance* get_or_create_exception(jobject& handle, symbolHandle name);
|
||||
ciInstance* get_or_create_exception(jobject& handle, Symbol* name);
|
||||
|
||||
// Get a ciMethod representing either an unfound method or
|
||||
// a method with an unloaded holder. Ensures uniqueness of
|
||||
|
@ -79,15 +79,15 @@ ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with(NULL) {
|
||||
constantPoolHandle cpool(thread, klass->get_instanceKlass()->constants());
|
||||
|
||||
// Get the field's name, signature, and type.
|
||||
symbolHandle name (thread, cpool->name_ref_at(index));
|
||||
_name = ciEnv::current(thread)->get_object(name())->as_symbol();
|
||||
Symbol* name = cpool->name_ref_at(index);
|
||||
_name = ciEnv::current(thread)->get_symbol(name);
|
||||
|
||||
int nt_index = cpool->name_and_type_ref_index_at(index);
|
||||
int sig_index = cpool->signature_ref_index_at(nt_index);
|
||||
symbolHandle signature (thread, cpool->symbol_at(sig_index));
|
||||
_signature = ciEnv::current(thread)->get_object(signature())->as_symbol();
|
||||
Symbol* signature = cpool->symbol_at(sig_index);
|
||||
_signature = ciEnv::current(thread)->get_symbol(signature);
|
||||
|
||||
BasicType field_type = FieldType::basic_type(signature());
|
||||
BasicType field_type = FieldType::basic_type(signature);
|
||||
|
||||
// If the field is a pointer type, get the klass of the
|
||||
// field.
|
||||
@ -100,7 +100,7 @@ ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with(NULL) {
|
||||
_type = ciType::make(field_type);
|
||||
}
|
||||
|
||||
_name = (ciSymbol*)ciEnv::current(thread)->get_object(name());
|
||||
_name = (ciSymbol*)ciEnv::current(thread)->get_symbol(name);
|
||||
|
||||
// Get the field's declared holder.
|
||||
//
|
||||
@ -130,7 +130,7 @@ ciField::ciField(ciInstanceKlass* klass, int index): _known_to_link_with(NULL) {
|
||||
// Perform the field lookup.
|
||||
fieldDescriptor field_desc;
|
||||
klassOop canonical_holder =
|
||||
loaded_decl_holder->find_field(name(), signature(), &field_desc);
|
||||
loaded_decl_holder->find_field(name, signature, &field_desc);
|
||||
if (canonical_holder == NULL) {
|
||||
// Field lookup failed. Will be detected by will_link.
|
||||
_holder = declared_holder;
|
||||
@ -150,8 +150,8 @@ ciField::ciField(fieldDescriptor *fd): _known_to_link_with(NULL) {
|
||||
|
||||
// Get the field's name, signature, and type.
|
||||
ciEnv* env = CURRENT_ENV;
|
||||
_name = env->get_object(fd->name())->as_symbol();
|
||||
_signature = env->get_object(fd->signature())->as_symbol();
|
||||
_name = env->get_symbol(fd->name());
|
||||
_signature = env->get_symbol(fd->signature());
|
||||
|
||||
BasicType field_type = fd->field_type();
|
||||
|
||||
|
@ -380,7 +380,7 @@ ciField* ciInstanceKlass::get_field_by_name(ciSymbol* name, ciSymbol* signature,
|
||||
VM_ENTRY_MARK;
|
||||
instanceKlass* k = get_instanceKlass();
|
||||
fieldDescriptor fd;
|
||||
klassOop def = k->find_field(name->get_symbolOop(), signature->get_symbolOop(), is_static, &fd);
|
||||
klassOop def = k->find_field(name->get_symbol(), signature->get_symbol(), is_static, &fd);
|
||||
if (def == NULL) {
|
||||
return NULL;
|
||||
}
|
||||
@ -541,8 +541,8 @@ ciInstanceKlass::compute_nonstatic_fields_impl(GrowableArray<ciField*>*
|
||||
ciMethod* ciInstanceKlass::find_method(ciSymbol* name, ciSymbol* signature) {
|
||||
VM_ENTRY_MARK;
|
||||
instanceKlass* k = get_instanceKlass();
|
||||
symbolOop name_sym = name->get_symbolOop();
|
||||
symbolOop sig_sym= signature->get_symbolOop();
|
||||
Symbol* name_sym = name->get_symbol();
|
||||
Symbol* sig_sym= signature->get_symbol();
|
||||
|
||||
methodOop m = k->find_method(name_sym, sig_sym);
|
||||
if (m == NULL) return NULL;
|
||||
|
@ -39,9 +39,9 @@ ciKlass::ciKlass(KlassHandle h_k) : ciType(h_k) {
|
||||
assert(get_oop()->is_klass(), "wrong type");
|
||||
Klass* k = get_Klass();
|
||||
_layout_helper = k->layout_helper();
|
||||
symbolOop klass_name = k->name();
|
||||
Symbol* klass_name = k->name();
|
||||
assert(klass_name != NULL, "wrong ciKlass constructor");
|
||||
_name = CURRENT_ENV->get_object(klass_name)->as_symbol();
|
||||
_name = CURRENT_ENV->get_symbol(klass_name);
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
|
@ -122,9 +122,9 @@ ciMethod::ciMethod(methodHandle h_m) : ciObject(h_m) {
|
||||
|
||||
// generating _signature may allow GC and therefore move m.
|
||||
// These fields are always filled in.
|
||||
_name = env->get_object(h_m()->name())->as_symbol();
|
||||
_name = env->get_symbol(h_m()->name());
|
||||
_holder = env->get_object(h_m()->method_holder())->as_instance_klass();
|
||||
ciSymbol* sig_symbol = env->get_object(h_m()->signature())->as_symbol();
|
||||
ciSymbol* sig_symbol = env->get_symbol(h_m()->signature());
|
||||
_signature = new (env->arena()) ciSignature(_holder, sig_symbol);
|
||||
_method_data = NULL;
|
||||
// Take a snapshot of these values, so they will be commensurate with the MDO.
|
||||
@ -649,8 +649,8 @@ ciMethod* ciMethod::resolve_invoke(ciKlass* caller, ciKlass* exact_receiver) {
|
||||
KlassHandle caller_klass (THREAD, caller->get_klassOop());
|
||||
KlassHandle h_recv (THREAD, exact_receiver->get_klassOop());
|
||||
KlassHandle h_resolved (THREAD, holder()->get_klassOop());
|
||||
symbolHandle h_name (THREAD, name()->get_symbolOop());
|
||||
symbolHandle h_signature (THREAD, signature()->get_symbolOop());
|
||||
Symbol* h_name = name()->get_symbol();
|
||||
Symbol* h_signature = signature()->get_symbol();
|
||||
|
||||
methodHandle m;
|
||||
// Only do exact lookup if receiver klass has been linked. Otherwise,
|
||||
@ -702,8 +702,8 @@ int ciMethod::resolve_vtable_index(ciKlass* caller, ciKlass* receiver) {
|
||||
|
||||
KlassHandle caller_klass (THREAD, caller->get_klassOop());
|
||||
KlassHandle h_recv (THREAD, receiver->get_klassOop());
|
||||
symbolHandle h_name (THREAD, name()->get_symbolOop());
|
||||
symbolHandle h_signature (THREAD, signature()->get_symbolOop());
|
||||
Symbol* h_name = name()->get_symbol();
|
||||
Symbol* h_signature = signature()->get_symbol();
|
||||
|
||||
vtable_index = LinkResolver::resolve_virtual_vtable_index(h_recv, h_recv, h_name, h_signature, caller_klass);
|
||||
if (vtable_index == methodOopDesc::nonvirtual_vtable_index) {
|
||||
|
@ -110,7 +110,7 @@ ciSymbol* ciObjArrayKlass::construct_array_name(ciSymbol* element_name,
|
||||
EXCEPTION_CONTEXT;
|
||||
int element_len = element_name->utf8_length();
|
||||
|
||||
symbolOop base_name_sym = element_name->get_symbolOop();
|
||||
Symbol* base_name_sym = element_name->get_symbol();
|
||||
char* name;
|
||||
|
||||
if (base_name_sym->byte_at(0) == '[' ||
|
||||
|
@ -268,10 +268,6 @@ public:
|
||||
assert(is_type_array_klass(), "bad cast");
|
||||
return (ciTypeArrayKlass*)this;
|
||||
}
|
||||
ciSymbolKlass* as_symbol_klass() {
|
||||
assert(is_symbol_klass(), "bad cast");
|
||||
return (ciSymbolKlass*)this;
|
||||
}
|
||||
ciKlassKlass* as_klass_klass() {
|
||||
assert(is_klass_klass(), "bad cast");
|
||||
return (ciKlassKlass*)this;
|
||||
|
@ -38,7 +38,6 @@
|
||||
#include "ci/ciObjArrayKlassKlass.hpp"
|
||||
#include "ci/ciObjectFactory.hpp"
|
||||
#include "ci/ciSymbol.hpp"
|
||||
#include "ci/ciSymbolKlass.hpp"
|
||||
#include "ci/ciTypeArray.hpp"
|
||||
#include "ci/ciTypeArrayKlass.hpp"
|
||||
#include "ci/ciTypeArrayKlassKlass.hpp"
|
||||
@ -98,6 +97,8 @@ ciObjectFactory::ciObjectFactory(Arena* arena,
|
||||
_unloaded_instances = new (arena) GrowableArray<ciInstance*>(arena, 4, 0, NULL);
|
||||
_return_addresses =
|
||||
new (arena) GrowableArray<ciReturnAddress*>(arena, 8, 0, NULL);
|
||||
|
||||
_symbols = new (arena) GrowableArray<ciSymbol*>(arena, 100, 0, NULL);
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -127,19 +128,19 @@ void ciObjectFactory::init_shared_objects() {
|
||||
// Create the shared symbols, but not in _shared_ci_objects.
|
||||
int i;
|
||||
for (i = vmSymbols::FIRST_SID; i < vmSymbols::SID_LIMIT; i++) {
|
||||
symbolHandle sym_handle = vmSymbolHandles::symbol_handle_at((vmSymbols::SID) i);
|
||||
assert(vmSymbols::find_sid(sym_handle()) == i, "1-1 mapping");
|
||||
ciSymbol* sym = new (_arena) ciSymbol(sym_handle, (vmSymbols::SID) i);
|
||||
Symbol* vmsym = vmSymbols::symbol_at((vmSymbols::SID) i);
|
||||
assert(vmSymbols::find_sid(vmsym) == i, "1-1 mapping");
|
||||
ciSymbol* sym = new (_arena) ciSymbol(vmsym, (vmSymbols::SID) i);
|
||||
init_ident_of(sym);
|
||||
_shared_ci_symbols[i] = sym;
|
||||
}
|
||||
#ifdef ASSERT
|
||||
for (i = vmSymbols::FIRST_SID; i < vmSymbols::SID_LIMIT; i++) {
|
||||
symbolHandle sym_handle = vmSymbolHandles::symbol_handle_at((vmSymbols::SID) i);
|
||||
Symbol* vmsym = vmSymbols::symbol_at((vmSymbols::SID) i);
|
||||
ciSymbol* sym = vm_symbol_at((vmSymbols::SID) i);
|
||||
assert(sym->get_oop() == sym_handle(), "oop must match");
|
||||
assert(sym->get_symbol() == vmsym, "oop must match");
|
||||
}
|
||||
assert(ciSymbol::void_class_signature()->get_oop() == vmSymbols::void_class_signature(), "spot check");
|
||||
assert(ciSymbol::void_class_signature()->get_symbol() == vmSymbols::void_class_signature(), "spot check");
|
||||
#endif
|
||||
}
|
||||
|
||||
@ -157,8 +158,6 @@ void ciObjectFactory::init_shared_objects() {
|
||||
init_ident_of(ciEnv::_null_object_instance);
|
||||
ciEnv::_method_klass_instance =
|
||||
get(Universe::methodKlassObj())->as_method_klass();
|
||||
ciEnv::_symbol_klass_instance =
|
||||
get(Universe::symbolKlassObj())->as_symbol_klass();
|
||||
ciEnv::_klass_klass_instance =
|
||||
get(Universe::klassKlassObj())->as_klass_klass();
|
||||
ciEnv::_instance_klass_klass_instance =
|
||||
@ -188,7 +187,7 @@ void ciObjectFactory::init_shared_objects() {
|
||||
}
|
||||
}
|
||||
|
||||
ciEnv::_unloaded_cisymbol = (ciSymbol*) ciObjectFactory::get(vmSymbols::dummy_symbol_oop());
|
||||
ciEnv::_unloaded_cisymbol = ciObjectFactory::get_symbol(vmSymbols::dummy_symbol());
|
||||
// Create dummy instanceKlass and objArrayKlass object and assign them idents
|
||||
ciEnv::_unloaded_ciinstance_klass = new (_arena) ciInstanceKlass(ciEnv::_unloaded_cisymbol, NULL, NULL);
|
||||
init_ident_of(ciEnv::_unloaded_ciinstance_klass);
|
||||
@ -218,6 +217,30 @@ void ciObjectFactory::init_shared_objects() {
|
||||
_shared_ci_objects = _ci_objects;
|
||||
}
|
||||
|
||||
|
||||
ciSymbol* ciObjectFactory::get_symbol(Symbol* key) {
|
||||
vmSymbols::SID sid = vmSymbols::find_sid(key);
|
||||
if (sid != vmSymbols::NO_SID) {
|
||||
// do not pollute the main cache with it
|
||||
return vm_symbol_at(sid);
|
||||
}
|
||||
|
||||
assert(vmSymbols::find_sid(key) == vmSymbols::NO_SID, "");
|
||||
ciSymbol* s = new (arena()) ciSymbol(key, vmSymbols::NO_SID);
|
||||
_symbols->push(s);
|
||||
return s;
|
||||
}
|
||||
|
||||
// Decrement the refcount when done on symbols referenced by this compilation.
|
||||
void ciObjectFactory::remove_symbols() {
|
||||
for (int i = 0; i < _symbols->length(); i++) {
|
||||
ciSymbol* s = _symbols->at(i);
|
||||
s->get_symbol()->decrement_refcount();
|
||||
}
|
||||
// Since _symbols is resource allocated we're not allowed to delete it
|
||||
// but it'll go away just the same.
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciObjectFactory::get
|
||||
//
|
||||
@ -255,15 +278,6 @@ ciObject* ciObjectFactory::get(oop key) {
|
||||
return bucket->object();
|
||||
}
|
||||
|
||||
// Check in the shared symbol area before putting it in the list.
|
||||
if (key->is_symbol()) {
|
||||
vmSymbols::SID sid = vmSymbols::find_sid((symbolOop)key);
|
||||
if (sid != vmSymbols::NO_SID) {
|
||||
// do not pollute the main cache with it
|
||||
return vm_symbol_at(sid);
|
||||
}
|
||||
}
|
||||
|
||||
// The ciObject does not yet exist. Create it and insert it
|
||||
// into the cache.
|
||||
Handle keyHandle(key);
|
||||
@ -297,11 +311,7 @@ ciObject* ciObjectFactory::get(oop key) {
|
||||
ciObject* ciObjectFactory::create_new_object(oop o) {
|
||||
EXCEPTION_CONTEXT;
|
||||
|
||||
if (o->is_symbol()) {
|
||||
symbolHandle h_o(THREAD, (symbolOop)o);
|
||||
assert(vmSymbols::find_sid(h_o()) == vmSymbols::NO_SID, "");
|
||||
return new (arena()) ciSymbol(h_o, vmSymbols::NO_SID);
|
||||
} else if (o->is_klass()) {
|
||||
if (o->is_klass()) {
|
||||
KlassHandle h_k(THREAD, (klassOop)o);
|
||||
Klass* k = ((klassOop)o)->klass_part();
|
||||
if (k->oop_is_instance()) {
|
||||
@ -312,8 +322,6 @@ ciObject* ciObjectFactory::create_new_object(oop o) {
|
||||
return new (arena()) ciTypeArrayKlass(h_k);
|
||||
} else if (k->oop_is_method()) {
|
||||
return new (arena()) ciMethodKlass(h_k);
|
||||
} else if (k->oop_is_symbol()) {
|
||||
return new (arena()) ciSymbolKlass(h_k);
|
||||
} else if (k->oop_is_klass()) {
|
||||
if (k->oop_is_objArrayKlass()) {
|
||||
return new (arena()) ciObjArrayKlassKlass(h_k);
|
||||
@ -426,22 +434,20 @@ ciKlass* ciObjectFactory::get_unloaded_klass(ciKlass* accessing_klass,
|
||||
// unloaded instanceKlass. Deal with both.
|
||||
if (name->byte_at(0) == '[') {
|
||||
// Decompose the name.'
|
||||
jint dimension = 0;
|
||||
symbolOop element_name = NULL;
|
||||
BasicType element_type= FieldType::get_array_info(name->get_symbolOop(),
|
||||
&dimension,
|
||||
&element_name,
|
||||
THREAD);
|
||||
FieldArrayInfo fd;
|
||||
BasicType element_type = FieldType::get_array_info(name->get_symbol(),
|
||||
fd, THREAD);
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
CLEAR_PENDING_EXCEPTION;
|
||||
CURRENT_THREAD_ENV->record_out_of_memory_failure();
|
||||
return ciEnv::_unloaded_ciobjarrayklass;
|
||||
}
|
||||
int dimension = fd.dimension();
|
||||
assert(element_type != T_ARRAY, "unsuccessful decomposition");
|
||||
ciKlass* element_klass = NULL;
|
||||
if (element_type == T_OBJECT) {
|
||||
ciEnv *env = CURRENT_THREAD_ENV;
|
||||
ciSymbol* ci_name = env->get_object(element_name)->as_symbol();
|
||||
ciSymbol* ci_name = env->get_symbol(fd.object_key());
|
||||
element_klass =
|
||||
env->get_klass_by_name(accessing_klass, ci_name, false)->as_instance_klass();
|
||||
} else {
|
||||
@ -573,6 +579,10 @@ void ciObjectFactory::init_ident_of(ciObject* obj) {
|
||||
obj->set_ident(_next_ident++);
|
||||
}
|
||||
|
||||
void ciObjectFactory::init_ident_of(ciSymbol* obj) {
|
||||
obj->set_ident(_next_ident++);
|
||||
}
|
||||
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciObjectFactory::find
|
||||
|
@ -48,6 +48,7 @@ private:
|
||||
GrowableArray<ciKlass*>* _unloaded_klasses;
|
||||
GrowableArray<ciInstance*>* _unloaded_instances;
|
||||
GrowableArray<ciReturnAddress*>* _return_addresses;
|
||||
GrowableArray<ciSymbol*>* _symbols; // keep list of symbols created
|
||||
int _next_ident;
|
||||
|
||||
public:
|
||||
@ -76,6 +77,7 @@ private:
|
||||
void insert_non_perm(NonPermObject* &where, oop key, ciObject* obj);
|
||||
|
||||
void init_ident_of(ciObject* obj);
|
||||
void init_ident_of(ciSymbol* obj);
|
||||
|
||||
Arena* arena() { return _arena; }
|
||||
|
||||
@ -88,13 +90,15 @@ public:
|
||||
|
||||
static void initialize();
|
||||
void init_shared_objects();
|
||||
void remove_symbols();
|
||||
|
||||
ciObjectFactory(Arena* arena, int expected_size);
|
||||
|
||||
|
||||
// Get the ciObject corresponding to some oop.
|
||||
ciObject* get(oop key);
|
||||
|
||||
ciSymbol* get_symbol(Symbol* key);
|
||||
|
||||
// Get the ciSymbol corresponding to one of the vmSymbols.
|
||||
static ciSymbol* vm_symbol_at(int index);
|
||||
|
||||
|
@ -47,7 +47,8 @@ ciSignature::ciSignature(ciKlass* accessing_klass, ciSymbol* symbol) {
|
||||
|
||||
int size = 0;
|
||||
int count = 0;
|
||||
symbolHandle sh (THREAD, symbol->get_symbolOop());
|
||||
ResourceMark rm(THREAD);
|
||||
Symbol* sh = symbol->get_symbol();
|
||||
SignatureStream ss(sh);
|
||||
for (; ; ss.next()) {
|
||||
// Process one element of the signature
|
||||
@ -55,14 +56,14 @@ ciSignature::ciSignature(ciKlass* accessing_klass, ciSymbol* symbol) {
|
||||
if (!ss.is_object()) {
|
||||
type = ciType::make(ss.type());
|
||||
} else {
|
||||
symbolOop name = ss.as_symbol(THREAD);
|
||||
Symbol* name = ss.as_symbol(THREAD);
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
type = ss.is_array() ? (ciType*)ciEnv::unloaded_ciobjarrayklass()
|
||||
: (ciType*)ciEnv::unloaded_ciinstance_klass();
|
||||
env->record_out_of_memory_failure();
|
||||
CLEAR_PENDING_EXCEPTION;
|
||||
} else {
|
||||
ciSymbol* klass_name = env->get_object(name)->as_symbol();
|
||||
ciSymbol* klass_name = env->get_symbol(name);
|
||||
type = env->get_klass_by_name_impl(_accessing_klass, klass_name, false);
|
||||
}
|
||||
}
|
||||
|
@ -48,7 +48,7 @@ private:
|
||||
|
||||
void get_all_klasses();
|
||||
|
||||
symbolOop get_symbolOop() const { return _symbol->get_symbolOop(); }
|
||||
Symbol* get_symbol() const { return _symbol->get_symbol(); }
|
||||
|
||||
public:
|
||||
ciSymbol* as_symbol() const { return _symbol; }
|
||||
|
@ -30,23 +30,27 @@
|
||||
// ------------------------------------------------------------------
|
||||
// ciSymbol::ciSymbol
|
||||
//
|
||||
// Preallocated handle variant. Used with handles from vmSymboHandles.
|
||||
ciSymbol::ciSymbol(symbolHandle h_s, vmSymbols::SID sid)
|
||||
: ciObject(h_s), _sid(sid)
|
||||
// Preallocated symbol variant. Used with symbols from vmSymbols.
|
||||
ciSymbol::ciSymbol(Symbol* s, vmSymbols::SID sid)
|
||||
: _symbol(s), _sid(sid)
|
||||
{
|
||||
assert(_symbol != NULL, "adding null symbol");
|
||||
_symbol->increment_refcount(); // increment ref count
|
||||
assert(sid_ok(), "must be in vmSymbols");
|
||||
}
|
||||
|
||||
// Normal case for non-famous symbols.
|
||||
ciSymbol::ciSymbol(symbolOop s)
|
||||
: ciObject(s), _sid(vmSymbols::NO_SID)
|
||||
ciSymbol::ciSymbol(Symbol* s)
|
||||
: _symbol(s), _sid(vmSymbols::NO_SID)
|
||||
{
|
||||
assert(_symbol != NULL, "adding null symbol");
|
||||
_symbol->increment_refcount(); // increment ref count
|
||||
assert(sid_ok(), "must not be in vmSymbols");
|
||||
}
|
||||
|
||||
// ciSymbol
|
||||
//
|
||||
// This class represents a symbolOop in the HotSpot virtual
|
||||
// This class represents a Symbol* in the HotSpot virtual
|
||||
// machine.
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -55,20 +59,20 @@ ciSymbol::ciSymbol(symbolOop s)
|
||||
// The text of the symbol as a null-terminated C string.
|
||||
const char* ciSymbol::as_utf8() {
|
||||
VM_QUICK_ENTRY_MARK;
|
||||
symbolOop s = get_symbolOop();
|
||||
Symbol* s = get_symbol();
|
||||
return s->as_utf8();
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciSymbol::base
|
||||
jbyte* ciSymbol::base() {
|
||||
GUARDED_VM_ENTRY(return get_symbolOop()->base();)
|
||||
const jbyte* ciSymbol::base() {
|
||||
GUARDED_VM_ENTRY(return get_symbol()->base();)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciSymbol::byte_at
|
||||
int ciSymbol::byte_at(int i) {
|
||||
GUARDED_VM_ENTRY(return get_symbolOop()->byte_at(i);)
|
||||
GUARDED_VM_ENTRY(return get_symbol()->byte_at(i);)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -76,7 +80,7 @@ int ciSymbol::byte_at(int i) {
|
||||
//
|
||||
// Tests if the symbol starts with the given prefix.
|
||||
bool ciSymbol::starts_with(const char* prefix, int len) const {
|
||||
GUARDED_VM_ENTRY(return get_symbolOop()->starts_with(prefix, len);)
|
||||
GUARDED_VM_ENTRY(return get_symbol()->starts_with(prefix, len);)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -84,13 +88,13 @@ bool ciSymbol::starts_with(const char* prefix, int len) const {
|
||||
//
|
||||
// Determines where the symbol contains the given substring.
|
||||
int ciSymbol::index_of_at(int i, const char* str, int len) const {
|
||||
GUARDED_VM_ENTRY(return get_symbolOop()->index_of_at(i, str, len);)
|
||||
GUARDED_VM_ENTRY(return get_symbol()->index_of_at(i, str, len);)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciSymbol::utf8_length
|
||||
int ciSymbol::utf8_length() {
|
||||
GUARDED_VM_ENTRY(return get_symbolOop()->utf8_length();)
|
||||
GUARDED_VM_ENTRY(return get_symbol()->utf8_length();)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -107,7 +111,7 @@ void ciSymbol::print_impl(outputStream* st) {
|
||||
//
|
||||
// Print the value of this symbol on an outputStream
|
||||
void ciSymbol::print_symbol_on(outputStream *st) {
|
||||
GUARDED_VM_ENTRY(get_symbolOop()->print_symbol_on(st);)
|
||||
GUARDED_VM_ENTRY(get_symbol()->print_symbol_on(st);)
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
@ -116,15 +120,13 @@ void ciSymbol::print_symbol_on(outputStream *st) {
|
||||
// Make a ciSymbol from a C string (implementation).
|
||||
ciSymbol* ciSymbol::make_impl(const char* s) {
|
||||
EXCEPTION_CONTEXT;
|
||||
// For some reason, oopFactory::new_symbol doesn't declare its
|
||||
// char* argument as const.
|
||||
symbolOop sym = oopFactory::new_symbol((char*)s, (int)strlen(s), THREAD);
|
||||
TempNewSymbol sym = SymbolTable::new_symbol(s, THREAD);
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
CLEAR_PENDING_EXCEPTION;
|
||||
CURRENT_THREAD_ENV->record_out_of_memory_failure();
|
||||
return ciEnv::_unloaded_cisymbol;
|
||||
}
|
||||
return CURRENT_THREAD_ENV->get_object(sym)->as_symbol();
|
||||
return CURRENT_THREAD_ENV->get_symbol(sym);
|
||||
}
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
|
@ -28,15 +28,18 @@
|
||||
#include "ci/ciObject.hpp"
|
||||
#include "ci/ciObjectFactory.hpp"
|
||||
#include "classfile/vmSymbols.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
|
||||
// ciSymbol
|
||||
//
|
||||
// This class represents a symbolOop in the HotSpot virtual
|
||||
// This class represents a Symbol* in the HotSpot virtual
|
||||
// machine.
|
||||
class ciSymbol : public ciObject {
|
||||
class ciSymbol : public ResourceObj {
|
||||
Symbol* _symbol;
|
||||
uint _ident;
|
||||
|
||||
CI_PACKAGE_ACCESS
|
||||
// These friends all make direct use of get_symbolOop:
|
||||
// These friends all make direct use of get_symbol:
|
||||
friend class ciEnv;
|
||||
friend class ciInstanceKlass;
|
||||
friend class ciSignature;
|
||||
@ -45,24 +48,28 @@ class ciSymbol : public ciObject {
|
||||
|
||||
private:
|
||||
const vmSymbols::SID _sid;
|
||||
DEBUG_ONLY( bool sid_ok() { return vmSymbols::find_sid(get_symbolOop()) == _sid; } )
|
||||
DEBUG_ONLY( bool sid_ok() { return vmSymbols::find_sid(get_symbol()) == _sid; } )
|
||||
|
||||
ciSymbol(symbolOop s); // normal case, for symbols not mentioned in vmSymbols
|
||||
ciSymbol(symbolHandle s, vmSymbols::SID sid); // for use with vmSymbolHandles
|
||||
ciSymbol(Symbol* s); // normal case, for symbols not mentioned in vmSymbols
|
||||
ciSymbol(Symbol* s, vmSymbols::SID sid); // for use with vmSymbols
|
||||
|
||||
symbolOop get_symbolOop() const { return (symbolOop)get_oop(); }
|
||||
Symbol* get_symbol() const { return _symbol; }
|
||||
|
||||
const char* type_string() { return "ciSymbol"; }
|
||||
|
||||
void print_impl(outputStream* st);
|
||||
|
||||
// This is public in symbolOop but private here, because the base can move:
|
||||
jbyte* base();
|
||||
// This is public in Symbol* but private here, because the base can move:
|
||||
const jbyte* base();
|
||||
|
||||
// Make a ciSymbol from a C string (implementation).
|
||||
static ciSymbol* make_impl(const char* s);
|
||||
|
||||
void set_ident(uint id) { _ident = id; }
|
||||
public:
|
||||
// A number unique to this object.
|
||||
uint ident() { return _ident; }
|
||||
|
||||
// The enumeration ID from vmSymbols, or vmSymbols::NO_SID if none.
|
||||
vmSymbols::SID sid() const { return _sid; }
|
||||
|
||||
@ -79,9 +86,6 @@ public:
|
||||
// Determines where the symbol contains the given substring.
|
||||
int index_of_at(int i, const char* str, int len) const;
|
||||
|
||||
// What kind of ciObject is this?
|
||||
bool is_symbol() { return true; }
|
||||
|
||||
void print_symbol_on(outputStream* st);
|
||||
void print_symbol() {
|
||||
print_symbol_on(tty);
|
||||
@ -96,6 +100,13 @@ public:
|
||||
static ciSymbol* name() { return ciObjectFactory::vm_symbol_at(vmSymbols::VM_SYMBOL_ENUM_NAME(name)); }
|
||||
VM_SYMBOLS_DO(CI_SYMBOL_DECLARE, CI_SYMBOL_DECLARE)
|
||||
#undef CI_SYMBOL_DECLARE
|
||||
|
||||
void print() {
|
||||
_symbol->print();
|
||||
}
|
||||
|
||||
// Are two ciSymbols equal?
|
||||
bool equals(ciSymbol* obj) { return this->_symbol == obj->get_symbol(); }
|
||||
};
|
||||
|
||||
#endif // SHARE_VM_CI_CISYMBOL_HPP
|
||||
|
@ -1,40 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, 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.
|
||||
*
|
||||
*/
|
||||
|
||||
#include "precompiled.hpp"
|
||||
#include "ci/ciSymbolKlass.hpp"
|
||||
#include "ci/ciUtilities.hpp"
|
||||
|
||||
// ciSymbolKlass
|
||||
//
|
||||
// This class represents a klassOop in the HotSpot virtual machine
|
||||
// whose Klass part is a symbolKlass.
|
||||
|
||||
// ------------------------------------------------------------------
|
||||
// ciSymbolKlass::instance
|
||||
//
|
||||
// Return the distinguished instance of this class
|
||||
ciSymbolKlass* ciSymbolKlass::make() {
|
||||
return CURRENT_ENV->_symbol_klass_instance;
|
||||
}
|
@ -1,60 +0,0 @@
|
||||
/*
|
||||
* Copyright (c) 1999, 2010, 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.
|
||||
*
|
||||
*/
|
||||
|
||||
#ifndef SHARE_VM_CI_CISYMBOLKLASS_HPP
|
||||
#define SHARE_VM_CI_CISYMBOLKLASS_HPP
|
||||
|
||||
#include "ci/ciKlass.hpp"
|
||||
#include "ci/ciSymbol.hpp"
|
||||
|
||||
// ciSymbolKlass
|
||||
//
|
||||
// This class represents a klassOop in the HotSpot virtual machine
|
||||
// whose Klass part in a symbolKlass. Although, in the VM
|
||||
// Klass hierarchy, symbolKlass is a direct subclass of typeArrayKlass,
|
||||
// we do not model this relationship in the ciObject hierarchy -- the
|
||||
// subclassing is used to share implementation and is not of note
|
||||
// to compiler writers.
|
||||
class ciSymbolKlass : public ciKlass {
|
||||
CI_PACKAGE_ACCESS
|
||||
|
||||
protected:
|
||||
ciSymbolKlass(KlassHandle h_k)
|
||||
: ciKlass(h_k, ciSymbol::make("unique_symbolKlass")) {
|
||||
assert(get_Klass()->oop_is_symbol(), "wrong type");
|
||||
}
|
||||
|
||||
symbolKlass* get_symbolKlass() { return (symbolKlass*)get_Klass(); }
|
||||
|
||||
const char* type_string() { return "ciSymbolKlass"; }
|
||||
|
||||
public:
|
||||
// What kind of ciObject is this?
|
||||
bool is_symbol_klass() { return true; }
|
||||
|
||||
// Return the distinguished ciSymbolKlass instance.
|
||||
static ciSymbolKlass* make();
|
||||
};
|
||||
|
||||
#endif // SHARE_VM_CI_CISYMBOLKLASS_HPP
|
@ -49,7 +49,6 @@
|
||||
#include "ci/ciSignature.hpp"
|
||||
#include "ci/ciStreams.hpp"
|
||||
#include "ci/ciSymbol.hpp"
|
||||
#include "ci/ciSymbolKlass.hpp"
|
||||
#include "ci/ciTypeArray.hpp"
|
||||
#include "ci/ciTypeArrayKlass.hpp"
|
||||
#include "ci/ciTypeArrayKlassKlass.hpp"
|
||||
|
@ -31,25 +31,25 @@
|
||||
|
||||
void ClassFileParser::classfile_parse_error(const char* msg, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbols::java_lang_ClassFormatError(),
|
||||
msg, _class_name->as_C_string());
|
||||
}
|
||||
|
||||
void ClassFileParser::classfile_parse_error(const char* msg, int index, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbols::java_lang_ClassFormatError(),
|
||||
msg, index, _class_name->as_C_string());
|
||||
}
|
||||
|
||||
void ClassFileParser::classfile_parse_error(const char* msg, const char *name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbols::java_lang_ClassFormatError(),
|
||||
msg, name, _class_name->as_C_string());
|
||||
}
|
||||
|
||||
void ClassFileParser::classfile_parse_error(const char* msg, int index, const char *name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION, vmSymbols::java_lang_ClassFormatError(),
|
||||
msg, index, name, _class_name->as_C_string());
|
||||
}
|
||||
|
||||
@ -57,7 +57,7 @@ void StackMapStream::stackmap_format_error(const char* msg, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"StackMapTable format error: %s", msg
|
||||
);
|
||||
}
|
||||
|
@ -41,7 +41,7 @@
|
||||
#include "oops/klassOop.hpp"
|
||||
#include "oops/klassVtable.hpp"
|
||||
#include "oops/methodOop.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
#include "prims/jvmtiExport.hpp"
|
||||
#include "runtime/javaCalls.hpp"
|
||||
#include "runtime/perfData.hpp"
|
||||
@ -267,14 +267,14 @@ void ClassFileParser::parse_constant_pool_entries(constantPoolHandle cp, int len
|
||||
}
|
||||
|
||||
unsigned int hash;
|
||||
symbolOop result = SymbolTable::lookup_only((char*)utf8_buffer, utf8_length, hash);
|
||||
Symbol* result = SymbolTable::lookup_only((char*)utf8_buffer, utf8_length, hash);
|
||||
if (result == NULL) {
|
||||
names[names_count] = (char*)utf8_buffer;
|
||||
lengths[names_count] = utf8_length;
|
||||
indices[names_count] = index;
|
||||
hashValues[names_count++] = hash;
|
||||
if (names_count == SymbolTable::symbol_alloc_batch_size) {
|
||||
oopFactory::new_symbols(cp, names_count, names, lengths, indices, hashValues, CHECK);
|
||||
SymbolTable::new_symbols(cp, names_count, names, lengths, indices, hashValues, CHECK);
|
||||
names_count = 0;
|
||||
}
|
||||
} else {
|
||||
@ -291,7 +291,7 @@ void ClassFileParser::parse_constant_pool_entries(constantPoolHandle cp, int len
|
||||
|
||||
// Allocate the remaining symbols
|
||||
if (names_count > 0) {
|
||||
oopFactory::new_symbols(cp, names_count, names, lengths, indices, hashValues, CHECK);
|
||||
SymbolTable::new_symbols(cp, names_count, names, lengths, indices, hashValues, CHECK);
|
||||
}
|
||||
|
||||
// Copy _current pointer of local copy back to stream().
|
||||
@ -301,6 +301,23 @@ void ClassFileParser::parse_constant_pool_entries(constantPoolHandle cp, int len
|
||||
cfs0->set_current(cfs1.current());
|
||||
}
|
||||
|
||||
// This class unreferences constant pool symbols if an error has occurred
|
||||
// while parsing the class before it is assigned into the class.
|
||||
// If it gets an error after that it is unloaded and the constant pool will
|
||||
// be cleaned up then.
|
||||
class ConstantPoolCleaner : public StackObj {
|
||||
constantPoolHandle _cphandle;
|
||||
bool _in_error;
|
||||
public:
|
||||
ConstantPoolCleaner(constantPoolHandle cp) : _cphandle(cp), _in_error(true) {}
|
||||
~ConstantPoolCleaner() {
|
||||
if (_in_error && _cphandle.not_null()) {
|
||||
_cphandle->unreference_symbols();
|
||||
}
|
||||
}
|
||||
void set_in_error(bool clean) { _in_error = clean; }
|
||||
};
|
||||
|
||||
bool inline valid_cp_range(int index, int length) { return (index > 0 && index < length); }
|
||||
|
||||
constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
@ -319,6 +336,7 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
constantPoolHandle cp (THREAD, constant_pool);
|
||||
|
||||
cp->set_partially_loaded(); // Enables heap verify to work on partial constantPoolOops
|
||||
ConstantPoolCleaner cp_in_error(cp); // set constant pool to be cleaned up.
|
||||
|
||||
// parsing constant pool entries
|
||||
parse_constant_pool_entries(cp, length, CHECK_(nullHandle));
|
||||
@ -411,7 +429,7 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
cp->tag_at(string_index).is_utf8(),
|
||||
"Invalid constant pool index %u in class file %s",
|
||||
string_index, CHECK_(nullHandle));
|
||||
symbolOop sym = cp->symbol_at(string_index);
|
||||
Symbol* sym = cp->symbol_at(string_index);
|
||||
cp->unresolved_string_at_put(index, sym);
|
||||
}
|
||||
break;
|
||||
@ -526,6 +544,7 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
}
|
||||
|
||||
if (!_need_verify) {
|
||||
cp_in_error.set_in_error(false);
|
||||
return cp;
|
||||
}
|
||||
|
||||
@ -535,7 +554,7 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
jbyte tag = cp->tag_at(index).value();
|
||||
switch (tag) {
|
||||
case JVM_CONSTANT_UnresolvedClass: {
|
||||
symbolHandle class_name(THREAD, cp->unresolved_klass_at(index));
|
||||
Symbol* class_name = cp->unresolved_klass_at(index);
|
||||
// check the name, even if _cp_patches will overwrite it
|
||||
verify_legal_class_name(class_name, CHECK_(nullHandle));
|
||||
break;
|
||||
@ -544,8 +563,8 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
if (_need_verify && _major_version >= JAVA_7_VERSION) {
|
||||
int sig_index = cp->signature_ref_index_at(index);
|
||||
int name_index = cp->name_ref_index_at(index);
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_index));
|
||||
symbolHandle sig(THREAD, cp->symbol_at(sig_index));
|
||||
Symbol* name = cp->symbol_at(name_index);
|
||||
Symbol* sig = cp->symbol_at(sig_index);
|
||||
if (sig->byte_at(0) == JVM_SIGNATURE_FUNC) {
|
||||
verify_legal_method_signature(name, sig, CHECK_(nullHandle));
|
||||
} else {
|
||||
@ -562,8 +581,8 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
int name_ref_index = cp->name_ref_index_at(name_and_type_ref_index);
|
||||
// already verified to be utf8
|
||||
int signature_ref_index = cp->signature_ref_index_at(name_and_type_ref_index);
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_ref_index));
|
||||
symbolHandle signature(THREAD, cp->symbol_at(signature_ref_index));
|
||||
Symbol* name = cp->symbol_at(name_ref_index);
|
||||
Symbol* signature = cp->symbol_at(signature_ref_index);
|
||||
if (tag == JVM_CONSTANT_Fieldref) {
|
||||
verify_legal_field_name(name, CHECK_(nullHandle));
|
||||
if (_need_verify && _major_version >= JAVA_7_VERSION) {
|
||||
@ -590,11 +609,11 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
}
|
||||
if (tag == JVM_CONSTANT_Methodref) {
|
||||
// 4509014: If a class method name begins with '<', it must be "<init>".
|
||||
assert(!name.is_null(), "method name in constant pool is null");
|
||||
assert(name != NULL, "method name in constant pool is null");
|
||||
unsigned int name_len = name->utf8_length();
|
||||
assert(name_len > 0, "bad method name"); // already verified as legal name
|
||||
if (name->byte_at(0) == '<') {
|
||||
if (name() != vmSymbols::object_initializer_name()) {
|
||||
if (name != vmSymbols::object_initializer_name()) {
|
||||
classfile_parse_error(
|
||||
"Bad method name at constant pool index %u in class file %s",
|
||||
name_ref_index, CHECK_(nullHandle));
|
||||
@ -615,15 +634,15 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
{
|
||||
int name_and_type_ref_index = cp->name_and_type_ref_index_at(ref_index);
|
||||
int name_ref_index = cp->name_ref_index_at(name_and_type_ref_index);
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_ref_index));
|
||||
Symbol* name = cp->symbol_at(name_ref_index);
|
||||
if (ref_kind == JVM_REF_newInvokeSpecial) {
|
||||
if (name() != vmSymbols::object_initializer_name()) {
|
||||
if (name != vmSymbols::object_initializer_name()) {
|
||||
classfile_parse_error(
|
||||
"Bad constructor name at constant pool index %u in class file %s",
|
||||
name_ref_index, CHECK_(nullHandle));
|
||||
}
|
||||
} else {
|
||||
if (name() == vmSymbols::object_initializer_name()) {
|
||||
if (name == vmSymbols::object_initializer_name()) {
|
||||
classfile_parse_error(
|
||||
"Bad method name at constant pool index %u in class file %s",
|
||||
name_ref_index, CHECK_(nullHandle));
|
||||
@ -636,14 +655,18 @@ constantPoolHandle ClassFileParser::parse_constant_pool(TRAPS) {
|
||||
break;
|
||||
}
|
||||
case JVM_CONSTANT_MethodType: {
|
||||
symbolHandle no_name = vmSymbolHandles::type_name(); // place holder
|
||||
symbolHandle signature(THREAD, cp->method_type_signature_at(index));
|
||||
Symbol* no_name = vmSymbols::type_name(); // place holder
|
||||
Symbol* signature = cp->method_type_signature_at(index);
|
||||
verify_legal_method_signature(no_name, signature, CHECK_(nullHandle));
|
||||
break;
|
||||
}
|
||||
case JVM_CONSTANT_Utf8: {
|
||||
assert(cp->symbol_at(index)->refcount() != 0, "count corrupted");
|
||||
}
|
||||
} // end of switch
|
||||
} // end of for
|
||||
|
||||
cp_in_error.set_in_error(false);
|
||||
return cp;
|
||||
}
|
||||
|
||||
@ -665,8 +688,8 @@ void ClassFileParser::patch_constant_pool(constantPoolHandle cp, int index, Hand
|
||||
guarantee_property(java_lang_String::is_instance(patch()),
|
||||
"Illegal class patch at %d in class file %s",
|
||||
index, CHECK);
|
||||
symbolHandle name = java_lang_String::as_symbol(patch(), CHECK);
|
||||
cp->unresolved_klass_at_put(index, name());
|
||||
Symbol* name = java_lang_String::as_symbol(patch(), CHECK);
|
||||
cp->unresolved_klass_at_put(index, name);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -717,15 +740,15 @@ void ClassFileParser::patch_constant_pool(constantPoolHandle cp, int index, Hand
|
||||
|
||||
class NameSigHash: public ResourceObj {
|
||||
public:
|
||||
symbolOop _name; // name
|
||||
symbolOop _sig; // signature
|
||||
Symbol* _name; // name
|
||||
Symbol* _sig; // signature
|
||||
NameSigHash* _next; // Next entry in hash table
|
||||
};
|
||||
|
||||
|
||||
#define HASH_ROW_SIZE 256
|
||||
|
||||
unsigned int hash(symbolOop name, symbolOop sig) {
|
||||
unsigned int hash(Symbol* name, Symbol* sig) {
|
||||
unsigned int raw_hash = 0;
|
||||
raw_hash += ((unsigned int)(uintptr_t)name) >> (LogHeapWordSize + 2);
|
||||
raw_hash += ((unsigned int)(uintptr_t)sig) >> LogHeapWordSize;
|
||||
@ -742,8 +765,8 @@ void initialize_hashtable(NameSigHash** table) {
|
||||
// Return true if no duplicate is found. And name/sig is added as a new entry in table.
|
||||
// The old format checker uses heap sort to find duplicates.
|
||||
// NOTE: caller should guarantee that GC doesn't happen during the life cycle
|
||||
// of table since we don't expect symbolOop's to move.
|
||||
bool put_after_lookup(symbolOop name, symbolOop sig, NameSigHash** table) {
|
||||
// of table since we don't expect Symbol*'s to move.
|
||||
bool put_after_lookup(Symbol* name, Symbol* sig, NameSigHash** table) {
|
||||
assert(name != NULL, "name in constant pool is NULL");
|
||||
|
||||
// First lookup for duplicates
|
||||
@ -773,7 +796,7 @@ objArrayHandle ClassFileParser::parse_interfaces(constantPoolHandle cp,
|
||||
int length,
|
||||
Handle class_loader,
|
||||
Handle protection_domain,
|
||||
symbolHandle class_name,
|
||||
Symbol* class_name,
|
||||
TRAPS) {
|
||||
ClassFileStream* cfs = stream();
|
||||
assert(length > 0, "only called for length>0");
|
||||
@ -793,7 +816,7 @@ objArrayHandle ClassFileParser::parse_interfaces(constantPoolHandle cp,
|
||||
if (cp->tag_at(interface_index).is_klass()) {
|
||||
interf = KlassHandle(THREAD, cp->resolved_klass_at(interface_index));
|
||||
} else {
|
||||
symbolHandle unresolved_klass (THREAD, cp->klass_name_at(interface_index));
|
||||
Symbol* unresolved_klass = cp->klass_name_at(interface_index);
|
||||
|
||||
// Don't need to check legal name because it's checked when parsing constant pool.
|
||||
// But need to make sure it's not an array type.
|
||||
@ -830,7 +853,7 @@ objArrayHandle ClassFileParser::parse_interfaces(constantPoolHandle cp,
|
||||
debug_only(No_Safepoint_Verifier nsv;)
|
||||
for (index = 0; index < length; index++) {
|
||||
klassOop k = (klassOop)interfaces->obj_at(index);
|
||||
symbolOop name = instanceKlass::cast(k)->name();
|
||||
Symbol* name = instanceKlass::cast(k)->name();
|
||||
// If no duplicates, add (name, NULL) in hashtable interface_names.
|
||||
if (!put_after_lookup(name, NULL, interface_names)) {
|
||||
dup = true;
|
||||
@ -908,7 +931,7 @@ void ClassFileParser::parse_field_attributes(constantPoolHandle cp,
|
||||
"Invalid field attribute index %u in class file %s",
|
||||
attribute_name_index,
|
||||
CHECK);
|
||||
symbolOop attribute_name = cp->symbol_at(attribute_name_index);
|
||||
Symbol* attribute_name = cp->symbol_at(attribute_name_index);
|
||||
if (is_static && attribute_name == vmSymbols::tag_constant_value()) {
|
||||
// ignore if non-static
|
||||
if (constantvalue_index != 0) {
|
||||
@ -1031,7 +1054,7 @@ typeArrayHandle ClassFileParser::parse_fields(constantPoolHandle cp, bool is_int
|
||||
valid_cp_range(name_index, cp_size) && cp->tag_at(name_index).is_utf8(),
|
||||
"Invalid constant pool index %u for field name in class file %s",
|
||||
name_index, CHECK_(nullHandle));
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_index));
|
||||
Symbol* name = cp->symbol_at(name_index);
|
||||
verify_legal_field_name(name, CHECK_(nullHandle));
|
||||
|
||||
u2 signature_index = cfs->get_u2_fast();
|
||||
@ -1040,7 +1063,7 @@ typeArrayHandle ClassFileParser::parse_fields(constantPoolHandle cp, bool is_int
|
||||
cp->tag_at(signature_index).is_utf8(),
|
||||
"Invalid constant pool index %u for field signature in class file %s",
|
||||
signature_index, CHECK_(nullHandle));
|
||||
symbolHandle sig(THREAD, cp->symbol_at(signature_index));
|
||||
Symbol* sig = cp->symbol_at(signature_index);
|
||||
verify_legal_field_signature(name, sig, CHECK_(nullHandle));
|
||||
|
||||
u2 constantvalue_index = 0;
|
||||
@ -1166,9 +1189,9 @@ typeArrayHandle ClassFileParser::parse_fields(constantPoolHandle cp, bool is_int
|
||||
debug_only(No_Safepoint_Verifier nsv;)
|
||||
for (int i = 0; i < length*instanceKlass::next_offset; i += instanceKlass::next_offset) {
|
||||
int name_index = fields->ushort_at(i + instanceKlass::name_index_offset);
|
||||
symbolOop name = cp->symbol_at(name_index);
|
||||
Symbol* name = cp->symbol_at(name_index);
|
||||
int sig_index = fields->ushort_at(i + instanceKlass::signature_index_offset);
|
||||
symbolOop sig = cp->symbol_at(sig_index);
|
||||
Symbol* sig = cp->symbol_at(sig_index);
|
||||
// If no duplicates, add name/signature in hashtable names_and_sigs.
|
||||
if (!put_after_lookup(name, sig, names_and_sigs)) {
|
||||
dup = true;
|
||||
@ -1422,16 +1445,16 @@ u2* ClassFileParser::parse_localvariable_table(u4 code_length,
|
||||
"Signature index %u in %s has bad constant type in class file %s",
|
||||
descriptor_index, tbl_name, CHECK_NULL);
|
||||
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_index));
|
||||
symbolHandle sig(THREAD, cp->symbol_at(descriptor_index));
|
||||
Symbol* name = cp->symbol_at(name_index);
|
||||
Symbol* sig = cp->symbol_at(descriptor_index);
|
||||
verify_legal_field_name(name, CHECK_NULL);
|
||||
u2 extra_slot = 0;
|
||||
if (!isLVTT) {
|
||||
verify_legal_field_signature(name, sig, CHECK_NULL);
|
||||
|
||||
// 4894874: check special cases for double and long local variables
|
||||
if (sig() == vmSymbols::type_signature(T_DOUBLE) ||
|
||||
sig() == vmSymbols::type_signature(T_LONG)) {
|
||||
if (sig == vmSymbols::type_signature(T_DOUBLE) ||
|
||||
sig == vmSymbols::type_signature(T_LONG)) {
|
||||
extra_slot = 1;
|
||||
}
|
||||
}
|
||||
@ -1539,7 +1562,7 @@ u2* ClassFileParser::parse_checked_exceptions(u2* checked_exceptions_length,
|
||||
}
|
||||
|
||||
void ClassFileParser::throwIllegalSignature(
|
||||
const char* type, symbolHandle name, symbolHandle sig, TRAPS) {
|
||||
const char* type, Symbol* name, Symbol* sig, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(THREAD_AND_LOCATION,
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
@ -1580,7 +1603,7 @@ methodHandle ClassFileParser::parse_method(constantPoolHandle cp, bool is_interf
|
||||
cp->tag_at(name_index).is_utf8(),
|
||||
"Illegal constant pool index %u for method name in class file %s",
|
||||
name_index, CHECK_(nullHandle));
|
||||
symbolHandle name(THREAD, cp->symbol_at(name_index));
|
||||
Symbol* name = cp->symbol_at(name_index);
|
||||
verify_legal_method_name(name, CHECK_(nullHandle));
|
||||
|
||||
u2 signature_index = cfs->get_u2_fast();
|
||||
@ -1589,7 +1612,7 @@ methodHandle ClassFileParser::parse_method(constantPoolHandle cp, bool is_interf
|
||||
cp->tag_at(signature_index).is_utf8(),
|
||||
"Illegal constant pool index %u for method signature in class file %s",
|
||||
signature_index, CHECK_(nullHandle));
|
||||
symbolHandle signature(THREAD, cp->symbol_at(signature_index));
|
||||
Symbol* signature = cp->symbol_at(signature_index);
|
||||
|
||||
AccessFlags access_flags;
|
||||
if (name == vmSymbols::class_initializer_name()) {
|
||||
@ -1660,7 +1683,7 @@ methodHandle ClassFileParser::parse_method(constantPoolHandle cp, bool is_interf
|
||||
"Invalid method attribute name index %u in class file %s",
|
||||
method_attribute_name_index, CHECK_(nullHandle));
|
||||
|
||||
symbolOop method_attribute_name = cp->symbol_at(method_attribute_name_index);
|
||||
Symbol* method_attribute_name = cp->symbol_at(method_attribute_name_index);
|
||||
if (method_attribute_name == vmSymbols::tag_code()) {
|
||||
// Parse Code attribute
|
||||
if (_need_verify) {
|
||||
@ -2057,16 +2080,16 @@ methodHandle ClassFileParser::parse_method(constantPoolHandle cp, bool is_interf
|
||||
0,
|
||||
CHECK_(nullHandle));
|
||||
|
||||
if (name() == vmSymbols::finalize_method_name() &&
|
||||
signature() == vmSymbols::void_method_signature()) {
|
||||
if (name == vmSymbols::finalize_method_name() &&
|
||||
signature == vmSymbols::void_method_signature()) {
|
||||
if (m->is_empty_method()) {
|
||||
_has_empty_finalizer = true;
|
||||
} else {
|
||||
_has_finalizer = true;
|
||||
}
|
||||
}
|
||||
if (name() == vmSymbols::object_initializer_name() &&
|
||||
signature() == vmSymbols::void_method_signature() &&
|
||||
if (name == vmSymbols::object_initializer_name() &&
|
||||
signature == vmSymbols::void_method_signature() &&
|
||||
m->is_vanilla_constructor()) {
|
||||
_has_vanilla_constructor = true;
|
||||
}
|
||||
@ -2193,7 +2216,7 @@ typeArrayHandle ClassFileParser::sort_methods(objArrayHandle methods,
|
||||
}
|
||||
}
|
||||
// Sort method array by ascending method name (for faster lookups & vtable construction)
|
||||
// Note that the ordering is not alphabetical, see symbolOopDesc::fast_compare
|
||||
// Note that the ordering is not alphabetical, see Symbol::fast_compare
|
||||
methodOopDesc::sort_methods(methods(),
|
||||
methods_annotations(),
|
||||
methods_parameter_annotations(),
|
||||
@ -2242,9 +2265,10 @@ void ClassFileParser::parse_classfile_source_debug_extension_attribute(constantP
|
||||
if (JvmtiExport::can_get_source_debug_extension()) {
|
||||
// Optimistically assume that only 1 byte UTF format is used
|
||||
// (common case)
|
||||
symbolOop sde_symbol = oopFactory::new_symbol((char*)sde_buffer,
|
||||
length, CHECK);
|
||||
TempNewSymbol sde_symbol = SymbolTable::new_symbol((const char*)sde_buffer, length, CHECK);
|
||||
k->set_source_debug_extension(sde_symbol);
|
||||
// Note that set_source_debug_extension() increments the reference count
|
||||
// for its copy of the Symbol*, so use a TempNewSymbol here.
|
||||
}
|
||||
// Got utf8 string, set stream position forward
|
||||
cfs->skip_u1(length, CHECK);
|
||||
@ -2440,7 +2464,7 @@ void ClassFileParser::parse_classfile_attributes(constantPoolHandle cp, instance
|
||||
cp->tag_at(attribute_name_index).is_utf8(),
|
||||
"Attribute name has bad constant pool index %u in class file %s",
|
||||
attribute_name_index, CHECK);
|
||||
symbolOop tag = cp->symbol_at(attribute_name_index);
|
||||
Symbol* tag = cp->symbol_at(attribute_name_index);
|
||||
if (tag == vmSymbols::tag_source_file()) {
|
||||
// Check for SourceFile tag
|
||||
if (_need_verify) {
|
||||
@ -2607,7 +2631,7 @@ static void initialize_static_field(fieldDescriptor* fd, TRAPS) {
|
||||
case T_OBJECT:
|
||||
{
|
||||
#ifdef ASSERT
|
||||
symbolOop sym = oopFactory::new_symbol("Ljava/lang/String;", CHECK);
|
||||
TempNewSymbol sym = SymbolTable::new_symbol("Ljava/lang/String;", CHECK);
|
||||
assert(fd->signature() == sym, "just checking");
|
||||
#endif
|
||||
oop string = fd->string_initial_value(CHECK);
|
||||
@ -2650,8 +2674,8 @@ void ClassFileParser::java_lang_ref_Reference_fix_pre(typeArrayHandle* fields_pt
|
||||
(*fields_ptr)()->ushort_at(i + instanceKlass::name_index_offset);
|
||||
int sig_index =
|
||||
(*fields_ptr)()->ushort_at(i + instanceKlass::signature_index_offset);
|
||||
symbolOop f_name = cp->symbol_at(name_index);
|
||||
symbolOop f_sig = cp->symbol_at(sig_index);
|
||||
Symbol* f_name = cp->symbol_at(name_index);
|
||||
Symbol* f_sig = cp->symbol_at(sig_index);
|
||||
if (f_sig == vmSymbols::reference_signature() && reference_index == 0) {
|
||||
// Save the index for reference signature for later use.
|
||||
// The fake discovered field does not entries in the
|
||||
@ -2805,9 +2829,8 @@ void ClassFileParser::java_dyn_MethodHandle_fix_pre(constantPoolHandle cp,
|
||||
int name_index = fields->ushort_at(i + instanceKlass::name_index_offset);
|
||||
int sig_index = fields->ushort_at(i + instanceKlass::signature_index_offset);
|
||||
int acc_flags = fields->ushort_at(i + instanceKlass::access_flags_offset);
|
||||
symbolOop f_name = cp->symbol_at(name_index);
|
||||
symbolOop f_sig = cp->symbol_at(sig_index);
|
||||
|
||||
Symbol* f_name = cp->symbol_at(name_index);
|
||||
Symbol* f_sig = cp->symbol_at(sig_index);
|
||||
if (f_name == vmSymbols::vmentry_name() && (acc_flags & JVM_ACC_STATIC) == 0) {
|
||||
if (f_sig == vmSymbols::machine_word_signature()) {
|
||||
// If the signature of vmentry is already changed, we're done.
|
||||
@ -2841,12 +2864,12 @@ void ClassFileParser::java_dyn_MethodHandle_fix_pre(constantPoolHandle cp,
|
||||
}
|
||||
|
||||
|
||||
instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
instanceKlassHandle ClassFileParser::parseClassFile(Symbol* name,
|
||||
Handle class_loader,
|
||||
Handle protection_domain,
|
||||
KlassHandle host_klass,
|
||||
GrowableArray<Handle>* cp_patches,
|
||||
symbolHandle& parsed_name,
|
||||
TempNewSymbol& parsed_name,
|
||||
bool verify,
|
||||
TRAPS) {
|
||||
// So that JVMTI can cache class file in the state before retransformable agents
|
||||
@ -2899,7 +2922,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
cfs->set_verify(_need_verify);
|
||||
|
||||
// Save the class file name for easier error message printing.
|
||||
_class_name = name.not_null()? name : vmSymbolHandles::unknown_class_name();
|
||||
_class_name = (name != NULL) ? name : vmSymbols::unknown_class_name();
|
||||
|
||||
cfs->guarantee_more(8, CHECK_(nullHandle)); // magic, major, minor
|
||||
// Magic value
|
||||
@ -2914,10 +2937,10 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
|
||||
// Check version numbers - we check this even with verifier off
|
||||
if (!is_supported_version(major_version, minor_version)) {
|
||||
if (name.is_null()) {
|
||||
if (name == NULL) {
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_UnsupportedClassVersionError(),
|
||||
vmSymbols::java_lang_UnsupportedClassVersionError(),
|
||||
"Unsupported major.minor version %u.%u",
|
||||
major_version,
|
||||
minor_version);
|
||||
@ -2925,7 +2948,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_UnsupportedClassVersionError(),
|
||||
vmSymbols::java_lang_UnsupportedClassVersionError(),
|
||||
"%s : Unsupported major.minor version %u.%u",
|
||||
name->as_C_string(),
|
||||
major_version,
|
||||
@ -2944,6 +2967,8 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
|
||||
// Constant pool
|
||||
constantPoolHandle cp = parse_constant_pool(CHECK_(nullHandle));
|
||||
ConstantPoolCleaner error_handler(cp); // set constant pool to be cleaned up.
|
||||
|
||||
int cp_size = cp->length();
|
||||
|
||||
cfs->guarantee_more(8, CHECK_(nullHandle)); // flags, this_class, super_class, infs_len
|
||||
@ -2968,12 +2993,15 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
"Invalid this class index %u in constant pool in class file %s",
|
||||
this_class_index, CHECK_(nullHandle));
|
||||
|
||||
symbolHandle class_name (THREAD, cp->unresolved_klass_at(this_class_index));
|
||||
assert(class_name.not_null(), "class_name can't be null");
|
||||
Symbol* class_name = cp->unresolved_klass_at(this_class_index);
|
||||
assert(class_name != NULL, "class_name can't be null");
|
||||
|
||||
// It's important to set parsed_name *before* resolving the super class.
|
||||
// (it's used for cleanup by the caller if parsing fails)
|
||||
parsed_name = class_name;
|
||||
// parsed_name is returned and can be used if there's an error, so add to
|
||||
// its reference count. Caller will decrement the refcount.
|
||||
parsed_name->increment_refcount();
|
||||
|
||||
// Update _class_name which could be null previously to be class_name
|
||||
_class_name = class_name;
|
||||
@ -2993,11 +3021,11 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
{ HandleMark hm(THREAD);
|
||||
|
||||
// Checks if name in class file matches requested name
|
||||
if (name.not_null() && class_name() != name()) {
|
||||
if (name != NULL && class_name != name) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_NoClassDefFoundError(),
|
||||
vmSymbols::java_lang_NoClassDefFoundError(),
|
||||
"%s (wrong name: %s)",
|
||||
name->as_C_string(),
|
||||
class_name->as_C_string()
|
||||
@ -3006,14 +3034,14 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
}
|
||||
|
||||
if (TraceClassLoadingPreorder) {
|
||||
tty->print("[Loading %s", name()->as_klass_external_name());
|
||||
tty->print("[Loading %s", name->as_klass_external_name());
|
||||
if (cfs->source() != NULL) tty->print(" from %s", cfs->source());
|
||||
tty->print_cr("]");
|
||||
}
|
||||
|
||||
u2 super_class_index = cfs->get_u2_fast();
|
||||
if (super_class_index == 0) {
|
||||
check_property(class_name() == vmSymbols::java_lang_Object(),
|
||||
check_property(class_name == vmSymbols::java_lang_Object(),
|
||||
"Invalid superclass index %u in class file %s",
|
||||
super_class_index,
|
||||
CHECK_(nullHandle));
|
||||
@ -3075,11 +3103,11 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
|
||||
// We check super class after class file is parsed and format is checked
|
||||
if (super_class_index > 0 && super_klass.is_null()) {
|
||||
symbolHandle sk (THREAD, cp->klass_name_at(super_class_index));
|
||||
Symbol* sk = cp->klass_name_at(super_class_index);
|
||||
if (access_flags.is_interface()) {
|
||||
// Before attempting to resolve the superclass, check for class format
|
||||
// errors not checked yet.
|
||||
guarantee_property(sk() == vmSymbols::java_lang_Object(),
|
||||
guarantee_property(sk == vmSymbols::java_lang_Object(),
|
||||
"Interfaces must have java.lang.Object as superclass in class file %s",
|
||||
CHECK_(nullHandle));
|
||||
}
|
||||
@ -3100,7 +3128,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_IncompatibleClassChangeError(),
|
||||
vmSymbols::java_lang_IncompatibleClassChangeError(),
|
||||
"class %s has interface %s as super class",
|
||||
class_name->as_klass_external_name(),
|
||||
super_klass->external_name()
|
||||
@ -3193,18 +3221,18 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
next_nonstatic_field_offset = first_nonstatic_field_offset;
|
||||
|
||||
// Add fake fields for java.lang.Class instances (also see below)
|
||||
if (class_name() == vmSymbols::java_lang_Class() && class_loader.is_null()) {
|
||||
if (class_name == vmSymbols::java_lang_Class() && class_loader.is_null()) {
|
||||
java_lang_Class_fix_pre(&methods, &fac, CHECK_(nullHandle));
|
||||
}
|
||||
|
||||
// adjust the vmentry field declaration in java.dyn.MethodHandle
|
||||
if (EnableMethodHandles && class_name() == vmSymbols::sun_dyn_MethodHandleImpl() && class_loader.is_null()) {
|
||||
if (EnableMethodHandles && class_name == vmSymbols::sun_dyn_MethodHandleImpl() && class_loader.is_null()) {
|
||||
java_dyn_MethodHandle_fix_pre(cp, fields, &fac, CHECK_(nullHandle));
|
||||
}
|
||||
|
||||
// Add a fake "discovered" field if it is not present
|
||||
// for compatibility with earlier jdk's.
|
||||
if (class_name() == vmSymbols::java_lang_ref_Reference()
|
||||
if (class_name == vmSymbols::java_lang_ref_Reference()
|
||||
&& class_loader.is_null()) {
|
||||
java_lang_ref_Reference_fix_pre(&fields, cp, &fac, CHECK_(nullHandle));
|
||||
}
|
||||
@ -3236,7 +3264,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
|
||||
// Add fake fields for java.lang.Class instances (also see above).
|
||||
// FieldsAllocationStyle and CompactFields values will be reset to default.
|
||||
if(class_name() == vmSymbols::java_lang_Class() && class_loader.is_null()) {
|
||||
if(class_name == vmSymbols::java_lang_Class() && class_loader.is_null()) {
|
||||
java_lang_Class_fix_post(&next_nonstatic_field_offset);
|
||||
nonstatic_oop_offsets[0] = first_nonstatic_field_offset;
|
||||
const uint fake_oop_count = (next_nonstatic_field_offset -
|
||||
@ -3279,22 +3307,22 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
// (see in JavaClasses::compute_hard_coded_offsets()).
|
||||
// Use default fields allocation order for them.
|
||||
if( (allocation_style != 0 || compact_fields ) && class_loader.is_null() &&
|
||||
(class_name() == vmSymbols::java_lang_AssertionStatusDirectives() ||
|
||||
class_name() == vmSymbols::java_lang_Class() ||
|
||||
class_name() == vmSymbols::java_lang_ClassLoader() ||
|
||||
class_name() == vmSymbols::java_lang_ref_Reference() ||
|
||||
class_name() == vmSymbols::java_lang_ref_SoftReference() ||
|
||||
class_name() == vmSymbols::java_lang_StackTraceElement() ||
|
||||
class_name() == vmSymbols::java_lang_String() ||
|
||||
class_name() == vmSymbols::java_lang_Throwable() ||
|
||||
class_name() == vmSymbols::java_lang_Boolean() ||
|
||||
class_name() == vmSymbols::java_lang_Character() ||
|
||||
class_name() == vmSymbols::java_lang_Float() ||
|
||||
class_name() == vmSymbols::java_lang_Double() ||
|
||||
class_name() == vmSymbols::java_lang_Byte() ||
|
||||
class_name() == vmSymbols::java_lang_Short() ||
|
||||
class_name() == vmSymbols::java_lang_Integer() ||
|
||||
class_name() == vmSymbols::java_lang_Long())) {
|
||||
(class_name == vmSymbols::java_lang_AssertionStatusDirectives() ||
|
||||
class_name == vmSymbols::java_lang_Class() ||
|
||||
class_name == vmSymbols::java_lang_ClassLoader() ||
|
||||
class_name == vmSymbols::java_lang_ref_Reference() ||
|
||||
class_name == vmSymbols::java_lang_ref_SoftReference() ||
|
||||
class_name == vmSymbols::java_lang_StackTraceElement() ||
|
||||
class_name == vmSymbols::java_lang_String() ||
|
||||
class_name == vmSymbols::java_lang_Throwable() ||
|
||||
class_name == vmSymbols::java_lang_Boolean() ||
|
||||
class_name == vmSymbols::java_lang_Character() ||
|
||||
class_name == vmSymbols::java_lang_Float() ||
|
||||
class_name == vmSymbols::java_lang_Double() ||
|
||||
class_name == vmSymbols::java_lang_Byte() ||
|
||||
class_name == vmSymbols::java_lang_Short() ||
|
||||
class_name == vmSymbols::java_lang_Integer() ||
|
||||
class_name == vmSymbols::java_lang_Long())) {
|
||||
allocation_style = 0; // Allocate oops first
|
||||
compact_fields = false; // Don't compact fields
|
||||
}
|
||||
@ -3543,6 +3571,7 @@ instanceKlassHandle ClassFileParser::parseClassFile(symbolHandle name,
|
||||
this_klass->set_has_nonstatic_fields(has_nonstatic_fields);
|
||||
this_klass->set_static_oop_field_size(fac.static_oop_count);
|
||||
cp->set_pool_holder(this_klass());
|
||||
error_handler.set_in_error(false); // turn off error handler for cp
|
||||
this_klass->set_constants(cp());
|
||||
this_klass->set_local_interfaces(local_interfaces());
|
||||
this_klass->set_fields(fields());
|
||||
@ -3935,7 +3964,7 @@ void ClassFileParser::check_super_class_access(instanceKlassHandle this_klass, T
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_IllegalAccessError(),
|
||||
vmSymbols::java_lang_IllegalAccessError(),
|
||||
"class %s cannot access its superclass %s",
|
||||
this_klass->external_name(),
|
||||
instanceKlass::cast(super)->external_name()
|
||||
@ -3955,7 +3984,7 @@ void ClassFileParser::check_super_interface_access(instanceKlassHandle this_klas
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_IllegalAccessError(),
|
||||
vmSymbols::java_lang_IllegalAccessError(),
|
||||
"class %s cannot access its superinterface %s",
|
||||
this_klass->external_name(),
|
||||
instanceKlass::cast(k)->external_name()
|
||||
@ -3979,8 +4008,8 @@ void ClassFileParser::check_final_method_override(instanceKlassHandle this_klass
|
||||
(!m->is_static()) &&
|
||||
(m->name() != vmSymbols::object_initializer_name())) {
|
||||
|
||||
symbolOop name = m->name();
|
||||
symbolOop signature = m->signature();
|
||||
Symbol* name = m->name();
|
||||
Symbol* signature = m->signature();
|
||||
klassOop k = this_klass->super();
|
||||
methodOop super_m = NULL;
|
||||
while (k != NULL) {
|
||||
@ -4003,7 +4032,7 @@ void ClassFileParser::check_final_method_override(instanceKlassHandle this_klass
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_VerifyError(),
|
||||
vmSymbols::java_lang_VerifyError(),
|
||||
"class %s overrides final method %s.%s",
|
||||
this_klass->external_name(),
|
||||
name->as_C_string(),
|
||||
@ -4037,7 +4066,7 @@ void ClassFileParser::check_illegal_static_method(instanceKlassHandle this_klass
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_VerifyError(),
|
||||
vmSymbols::java_lang_VerifyError(),
|
||||
"Illegal static method %s in interface %s",
|
||||
m->name()->as_C_string(),
|
||||
this_klass->external_name()
|
||||
@ -4067,7 +4096,7 @@ void ClassFileParser::verify_legal_class_modifiers(jint flags, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Illegal class modifiers in class %s: 0x%X",
|
||||
_class_name->as_C_string(), flags
|
||||
);
|
||||
@ -4127,7 +4156,7 @@ void ClassFileParser::verify_legal_field_modifiers(
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Illegal field modifiers in class %s: 0x%X",
|
||||
_class_name->as_C_string(), flags);
|
||||
return;
|
||||
@ -4135,7 +4164,7 @@ void ClassFileParser::verify_legal_field_modifiers(
|
||||
}
|
||||
|
||||
void ClassFileParser::verify_legal_method_modifiers(
|
||||
jint flags, bool is_interface, symbolHandle name, TRAPS) {
|
||||
jint flags, bool is_interface, Symbol* name, TRAPS) {
|
||||
if (!_need_verify) { return; }
|
||||
|
||||
const bool is_public = (flags & JVM_ACC_PUBLIC) != 0;
|
||||
@ -4180,7 +4209,7 @@ void ClassFileParser::verify_legal_method_modifiers(
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Method %s in class %s has illegal modifiers: 0x%X",
|
||||
name->as_C_string(), _class_name->as_C_string(), flags);
|
||||
return;
|
||||
@ -4251,7 +4280,7 @@ void ClassFileParser::verify_legal_utf8(const unsigned char* buffer, int length,
|
||||
}
|
||||
|
||||
// Checks if name is a legal class name.
|
||||
void ClassFileParser::verify_legal_class_name(symbolHandle name, TRAPS) {
|
||||
void ClassFileParser::verify_legal_class_name(Symbol* name, TRAPS) {
|
||||
if (!_need_verify || _relax_verify) { return; }
|
||||
|
||||
char buf[fixed_buffer_size];
|
||||
@ -4281,7 +4310,7 @@ void ClassFileParser::verify_legal_class_name(symbolHandle name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Illegal class name \"%s\" in class file %s", bytes,
|
||||
_class_name->as_C_string()
|
||||
);
|
||||
@ -4290,7 +4319,7 @@ void ClassFileParser::verify_legal_class_name(symbolHandle name, TRAPS) {
|
||||
}
|
||||
|
||||
// Checks if name is a legal field name.
|
||||
void ClassFileParser::verify_legal_field_name(symbolHandle name, TRAPS) {
|
||||
void ClassFileParser::verify_legal_field_name(Symbol* name, TRAPS) {
|
||||
if (!_need_verify || _relax_verify) { return; }
|
||||
|
||||
char buf[fixed_buffer_size];
|
||||
@ -4314,7 +4343,7 @@ void ClassFileParser::verify_legal_field_name(symbolHandle name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Illegal field name \"%s\" in class %s", bytes,
|
||||
_class_name->as_C_string()
|
||||
);
|
||||
@ -4323,10 +4352,10 @@ void ClassFileParser::verify_legal_field_name(symbolHandle name, TRAPS) {
|
||||
}
|
||||
|
||||
// Checks if name is a legal method name.
|
||||
void ClassFileParser::verify_legal_method_name(symbolHandle name, TRAPS) {
|
||||
void ClassFileParser::verify_legal_method_name(Symbol* name, TRAPS) {
|
||||
if (!_need_verify || _relax_verify) { return; }
|
||||
|
||||
assert(!name.is_null(), "method name is null");
|
||||
assert(name != NULL, "method name is null");
|
||||
char buf[fixed_buffer_size];
|
||||
char* bytes = name->as_utf8_flexible_buffer(THREAD, buf, fixed_buffer_size);
|
||||
unsigned int length = name->utf8_length();
|
||||
@ -4351,7 +4380,7 @@ void ClassFileParser::verify_legal_method_name(symbolHandle name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
Exceptions::fthrow(
|
||||
THREAD_AND_LOCATION,
|
||||
vmSymbolHandles::java_lang_ClassFormatError(),
|
||||
vmSymbols::java_lang_ClassFormatError(),
|
||||
"Illegal method name \"%s\" in class %s", bytes,
|
||||
_class_name->as_C_string()
|
||||
);
|
||||
@ -4361,7 +4390,7 @@ void ClassFileParser::verify_legal_method_name(symbolHandle name, TRAPS) {
|
||||
|
||||
|
||||
// Checks if signature is a legal field signature.
|
||||
void ClassFileParser::verify_legal_field_signature(symbolHandle name, symbolHandle signature, TRAPS) {
|
||||
void ClassFileParser::verify_legal_field_signature(Symbol* name, Symbol* signature, TRAPS) {
|
||||
if (!_need_verify) { return; }
|
||||
|
||||
char buf[fixed_buffer_size];
|
||||
@ -4376,7 +4405,7 @@ void ClassFileParser::verify_legal_field_signature(symbolHandle name, symbolHand
|
||||
|
||||
// Checks if signature is a legal method signature.
|
||||
// Returns number of parameters
|
||||
int ClassFileParser::verify_legal_method_signature(symbolHandle name, symbolHandle signature, TRAPS) {
|
||||
int ClassFileParser::verify_legal_method_signature(Symbol* name, Symbol* signature, TRAPS) {
|
||||
if (!_need_verify) {
|
||||
// make sure caller's args_size will be less than 0 even for non-static
|
||||
// method so it will be recomputed in compute_size_of_parameters().
|
||||
@ -4508,8 +4537,8 @@ char* ClassFileParser::skip_over_field_name(char* name, bool slash_ok, unsigned
|
||||
// public static boolean isJavaIdentifierStart(char ch);
|
||||
JavaCalls::call_static(&result,
|
||||
klass,
|
||||
vmSymbolHandles::isJavaIdentifierStart_name(),
|
||||
vmSymbolHandles::int_bool_signature(),
|
||||
vmSymbols::isJavaIdentifierStart_name(),
|
||||
vmSymbols::int_bool_signature(),
|
||||
&args,
|
||||
THREAD);
|
||||
|
||||
@ -4525,8 +4554,8 @@ char* ClassFileParser::skip_over_field_name(char* name, bool slash_ok, unsigned
|
||||
// public static boolean isJavaIdentifierPart(char ch);
|
||||
JavaCalls::call_static(&result,
|
||||
klass,
|
||||
vmSymbolHandles::isJavaIdentifierPart_name(),
|
||||
vmSymbolHandles::int_bool_signature(),
|
||||
vmSymbols::isJavaIdentifierPart_name(),
|
||||
vmSymbols::int_bool_signature(),
|
||||
&args,
|
||||
THREAD);
|
||||
|
||||
|
@ -32,6 +32,7 @@
|
||||
#include "runtime/handles.inline.hpp"
|
||||
#include "utilities/accessFlags.hpp"
|
||||
|
||||
class TempNewSymbol;
|
||||
// Parser for for .class files
|
||||
//
|
||||
// The bytes describing the class file structure is read from a Stream object
|
||||
@ -42,7 +43,7 @@ class ClassFileParser VALUE_OBJ_CLASS_SPEC {
|
||||
bool _relax_verify;
|
||||
u2 _major_version;
|
||||
u2 _minor_version;
|
||||
symbolHandle _class_name;
|
||||
Symbol* _class_name;
|
||||
KlassHandle _host_klass;
|
||||
GrowableArray<Handle>* _cp_patches; // overrides for CP entries
|
||||
|
||||
@ -73,7 +74,7 @@ class ClassFileParser VALUE_OBJ_CLASS_SPEC {
|
||||
int length,
|
||||
Handle class_loader,
|
||||
Handle protection_domain,
|
||||
symbolHandle class_name,
|
||||
Symbol* class_name,
|
||||
TRAPS);
|
||||
|
||||
// Field parsing
|
||||
@ -209,21 +210,21 @@ class ClassFileParser VALUE_OBJ_CLASS_SPEC {
|
||||
}
|
||||
|
||||
void throwIllegalSignature(
|
||||
const char* type, symbolHandle name, symbolHandle sig, TRAPS);
|
||||
const char* type, Symbol* name, Symbol* sig, TRAPS);
|
||||
|
||||
bool is_supported_version(u2 major, u2 minor);
|
||||
bool has_illegal_visibility(jint flags);
|
||||
|
||||
void verify_constantvalue(int constantvalue_index, int signature_index, constantPoolHandle cp, TRAPS);
|
||||
void verify_legal_utf8(const unsigned char* buffer, int length, TRAPS);
|
||||
void verify_legal_class_name(symbolHandle name, TRAPS);
|
||||
void verify_legal_field_name(symbolHandle name, TRAPS);
|
||||
void verify_legal_method_name(symbolHandle name, TRAPS);
|
||||
void verify_legal_field_signature(symbolHandle fieldname, symbolHandle signature, TRAPS);
|
||||
int verify_legal_method_signature(symbolHandle methodname, symbolHandle signature, TRAPS);
|
||||
void verify_legal_class_name(Symbol* name, TRAPS);
|
||||
void verify_legal_field_name(Symbol* name, TRAPS);
|
||||
void verify_legal_method_name(Symbol* name, TRAPS);
|
||||
void verify_legal_field_signature(Symbol* fieldname, Symbol* signature, TRAPS);
|
||||
int verify_legal_method_signature(Symbol* methodname, Symbol* signature, TRAPS);
|
||||
void verify_legal_class_modifiers(jint flags, TRAPS);
|
||||
void verify_legal_field_modifiers(jint flags, bool is_interface, TRAPS);
|
||||
void verify_legal_method_modifiers(jint flags, bool is_interface, symbolHandle name, TRAPS);
|
||||
void verify_legal_method_modifiers(jint flags, bool is_interface, Symbol* name, TRAPS);
|
||||
bool verify_unqualified_name(char* name, unsigned int length, int type);
|
||||
char* skip_over_field_name(char* name, bool slash_ok, unsigned int length);
|
||||
char* skip_over_field_signature(char* signature, bool void_ok, unsigned int length, TRAPS);
|
||||
@ -272,21 +273,21 @@ class ClassFileParser VALUE_OBJ_CLASS_SPEC {
|
||||
//
|
||||
// "parsed_name" is updated by this method, and is the name found
|
||||
// while parsing the stream.
|
||||
instanceKlassHandle parseClassFile(symbolHandle name,
|
||||
instanceKlassHandle parseClassFile(Symbol* name,
|
||||
Handle class_loader,
|
||||
Handle protection_domain,
|
||||
symbolHandle& parsed_name,
|
||||
TempNewSymbol& parsed_name,
|
||||
bool verify,
|
||||
TRAPS) {
|
||||
KlassHandle no_host_klass;
|
||||
return parseClassFile(name, class_loader, protection_domain, no_host_klass, NULL, parsed_name, verify, THREAD);
|
||||
}
|
||||
instanceKlassHandle parseClassFile(symbolHandle name,
|
||||
instanceKlassHandle parseClassFile(Symbol* name,
|
||||
Handle class_loader,
|
||||
Handle protection_domain,
|
||||
KlassHandle host_klass,
|
||||
GrowableArray<Handle>* cp_patches,
|
||||
symbolHandle& parsed_name,
|
||||
TempNewSymbol& parsed_name,
|
||||
bool verify,
|
||||
TRAPS);
|
||||
|
||||
|
@ -41,7 +41,7 @@
|
||||
#include "oops/instanceKlass.hpp"
|
||||
#include "oops/instanceRefKlass.hpp"
|
||||
#include "oops/oop.inline.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
#include "prims/jvm_misc.hpp"
|
||||
#include "runtime/arguments.hpp"
|
||||
#include "runtime/compilationPolicy.hpp"
|
||||
@ -752,11 +752,7 @@ void PackageHashtable::copy_table(char** top, char* end,
|
||||
}
|
||||
}
|
||||
if (*top + n + sizeof(intptr_t) >= end) {
|
||||
warning("\nThe shared miscellaneous data space is not large "
|
||||
"enough to \npreload requested classes. Use "
|
||||
"-XX:SharedMiscDataSize= to increase \nthe initial "
|
||||
"size of the miscellaneous data space.\n");
|
||||
exit(2);
|
||||
report_out_of_shared_space(SharedMiscData);
|
||||
}
|
||||
|
||||
// Copy the table data (the strings) to the shared space.
|
||||
@ -875,9 +871,9 @@ objArrayOop ClassLoader::get_system_packages(TRAPS) {
|
||||
}
|
||||
|
||||
|
||||
instanceKlassHandle ClassLoader::load_classfile(symbolHandle h_name, TRAPS) {
|
||||
instanceKlassHandle ClassLoader::load_classfile(Symbol* h_name, TRAPS) {
|
||||
ResourceMark rm(THREAD);
|
||||
EventMark m("loading class " INTPTR_FORMAT, (address)h_name());
|
||||
EventMark m("loading class " INTPTR_FORMAT, (address)h_name);
|
||||
ThreadProfilerMark tpm(ThreadProfilerMark::classLoaderRegion);
|
||||
|
||||
stringStream st;
|
||||
@ -912,7 +908,7 @@ instanceKlassHandle ClassLoader::load_classfile(symbolHandle h_name, TRAPS) {
|
||||
ClassFileParser parser(stream);
|
||||
Handle class_loader;
|
||||
Handle protection_domain;
|
||||
symbolHandle parsed_name;
|
||||
TempNewSymbol parsed_name = NULL;
|
||||
instanceKlassHandle result = parser.parseClassFile(h_name,
|
||||
class_loader,
|
||||
protection_domain,
|
||||
@ -1308,7 +1304,7 @@ void ClassLoader::compile_the_world_in(char* name, Handle loader, TRAPS) {
|
||||
if (_compile_the_world_counter > CompileTheWorldStopAt) return;
|
||||
|
||||
// Construct name without extension
|
||||
symbolHandle sym = oopFactory::new_symbol_handle(buffer, CHECK);
|
||||
TempNewSymbol sym = SymbolTable::new_symbol(buffer, CHECK);
|
||||
// Use loader to load and initialize class
|
||||
klassOop ik = SystemDictionary::resolve_or_null(sym, loader, Handle(), THREAD);
|
||||
instanceKlassHandle k (THREAD, ik);
|
||||
|
@ -280,7 +280,7 @@ class ClassLoader: AllStatic {
|
||||
}
|
||||
|
||||
// Load individual .class file
|
||||
static instanceKlassHandle load_classfile(symbolHandle h_name, TRAPS);
|
||||
static instanceKlassHandle load_classfile(Symbol* h_name, TRAPS);
|
||||
|
||||
// If the specified package has been loaded by the system, then returns
|
||||
// the name of the directory or ZIP file that the package was loaded from.
|
||||
|
@ -36,7 +36,7 @@ int Dictionary::_current_class_index = 0;
|
||||
|
||||
|
||||
Dictionary::Dictionary(int table_size)
|
||||
: TwoOopHashtable(table_size, sizeof(DictionaryEntry)) {
|
||||
: TwoOopHashtable<klassOop>(table_size, sizeof(DictionaryEntry)) {
|
||||
_current_class_index = 0;
|
||||
_current_class_entry = NULL;
|
||||
};
|
||||
@ -45,7 +45,7 @@ Dictionary::Dictionary(int table_size)
|
||||
|
||||
Dictionary::Dictionary(int table_size, HashtableBucket* t,
|
||||
int number_of_entries)
|
||||
: TwoOopHashtable(table_size, sizeof(DictionaryEntry), t, number_of_entries) {
|
||||
: TwoOopHashtable<klassOop>(table_size, sizeof(DictionaryEntry), t, number_of_entries) {
|
||||
_current_class_index = 0;
|
||||
_current_class_entry = NULL;
|
||||
};
|
||||
@ -54,7 +54,7 @@ Dictionary::Dictionary(int table_size, HashtableBucket* t,
|
||||
DictionaryEntry* Dictionary::new_entry(unsigned int hash, klassOop klass,
|
||||
oop loader) {
|
||||
DictionaryEntry* entry;
|
||||
entry = (DictionaryEntry*)Hashtable::new_entry(hash, klass);
|
||||
entry = (DictionaryEntry*)Hashtable<klassOop>::new_entry(hash, klass);
|
||||
entry->set_loader(loader);
|
||||
entry->set_pd_set(NULL);
|
||||
return entry;
|
||||
@ -62,7 +62,7 @@ DictionaryEntry* Dictionary::new_entry(unsigned int hash, klassOop klass,
|
||||
|
||||
|
||||
DictionaryEntry* Dictionary::new_entry() {
|
||||
DictionaryEntry* entry = (DictionaryEntry*)Hashtable::new_entry(0L, NULL);
|
||||
DictionaryEntry* entry = (DictionaryEntry*)Hashtable<klassOop>::new_entry(0L, NULL);
|
||||
entry->set_loader(NULL);
|
||||
entry->set_pd_set(NULL);
|
||||
return entry;
|
||||
@ -76,7 +76,7 @@ void Dictionary::free_entry(DictionaryEntry* entry) {
|
||||
entry->set_pd_set(to_delete->next());
|
||||
delete to_delete;
|
||||
}
|
||||
Hashtable::free_entry(entry);
|
||||
Hashtable<klassOop>::free_entry(entry);
|
||||
}
|
||||
|
||||
|
||||
@ -298,7 +298,7 @@ void Dictionary::always_strong_classes_do(OopClosure* blk) {
|
||||
for (DictionaryEntry *probe = bucket(index);
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
oop e = probe->klass();
|
||||
klassOop e = probe->klass();
|
||||
oop class_loader = probe->loader();
|
||||
if (is_strongly_reachable(class_loader, e)) {
|
||||
blk->do_oop((oop*)probe->klass_addr());
|
||||
@ -421,11 +421,11 @@ klassOop Dictionary::try_get_next_class() {
|
||||
// also cast to volatile; we do this to ensure store order is maintained
|
||||
// by the compilers.
|
||||
|
||||
void Dictionary::add_klass(symbolHandle class_name, Handle class_loader,
|
||||
void Dictionary::add_klass(Symbol* class_name, Handle class_loader,
|
||||
KlassHandle obj) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
assert(obj() != NULL, "adding NULL obj");
|
||||
assert(Klass::cast(obj())->name() == class_name(), "sanity check on name");
|
||||
assert(Klass::cast(obj())->name() == class_name, "sanity check on name");
|
||||
|
||||
unsigned int hash = compute_hash(class_name, class_loader);
|
||||
int index = hash_to_index(hash);
|
||||
@ -444,15 +444,14 @@ void Dictionary::add_klass(symbolHandle class_name, Handle class_loader,
|
||||
// Callers should be aware that an entry could be added just after
|
||||
// _buckets[index] is read here, so the caller will not see the new entry.
|
||||
DictionaryEntry* Dictionary::get_entry(int index, unsigned int hash,
|
||||
symbolHandle class_name,
|
||||
Symbol* class_name,
|
||||
Handle class_loader) {
|
||||
symbolOop name_ = class_name();
|
||||
oop loader_ = class_loader();
|
||||
oop loader = class_loader();
|
||||
debug_only(_lookup_count++);
|
||||
for (DictionaryEntry* entry = bucket(index);
|
||||
entry != NULL;
|
||||
entry = entry->next()) {
|
||||
if (entry->hash() == hash && entry->equals(name_, loader_)) {
|
||||
if (entry->hash() == hash && entry->equals(class_name, loader)) {
|
||||
return entry;
|
||||
}
|
||||
debug_only(_lookup_length++);
|
||||
@ -461,7 +460,7 @@ DictionaryEntry* Dictionary::get_entry(int index, unsigned int hash,
|
||||
}
|
||||
|
||||
|
||||
klassOop Dictionary::find(int index, unsigned int hash, symbolHandle name,
|
||||
klassOop Dictionary::find(int index, unsigned int hash, Symbol* name,
|
||||
Handle loader, Handle protection_domain, TRAPS) {
|
||||
DictionaryEntry* entry = get_entry(index, hash, name, loader);
|
||||
if (entry != NULL && entry->is_valid_protection_domain(protection_domain)) {
|
||||
@ -473,7 +472,7 @@ klassOop Dictionary::find(int index, unsigned int hash, symbolHandle name,
|
||||
|
||||
|
||||
klassOop Dictionary::find_class(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader) {
|
||||
Symbol* name, Handle loader) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
assert (index == index_for(name, loader), "incorrect index?");
|
||||
|
||||
@ -486,7 +485,7 @@ klassOop Dictionary::find_class(int index, unsigned int hash,
|
||||
// that table is static.
|
||||
|
||||
klassOop Dictionary::find_shared_class(int index, unsigned int hash,
|
||||
symbolHandle name) {
|
||||
Symbol* name) {
|
||||
assert (index == index_for(name, Handle()), "incorrect index?");
|
||||
|
||||
DictionaryEntry* entry = get_entry(index, hash, name, Handle());
|
||||
@ -498,7 +497,7 @@ void Dictionary::add_protection_domain(int index, unsigned int hash,
|
||||
instanceKlassHandle klass,
|
||||
Handle loader, Handle protection_domain,
|
||||
TRAPS) {
|
||||
symbolHandle klass_name(THREAD, klass->name());
|
||||
Symbol* klass_name = klass->name();
|
||||
DictionaryEntry* entry = get_entry(index, hash, klass_name, loader);
|
||||
|
||||
assert(entry != NULL,"entry must be present, we just created it");
|
||||
@ -513,7 +512,7 @@ void Dictionary::add_protection_domain(int index, unsigned int hash,
|
||||
|
||||
|
||||
bool Dictionary::is_valid_protection_domain(int index, unsigned int hash,
|
||||
symbolHandle name,
|
||||
Symbol* name,
|
||||
Handle loader,
|
||||
Handle protection_domain) {
|
||||
DictionaryEntry* entry = get_entry(index, hash, name, loader);
|
||||
@ -545,7 +544,7 @@ void Dictionary::reorder_dictionary() {
|
||||
DictionaryEntry* p = master_list;
|
||||
master_list = master_list->next();
|
||||
p->set_next(NULL);
|
||||
symbolHandle class_name (thread, instanceKlass::cast((klassOop)(p->klass()))->name());
|
||||
Symbol* class_name = instanceKlass::cast((klassOop)(p->klass()))->name();
|
||||
unsigned int hash = compute_hash(class_name, Handle(thread, p->loader()));
|
||||
int index = hash_to_index(hash);
|
||||
p->set_hash(hash);
|
||||
@ -555,22 +554,22 @@ void Dictionary::reorder_dictionary() {
|
||||
}
|
||||
|
||||
SymbolPropertyTable::SymbolPropertyTable(int table_size)
|
||||
: Hashtable(table_size, sizeof(SymbolPropertyEntry))
|
||||
: Hashtable<Symbol*>(table_size, sizeof(SymbolPropertyEntry))
|
||||
{
|
||||
}
|
||||
SymbolPropertyTable::SymbolPropertyTable(int table_size, HashtableBucket* t,
|
||||
int number_of_entries)
|
||||
: Hashtable(table_size, sizeof(SymbolPropertyEntry), t, number_of_entries)
|
||||
: Hashtable<Symbol*>(table_size, sizeof(SymbolPropertyEntry), t, number_of_entries)
|
||||
{
|
||||
}
|
||||
|
||||
|
||||
SymbolPropertyEntry* SymbolPropertyTable::find_entry(int index, unsigned int hash,
|
||||
symbolHandle sym,
|
||||
Symbol* sym,
|
||||
intptr_t sym_mode) {
|
||||
assert(index == index_for(sym, sym_mode), "incorrect index?");
|
||||
for (SymbolPropertyEntry* p = bucket(index); p != NULL; p = p->next()) {
|
||||
if (p->hash() == hash && p->symbol() == sym() && p->symbol_mode() == sym_mode) {
|
||||
if (p->hash() == hash && p->symbol() == sym && p->symbol_mode() == sym_mode) {
|
||||
return p;
|
||||
}
|
||||
}
|
||||
@ -579,13 +578,13 @@ SymbolPropertyEntry* SymbolPropertyTable::find_entry(int index, unsigned int has
|
||||
|
||||
|
||||
SymbolPropertyEntry* SymbolPropertyTable::add_entry(int index, unsigned int hash,
|
||||
symbolHandle sym, intptr_t sym_mode) {
|
||||
Symbol* sym, intptr_t sym_mode) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
assert(index == index_for(sym, sym_mode), "incorrect index?");
|
||||
assert(find_entry(index, hash, sym, sym_mode) == NULL, "no double entry");
|
||||
|
||||
SymbolPropertyEntry* p = new_entry(hash, sym(), sym_mode);
|
||||
Hashtable::add_entry(index, p);
|
||||
SymbolPropertyEntry* p = new_entry(hash, sym, sym_mode);
|
||||
Hashtable<Symbol*>::add_entry(index, p);
|
||||
return p;
|
||||
}
|
||||
|
||||
@ -593,7 +592,6 @@ SymbolPropertyEntry* SymbolPropertyTable::add_entry(int index, unsigned int hash
|
||||
void SymbolPropertyTable::oops_do(OopClosure* f) {
|
||||
for (int index = 0; index < table_size(); index++) {
|
||||
for (SymbolPropertyEntry* p = bucket(index); p != NULL; p = p->next()) {
|
||||
f->do_oop((oop*) p->symbol_addr());
|
||||
if (p->property_oop() != NULL) {
|
||||
f->do_oop(p->property_oop_addr());
|
||||
}
|
||||
|
@ -36,7 +36,7 @@ class DictionaryEntry;
|
||||
// The data structure for the system dictionary (and the shared system
|
||||
// dictionary).
|
||||
|
||||
class Dictionary : public TwoOopHashtable {
|
||||
class Dictionary : public TwoOopHashtable<klassOop> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
// current iteration index.
|
||||
@ -45,19 +45,19 @@ private:
|
||||
static DictionaryEntry* _current_class_entry;
|
||||
|
||||
DictionaryEntry* get_entry(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader);
|
||||
Symbol* name, Handle loader);
|
||||
|
||||
DictionaryEntry* bucket(int i) {
|
||||
return (DictionaryEntry*)Hashtable::bucket(i);
|
||||
return (DictionaryEntry*)Hashtable<klassOop>::bucket(i);
|
||||
}
|
||||
|
||||
// The following method is not MT-safe and must be done under lock.
|
||||
DictionaryEntry** bucket_addr(int i) {
|
||||
return (DictionaryEntry**)Hashtable::bucket_addr(i);
|
||||
return (DictionaryEntry**)Hashtable<klassOop>::bucket_addr(i);
|
||||
}
|
||||
|
||||
void add_entry(int index, DictionaryEntry* new_entry) {
|
||||
Hashtable::add_entry(index, (HashtableEntry*)new_entry);
|
||||
Hashtable<klassOop>::add_entry(index, (HashtableEntry<oop>*)new_entry);
|
||||
}
|
||||
|
||||
|
||||
@ -71,12 +71,12 @@ public:
|
||||
|
||||
void free_entry(DictionaryEntry* entry);
|
||||
|
||||
void add_klass(symbolHandle class_name, Handle class_loader,KlassHandle obj);
|
||||
void add_klass(Symbol* class_name, Handle class_loader,KlassHandle obj);
|
||||
|
||||
klassOop find_class(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader);
|
||||
Symbol* name, Handle loader);
|
||||
|
||||
klassOop find_shared_class(int index, unsigned int hash, symbolHandle name);
|
||||
klassOop find_shared_class(int index, unsigned int hash, Symbol* name);
|
||||
|
||||
// Compiler support
|
||||
klassOop try_get_next_class();
|
||||
@ -95,7 +95,7 @@ public:
|
||||
|
||||
// Classes loaded by the bootstrap loader are always strongly reachable.
|
||||
// If we're not doing class unloading, all classes are strongly reachable.
|
||||
static bool is_strongly_reachable(oop class_loader, oop klass) {
|
||||
static bool is_strongly_reachable(oop class_loader, klassOop klass) {
|
||||
assert (klass != NULL, "should have non-null klass");
|
||||
return (class_loader == NULL || !ClassUnloading);
|
||||
}
|
||||
@ -105,10 +105,10 @@ public:
|
||||
bool do_unloading(BoolObjectClosure* is_alive);
|
||||
|
||||
// Protection domains
|
||||
klassOop find(int index, unsigned int hash, symbolHandle name,
|
||||
klassOop find(int index, unsigned int hash, Symbol* name,
|
||||
Handle loader, Handle protection_domain, TRAPS);
|
||||
bool is_valid_protection_domain(int index, unsigned int hash,
|
||||
symbolHandle name, Handle class_loader,
|
||||
Symbol* name, Handle class_loader,
|
||||
Handle protection_domain);
|
||||
void add_protection_domain(int index, unsigned int hash,
|
||||
instanceKlassHandle klass, Handle loader,
|
||||
@ -147,7 +147,7 @@ class ProtectionDomainEntry :public CHeapObj {
|
||||
// An entry in the system dictionary, this describes a class as
|
||||
// { klassOop, loader, protection_domain }.
|
||||
|
||||
class DictionaryEntry : public HashtableEntry {
|
||||
class DictionaryEntry : public HashtableEntry<klassOop> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
// Contains the set of approved protection domains that can access
|
||||
@ -166,11 +166,11 @@ class DictionaryEntry : public HashtableEntry {
|
||||
klassOop* klass_addr() { return (klassOop*)literal_addr(); }
|
||||
|
||||
DictionaryEntry* next() const {
|
||||
return (DictionaryEntry*)HashtableEntry::next();
|
||||
return (DictionaryEntry*)HashtableEntry<klassOop>::next();
|
||||
}
|
||||
|
||||
DictionaryEntry** next_addr() {
|
||||
return (DictionaryEntry**)HashtableEntry::next_addr();
|
||||
return (DictionaryEntry**)HashtableEntry<klassOop>::next_addr();
|
||||
}
|
||||
|
||||
oop loader() const { return _loader; }
|
||||
@ -209,7 +209,7 @@ class DictionaryEntry : public HashtableEntry {
|
||||
}
|
||||
}
|
||||
|
||||
bool equals(symbolOop class_name, oop class_loader) const {
|
||||
bool equals(Symbol* class_name, oop class_loader) const {
|
||||
klassOop klass = (klassOop)literal();
|
||||
return (instanceKlass::cast(klass)->name() == class_name &&
|
||||
_loader == class_loader);
|
||||
@ -226,9 +226,9 @@ class DictionaryEntry : public HashtableEntry {
|
||||
}
|
||||
};
|
||||
|
||||
// Entry in a SymbolPropertyTable, mapping a single symbolOop
|
||||
// Entry in a SymbolPropertyTable, mapping a single Symbol*
|
||||
// to a managed and an unmanaged pointer.
|
||||
class SymbolPropertyEntry : public HashtableEntry {
|
||||
class SymbolPropertyEntry : public HashtableEntry<Symbol*> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
intptr_t _symbol_mode; // secondary key
|
||||
@ -236,7 +236,7 @@ class SymbolPropertyEntry : public HashtableEntry {
|
||||
address _property_data;
|
||||
|
||||
public:
|
||||
symbolOop symbol() const { return (symbolOop) literal(); }
|
||||
Symbol* symbol() const { return literal(); }
|
||||
|
||||
intptr_t symbol_mode() const { return _symbol_mode; }
|
||||
void set_symbol_mode(intptr_t m) { _symbol_mode = m; }
|
||||
@ -248,14 +248,13 @@ class SymbolPropertyEntry : public HashtableEntry {
|
||||
void set_property_data(address p) { _property_data = p; }
|
||||
|
||||
SymbolPropertyEntry* next() const {
|
||||
return (SymbolPropertyEntry*)HashtableEntry::next();
|
||||
return (SymbolPropertyEntry*)HashtableEntry<Symbol*>::next();
|
||||
}
|
||||
|
||||
SymbolPropertyEntry** next_addr() {
|
||||
return (SymbolPropertyEntry**)HashtableEntry::next_addr();
|
||||
return (SymbolPropertyEntry**)HashtableEntry<Symbol*>::next_addr();
|
||||
}
|
||||
|
||||
oop* symbol_addr() { return literal_addr(); }
|
||||
oop* property_oop_addr() { return &_property_oop; }
|
||||
|
||||
void print_on(outputStream* st) const {
|
||||
@ -279,16 +278,16 @@ class SymbolPropertyEntry : public HashtableEntry {
|
||||
// A system-internal mapping of symbols to pointers, both managed
|
||||
// and unmanaged. Used to record the auto-generation of each method
|
||||
// MethodHandle.invoke(S)T, for all signatures (S)T.
|
||||
class SymbolPropertyTable : public Hashtable {
|
||||
class SymbolPropertyTable : public Hashtable<Symbol*> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
SymbolPropertyEntry* bucket(int i) {
|
||||
return (SymbolPropertyEntry*) Hashtable::bucket(i);
|
||||
return (SymbolPropertyEntry*) Hashtable<Symbol*>::bucket(i);
|
||||
}
|
||||
|
||||
// The following method is not MT-safe and must be done under lock.
|
||||
SymbolPropertyEntry** bucket_addr(int i) {
|
||||
return (SymbolPropertyEntry**) Hashtable::bucket_addr(i);
|
||||
return (SymbolPropertyEntry**) Hashtable<Symbol*>::bucket_addr(i);
|
||||
}
|
||||
|
||||
void add_entry(int index, SymbolPropertyEntry* new_entry) {
|
||||
@ -298,8 +297,10 @@ private:
|
||||
ShouldNotReachHere();
|
||||
}
|
||||
|
||||
SymbolPropertyEntry* new_entry(unsigned int hash, symbolOop symbol, intptr_t symbol_mode) {
|
||||
SymbolPropertyEntry* entry = (SymbolPropertyEntry*) Hashtable::new_entry(hash, symbol);
|
||||
SymbolPropertyEntry* new_entry(unsigned int hash, Symbol* symbol, intptr_t symbol_mode) {
|
||||
SymbolPropertyEntry* entry = (SymbolPropertyEntry*) Hashtable<Symbol*>::new_entry(hash, symbol);
|
||||
// Hashtable with Symbol* literal must increment and decrement refcount.
|
||||
symbol->increment_refcount();
|
||||
entry->set_symbol_mode(symbol_mode);
|
||||
entry->set_property_oop(NULL);
|
||||
entry->set_property_data(NULL);
|
||||
@ -311,23 +312,25 @@ public:
|
||||
SymbolPropertyTable(int table_size, HashtableBucket* t, int number_of_entries);
|
||||
|
||||
void free_entry(SymbolPropertyEntry* entry) {
|
||||
Hashtable::free_entry(entry);
|
||||
// decrement Symbol refcount here because hashtable doesn't.
|
||||
entry->literal()->decrement_refcount();
|
||||
Hashtable<Symbol*>::free_entry(entry);
|
||||
}
|
||||
|
||||
unsigned int compute_hash(symbolHandle sym, intptr_t symbol_mode) {
|
||||
unsigned int compute_hash(Symbol* sym, intptr_t symbol_mode) {
|
||||
// Use the regular identity_hash.
|
||||
return Hashtable::compute_hash(sym) ^ symbol_mode;
|
||||
return Hashtable<Symbol*>::compute_hash(sym) ^ symbol_mode;
|
||||
}
|
||||
|
||||
int index_for(symbolHandle name, intptr_t symbol_mode) {
|
||||
int index_for(Symbol* name, intptr_t symbol_mode) {
|
||||
return hash_to_index(compute_hash(name, symbol_mode));
|
||||
}
|
||||
|
||||
// need not be locked; no state change
|
||||
SymbolPropertyEntry* find_entry(int index, unsigned int hash, symbolHandle name, intptr_t name_mode);
|
||||
SymbolPropertyEntry* find_entry(int index, unsigned int hash, Symbol* name, intptr_t name_mode);
|
||||
|
||||
// must be done under SystemDictionary_lock
|
||||
SymbolPropertyEntry* add_entry(int index, unsigned int hash, symbolHandle name, intptr_t name_mode);
|
||||
SymbolPropertyEntry* add_entry(int index, unsigned int hash, Symbol* name, intptr_t name_mode);
|
||||
|
||||
// GC support
|
||||
void oops_do(OopClosure* f);
|
||||
@ -343,6 +346,4 @@ public:
|
||||
#endif
|
||||
void verify();
|
||||
};
|
||||
|
||||
|
||||
#endif // SHARE_VM_CLASSFILE_DICTIONARY_HPP
|
||||
|
@ -93,7 +93,7 @@ void JavaAssertions::addOption(const char* name, bool enable) {
|
||||
}
|
||||
|
||||
oop JavaAssertions::createAssertionStatusDirectives(TRAPS) {
|
||||
symbolHandle asd_sym = vmSymbolHandles::java_lang_AssertionStatusDirectives();
|
||||
Symbol* asd_sym = vmSymbols::java_lang_AssertionStatusDirectives();
|
||||
klassOop k = SystemDictionary::resolve_or_fail(asd_sym, true, CHECK_NULL);
|
||||
instanceKlassHandle asd_klass (THREAD, k);
|
||||
asd_klass->initialize(CHECK_NULL);
|
||||
|
@ -36,7 +36,7 @@
|
||||
#include "oops/klass.hpp"
|
||||
#include "oops/klassOop.hpp"
|
||||
#include "oops/methodOop.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
#include "oops/typeArrayOop.hpp"
|
||||
#include "runtime/fieldDescriptor.hpp"
|
||||
#include "runtime/handles.inline.hpp"
|
||||
@ -57,7 +57,7 @@
|
||||
#endif
|
||||
|
||||
static bool find_field(instanceKlass* ik,
|
||||
symbolOop name_symbol, symbolOop signature_symbol,
|
||||
Symbol* name_symbol, Symbol* signature_symbol,
|
||||
fieldDescriptor* fd,
|
||||
bool allow_super = false) {
|
||||
if (allow_super)
|
||||
@ -69,7 +69,7 @@ static bool find_field(instanceKlass* ik,
|
||||
// Helpful routine for computing field offsets at run time rather than hardcoding them
|
||||
static void
|
||||
compute_offset(int &dest_offset,
|
||||
klassOop klass_oop, symbolOop name_symbol, symbolOop signature_symbol,
|
||||
klassOop klass_oop, Symbol* name_symbol, Symbol* signature_symbol,
|
||||
bool allow_super = false) {
|
||||
fieldDescriptor fd;
|
||||
instanceKlass* ik = instanceKlass::cast(klass_oop);
|
||||
@ -84,7 +84,7 @@ compute_offset(int &dest_offset,
|
||||
// Same as above but for "optional" offsets that might not be present in certain JDK versions
|
||||
static void
|
||||
compute_optional_offset(int& dest_offset,
|
||||
klassOop klass_oop, symbolOop name_symbol, symbolOop signature_symbol,
|
||||
klassOop klass_oop, Symbol* name_symbol, Symbol* signature_symbol,
|
||||
bool allow_super = false) {
|
||||
fieldDescriptor fd;
|
||||
instanceKlass* ik = instanceKlass::cast(klass_oop);
|
||||
@ -164,7 +164,7 @@ oop java_lang_String::create_oop_from_str(const char* utf8_str, TRAPS) {
|
||||
return h_obj();
|
||||
}
|
||||
|
||||
Handle java_lang_String::create_from_symbol(symbolHandle symbol, TRAPS) {
|
||||
Handle java_lang_String::create_from_symbol(Symbol* symbol, TRAPS) {
|
||||
int length = UTF8::unicode_length((char*)symbol->bytes(), symbol->utf8_length());
|
||||
Handle h_obj = basic_create(length, false, CHECK_NH);
|
||||
if (length > 0) {
|
||||
@ -278,17 +278,17 @@ jchar* java_lang_String::as_unicode_string(oop java_string, int& length) {
|
||||
return result;
|
||||
}
|
||||
|
||||
symbolHandle java_lang_String::as_symbol(Handle java_string, TRAPS) {
|
||||
Symbol* java_lang_String::as_symbol(Handle java_string, TRAPS) {
|
||||
oop obj = java_string();
|
||||
typeArrayOop value = java_lang_String::value(obj);
|
||||
int offset = java_lang_String::offset(obj);
|
||||
int length = java_lang_String::length(obj);
|
||||
jchar* base = (length == 0) ? NULL : value->char_at_addr(offset);
|
||||
symbolOop sym = SymbolTable::lookup_unicode(base, length, THREAD);
|
||||
return symbolHandle(THREAD, sym);
|
||||
Symbol* sym = SymbolTable::lookup_unicode(base, length, THREAD);
|
||||
return sym;
|
||||
}
|
||||
|
||||
symbolOop java_lang_String::as_symbol_or_null(oop java_string) {
|
||||
Symbol* java_lang_String::as_symbol_or_null(oop java_string) {
|
||||
typeArrayOop value = java_lang_String::value(java_string);
|
||||
int offset = java_lang_String::offset(java_string);
|
||||
int length = java_lang_String::length(java_string);
|
||||
@ -437,7 +437,7 @@ klassOop java_lang_Class::as_klassOop(oop java_class) {
|
||||
|
||||
void java_lang_Class::print_signature(oop java_class, outputStream* st) {
|
||||
assert(java_lang_Class::is_instance(java_class), "must be a Class object");
|
||||
symbolOop name = NULL;
|
||||
Symbol* name = NULL;
|
||||
bool is_instance = false;
|
||||
if (is_primitive(java_class)) {
|
||||
name = vmSymbols::type_signature(primitive_type(java_class));
|
||||
@ -455,25 +455,32 @@ void java_lang_Class::print_signature(oop java_class, outputStream* st) {
|
||||
if (is_instance) st->print(";");
|
||||
}
|
||||
|
||||
symbolOop java_lang_Class::as_signature(oop java_class, bool intern_if_not_found, TRAPS) {
|
||||
Symbol* java_lang_Class::as_signature(oop java_class, bool intern_if_not_found, TRAPS) {
|
||||
assert(java_lang_Class::is_instance(java_class), "must be a Class object");
|
||||
symbolOop name = NULL;
|
||||
Symbol* name;
|
||||
if (is_primitive(java_class)) {
|
||||
return vmSymbols::type_signature(primitive_type(java_class));
|
||||
name = vmSymbols::type_signature(primitive_type(java_class));
|
||||
// Because this can create a new symbol, the caller has to decrement
|
||||
// the refcount, so make adjustment here and below for symbols returned
|
||||
// that are not created or incremented due to a successful lookup.
|
||||
name->increment_refcount();
|
||||
} else {
|
||||
klassOop k = as_klassOop(java_class);
|
||||
if (!Klass::cast(k)->oop_is_instance()) {
|
||||
return Klass::cast(k)->name();
|
||||
name = Klass::cast(k)->name();
|
||||
name->increment_refcount();
|
||||
} else {
|
||||
ResourceMark rm;
|
||||
const char* sigstr = Klass::cast(k)->signature_name();
|
||||
int siglen = (int) strlen(sigstr);
|
||||
if (!intern_if_not_found)
|
||||
return SymbolTable::probe(sigstr, siglen);
|
||||
else
|
||||
return oopFactory::new_symbol(sigstr, siglen, THREAD);
|
||||
if (!intern_if_not_found) {
|
||||
name = SymbolTable::probe(sigstr, siglen);
|
||||
} else {
|
||||
name = SymbolTable::new_symbol(sigstr, siglen, THREAD);
|
||||
}
|
||||
}
|
||||
}
|
||||
return name;
|
||||
}
|
||||
|
||||
|
||||
@ -1022,8 +1029,8 @@ void java_lang_Throwable::print_to_stream(Handle stream, const char* str) {
|
||||
JavaCalls::call_virtual(&result,
|
||||
stream,
|
||||
KlassHandle(THREAD, stream->klass()),
|
||||
vmSymbolHandles::println_name(),
|
||||
vmSymbolHandles::char_array_void_signature(),
|
||||
vmSymbols::println_name(),
|
||||
vmSymbols::char_array_void_signature(),
|
||||
arg,
|
||||
THREAD);
|
||||
}
|
||||
@ -1077,8 +1084,8 @@ void java_lang_Throwable::print_stack_trace(oop throwable, outputStream* st) {
|
||||
JavaCalls::call_virtual(&result,
|
||||
h_throwable,
|
||||
KlassHandle(THREAD, h_throwable->klass()),
|
||||
vmSymbolHandles::getCause_name(),
|
||||
vmSymbolHandles::void_throwable_signature(),
|
||||
vmSymbols::getCause_name(),
|
||||
vmSymbols::void_throwable_signature(),
|
||||
THREAD);
|
||||
// Ignore any exceptions. we are in the middle of exception handling. Same as classic VM.
|
||||
if (HAS_PENDING_EXCEPTION) {
|
||||
@ -1516,7 +1523,7 @@ oop java_lang_StackTraceElement::create(methodHandle method, int bci, TRAPS) {
|
||||
oop methodname = StringTable::intern(method->name(), CHECK_0);
|
||||
java_lang_StackTraceElement::set_methodName(element(), methodname);
|
||||
// Fill in source file name
|
||||
symbolOop source = instanceKlass::cast(method->method_holder())->source_file_name();
|
||||
Symbol* source = instanceKlass::cast(method->method_holder())->source_file_name();
|
||||
oop filename = StringTable::intern(source, CHECK_0);
|
||||
java_lang_StackTraceElement::set_fileName(element(), filename);
|
||||
// File in source line number
|
||||
@ -1732,7 +1739,7 @@ void java_lang_reflect_Constructor::compute_offsets() {
|
||||
|
||||
Handle java_lang_reflect_Constructor::create(TRAPS) {
|
||||
assert(Universe::is_fully_initialized(), "Need to find another solution to the reflection problem");
|
||||
symbolHandle name = vmSymbolHandles::java_lang_reflect_Constructor();
|
||||
Symbol* name = vmSymbols::java_lang_reflect_Constructor();
|
||||
klassOop k = SystemDictionary::resolve_or_fail(name, true, CHECK_NH);
|
||||
instanceKlassHandle klass (THREAD, k);
|
||||
// Ensure it is initialized
|
||||
@ -1854,7 +1861,7 @@ void java_lang_reflect_Field::compute_offsets() {
|
||||
|
||||
Handle java_lang_reflect_Field::create(TRAPS) {
|
||||
assert(Universe::is_fully_initialized(), "Need to find another solution to the reflection problem");
|
||||
symbolHandle name = vmSymbolHandles::java_lang_reflect_Field();
|
||||
Symbol* name = vmSymbols::java_lang_reflect_Field();
|
||||
klassOop k = SystemDictionary::resolve_or_fail(name, true, CHECK_NH);
|
||||
instanceKlassHandle klass (THREAD, k);
|
||||
// Ensure it is initialized
|
||||
@ -2422,16 +2429,19 @@ void java_dyn_MethodType::print_signature(oop mt, outputStream* st) {
|
||||
java_lang_Class::print_signature(rtype(mt), st);
|
||||
}
|
||||
|
||||
symbolOop java_dyn_MethodType::as_signature(oop mt, bool intern_if_not_found, TRAPS) {
|
||||
Symbol* java_dyn_MethodType::as_signature(oop mt, bool intern_if_not_found, TRAPS) {
|
||||
ResourceMark rm;
|
||||
stringStream buffer(128);
|
||||
print_signature(mt, &buffer);
|
||||
const char* sigstr = buffer.base();
|
||||
int siglen = (int) buffer.size();
|
||||
if (!intern_if_not_found)
|
||||
return SymbolTable::probe(sigstr, siglen);
|
||||
else
|
||||
return oopFactory::new_symbol(sigstr, siglen, THREAD);
|
||||
Symbol *name;
|
||||
if (!intern_if_not_found) {
|
||||
name = SymbolTable::probe(sigstr, siglen);
|
||||
} else {
|
||||
name = SymbolTable::new_symbol(sigstr, siglen, THREAD);
|
||||
}
|
||||
return name;
|
||||
}
|
||||
|
||||
oop java_dyn_MethodType::rtype(oop mt) {
|
||||
@ -2908,13 +2918,12 @@ void JavaClasses::compute_offsets() {
|
||||
bool JavaClasses::check_offset(const char *klass_name, int hardcoded_offset, const char *field_name, const char* field_sig) {
|
||||
EXCEPTION_MARK;
|
||||
fieldDescriptor fd;
|
||||
symbolHandle klass_sym = oopFactory::new_symbol_handle(klass_name, CATCH);
|
||||
TempNewSymbol klass_sym = SymbolTable::new_symbol(klass_name, CATCH);
|
||||
klassOop k = SystemDictionary::resolve_or_fail(klass_sym, true, CATCH);
|
||||
instanceKlassHandle h_klass (THREAD, k);
|
||||
//instanceKlassHandle h_klass(klass);
|
||||
symbolHandle f_name = oopFactory::new_symbol_handle(field_name, CATCH);
|
||||
symbolHandle f_sig = oopFactory::new_symbol_handle(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name(), f_sig(), &fd)) {
|
||||
TempNewSymbol f_name = SymbolTable::new_symbol(field_name, CATCH);
|
||||
TempNewSymbol f_sig = SymbolTable::new_symbol(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name, f_sig, &fd)) {
|
||||
tty->print_cr("Nonstatic field %s.%s not found", klass_name, field_name);
|
||||
return false;
|
||||
}
|
||||
@ -2935,12 +2944,12 @@ bool JavaClasses::check_offset(const char *klass_name, int hardcoded_offset, con
|
||||
bool JavaClasses::check_static_offset(const char *klass_name, int hardcoded_offset, const char *field_name, const char* field_sig) {
|
||||
EXCEPTION_MARK;
|
||||
fieldDescriptor fd;
|
||||
symbolHandle klass_sym = oopFactory::new_symbol_handle(klass_name, CATCH);
|
||||
TempNewSymbol klass_sym = SymbolTable::new_symbol(klass_name, CATCH);
|
||||
klassOop k = SystemDictionary::resolve_or_fail(klass_sym, true, CATCH);
|
||||
instanceKlassHandle h_klass (THREAD, k);
|
||||
symbolHandle f_name = oopFactory::new_symbol_handle(field_name, CATCH);
|
||||
symbolHandle f_sig = oopFactory::new_symbol_handle(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name(), f_sig(), &fd)) {
|
||||
TempNewSymbol f_name = SymbolTable::new_symbol(field_name, CATCH);
|
||||
TempNewSymbol f_sig = SymbolTable::new_symbol(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name, f_sig, &fd)) {
|
||||
tty->print_cr("Static field %s.%s not found", klass_name, field_name);
|
||||
return false;
|
||||
}
|
||||
@ -2960,12 +2969,12 @@ bool JavaClasses::check_static_offset(const char *klass_name, int hardcoded_offs
|
||||
bool JavaClasses::check_constant(const char *klass_name, int hardcoded_constant, const char *field_name, const char* field_sig) {
|
||||
EXCEPTION_MARK;
|
||||
fieldDescriptor fd;
|
||||
symbolHandle klass_sym = oopFactory::new_symbol_handle(klass_name, CATCH);
|
||||
TempNewSymbol klass_sym = SymbolTable::new_symbol(klass_name, CATCH);
|
||||
klassOop k = SystemDictionary::resolve_or_fail(klass_sym, true, CATCH);
|
||||
instanceKlassHandle h_klass (THREAD, k);
|
||||
symbolHandle f_name = oopFactory::new_symbol_handle(field_name, CATCH);
|
||||
symbolHandle f_sig = oopFactory::new_symbol_handle(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name(), f_sig(), &fd)) {
|
||||
TempNewSymbol f_name = SymbolTable::new_symbol(field_name, CATCH);
|
||||
TempNewSymbol f_sig = SymbolTable::new_symbol(field_sig, CATCH);
|
||||
if (!h_klass->find_local_field(f_name, f_sig, &fd)) {
|
||||
tty->print_cr("Static field %s.%s not found", klass_name, field_name);
|
||||
return false;
|
||||
}
|
||||
|
@ -78,7 +78,7 @@ class java_lang_String : AllStatic {
|
||||
static oop create_oop_from_unicode(jchar* unicode, int len, TRAPS);
|
||||
static Handle create_from_str(const char* utf8_str, TRAPS);
|
||||
static oop create_oop_from_str(const char* utf8_str, TRAPS);
|
||||
static Handle create_from_symbol(symbolHandle symbol, TRAPS);
|
||||
static Handle create_from_symbol(Symbol* symbol, TRAPS);
|
||||
static Handle create_from_platform_dependent_str(const char* str, TRAPS);
|
||||
static Handle char_converter(Handle java_string, jchar from_char, jchar to_char, TRAPS);
|
||||
|
||||
@ -116,8 +116,8 @@ class java_lang_String : AllStatic {
|
||||
static Handle internalize_classname(Handle java_string, TRAPS) { return char_converter(java_string, '.', '/', THREAD); }
|
||||
|
||||
// Conversion
|
||||
static symbolHandle as_symbol(Handle java_string, TRAPS);
|
||||
static symbolOop as_symbol_or_null(oop java_string);
|
||||
static Symbol* as_symbol(Handle java_string, TRAPS);
|
||||
static Symbol* as_symbol_or_null(oop java_string);
|
||||
|
||||
// Testers
|
||||
static bool is_instance(oop obj) {
|
||||
@ -167,7 +167,7 @@ class java_lang_Class : AllStatic {
|
||||
(*reference_klass) = KlassHandle(refk_oop);
|
||||
return result;
|
||||
}
|
||||
static symbolOop as_signature(oop java_class, bool intern_if_not_found, TRAPS);
|
||||
static Symbol* as_signature(oop java_class, bool intern_if_not_found, TRAPS);
|
||||
static void print_signature(oop java_class, outputStream *st);
|
||||
// Testing
|
||||
static bool is_instance(oop obj) {
|
||||
@ -1039,7 +1039,7 @@ class java_dyn_MethodType: AllStatic {
|
||||
static oop ptype(oop mt, int index);
|
||||
static int ptype_count(oop mt);
|
||||
|
||||
static symbolOop as_signature(oop mt, bool intern_if_not_found, TRAPS);
|
||||
static Symbol* as_signature(oop mt, bool intern_if_not_found, TRAPS);
|
||||
static void print_signature(oop mt, outputStream* st);
|
||||
|
||||
static bool is_instance(oop obj) {
|
||||
|
@ -31,28 +31,33 @@
|
||||
#include "utilities/hashtable.inline.hpp"
|
||||
|
||||
LoaderConstraintTable::LoaderConstraintTable(int nof_buckets)
|
||||
: Hashtable(nof_buckets, sizeof(LoaderConstraintEntry)) {};
|
||||
: Hashtable<klassOop>(nof_buckets, sizeof(LoaderConstraintEntry)) {};
|
||||
|
||||
|
||||
LoaderConstraintEntry* LoaderConstraintTable::new_entry(
|
||||
unsigned int hash, symbolOop name,
|
||||
unsigned int hash, Symbol* name,
|
||||
klassOop klass, int num_loaders,
|
||||
int max_loaders) {
|
||||
LoaderConstraintEntry* entry;
|
||||
entry = (LoaderConstraintEntry*)Hashtable::new_entry(hash, klass);
|
||||
entry = (LoaderConstraintEntry*)Hashtable<klassOop>::new_entry(hash, klass);
|
||||
entry->set_name(name);
|
||||
entry->set_num_loaders(num_loaders);
|
||||
entry->set_max_loaders(max_loaders);
|
||||
return entry;
|
||||
}
|
||||
|
||||
void LoaderConstraintTable::free_entry(LoaderConstraintEntry *entry) {
|
||||
// decrement name refcount before freeing
|
||||
entry->name()->decrement_refcount();
|
||||
Hashtable<klassOop>::free_entry(entry);
|
||||
}
|
||||
|
||||
|
||||
void LoaderConstraintTable::oops_do(OopClosure* f) {
|
||||
for (int index = 0; index < table_size(); index++) {
|
||||
for (LoaderConstraintEntry* probe = bucket(index);
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
f->do_oop((oop*)(probe->name_addr()));
|
||||
if (probe->klass() != NULL) {
|
||||
f->do_oop((oop*)probe->klass_addr());
|
||||
}
|
||||
@ -65,27 +70,13 @@ void LoaderConstraintTable::oops_do(OopClosure* f) {
|
||||
}
|
||||
}
|
||||
|
||||
// We must keep the symbolOop used in the name alive. We'll use the
|
||||
// loaders to decide if a particular entry can be purged.
|
||||
void LoaderConstraintTable::always_strong_classes_do(OopClosure* blk) {
|
||||
// We must keep the symbolOop used in the name alive.
|
||||
for (int cindex = 0; cindex < table_size(); cindex++) {
|
||||
for (LoaderConstraintEntry* lc_probe = bucket(cindex);
|
||||
lc_probe != NULL;
|
||||
lc_probe = lc_probe->next()) {
|
||||
assert (lc_probe->name() != NULL, "corrupted loader constraint table");
|
||||
blk->do_oop((oop*)lc_probe->name_addr());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
// The loaderConstraintTable must always be accessed with the
|
||||
// SystemDictionary lock held. This is true even for readers as
|
||||
// entries in the table could be being dynamically resized.
|
||||
|
||||
LoaderConstraintEntry** LoaderConstraintTable::find_loader_constraint(
|
||||
symbolHandle name, Handle loader) {
|
||||
Symbol* name, Handle loader) {
|
||||
|
||||
unsigned int hash = compute_hash(name);
|
||||
int index = hash_to_index(hash);
|
||||
@ -93,7 +84,7 @@ LoaderConstraintEntry** LoaderConstraintTable::find_loader_constraint(
|
||||
while (*pp) {
|
||||
LoaderConstraintEntry* p = *pp;
|
||||
if (p->hash() == hash) {
|
||||
if (p->name() == name()) {
|
||||
if (p->name() == name) {
|
||||
for (int i = p->num_loaders() - 1; i >= 0; i--) {
|
||||
if (p->loader(i) == loader()) {
|
||||
return pp;
|
||||
@ -177,7 +168,6 @@ void LoaderConstraintTable::purge_loader_constraints(BoolObjectClosure* is_alive
|
||||
free_entry(probe);
|
||||
} else {
|
||||
#ifdef ASSERT
|
||||
assert(is_alive->do_object_b(probe->name()), "name should be live");
|
||||
if (probe->klass() != NULL) {
|
||||
assert(is_alive->do_object_b(probe->klass()), "klass should be live");
|
||||
}
|
||||
@ -194,7 +184,7 @@ void LoaderConstraintTable::purge_loader_constraints(BoolObjectClosure* is_alive
|
||||
}
|
||||
}
|
||||
|
||||
bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
bool LoaderConstraintTable::add_entry(Symbol* class_name,
|
||||
klassOop klass1, Handle class_loader1,
|
||||
klassOop klass2, Handle class_loader2) {
|
||||
int failure_code = 0; // encode different reasons for failing
|
||||
@ -233,7 +223,7 @@ bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
unsigned int hash = compute_hash(class_name);
|
||||
int index = hash_to_index(hash);
|
||||
LoaderConstraintEntry* p;
|
||||
p = new_entry(hash, class_name(), klass, 2, 2);
|
||||
p = new_entry(hash, class_name, klass, 2, 2);
|
||||
p->set_loaders(NEW_C_HEAP_ARRAY(oop, 2));
|
||||
p->set_loader(0, class_loader1());
|
||||
p->set_loader(1, class_loader2());
|
||||
@ -244,7 +234,7 @@ bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
ResourceMark rm;
|
||||
tty->print("[Adding new constraint for name: %s, loader[0]: %s,"
|
||||
" loader[1]: %s ]\n",
|
||||
class_name()->as_C_string(),
|
||||
class_name->as_C_string(),
|
||||
SystemDictionary::loader_name(class_loader1()),
|
||||
SystemDictionary::loader_name(class_loader2())
|
||||
);
|
||||
@ -257,7 +247,7 @@ bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
ResourceMark rm;
|
||||
tty->print("[Setting class object in existing constraint for"
|
||||
" name: %s and loader %s ]\n",
|
||||
class_name()->as_C_string(),
|
||||
class_name->as_C_string(),
|
||||
SystemDictionary::loader_name(class_loader1())
|
||||
);
|
||||
}
|
||||
@ -288,7 +278,7 @@ bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
}
|
||||
tty->print("[Failed to add constraint for name: %s, loader[0]: %s,"
|
||||
" loader[1]: %s, Reason: %s ]\n",
|
||||
class_name()->as_C_string(),
|
||||
class_name->as_C_string(),
|
||||
SystemDictionary::loader_name(class_loader1()),
|
||||
SystemDictionary::loader_name(class_loader2()),
|
||||
reason
|
||||
@ -303,14 +293,14 @@ bool LoaderConstraintTable::add_entry(symbolHandle class_name,
|
||||
// violated
|
||||
bool LoaderConstraintTable::check_or_update(instanceKlassHandle k,
|
||||
Handle loader,
|
||||
symbolHandle name) {
|
||||
Symbol* name) {
|
||||
LoaderConstraintEntry* p = *(find_loader_constraint(name, loader));
|
||||
if (p && p->klass() != NULL && p->klass() != k()) {
|
||||
if (TraceLoaderConstraints) {
|
||||
ResourceMark rm;
|
||||
tty->print("[Constraint check failed for name %s, loader %s: "
|
||||
"the presented class object differs from that stored ]\n",
|
||||
name()->as_C_string(),
|
||||
name->as_C_string(),
|
||||
SystemDictionary::loader_name(loader()));
|
||||
}
|
||||
return false;
|
||||
@ -321,7 +311,7 @@ bool LoaderConstraintTable::check_or_update(instanceKlassHandle k,
|
||||
ResourceMark rm;
|
||||
tty->print("[Updating constraint for name %s, loader %s, "
|
||||
"by setting class object ]\n",
|
||||
name()->as_C_string(),
|
||||
name->as_C_string(),
|
||||
SystemDictionary::loader_name(loader()));
|
||||
}
|
||||
}
|
||||
@ -329,7 +319,7 @@ bool LoaderConstraintTable::check_or_update(instanceKlassHandle k,
|
||||
}
|
||||
}
|
||||
|
||||
klassOop LoaderConstraintTable::find_constrained_klass(symbolHandle name,
|
||||
klassOop LoaderConstraintTable::find_constrained_klass(Symbol* name,
|
||||
Handle loader) {
|
||||
LoaderConstraintEntry *p = *(find_loader_constraint(name, loader));
|
||||
if (p != NULL && p->klass() != NULL)
|
||||
@ -442,11 +432,10 @@ void LoaderConstraintTable::verify(Dictionary* dictionary,
|
||||
for (LoaderConstraintEntry* probe = bucket(cindex);
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
guarantee(probe->name()->is_symbol(), "should be symbol");
|
||||
if (probe->klass() != NULL) {
|
||||
instanceKlass* ik = instanceKlass::cast(probe->klass());
|
||||
guarantee(ik->name() == probe->name(), "name should match");
|
||||
symbolHandle name (thread, ik->name());
|
||||
Symbol* name = ik->name();
|
||||
Handle loader(thread, ik->class_loader());
|
||||
unsigned int d_hash = dictionary->compute_hash(name, loader);
|
||||
int d_index = dictionary->hash_to_index(d_hash);
|
||||
|
@ -31,7 +31,7 @@
|
||||
|
||||
class LoaderConstraintEntry;
|
||||
|
||||
class LoaderConstraintTable : public Hashtable {
|
||||
class LoaderConstraintTable : public Hashtable<klassOop> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
|
||||
@ -40,39 +40,39 @@ private:
|
||||
_nof_buckets = 1009 // number of buckets in hash table
|
||||
};
|
||||
|
||||
LoaderConstraintEntry** find_loader_constraint(symbolHandle name,
|
||||
LoaderConstraintEntry** find_loader_constraint(Symbol* name,
|
||||
Handle loader);
|
||||
|
||||
public:
|
||||
|
||||
LoaderConstraintTable(int nof_buckets);
|
||||
|
||||
LoaderConstraintEntry* new_entry(unsigned int hash, symbolOop name,
|
||||
LoaderConstraintEntry* new_entry(unsigned int hash, Symbol* name,
|
||||
klassOop klass, int num_loaders,
|
||||
int max_loaders);
|
||||
void free_entry(LoaderConstraintEntry *entry);
|
||||
|
||||
LoaderConstraintEntry* bucket(int i) {
|
||||
return (LoaderConstraintEntry*)Hashtable::bucket(i);
|
||||
return (LoaderConstraintEntry*)Hashtable<klassOop>::bucket(i);
|
||||
}
|
||||
|
||||
LoaderConstraintEntry** bucket_addr(int i) {
|
||||
return (LoaderConstraintEntry**)Hashtable::bucket_addr(i);
|
||||
return (LoaderConstraintEntry**)Hashtable<klassOop>::bucket_addr(i);
|
||||
}
|
||||
|
||||
// GC support
|
||||
void oops_do(OopClosure* f);
|
||||
void always_strong_classes_do(OopClosure* blk);
|
||||
|
||||
// Check class loader constraints
|
||||
bool add_entry(symbolHandle name, klassOop klass1, Handle loader1,
|
||||
bool add_entry(Symbol* name, klassOop klass1, Handle loader1,
|
||||
klassOop klass2, Handle loader2);
|
||||
|
||||
// Note: The main entry point for this module is via SystemDictionary.
|
||||
// SystemDictionary::check_signature_loaders(symbolHandle signature,
|
||||
// SystemDictionary::check_signature_loaders(Symbol* signature,
|
||||
// Handle loader1, Handle loader2,
|
||||
// bool is_method, TRAPS)
|
||||
|
||||
klassOop find_constrained_klass(symbolHandle name, Handle loader);
|
||||
klassOop find_constrained_klass(Symbol* name, Handle loader);
|
||||
|
||||
// Class loader constraints
|
||||
|
||||
@ -83,7 +83,7 @@ public:
|
||||
LoaderConstraintEntry** pp2, klassOop klass);
|
||||
|
||||
bool check_or_update(instanceKlassHandle k, Handle loader,
|
||||
symbolHandle name);
|
||||
Symbol* name);
|
||||
|
||||
|
||||
void purge_loader_constraints(BoolObjectClosure* is_alive);
|
||||
@ -94,34 +94,36 @@ public:
|
||||
#endif
|
||||
};
|
||||
|
||||
class LoaderConstraintEntry : public HashtableEntry {
|
||||
class LoaderConstraintEntry : public HashtableEntry<klassOop> {
|
||||
friend class VMStructs;
|
||||
private:
|
||||
symbolOop _name; // class name
|
||||
Symbol* _name; // class name
|
||||
int _num_loaders;
|
||||
int _max_loaders;
|
||||
oop* _loaders; // initiating loaders
|
||||
|
||||
public:
|
||||
|
||||
klassOop klass() { return (klassOop)literal(); }
|
||||
klassOop* klass_addr() { return (klassOop*)literal_addr(); }
|
||||
klassOop klass() { return literal(); }
|
||||
klassOop* klass_addr() { return literal_addr(); }
|
||||
void set_klass(klassOop k) { set_literal(k); }
|
||||
|
||||
LoaderConstraintEntry* next() {
|
||||
return (LoaderConstraintEntry*)HashtableEntry::next();
|
||||
return (LoaderConstraintEntry*)HashtableEntry<klassOop>::next();
|
||||
}
|
||||
|
||||
LoaderConstraintEntry** next_addr() {
|
||||
return (LoaderConstraintEntry**)HashtableEntry::next_addr();
|
||||
return (LoaderConstraintEntry**)HashtableEntry<klassOop>::next_addr();
|
||||
}
|
||||
void set_next(LoaderConstraintEntry* next) {
|
||||
HashtableEntry::set_next(next);
|
||||
HashtableEntry<klassOop>::set_next(next);
|
||||
}
|
||||
|
||||
symbolOop name() { return _name; }
|
||||
symbolOop* name_addr() { return &_name; }
|
||||
void set_name(symbolOop name) { _name = name; }
|
||||
Symbol* name() { return _name; }
|
||||
void set_name(Symbol* name) {
|
||||
_name = name;
|
||||
if (name != NULL) name->increment_refcount();
|
||||
}
|
||||
|
||||
int num_loaders() { return _num_loaders; }
|
||||
void set_num_loaders(int i) { _num_loaders = i; }
|
||||
|
@ -31,10 +31,12 @@
|
||||
|
||||
// Placeholder methods
|
||||
|
||||
PlaceholderEntry* PlaceholderTable::new_entry(int hash, symbolOop name,
|
||||
PlaceholderEntry* PlaceholderTable::new_entry(int hash, Symbol* name,
|
||||
oop loader, bool havesupername,
|
||||
symbolOop supername) {
|
||||
PlaceholderEntry* entry = (PlaceholderEntry*)Hashtable::new_entry(hash, name);
|
||||
Symbol* supername) {
|
||||
PlaceholderEntry* entry = (PlaceholderEntry*)Hashtable<Symbol*>::new_entry(hash, name);
|
||||
// Hashtable with Symbol* literal must increment and decrement refcount.
|
||||
name->increment_refcount();
|
||||
entry->set_loader(loader);
|
||||
entry->set_havesupername(havesupername);
|
||||
entry->set_supername(supername);
|
||||
@ -46,33 +48,40 @@ PlaceholderEntry* PlaceholderTable::new_entry(int hash, symbolOop name,
|
||||
return entry;
|
||||
}
|
||||
|
||||
void PlaceholderTable::free_entry(PlaceholderEntry* entry) {
|
||||
// decrement Symbol refcount here because Hashtable doesn't.
|
||||
entry->literal()->decrement_refcount();
|
||||
if (entry->supername() != NULL) entry->supername()->decrement_refcount();
|
||||
Hashtable<Symbol*>::free_entry(entry);
|
||||
}
|
||||
|
||||
|
||||
// Placeholder objects represent classes currently being loaded.
|
||||
// All threads examining the placeholder table must hold the
|
||||
// SystemDictionary_lock, so we don't need special precautions
|
||||
// on store ordering here.
|
||||
void PlaceholderTable::add_entry(int index, unsigned int hash,
|
||||
symbolHandle class_name, Handle class_loader,
|
||||
bool havesupername, symbolHandle supername){
|
||||
Symbol* class_name, Handle class_loader,
|
||||
bool havesupername, Symbol* supername){
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
assert(!class_name.is_null(), "adding NULL obj");
|
||||
assert(class_name != NULL, "adding NULL obj");
|
||||
|
||||
// Both readers and writers are locked so it's safe to just
|
||||
// create the placeholder and insert it in the list without a membar.
|
||||
PlaceholderEntry* entry = new_entry(hash, class_name(), class_loader(), havesupername, supername());
|
||||
PlaceholderEntry* entry = new_entry(hash, class_name, class_loader(), havesupername, supername);
|
||||
add_entry(index, entry);
|
||||
}
|
||||
|
||||
|
||||
// Remove a placeholder object.
|
||||
void PlaceholderTable::remove_entry(int index, unsigned int hash,
|
||||
symbolHandle class_name,
|
||||
Symbol* class_name,
|
||||
Handle class_loader) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
PlaceholderEntry** p = bucket_addr(index);
|
||||
while (*p) {
|
||||
PlaceholderEntry *probe = *p;
|
||||
if (probe->hash() == hash && probe->equals(class_name(), class_loader())) {
|
||||
if (probe->hash() == hash && probe->equals(class_name, class_loader())) {
|
||||
// Delete entry
|
||||
*p = probe->next();
|
||||
free_entry(probe);
|
||||
@ -83,29 +92,28 @@ void PlaceholderTable::remove_entry(int index, unsigned int hash,
|
||||
}
|
||||
|
||||
PlaceholderEntry* PlaceholderTable::get_entry(int index, unsigned int hash,
|
||||
symbolHandle class_name,
|
||||
Symbol* class_name,
|
||||
Handle class_loader) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
|
||||
symbolOop class_name_ = class_name();
|
||||
oop class_loader_ = class_loader();
|
||||
|
||||
for (PlaceholderEntry *place_probe = bucket(index);
|
||||
place_probe != NULL;
|
||||
place_probe = place_probe->next()) {
|
||||
if (place_probe->hash() == hash &&
|
||||
place_probe->equals(class_name_, class_loader_)) {
|
||||
place_probe->equals(class_name, class_loader_)) {
|
||||
return place_probe;
|
||||
}
|
||||
}
|
||||
return NULL;
|
||||
}
|
||||
|
||||
symbolOop PlaceholderTable::find_entry(int index, unsigned int hash,
|
||||
symbolHandle class_name,
|
||||
Symbol* PlaceholderTable::find_entry(int index, unsigned int hash,
|
||||
Symbol* class_name,
|
||||
Handle class_loader) {
|
||||
PlaceholderEntry* probe = get_entry(index, hash, class_name, class_loader);
|
||||
return (probe? probe->klass(): symbolOop(NULL));
|
||||
return (probe? probe->klassname(): (Symbol*)NULL);
|
||||
}
|
||||
|
||||
// find_and_add returns probe pointer - old or new
|
||||
@ -113,7 +121,7 @@ symbolOop PlaceholderTable::find_entry(int index, unsigned int hash,
|
||||
// If entry exists, reuse entry
|
||||
// For both, push SeenThread for classloadAction
|
||||
// if havesupername: this is used for circularity for instanceklass loading
|
||||
PlaceholderEntry* PlaceholderTable::find_and_add(int index, unsigned int hash, symbolHandle name, Handle loader, classloadAction action, symbolHandle supername, Thread* thread) {
|
||||
PlaceholderEntry* PlaceholderTable::find_and_add(int index, unsigned int hash, Symbol* name, Handle loader, classloadAction action, Symbol* supername, Thread* thread) {
|
||||
PlaceholderEntry* probe = get_entry(index, hash, name, loader);
|
||||
if (probe == NULL) {
|
||||
// Nothing found, add place holder
|
||||
@ -122,7 +130,7 @@ PlaceholderEntry* PlaceholderTable::find_and_add(int index, unsigned int hash, s
|
||||
} else {
|
||||
if (action == LOAD_SUPER) {
|
||||
probe->set_havesupername(true);
|
||||
probe->set_supername(supername());
|
||||
probe->set_supername(supername);
|
||||
}
|
||||
}
|
||||
if (probe) probe->add_seen_thread(thread, action);
|
||||
@ -145,7 +153,7 @@ PlaceholderEntry* PlaceholderTable::find_and_add(int index, unsigned int hash, s
|
||||
// Therefore - must always check SD first
|
||||
// Ignores the case where entry is not found
|
||||
void PlaceholderTable::find_and_remove(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader, Thread* thread) {
|
||||
Symbol* name, Handle loader, Thread* thread) {
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
PlaceholderEntry *probe = get_entry(index, hash, name, loader);
|
||||
if (probe != NULL) {
|
||||
@ -158,7 +166,7 @@ void PlaceholderTable::find_and_remove(int index, unsigned int hash,
|
||||
}
|
||||
|
||||
PlaceholderTable::PlaceholderTable(int table_size)
|
||||
: TwoOopHashtable(table_size, sizeof(PlaceholderEntry)) {
|
||||
: TwoOopHashtable<Symbol*>(table_size, sizeof(PlaceholderEntry)) {
|
||||
}
|
||||
|
||||
|
||||
@ -174,26 +182,22 @@ void PlaceholderTable::oops_do(OopClosure* f) {
|
||||
|
||||
|
||||
void PlaceholderEntry::oops_do(OopClosure* blk) {
|
||||
assert(klass() != NULL, "should have a non-null klass");
|
||||
blk->do_oop((oop*)klass_addr());
|
||||
assert(klassname() != NULL, "should have a non-null klass");
|
||||
if (_loader != NULL) {
|
||||
blk->do_oop(loader_addr());
|
||||
}
|
||||
if (_supername != NULL) {
|
||||
blk->do_oop((oop*)supername_addr());
|
||||
}
|
||||
if (_instanceKlass != NULL) {
|
||||
blk->do_oop((oop*)instanceKlass_addr());
|
||||
}
|
||||
}
|
||||
|
||||
// do all entries in the placeholder table
|
||||
void PlaceholderTable::entries_do(void f(symbolOop, oop)) {
|
||||
void PlaceholderTable::entries_do(void f(Symbol*, oop)) {
|
||||
for (int index = 0; index < table_size(); index++) {
|
||||
for (PlaceholderEntry* probe = bucket(index);
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
f(probe->klass(), probe->loader());
|
||||
f(probe->klassname(), probe->loader());
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -202,7 +206,7 @@ void PlaceholderTable::entries_do(void f(symbolOop, oop)) {
|
||||
#ifndef PRODUCT
|
||||
// Note, doesn't append a cr
|
||||
void PlaceholderEntry::print() const {
|
||||
klass()->print_value();
|
||||
klassname()->print_value();
|
||||
if (loader() != NULL) {
|
||||
tty->print(", loader ");
|
||||
loader()->print_value();
|
||||
@ -238,7 +242,6 @@ void PlaceholderEntry::verify() const {
|
||||
guarantee(instanceKlass() == NULL
|
||||
|| Klass::cast(instanceKlass())->oop_is_instance(),
|
||||
"checking type of instanceKlass result");
|
||||
klass()->verify();
|
||||
}
|
||||
|
||||
void PlaceholderTable::verify() {
|
||||
|
@ -34,35 +34,36 @@ class PlaceholderEntry;
|
||||
// being loaded, as well as arrays of primitives.
|
||||
//
|
||||
|
||||
class PlaceholderTable : public TwoOopHashtable {
|
||||
class PlaceholderTable : public TwoOopHashtable<Symbol*> {
|
||||
friend class VMStructs;
|
||||
|
||||
public:
|
||||
PlaceholderTable(int table_size);
|
||||
|
||||
PlaceholderEntry* new_entry(int hash, symbolOop name, oop loader, bool havesupername, symbolOop supername);
|
||||
PlaceholderEntry* new_entry(int hash, Symbol* name, oop loader, bool havesupername, Symbol* supername);
|
||||
void free_entry(PlaceholderEntry* entry);
|
||||
|
||||
PlaceholderEntry* bucket(int i) {
|
||||
return (PlaceholderEntry*)Hashtable::bucket(i);
|
||||
return (PlaceholderEntry*)Hashtable<Symbol*>::bucket(i);
|
||||
}
|
||||
|
||||
PlaceholderEntry** bucket_addr(int i) {
|
||||
return (PlaceholderEntry**)Hashtable::bucket_addr(i);
|
||||
return (PlaceholderEntry**)Hashtable<Symbol*>::bucket_addr(i);
|
||||
}
|
||||
|
||||
void add_entry(int index, PlaceholderEntry* new_entry) {
|
||||
Hashtable::add_entry(index, (HashtableEntry*)new_entry);
|
||||
Hashtable<Symbol*>::add_entry(index, (HashtableEntry<Symbol*>*)new_entry);
|
||||
}
|
||||
|
||||
void add_entry(int index, unsigned int hash, symbolHandle name,
|
||||
Handle loader, bool havesupername, symbolHandle supername);
|
||||
void add_entry(int index, unsigned int hash, Symbol* name,
|
||||
Handle loader, bool havesupername, Symbol* supername);
|
||||
|
||||
// This returns a symbolOop to match type for SystemDictionary
|
||||
symbolOop find_entry(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader);
|
||||
// This returns a Symbol* to match type for SystemDictionary
|
||||
Symbol* find_entry(int index, unsigned int hash,
|
||||
Symbol* name, Handle loader);
|
||||
|
||||
PlaceholderEntry* get_entry(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader);
|
||||
Symbol* name, Handle loader);
|
||||
|
||||
// caller to create a placeholder entry must enumerate an action
|
||||
// caller claims ownership of that action
|
||||
@ -84,22 +85,22 @@ public:
|
||||
// If no entry exists, add a placeholder entry and push SeenThread
|
||||
// If entry exists, reuse entry and push SeenThread for classloadAction
|
||||
PlaceholderEntry* find_and_add(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader,
|
||||
classloadAction action, symbolHandle supername,
|
||||
Symbol* name, Handle loader,
|
||||
classloadAction action, Symbol* supername,
|
||||
Thread* thread);
|
||||
|
||||
void remove_entry(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader);
|
||||
Symbol* name, Handle loader);
|
||||
|
||||
// Remove placeholder information
|
||||
void find_and_remove(int index, unsigned int hash,
|
||||
symbolHandle name, Handle loader, Thread* thread);
|
||||
Symbol* name, Handle loader, Thread* thread);
|
||||
|
||||
// GC support.
|
||||
void oops_do(OopClosure* f);
|
||||
|
||||
// JVMTI support
|
||||
void entries_do(void f(symbolOop, oop));
|
||||
void entries_do(void f(Symbol*, oop));
|
||||
|
||||
#ifndef PRODUCT
|
||||
void print();
|
||||
@ -151,14 +152,14 @@ public:
|
||||
// on store ordering here.
|
||||
// The system dictionary is the only user of this class.
|
||||
|
||||
class PlaceholderEntry : public HashtableEntry {
|
||||
class PlaceholderEntry : public HashtableEntry<Symbol*> {
|
||||
friend class VMStructs;
|
||||
|
||||
|
||||
private:
|
||||
oop _loader; // initiating loader
|
||||
bool _havesupername; // distinguish between null supername, and unknown
|
||||
symbolOop _supername;
|
||||
Symbol* _supername;
|
||||
Thread* _definer; // owner of define token
|
||||
klassOop _instanceKlass; // instanceKlass from successful define
|
||||
SeenThread* _superThreadQ; // doubly-linked queue of Threads loading a superclass for this class
|
||||
@ -173,8 +174,7 @@ class PlaceholderEntry : public HashtableEntry {
|
||||
|
||||
public:
|
||||
// Simple accessors, used only by SystemDictionary
|
||||
symbolOop klass() const { return (symbolOop)literal(); }
|
||||
symbolOop* klass_addr() { return (symbolOop*)literal_addr(); }
|
||||
Symbol* klassname() const { return literal(); }
|
||||
|
||||
oop loader() const { return _loader; }
|
||||
void set_loader(oop loader) { _loader = loader; }
|
||||
@ -183,9 +183,11 @@ class PlaceholderEntry : public HashtableEntry {
|
||||
bool havesupername() const { return _havesupername; }
|
||||
void set_havesupername(bool havesupername) { _havesupername = havesupername; }
|
||||
|
||||
symbolOop supername() const { return _supername; }
|
||||
void set_supername(symbolOop supername) { _supername = supername; }
|
||||
symbolOop* supername_addr() { return &_supername; }
|
||||
Symbol* supername() const { return _supername; }
|
||||
void set_supername(Symbol* supername) {
|
||||
_supername = supername;
|
||||
if (_supername != NULL) _supername->increment_refcount();
|
||||
}
|
||||
|
||||
Thread* definer() const {return _definer; }
|
||||
void set_definer(Thread* definer) { _definer = definer; }
|
||||
@ -204,17 +206,17 @@ class PlaceholderEntry : public HashtableEntry {
|
||||
void set_defineThreadQ(SeenThread* SeenThread) { _defineThreadQ = SeenThread; }
|
||||
|
||||
PlaceholderEntry* next() const {
|
||||
return (PlaceholderEntry*)HashtableEntry::next();
|
||||
return (PlaceholderEntry*)HashtableEntry<Symbol*>::next();
|
||||
}
|
||||
|
||||
PlaceholderEntry** next_addr() {
|
||||
return (PlaceholderEntry**)HashtableEntry::next_addr();
|
||||
return (PlaceholderEntry**)HashtableEntry<Symbol*>::next_addr();
|
||||
}
|
||||
|
||||
// Test for equality
|
||||
// Entries are unique for class/classloader name pair
|
||||
bool equals(symbolOop class_name, oop class_loader) const {
|
||||
return (klass() == class_name && loader() == class_loader);
|
||||
bool equals(Symbol* class_name, oop class_loader) const {
|
||||
return (klassname() == class_name && loader() == class_loader);
|
||||
}
|
||||
|
||||
SeenThread* actionToQueue(PlaceholderTable::classloadAction action) {
|
||||
|
@ -32,12 +32,12 @@
|
||||
|
||||
// add new entry to the table
|
||||
void ResolutionErrorTable::add_entry(int index, unsigned int hash,
|
||||
constantPoolHandle pool, int cp_index, symbolHandle error)
|
||||
constantPoolHandle pool, int cp_index, Symbol* error)
|
||||
{
|
||||
assert_locked_or_safepoint(SystemDictionary_lock);
|
||||
assert(!pool.is_null() && !error.is_null(), "adding NULL obj");
|
||||
assert(!pool.is_null() && error != NULL, "adding NULL obj");
|
||||
|
||||
ResolutionErrorEntry* entry = new_entry(hash, pool(), cp_index, error());
|
||||
ResolutionErrorEntry* entry = new_entry(hash, pool(), cp_index, error);
|
||||
add_entry(index, entry);
|
||||
}
|
||||
|
||||
@ -57,20 +57,35 @@ ResolutionErrorEntry* ResolutionErrorTable::find_entry(int index, unsigned int h
|
||||
return NULL;
|
||||
}
|
||||
|
||||
void ResolutionErrorEntry::set_error(Symbol* e) {
|
||||
assert(e == NULL || _error == NULL, "cannot reset error");
|
||||
_error = e;
|
||||
if (_error != NULL) _error->increment_refcount();
|
||||
}
|
||||
|
||||
// create new error entry
|
||||
ResolutionErrorEntry* ResolutionErrorTable::new_entry(int hash, constantPoolOop pool,
|
||||
int cp_index, symbolOop error)
|
||||
int cp_index, Symbol* error)
|
||||
{
|
||||
ResolutionErrorEntry* entry = (ResolutionErrorEntry*)Hashtable::new_entry(hash, pool);
|
||||
ResolutionErrorEntry* entry = (ResolutionErrorEntry*)Hashtable<constantPoolOop>::new_entry(hash, pool);
|
||||
entry->set_cp_index(cp_index);
|
||||
NOT_PRODUCT(entry->set_error(NULL);)
|
||||
entry->set_error(error);
|
||||
|
||||
return entry;
|
||||
}
|
||||
|
||||
void ResolutionErrorTable::free_entry(ResolutionErrorEntry *entry) {
|
||||
// decrement error refcount
|
||||
assert(entry->error() != NULL, "error should be set");
|
||||
entry->error()->decrement_refcount();
|
||||
Hashtable<constantPoolOop>::free_entry(entry);
|
||||
}
|
||||
|
||||
|
||||
// create resolution error table
|
||||
ResolutionErrorTable::ResolutionErrorTable(int table_size)
|
||||
: Hashtable(table_size, sizeof(ResolutionErrorEntry)) {
|
||||
: Hashtable<constantPoolOop>(table_size, sizeof(ResolutionErrorEntry)) {
|
||||
}
|
||||
|
||||
// GC support
|
||||
@ -80,7 +95,7 @@ void ResolutionErrorTable::oops_do(OopClosure* f) {
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
assert(probe->pool() != (constantPoolOop)NULL, "resolution error table is corrupt");
|
||||
assert(probe->error() != (symbolOop)NULL, "resolution error table is corrupt");
|
||||
assert(probe->error() != (Symbol*)NULL, "resolution error table is corrupt");
|
||||
probe->oops_do(f);
|
||||
}
|
||||
}
|
||||
@ -89,20 +104,6 @@ void ResolutionErrorTable::oops_do(OopClosure* f) {
|
||||
// GC support
|
||||
void ResolutionErrorEntry::oops_do(OopClosure* blk) {
|
||||
blk->do_oop((oop*)pool_addr());
|
||||
blk->do_oop((oop*)error_addr());
|
||||
}
|
||||
|
||||
// We must keep the symbolOop used in the error alive. The constantPoolOop will
|
||||
// decide when the entry can be purged.
|
||||
void ResolutionErrorTable::always_strong_classes_do(OopClosure* blk) {
|
||||
for (int i = 0; i < table_size(); i++) {
|
||||
for (ResolutionErrorEntry* probe = bucket(i);
|
||||
probe != NULL;
|
||||
probe = probe->next()) {
|
||||
assert(probe->error() != (symbolOop)NULL, "resolution error table is corrupt");
|
||||
blk->do_oop((oop*)probe->error_addr());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Remove unloaded entries from the table
|
||||
|
@ -33,27 +33,28 @@ class ResolutionErrorEntry;
|
||||
// ResolutionError objects are used to record errors encountered during
|
||||
// constant pool resolution (JVMS 5.4.3).
|
||||
|
||||
class ResolutionErrorTable : public Hashtable {
|
||||
class ResolutionErrorTable : public Hashtable<constantPoolOop> {
|
||||
|
||||
public:
|
||||
ResolutionErrorTable(int table_size);
|
||||
|
||||
ResolutionErrorEntry* new_entry(int hash, constantPoolOop pool, int cp_index, symbolOop error);
|
||||
ResolutionErrorEntry* new_entry(int hash, constantPoolOop pool, int cp_index, Symbol* error);
|
||||
void free_entry(ResolutionErrorEntry *entry);
|
||||
|
||||
ResolutionErrorEntry* bucket(int i) {
|
||||
return (ResolutionErrorEntry*)Hashtable::bucket(i);
|
||||
return (ResolutionErrorEntry*)Hashtable<constantPoolOop>::bucket(i);
|
||||
}
|
||||
|
||||
ResolutionErrorEntry** bucket_addr(int i) {
|
||||
return (ResolutionErrorEntry**)Hashtable::bucket_addr(i);
|
||||
return (ResolutionErrorEntry**)Hashtable<constantPoolOop>::bucket_addr(i);
|
||||
}
|
||||
|
||||
void add_entry(int index, ResolutionErrorEntry* new_entry) {
|
||||
Hashtable::add_entry(index, (HashtableEntry*)new_entry);
|
||||
Hashtable<constantPoolOop>::add_entry(index, (HashtableEntry<constantPoolOop>*)new_entry);
|
||||
}
|
||||
|
||||
void add_entry(int index, unsigned int hash,
|
||||
constantPoolHandle pool, int which, symbolHandle error);
|
||||
constantPoolHandle pool, int which, Symbol* error);
|
||||
|
||||
|
||||
// find error given the constant pool and constant pool index
|
||||
@ -68,18 +69,15 @@ public:
|
||||
// purges unloaded entries from the table
|
||||
void purge_resolution_errors(BoolObjectClosure* is_alive);
|
||||
|
||||
// this table keeps symbolOops alive
|
||||
void always_strong_classes_do(OopClosure* blk);
|
||||
|
||||
// GC support.
|
||||
void oops_do(OopClosure* f);
|
||||
};
|
||||
|
||||
|
||||
class ResolutionErrorEntry : public HashtableEntry {
|
||||
class ResolutionErrorEntry : public HashtableEntry<constantPoolOop> {
|
||||
private:
|
||||
int _cp_index;
|
||||
symbolOop _error;
|
||||
Symbol* _error;
|
||||
|
||||
public:
|
||||
constantPoolOop pool() const { return (constantPoolOop)literal(); }
|
||||
@ -88,16 +86,15 @@ class ResolutionErrorEntry : public HashtableEntry {
|
||||
int cp_index() const { return _cp_index; }
|
||||
void set_cp_index(int cp_index) { _cp_index = cp_index; }
|
||||
|
||||
symbolOop error() const { return _error; }
|
||||
void set_error(symbolOop e) { _error = e; }
|
||||
symbolOop* error_addr() { return &_error; }
|
||||
Symbol* error() const { return _error; }
|
||||
void set_error(Symbol* e);
|
||||
|
||||
ResolutionErrorEntry* next() const {
|
||||
return (ResolutionErrorEntry*)HashtableEntry::next();
|
||||
return (ResolutionErrorEntry*)HashtableEntry<constantPoolOop>::next();
|
||||
}
|
||||
|
||||
ResolutionErrorEntry** next_addr() {
|
||||
return (ResolutionErrorEntry**)HashtableEntry::next_addr();
|
||||
return (ResolutionErrorEntry**)HashtableEntry<constantPoolOop>::next_addr();
|
||||
}
|
||||
|
||||
// GC support
|
||||
|
@ -27,7 +27,7 @@
|
||||
#include "classfile/verifier.hpp"
|
||||
#include "memory/resourceArea.hpp"
|
||||
#include "oops/oop.inline.hpp"
|
||||
#include "oops/symbolOop.hpp"
|
||||
#include "oops/symbol.hpp"
|
||||
#include "runtime/handles.inline.hpp"
|
||||
#include "utilities/globalDefinitions.hpp"
|
||||
|
||||
@ -90,8 +90,7 @@ void StackMapFrame::initialize_object(
|
||||
|
||||
VerificationType StackMapFrame::set_locals_from_arg(
|
||||
const methodHandle m, VerificationType thisKlass, TRAPS) {
|
||||
symbolHandle signature(THREAD, m->signature());
|
||||
SignatureStream ss(signature);
|
||||
SignatureStream ss(m->signature());
|
||||
int init_local_num = 0;
|
||||
if (!m->is_static()) {
|
||||
init_local_num++;
|
||||
@ -118,8 +117,14 @@ VerificationType StackMapFrame::set_locals_from_arg(
|
||||
case T_OBJECT:
|
||||
case T_ARRAY:
|
||||
{
|
||||
symbolOop sig = ss.as_symbol(CHECK_(VerificationType::bogus_type()));
|
||||
return VerificationType::reference_type(symbolHandle(THREAD, sig));
|
||||
Symbol* sig = ss.as_symbol(CHECK_(VerificationType::bogus_type()));
|
||||
// Create another symbol to save as signature stream unreferences
|
||||
// this symbol.
|
||||
Symbol* sig_copy =
|
||||
verifier()->create_temporary_symbol(sig, 0, sig->utf8_length(),
|
||||
CHECK_(VerificationType::bogus_type()));
|
||||
assert(sig_copy == sig, "symbols don't match");
|
||||
return VerificationType::reference_type(sig_copy);
|
||||
}
|
||||
case T_INT: return VerificationType::integer_type();
|
||||
case T_BYTE: return VerificationType::byte_type();
|
||||
@ -157,7 +162,7 @@ bool StackMapFrame::is_assignable_to(
|
||||
VerificationType* from, VerificationType* to, int32_t len, TRAPS) const {
|
||||
for (int32_t i = 0; i < len; i++) {
|
||||
bool subtype = to[i].is_assignable_from(
|
||||
from[i], verifier()->current_class(), THREAD);
|
||||
from[i], verifier(), THREAD);
|
||||
if (!subtype) {
|
||||
return false;
|
||||
}
|
||||
@ -187,7 +192,7 @@ VerificationType StackMapFrame::pop_stack_ex(VerificationType type, TRAPS) {
|
||||
}
|
||||
VerificationType top = _stack[--_stack_size];
|
||||
bool subtype = type.is_assignable_from(
|
||||
top, verifier()->current_class(), CHECK_(VerificationType::bogus_type()));
|
||||
top, verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
if (!subtype) {
|
||||
verifier()->verify_error(_offset, "Bad type on operand stack");
|
||||
return VerificationType::bogus_type();
|
||||
@ -203,7 +208,7 @@ VerificationType StackMapFrame::get_local(
|
||||
return VerificationType::bogus_type();
|
||||
}
|
||||
bool subtype = type.is_assignable_from(_locals[index],
|
||||
verifier()->current_class(), CHECK_(VerificationType::bogus_type()));
|
||||
verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
if (!subtype) {
|
||||
verifier()->verify_error(_offset, "Bad local variable type");
|
||||
return VerificationType::bogus_type();
|
||||
@ -221,9 +226,9 @@ void StackMapFrame::get_local_2(
|
||||
return;
|
||||
}
|
||||
bool subtype1 = type1.is_assignable_from(
|
||||
_locals[index], verifier()->current_class(), CHECK);
|
||||
_locals[index], verifier(), CHECK);
|
||||
bool subtype2 = type2.is_assignable_from(
|
||||
_locals[index+1], verifier()->current_class(), CHECK);
|
||||
_locals[index+1], verifier(), CHECK);
|
||||
if (!subtype1 || !subtype2) {
|
||||
verifier()->verify_error(_offset, "Bad local variable type");
|
||||
return;
|
||||
|
@ -177,8 +177,7 @@ class StackMapFrame : public ResourceObj {
|
||||
if (_stack_size != 0) {
|
||||
VerificationType top = _stack[_stack_size - 1];
|
||||
bool subtype = type.is_assignable_from(
|
||||
top, verifier()->current_class(),
|
||||
CHECK_(VerificationType::bogus_type()));
|
||||
top, verifier(), CHECK_(VerificationType::bogus_type()));
|
||||
if (subtype) {
|
||||
_stack_size --;
|
||||
NOT_PRODUCT( _stack[_stack_size] = VerificationType::bogus_type(); )
|
||||
@ -194,11 +193,9 @@ class StackMapFrame : public ResourceObj {
|
||||
assert(type2.is_long() || type2.is_double(), "must be long/double_2");
|
||||
if (_stack_size >= 2) {
|
||||
VerificationType top1 = _stack[_stack_size - 1];
|
||||
bool subtype1 = type1.is_assignable_from(
|
||||
top1, verifier()->current_class(), CHECK);
|
||||
bool subtype1 = type1.is_assignable_from(top1, verifier(), CHECK);
|
||||
VerificationType top2 = _stack[_stack_size - 2];
|
||||
bool subtype2 = type2.is_assignable_from(
|
||||
top2, verifier()->current_class(), CHECK);
|
||||
bool subtype2 = type2.is_assignable_from(top2, verifier(), CHECK);
|
||||
if (subtype1 && subtype2) {
|
||||
_stack_size -= 2;
|
||||
NOT_PRODUCT( _stack[_stack_size] = VerificationType::bogus_type(); )
|
||||
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user