annotate agent/src/share/classes/sun/jvm/hotspot/oops/ConstantPool.java @ 1602:136b78722a08

6939203: JSR 292 needs method handle constants Summary: Add new CP types CONSTANT_MethodHandle, CONSTANT_MethodType; extend 'ldc' bytecode. Reviewed-by: twisti, never
author jrose
date Wed, 09 Jun 2010 18:50:45 -0700
parents c18cbe5936b8
children 083fde3b838e
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1385
diff changeset
2 * Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1385
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1385
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 1385
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
a61af66fc99e Initial load
duke
parents:
diff changeset
25 package sun.jvm.hotspot.oops;
a61af66fc99e Initial load
duke
parents:
diff changeset
26
a61af66fc99e Initial load
duke
parents:
diff changeset
27 import java.io.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
28 import java.util.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
29 import sun.jvm.hotspot.debugger.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
30 import sun.jvm.hotspot.runtime.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
31 import sun.jvm.hotspot.types.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
32 import sun.jvm.hotspot.utilities.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
33
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
34 // A ConstantPool is an oop containing class constants
0
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // as described in the class file
a61af66fc99e Initial load
duke
parents:
diff changeset
36
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
37 public class ConstantPool extends Oop implements ClassConstants {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // Used for debugging this code
a61af66fc99e Initial load
duke
parents:
diff changeset
39 private static final boolean DEBUG = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
40
a61af66fc99e Initial load
duke
parents:
diff changeset
41 protected void debugMessage(String message) {
a61af66fc99e Initial load
duke
parents:
diff changeset
42 System.out.println(message);
a61af66fc99e Initial load
duke
parents:
diff changeset
43 }
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45 static {
a61af66fc99e Initial load
duke
parents:
diff changeset
46 VM.registerVMInitializedObserver(new Observer() {
a61af66fc99e Initial load
duke
parents:
diff changeset
47 public void update(Observable o, Object data) {
a61af66fc99e Initial load
duke
parents:
diff changeset
48 initialize(VM.getVM().getTypeDataBase());
a61af66fc99e Initial load
duke
parents:
diff changeset
49 }
a61af66fc99e Initial load
duke
parents:
diff changeset
50 });
a61af66fc99e Initial load
duke
parents:
diff changeset
51 }
a61af66fc99e Initial load
duke
parents:
diff changeset
52
a61af66fc99e Initial load
duke
parents:
diff changeset
53 private static synchronized void initialize(TypeDataBase db) throws WrongTypeException {
a61af66fc99e Initial load
duke
parents:
diff changeset
54 Type type = db.lookupType("constantPoolOopDesc");
a61af66fc99e Initial load
duke
parents:
diff changeset
55 tags = new OopField(type.getOopField("_tags"), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
56 cache = new OopField(type.getOopField("_cache"), 0);
a61af66fc99e Initial load
duke
parents:
diff changeset
57 poolHolder = new OopField(type.getOopField("_pool_holder"), 0);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
58 length = new CIntField(type.getCIntegerField("_length"), 0);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
59 headerSize = type.getSize();
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
60 elementSize = 0;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
61 }
a61af66fc99e Initial load
duke
parents:
diff changeset
62
a61af66fc99e Initial load
duke
parents:
diff changeset
63 ConstantPool(OopHandle handle, ObjectHeap heap) {
a61af66fc99e Initial load
duke
parents:
diff changeset
64 super(handle, heap);
a61af66fc99e Initial load
duke
parents:
diff changeset
65 }
a61af66fc99e Initial load
duke
parents:
diff changeset
66
a61af66fc99e Initial load
duke
parents:
diff changeset
67 public boolean isConstantPool() { return true; }
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 private static OopField tags;
a61af66fc99e Initial load
duke
parents:
diff changeset
70 private static OopField cache;
a61af66fc99e Initial load
duke
parents:
diff changeset
71 private static OopField poolHolder;
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
72 private static CIntField length; // number of elements in oop
0
a61af66fc99e Initial load
duke
parents:
diff changeset
73
a61af66fc99e Initial load
duke
parents:
diff changeset
74 private static long headerSize;
a61af66fc99e Initial load
duke
parents:
diff changeset
75 private static long elementSize;
a61af66fc99e Initial load
duke
parents:
diff changeset
76
a61af66fc99e Initial load
duke
parents:
diff changeset
77 public TypeArray getTags() { return (TypeArray) tags.getValue(this); }
a61af66fc99e Initial load
duke
parents:
diff changeset
78 public ConstantPoolCache getCache() { return (ConstantPoolCache) cache.getValue(this); }
a61af66fc99e Initial load
duke
parents:
diff changeset
79 public Klass getPoolHolder() { return (Klass) poolHolder.getValue(this); }
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
80 public int getLength() { return (int)length.getValue(this); }
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
81
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
82 private long getElementSize() {
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
83 if (elementSize !=0 ) {
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
84 return elementSize;
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
85 } else {
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
86 elementSize = VM.getVM().getOopSize();
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
87 }
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
88 return elementSize;
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
89 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
90
a61af66fc99e Initial load
duke
parents:
diff changeset
91 private long indexOffset(long index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
92 if (Assert.ASSERTS_ENABLED) {
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
93 Assert.that(index > 0 && index < getLength(), "invalid cp index " + index + " " + getLength());
0
a61af66fc99e Initial load
duke
parents:
diff changeset
94 }
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
95 return (index * getElementSize()) + headerSize;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
96 }
a61af66fc99e Initial load
duke
parents:
diff changeset
97
a61af66fc99e Initial load
duke
parents:
diff changeset
98 public ConstantTag getTagAt(long index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
99 return new ConstantTag(getTags().getByteAt((int) index));
a61af66fc99e Initial load
duke
parents:
diff changeset
100 }
a61af66fc99e Initial load
duke
parents:
diff changeset
101
a61af66fc99e Initial load
duke
parents:
diff changeset
102 public Oop getObjAt(long index){
a61af66fc99e Initial load
duke
parents:
diff changeset
103 return getHeap().newOop(getHandle().getOopHandleAt(indexOffset(index)));
a61af66fc99e Initial load
duke
parents:
diff changeset
104 }
a61af66fc99e Initial load
duke
parents:
diff changeset
105
a61af66fc99e Initial load
duke
parents:
diff changeset
106 public Symbol getSymbolAt(long index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
107 return (Symbol) getObjAt(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
108 }
a61af66fc99e Initial load
duke
parents:
diff changeset
109
a61af66fc99e Initial load
duke
parents:
diff changeset
110 public int getIntAt(long index){
a61af66fc99e Initial load
duke
parents:
diff changeset
111 return getHandle().getJIntAt(indexOffset(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
113
a61af66fc99e Initial load
duke
parents:
diff changeset
114 public float getFloatAt(long index){
a61af66fc99e Initial load
duke
parents:
diff changeset
115 return getHandle().getJFloatAt(indexOffset(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
116 }
a61af66fc99e Initial load
duke
parents:
diff changeset
117
a61af66fc99e Initial load
duke
parents:
diff changeset
118 public long getLongAt(long index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
119 int oneHalf = getHandle().getJIntAt(indexOffset(index + 1));
a61af66fc99e Initial load
duke
parents:
diff changeset
120 int otherHalf = getHandle().getJIntAt(indexOffset(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // buildLongFromIntsPD accepts higher address value, lower address value
a61af66fc99e Initial load
duke
parents:
diff changeset
122 // in that order.
a61af66fc99e Initial load
duke
parents:
diff changeset
123 return VM.getVM().buildLongFromIntsPD(oneHalf, otherHalf);
a61af66fc99e Initial load
duke
parents:
diff changeset
124 }
a61af66fc99e Initial load
duke
parents:
diff changeset
125
a61af66fc99e Initial load
duke
parents:
diff changeset
126 public double getDoubleAt(long index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
127 return Double.longBitsToDouble(getLongAt(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
128 }
a61af66fc99e Initial load
duke
parents:
diff changeset
129
a61af66fc99e Initial load
duke
parents:
diff changeset
130 public int getFieldOrMethodAt(int which) {
a61af66fc99e Initial load
duke
parents:
diff changeset
131 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
132 System.err.print("ConstantPool.getFieldOrMethodAt(" + which + "): new index = ");
a61af66fc99e Initial load
duke
parents:
diff changeset
133 }
a61af66fc99e Initial load
duke
parents:
diff changeset
134 int i = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
135 ConstantPoolCache cache = getCache();
a61af66fc99e Initial load
duke
parents:
diff changeset
136 if (cache == null) {
a61af66fc99e Initial load
duke
parents:
diff changeset
137 i = which;
a61af66fc99e Initial load
duke
parents:
diff changeset
138 } else {
a61af66fc99e Initial load
duke
parents:
diff changeset
139 // change byte-ordering and go via cache
a61af66fc99e Initial load
duke
parents:
diff changeset
140 i = cache.getEntryAt(0xFFFF & VM.getVM().getBytes().swapShort((short) which)).getConstantPoolIndex();
a61af66fc99e Initial load
duke
parents:
diff changeset
141 }
a61af66fc99e Initial load
duke
parents:
diff changeset
142 if (Assert.ASSERTS_ENABLED) {
a61af66fc99e Initial load
duke
parents:
diff changeset
143 Assert.that(getTagAt(i).isFieldOrMethod(), "Corrupted constant pool");
a61af66fc99e Initial load
duke
parents:
diff changeset
144 }
a61af66fc99e Initial load
duke
parents:
diff changeset
145 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
146 System.err.println(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
147 }
a61af66fc99e Initial load
duke
parents:
diff changeset
148 int res = getIntAt(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
149 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
150 System.err.println("ConstantPool.getFieldOrMethodAt(" + i + "): result = " + res);
a61af66fc99e Initial load
duke
parents:
diff changeset
151 }
a61af66fc99e Initial load
duke
parents:
diff changeset
152 return res;
a61af66fc99e Initial load
duke
parents:
diff changeset
153 }
a61af66fc99e Initial load
duke
parents:
diff changeset
154
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
155 public int[] getNameAndTypeAt(int which) {
0
a61af66fc99e Initial load
duke
parents:
diff changeset
156 if (Assert.ASSERTS_ENABLED) {
a61af66fc99e Initial load
duke
parents:
diff changeset
157 Assert.that(getTagAt(which).isNameAndType(), "Corrupted constant pool");
a61af66fc99e Initial load
duke
parents:
diff changeset
158 }
a61af66fc99e Initial load
duke
parents:
diff changeset
159 int i = getIntAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
160 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
161 System.err.println("ConstantPool.getNameAndTypeAt(" + which + "): result = " + i);
a61af66fc99e Initial load
duke
parents:
diff changeset
162 }
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
163 return new int[] { extractLowShortFromInt(i), extractHighShortFromInt(i) };
0
a61af66fc99e Initial load
duke
parents:
diff changeset
164 }
a61af66fc99e Initial load
duke
parents:
diff changeset
165
a61af66fc99e Initial load
duke
parents:
diff changeset
166 public Symbol getNameRefAt(int which) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
167 int nameIndex = getNameAndTypeAt(getNameAndTypeRefIndexAt(which))[0];
0
a61af66fc99e Initial load
duke
parents:
diff changeset
168 return getSymbolAt(nameIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
169 }
a61af66fc99e Initial load
duke
parents:
diff changeset
170
a61af66fc99e Initial load
duke
parents:
diff changeset
171 public Symbol getSignatureRefAt(int which) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
172 int sigIndex = getNameAndTypeAt(getNameAndTypeRefIndexAt(which))[1];
0
a61af66fc99e Initial load
duke
parents:
diff changeset
173 return getSymbolAt(sigIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
174 }
a61af66fc99e Initial load
duke
parents:
diff changeset
175
a61af66fc99e Initial load
duke
parents:
diff changeset
176 // returns null, if not resolved.
a61af66fc99e Initial load
duke
parents:
diff changeset
177 public Klass getKlassRefAt(int which) {
a61af66fc99e Initial load
duke
parents:
diff changeset
178 if( ! getTagAt(which).isKlass()) return null;
a61af66fc99e Initial load
duke
parents:
diff changeset
179 return (Klass) getObjAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
180 }
a61af66fc99e Initial load
duke
parents:
diff changeset
181
a61af66fc99e Initial load
duke
parents:
diff changeset
182 // returns null, if not resolved.
a61af66fc99e Initial load
duke
parents:
diff changeset
183 public InstanceKlass getFieldOrMethodKlassRefAt(int which) {
a61af66fc99e Initial load
duke
parents:
diff changeset
184 int refIndex = getFieldOrMethodAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
185 int klassIndex = extractLowShortFromInt(refIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
186 return (InstanceKlass) getKlassRefAt(klassIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
187 }
a61af66fc99e Initial load
duke
parents:
diff changeset
188
a61af66fc99e Initial load
duke
parents:
diff changeset
189 // returns null, if not resolved.
a61af66fc99e Initial load
duke
parents:
diff changeset
190 public Method getMethodRefAt(int which) {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 InstanceKlass klass = getFieldOrMethodKlassRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
192 if (klass == null) return null;
a61af66fc99e Initial load
duke
parents:
diff changeset
193 Symbol name = getNameRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
194 Symbol sig = getSignatureRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
195 return klass.findMethod(name, sig);
a61af66fc99e Initial load
duke
parents:
diff changeset
196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
197
a61af66fc99e Initial load
duke
parents:
diff changeset
198 // returns null, if not resolved.
a61af66fc99e Initial load
duke
parents:
diff changeset
199 public Field getFieldRefAt(int which) {
a61af66fc99e Initial load
duke
parents:
diff changeset
200 InstanceKlass klass = getFieldOrMethodKlassRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
201 if (klass == null) return null;
a61af66fc99e Initial load
duke
parents:
diff changeset
202 Symbol name = getNameRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
203 Symbol sig = getSignatureRefAt(which);
a61af66fc99e Initial load
duke
parents:
diff changeset
204 return klass.findField(name, sig);
a61af66fc99e Initial load
duke
parents:
diff changeset
205 }
a61af66fc99e Initial load
duke
parents:
diff changeset
206
a61af66fc99e Initial load
duke
parents:
diff changeset
207 public int getNameAndTypeRefIndexAt(int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
208 int refIndex = getFieldOrMethodAt(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
209 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
210 System.err.println("ConstantPool.getNameAndTypeRefIndexAt(" + index + "): refIndex = " + refIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
211 }
a61af66fc99e Initial load
duke
parents:
diff changeset
212 int i = extractHighShortFromInt(refIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
213 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
214 System.err.println("ConstantPool.getNameAndTypeRefIndexAt(" + index + "): result = " + i);
a61af66fc99e Initial load
duke
parents:
diff changeset
215 }
a61af66fc99e Initial load
duke
parents:
diff changeset
216 return i;
a61af66fc99e Initial load
duke
parents:
diff changeset
217 }
a61af66fc99e Initial load
duke
parents:
diff changeset
218
a61af66fc99e Initial load
duke
parents:
diff changeset
219 /** Lookup for entries consisting of (name_index, signature_index) */
a61af66fc99e Initial load
duke
parents:
diff changeset
220 public int getNameRefIndexAt(int index) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
221 int[] refIndex = getNameAndTypeAt(index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
222 if (DEBUG) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
223 System.err.println("ConstantPool.getNameRefIndexAt(" + index + "): refIndex = " + refIndex[0]+"/"+refIndex[1]);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
224 }
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
225 int i = refIndex[0];
0
a61af66fc99e Initial load
duke
parents:
diff changeset
226 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
227 System.err.println("ConstantPool.getNameRefIndexAt(" + index + "): result = " + i);
a61af66fc99e Initial load
duke
parents:
diff changeset
228 }
a61af66fc99e Initial load
duke
parents:
diff changeset
229 return i;
a61af66fc99e Initial load
duke
parents:
diff changeset
230 }
a61af66fc99e Initial load
duke
parents:
diff changeset
231
a61af66fc99e Initial load
duke
parents:
diff changeset
232 /** Lookup for entries consisting of (name_index, signature_index) */
a61af66fc99e Initial load
duke
parents:
diff changeset
233 public int getSignatureRefIndexAt(int index) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
234 int[] refIndex = getNameAndTypeAt(index);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
235 if (DEBUG) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
236 System.err.println("ConstantPool.getSignatureRefIndexAt(" + index + "): refIndex = " + refIndex[0]+"/"+refIndex[1]);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
237 }
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
238 int i = refIndex[1];
0
a61af66fc99e Initial load
duke
parents:
diff changeset
239 if (DEBUG) {
a61af66fc99e Initial load
duke
parents:
diff changeset
240 System.err.println("ConstantPool.getSignatureRefIndexAt(" + index + "): result = " + i);
a61af66fc99e Initial load
duke
parents:
diff changeset
241 }
a61af66fc99e Initial load
duke
parents:
diff changeset
242 return i;
a61af66fc99e Initial load
duke
parents:
diff changeset
243 }
a61af66fc99e Initial load
duke
parents:
diff changeset
244
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
245 /** Lookup for MethodHandle entries. */
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
246 public int getMethodHandleIndexAt(int i) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
247 if (Assert.ASSERTS_ENABLED) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
248 Assert.that(getTagAt(i).isMethodHandle(), "Corrupted constant pool");
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
249 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
250 int res = extractHighShortFromInt(getIntAt(i));
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
251 if (DEBUG) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
252 System.err.println("ConstantPool.getMethodHandleIndexAt(" + i + "): result = " + res);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
253 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
254 return res;
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
255 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
256
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
257 /** Lookup for MethodHandle entries. */
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
258 public int getMethodHandleRefKindAt(int i) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
259 if (Assert.ASSERTS_ENABLED) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
260 Assert.that(getTagAt(i).isMethodHandle(), "Corrupted constant pool");
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
261 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
262 int res = extractLowShortFromInt(getIntAt(i));
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
263 if (DEBUG) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
264 System.err.println("ConstantPool.getMethodHandleRefKindAt(" + i + "): result = " + res);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
265 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
266 return res;
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
267 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
268
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
269 /** Lookup for MethodType entries. */
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
270 public int getMethodTypeIndexAt(int i) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
271 if (Assert.ASSERTS_ENABLED) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
272 Assert.that(getTagAt(i).isMethodType(), "Corrupted constant pool");
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
273 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
274 int res = getIntAt(i);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
275 if (DEBUG) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
276 System.err.println("ConstantPool.getMethodHandleTypeAt(" + i + "): result = " + res);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
277 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
278 return res;
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
279 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
280
0
a61af66fc99e Initial load
duke
parents:
diff changeset
281 final private static String[] nameForTag = new String[] {
a61af66fc99e Initial load
duke
parents:
diff changeset
282 };
a61af66fc99e Initial load
duke
parents:
diff changeset
283
a61af66fc99e Initial load
duke
parents:
diff changeset
284 private String nameForTag(int tag) {
a61af66fc99e Initial load
duke
parents:
diff changeset
285 switch (tag) {
a61af66fc99e Initial load
duke
parents:
diff changeset
286 case JVM_CONSTANT_Utf8: return "JVM_CONSTANT_Utf8";
a61af66fc99e Initial load
duke
parents:
diff changeset
287 case JVM_CONSTANT_Unicode: return "JVM_CONSTANT_Unicode";
a61af66fc99e Initial load
duke
parents:
diff changeset
288 case JVM_CONSTANT_Integer: return "JVM_CONSTANT_Integer";
a61af66fc99e Initial load
duke
parents:
diff changeset
289 case JVM_CONSTANT_Float: return "JVM_CONSTANT_Float";
a61af66fc99e Initial load
duke
parents:
diff changeset
290 case JVM_CONSTANT_Long: return "JVM_CONSTANT_Long";
a61af66fc99e Initial load
duke
parents:
diff changeset
291 case JVM_CONSTANT_Double: return "JVM_CONSTANT_Double";
a61af66fc99e Initial load
duke
parents:
diff changeset
292 case JVM_CONSTANT_Class: return "JVM_CONSTANT_Class";
a61af66fc99e Initial load
duke
parents:
diff changeset
293 case JVM_CONSTANT_String: return "JVM_CONSTANT_String";
a61af66fc99e Initial load
duke
parents:
diff changeset
294 case JVM_CONSTANT_Fieldref: return "JVM_CONSTANT_Fieldref";
a61af66fc99e Initial load
duke
parents:
diff changeset
295 case JVM_CONSTANT_Methodref: return "JVM_CONSTANT_Methodref";
a61af66fc99e Initial load
duke
parents:
diff changeset
296 case JVM_CONSTANT_InterfaceMethodref: return "JVM_CONSTANT_InterfaceMethodref";
a61af66fc99e Initial load
duke
parents:
diff changeset
297 case JVM_CONSTANT_NameAndType: return "JVM_CONSTANT_NameAndType";
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
298 case JVM_CONSTANT_MethodHandle: return "JVM_CONSTANT_MethodHandle";
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
299 case JVM_CONSTANT_MethodType: return "JVM_CONSTANT_MethodType";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
300 case JVM_CONSTANT_Invalid: return "JVM_CONSTANT_Invalid";
a61af66fc99e Initial load
duke
parents:
diff changeset
301 case JVM_CONSTANT_UnresolvedClass: return "JVM_CONSTANT_UnresolvedClass";
1385
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
302 case JVM_CONSTANT_UnresolvedClassInError: return "JVM_CONSTANT_UnresolvedClassInError";
0
a61af66fc99e Initial load
duke
parents:
diff changeset
303 case JVM_CONSTANT_ClassIndex: return "JVM_CONSTANT_ClassIndex";
a61af66fc99e Initial load
duke
parents:
diff changeset
304 case JVM_CONSTANT_UnresolvedString: return "JVM_CONSTANT_UnresolvedString";
a61af66fc99e Initial load
duke
parents:
diff changeset
305 case JVM_CONSTANT_StringIndex: return "JVM_CONSTANT_StringIndex";
a61af66fc99e Initial load
duke
parents:
diff changeset
306 }
1385
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
307 throw new InternalError("Unknown tag: " + tag);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
308 }
a61af66fc99e Initial load
duke
parents:
diff changeset
309
a61af66fc99e Initial load
duke
parents:
diff changeset
310 public void iterateFields(OopVisitor visitor, boolean doVMFields) {
a61af66fc99e Initial load
duke
parents:
diff changeset
311 super.iterateFields(visitor, doVMFields);
a61af66fc99e Initial load
duke
parents:
diff changeset
312 if (doVMFields) {
a61af66fc99e Initial load
duke
parents:
diff changeset
313 visitor.doOop(tags, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
314 visitor.doOop(cache, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
315 visitor.doOop(poolHolder, true);
a61af66fc99e Initial load
duke
parents:
diff changeset
316
a61af66fc99e Initial load
duke
parents:
diff changeset
317 final int length = (int) getLength();
a61af66fc99e Initial load
duke
parents:
diff changeset
318 // zero'th pool entry is always invalid. ignore it.
a61af66fc99e Initial load
duke
parents:
diff changeset
319 for (int index = 1; index < length; index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
320 int ctag = (int) getTags().getByteAt((int) index);
a61af66fc99e Initial load
duke
parents:
diff changeset
321 switch (ctag) {
a61af66fc99e Initial load
duke
parents:
diff changeset
322 case JVM_CONSTANT_ClassIndex:
a61af66fc99e Initial load
duke
parents:
diff changeset
323 case JVM_CONSTANT_StringIndex:
a61af66fc99e Initial load
duke
parents:
diff changeset
324 case JVM_CONSTANT_Integer:
a61af66fc99e Initial load
duke
parents:
diff changeset
325 visitor.doInt(new IntField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
326 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
327
a61af66fc99e Initial load
duke
parents:
diff changeset
328 case JVM_CONSTANT_Float:
a61af66fc99e Initial load
duke
parents:
diff changeset
329 visitor.doFloat(new FloatField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
330 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
331
a61af66fc99e Initial load
duke
parents:
diff changeset
332 case JVM_CONSTANT_Long:
a61af66fc99e Initial load
duke
parents:
diff changeset
333 visitor.doLong(new LongField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
334 // long entries occupy two slots
a61af66fc99e Initial load
duke
parents:
diff changeset
335 index++;
a61af66fc99e Initial load
duke
parents:
diff changeset
336 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
337
a61af66fc99e Initial load
duke
parents:
diff changeset
338 case JVM_CONSTANT_Double:
a61af66fc99e Initial load
duke
parents:
diff changeset
339 visitor.doDouble(new DoubleField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
340 // double entries occupy two slots
a61af66fc99e Initial load
duke
parents:
diff changeset
341 index++;
a61af66fc99e Initial load
duke
parents:
diff changeset
342 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
343
1385
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
344 case JVM_CONSTANT_UnresolvedClassInError:
0
a61af66fc99e Initial load
duke
parents:
diff changeset
345 case JVM_CONSTANT_UnresolvedClass:
a61af66fc99e Initial load
duke
parents:
diff changeset
346 case JVM_CONSTANT_Class:
a61af66fc99e Initial load
duke
parents:
diff changeset
347 case JVM_CONSTANT_UnresolvedString:
a61af66fc99e Initial load
duke
parents:
diff changeset
348 case JVM_CONSTANT_Utf8:
a61af66fc99e Initial load
duke
parents:
diff changeset
349 visitor.doOop(new OopField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
350 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
351
a61af66fc99e Initial load
duke
parents:
diff changeset
352 case JVM_CONSTANT_Fieldref:
a61af66fc99e Initial load
duke
parents:
diff changeset
353 case JVM_CONSTANT_Methodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
354 case JVM_CONSTANT_InterfaceMethodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
355 case JVM_CONSTANT_NameAndType:
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
356 case JVM_CONSTANT_MethodHandle:
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
357 case JVM_CONSTANT_MethodType:
0
a61af66fc99e Initial load
duke
parents:
diff changeset
358 visitor.doInt(new IntField(new NamedFieldIdentifier(nameForTag(ctag)), indexOffset(index), true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
359 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
360 }
a61af66fc99e Initial load
duke
parents:
diff changeset
361 }
a61af66fc99e Initial load
duke
parents:
diff changeset
362 }
a61af66fc99e Initial load
duke
parents:
diff changeset
363 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
364 int length = getLength();
a61af66fc99e Initial load
duke
parents:
diff changeset
365 for (int index = 0; index < length; index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
366 long offset = baseOffset + (index + typeDataBase.getOopSize());
a61af66fc99e Initial load
duke
parents:
diff changeset
367 visitor.doOop(new IndexableField(index, offset, false), getObjAt(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
368 }
a61af66fc99e Initial load
duke
parents:
diff changeset
369 */
a61af66fc99e Initial load
duke
parents:
diff changeset
370 }
a61af66fc99e Initial load
duke
parents:
diff changeset
371
a61af66fc99e Initial load
duke
parents:
diff changeset
372 public void writeBytes(OutputStream os) throws IOException {
a61af66fc99e Initial load
duke
parents:
diff changeset
373 // Map between any modified UTF-8 and it's constant pool index.
a61af66fc99e Initial load
duke
parents:
diff changeset
374 Map utf8ToIndex = new HashMap();
a61af66fc99e Initial load
duke
parents:
diff changeset
375 DataOutputStream dos = new DataOutputStream(os);
a61af66fc99e Initial load
duke
parents:
diff changeset
376 TypeArray tags = getTags();
a61af66fc99e Initial load
duke
parents:
diff changeset
377 int len = (int)getLength();
a61af66fc99e Initial load
duke
parents:
diff changeset
378 int ci = 0; // constant pool index
a61af66fc99e Initial load
duke
parents:
diff changeset
379
a61af66fc99e Initial load
duke
parents:
diff changeset
380 // collect all modified UTF-8 Strings from Constant Pool
a61af66fc99e Initial load
duke
parents:
diff changeset
381
a61af66fc99e Initial load
duke
parents:
diff changeset
382 for (ci = 1; ci < len; ci++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
383 byte cpConstType = tags.getByteAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
384 if(cpConstType == JVM_CONSTANT_Utf8) {
a61af66fc99e Initial load
duke
parents:
diff changeset
385 Symbol sym = getSymbolAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
386 utf8ToIndex.put(sym.asString(), new Short((short) ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
387 }
a61af66fc99e Initial load
duke
parents:
diff changeset
388 else if(cpConstType == JVM_CONSTANT_Long ||
a61af66fc99e Initial load
duke
parents:
diff changeset
389 cpConstType == JVM_CONSTANT_Double) {
a61af66fc99e Initial load
duke
parents:
diff changeset
390 ci++;
a61af66fc99e Initial load
duke
parents:
diff changeset
391 }
a61af66fc99e Initial load
duke
parents:
diff changeset
392 }
a61af66fc99e Initial load
duke
parents:
diff changeset
393
a61af66fc99e Initial load
duke
parents:
diff changeset
394
a61af66fc99e Initial load
duke
parents:
diff changeset
395 for(ci = 1; ci < len; ci++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
396 int cpConstType = (int)tags.getByteAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
397 // write cp_info
a61af66fc99e Initial load
duke
parents:
diff changeset
398 // write constant type
a61af66fc99e Initial load
duke
parents:
diff changeset
399 switch(cpConstType) {
a61af66fc99e Initial load
duke
parents:
diff changeset
400 case JVM_CONSTANT_Utf8: {
a61af66fc99e Initial load
duke
parents:
diff changeset
401 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
402 Symbol sym = getSymbolAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
403 dos.writeShort((short)sym.getLength());
a61af66fc99e Initial load
duke
parents:
diff changeset
404 dos.write(sym.asByteArray());
a61af66fc99e Initial load
duke
parents:
diff changeset
405 if (DEBUG) debugMessage("CP[" + ci + "] = modified UTF-8 " + sym.asString());
a61af66fc99e Initial load
duke
parents:
diff changeset
406 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
407 }
a61af66fc99e Initial load
duke
parents:
diff changeset
408
a61af66fc99e Initial load
duke
parents:
diff changeset
409 case JVM_CONSTANT_Unicode:
a61af66fc99e Initial load
duke
parents:
diff changeset
410 throw new IllegalArgumentException("Unicode constant!");
a61af66fc99e Initial load
duke
parents:
diff changeset
411
a61af66fc99e Initial load
duke
parents:
diff changeset
412 case JVM_CONSTANT_Integer:
a61af66fc99e Initial load
duke
parents:
diff changeset
413 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
414 dos.writeInt(getIntAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
415 if (DEBUG) debugMessage("CP[" + ci + "] = int " + getIntAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
416 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
417
a61af66fc99e Initial load
duke
parents:
diff changeset
418 case JVM_CONSTANT_Float:
a61af66fc99e Initial load
duke
parents:
diff changeset
419 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
420 dos.writeFloat(getFloatAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
421 if (DEBUG) debugMessage("CP[" + ci + "] = float " + getFloatAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
422 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
423
a61af66fc99e Initial load
duke
parents:
diff changeset
424 case JVM_CONSTANT_Long: {
a61af66fc99e Initial load
duke
parents:
diff changeset
425 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
426 long l = getLongAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
427 // long entries occupy two pool entries
a61af66fc99e Initial load
duke
parents:
diff changeset
428 ci++;
a61af66fc99e Initial load
duke
parents:
diff changeset
429 dos.writeLong(l);
a61af66fc99e Initial load
duke
parents:
diff changeset
430 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
431 }
a61af66fc99e Initial load
duke
parents:
diff changeset
432
a61af66fc99e Initial load
duke
parents:
diff changeset
433 case JVM_CONSTANT_Double:
a61af66fc99e Initial load
duke
parents:
diff changeset
434 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
435 dos.writeDouble(getDoubleAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
436 // double entries occupy two pool entries
a61af66fc99e Initial load
duke
parents:
diff changeset
437 ci++;
a61af66fc99e Initial load
duke
parents:
diff changeset
438 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
439
a61af66fc99e Initial load
duke
parents:
diff changeset
440 case JVM_CONSTANT_Class: {
a61af66fc99e Initial load
duke
parents:
diff changeset
441 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
442 // Klass already resolved. ConstantPool constains klassOop.
a61af66fc99e Initial load
duke
parents:
diff changeset
443 Klass refKls = (Klass) getObjAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
444 String klassName = refKls.getName().asString();
a61af66fc99e Initial load
duke
parents:
diff changeset
445 Short s = (Short) utf8ToIndex.get(klassName);
a61af66fc99e Initial load
duke
parents:
diff changeset
446 dos.writeShort(s.shortValue());
a61af66fc99e Initial load
duke
parents:
diff changeset
447 if (DEBUG) debugMessage("CP[" + ci + "] = class " + s);
a61af66fc99e Initial load
duke
parents:
diff changeset
448 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
449 }
a61af66fc99e Initial load
duke
parents:
diff changeset
450
a61af66fc99e Initial load
duke
parents:
diff changeset
451 // case JVM_CONSTANT_ClassIndex:
1385
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
452 case JVM_CONSTANT_UnresolvedClassInError:
0
a61af66fc99e Initial load
duke
parents:
diff changeset
453 case JVM_CONSTANT_UnresolvedClass: {
a61af66fc99e Initial load
duke
parents:
diff changeset
454 dos.writeByte(JVM_CONSTANT_Class);
a61af66fc99e Initial load
duke
parents:
diff changeset
455 String klassName = getSymbolAt(ci).asString();
a61af66fc99e Initial load
duke
parents:
diff changeset
456 Short s = (Short) utf8ToIndex.get(klassName);
a61af66fc99e Initial load
duke
parents:
diff changeset
457 dos.writeShort(s.shortValue());
a61af66fc99e Initial load
duke
parents:
diff changeset
458 if (DEBUG) debugMessage("CP[" + ci + "] = class " + s);
a61af66fc99e Initial load
duke
parents:
diff changeset
459 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
460 }
a61af66fc99e Initial load
duke
parents:
diff changeset
461
a61af66fc99e Initial load
duke
parents:
diff changeset
462 case JVM_CONSTANT_String: {
a61af66fc99e Initial load
duke
parents:
diff changeset
463 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
464 String str = OopUtilities.stringOopToString(getObjAt(ci));
a61af66fc99e Initial load
duke
parents:
diff changeset
465 Short s = (Short) utf8ToIndex.get(str);
a61af66fc99e Initial load
duke
parents:
diff changeset
466 dos.writeShort(s.shortValue());
a61af66fc99e Initial load
duke
parents:
diff changeset
467 if (DEBUG) debugMessage("CP[" + ci + "] = string " + s);
a61af66fc99e Initial load
duke
parents:
diff changeset
468 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
469 }
a61af66fc99e Initial load
duke
parents:
diff changeset
470
a61af66fc99e Initial load
duke
parents:
diff changeset
471 // case JVM_CONSTANT_StringIndex:
a61af66fc99e Initial load
duke
parents:
diff changeset
472 case JVM_CONSTANT_UnresolvedString: {
a61af66fc99e Initial load
duke
parents:
diff changeset
473 dos.writeByte(JVM_CONSTANT_String);
a61af66fc99e Initial load
duke
parents:
diff changeset
474 String val = getSymbolAt(ci).asString();
a61af66fc99e Initial load
duke
parents:
diff changeset
475
a61af66fc99e Initial load
duke
parents:
diff changeset
476 Short s = (Short) utf8ToIndex.get(val);
a61af66fc99e Initial load
duke
parents:
diff changeset
477 dos.writeShort(s.shortValue());
a61af66fc99e Initial load
duke
parents:
diff changeset
478 if (DEBUG) debugMessage("CP[" + ci + "] = string " + s);
a61af66fc99e Initial load
duke
parents:
diff changeset
479 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
480 }
a61af66fc99e Initial load
duke
parents:
diff changeset
481
a61af66fc99e Initial load
duke
parents:
diff changeset
482 // all external, internal method/field references
a61af66fc99e Initial load
duke
parents:
diff changeset
483 case JVM_CONSTANT_Fieldref:
a61af66fc99e Initial load
duke
parents:
diff changeset
484 case JVM_CONSTANT_Methodref:
a61af66fc99e Initial load
duke
parents:
diff changeset
485 case JVM_CONSTANT_InterfaceMethodref: {
a61af66fc99e Initial load
duke
parents:
diff changeset
486 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
487 int value = getIntAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
488 short klassIndex = (short) extractLowShortFromInt(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
489 short nameAndTypeIndex = (short) extractHighShortFromInt(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
490 dos.writeShort(klassIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
491 dos.writeShort(nameAndTypeIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
492 if (DEBUG) debugMessage("CP[" + ci + "] = ref klass = " +
a61af66fc99e Initial load
duke
parents:
diff changeset
493 klassIndex + ", N&T = " + nameAndTypeIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
494 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
495 }
a61af66fc99e Initial load
duke
parents:
diff changeset
496
a61af66fc99e Initial load
duke
parents:
diff changeset
497 case JVM_CONSTANT_NameAndType: {
a61af66fc99e Initial load
duke
parents:
diff changeset
498 dos.writeByte(cpConstType);
a61af66fc99e Initial load
duke
parents:
diff changeset
499 int value = getIntAt(ci);
a61af66fc99e Initial load
duke
parents:
diff changeset
500 short nameIndex = (short) extractLowShortFromInt(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
501 short signatureIndex = (short) extractHighShortFromInt(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
502 dos.writeShort(nameIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
503 dos.writeShort(signatureIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
504 if (DEBUG) debugMessage("CP[" + ci + "] = N&T name = " + nameIndex
a61af66fc99e Initial load
duke
parents:
diff changeset
505 + ", type = " + signatureIndex);
a61af66fc99e Initial load
duke
parents:
diff changeset
506 break;
a61af66fc99e Initial load
duke
parents:
diff changeset
507 }
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
508
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
509 case JVM_CONSTANT_MethodHandle: {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
510 dos.writeByte(cpConstType);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
511 int value = getIntAt(ci);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
512 short nameIndex = (short) extractLowShortFromInt(value);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
513 short signatureIndex = (short) extractHighShortFromInt(value);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
514 dos.writeShort(nameIndex);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
515 dos.writeShort(signatureIndex);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
516 if (DEBUG) debugMessage("CP[" + ci + "] = N&T name = " + nameIndex
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
517 + ", type = " + signatureIndex);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
518 break;
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
519 }
1385
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
520 default:
bc32f286fae0 6945219: minor SA fixes
never
parents: 196
diff changeset
521 throw new InternalError("unknown tag: " + cpConstType);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
522 } // switch
a61af66fc99e Initial load
duke
parents:
diff changeset
523 }
a61af66fc99e Initial load
duke
parents:
diff changeset
524 dos.flush();
a61af66fc99e Initial load
duke
parents:
diff changeset
525 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
526 }
a61af66fc99e Initial load
duke
parents:
diff changeset
527
a61af66fc99e Initial load
duke
parents:
diff changeset
528 public void printValueOn(PrintStream tty) {
a61af66fc99e Initial load
duke
parents:
diff changeset
529 tty.print("ConstantPool for " + getPoolHolder().getName().asString());
a61af66fc99e Initial load
duke
parents:
diff changeset
530 }
a61af66fc99e Initial load
duke
parents:
diff changeset
531
a61af66fc99e Initial load
duke
parents:
diff changeset
532 public long getObjectSize() {
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
533 return alignObjectSize(headerSize + (getLength() * getElementSize()));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
534 }
a61af66fc99e Initial load
duke
parents:
diff changeset
535
a61af66fc99e Initial load
duke
parents:
diff changeset
536 //----------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
537 // Internals only below this point
a61af66fc99e Initial load
duke
parents:
diff changeset
538 //
a61af66fc99e Initial load
duke
parents:
diff changeset
539
a61af66fc99e Initial load
duke
parents:
diff changeset
540 private static int extractHighShortFromInt(int val) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
541 // must stay in sync with constantPoolOopDesc::name_and_type_at_put, method_at_put, etc.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
542 return (val >> 16) & 0xFFFF;
a61af66fc99e Initial load
duke
parents:
diff changeset
543 }
a61af66fc99e Initial load
duke
parents:
diff changeset
544
a61af66fc99e Initial load
duke
parents:
diff changeset
545 private static int extractLowShortFromInt(int val) {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
546 // must stay in sync with constantPoolOopDesc::name_and_type_at_put, method_at_put, etc.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
547 return val & 0xFFFF;
a61af66fc99e Initial load
duke
parents:
diff changeset
548 }
a61af66fc99e Initial load
duke
parents:
diff changeset
549 }