annotate agent/src/share/classes/sun/jvm/hotspot/oops/ConstantPoolCacheEntry.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 0a8e0d4345b3
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: 0
diff changeset
2 * Copyright (c) 2001, 2005, 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: 0
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
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: 0
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.util.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
28 import sun.jvm.hotspot.debugger.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
29 import sun.jvm.hotspot.runtime.*;
a61af66fc99e Initial load
duke
parents:
diff changeset
30 import sun.jvm.hotspot.types.*;
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
31 import sun.jvm.hotspot.utilities.*;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
32
a61af66fc99e Initial load
duke
parents:
diff changeset
33 public class ConstantPoolCacheEntry {
a61af66fc99e Initial load
duke
parents:
diff changeset
34 private static long size;
a61af66fc99e Initial load
duke
parents:
diff changeset
35 private static long baseOffset;
a61af66fc99e Initial load
duke
parents:
diff changeset
36 private static CIntegerField indices;
a61af66fc99e Initial load
duke
parents:
diff changeset
37 private static sun.jvm.hotspot.types.OopField f1;
a61af66fc99e Initial load
duke
parents:
diff changeset
38 private static CIntegerField f2;
a61af66fc99e Initial load
duke
parents:
diff changeset
39 private static CIntegerField flags;
a61af66fc99e Initial load
duke
parents:
diff changeset
40
a61af66fc99e Initial load
duke
parents:
diff changeset
41 private ConstantPoolCache cp;
a61af66fc99e Initial load
duke
parents:
diff changeset
42 private long offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
43
a61af66fc99e Initial load
duke
parents:
diff changeset
44 static {
a61af66fc99e Initial load
duke
parents:
diff changeset
45 VM.registerVMInitializedObserver(new Observer() {
a61af66fc99e Initial load
duke
parents:
diff changeset
46 public void update(Observable o, Object data) {
a61af66fc99e Initial load
duke
parents:
diff changeset
47 initialize(VM.getVM().getTypeDataBase());
a61af66fc99e Initial load
duke
parents:
diff changeset
48 }
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 private static synchronized void initialize(TypeDataBase db) throws WrongTypeException {
a61af66fc99e Initial load
duke
parents:
diff changeset
53 Type type = db.lookupType("ConstantPoolCacheEntry");
a61af66fc99e Initial load
duke
parents:
diff changeset
54 size = type.getSize();
a61af66fc99e Initial load
duke
parents:
diff changeset
55
a61af66fc99e Initial load
duke
parents:
diff changeset
56 indices = type.getCIntegerField("_indices");
a61af66fc99e Initial load
duke
parents:
diff changeset
57 f1 = type.getOopField ("_f1");
a61af66fc99e Initial load
duke
parents:
diff changeset
58 f2 = type.getCIntegerField("_f2");
a61af66fc99e Initial load
duke
parents:
diff changeset
59 flags = type.getCIntegerField("_flags");
a61af66fc99e Initial load
duke
parents:
diff changeset
60
a61af66fc99e Initial load
duke
parents:
diff changeset
61 type = db.lookupType("constantPoolCacheOopDesc");
a61af66fc99e Initial load
duke
parents:
diff changeset
62 baseOffset = type.getSize();
a61af66fc99e Initial load
duke
parents:
diff changeset
63 }
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65 ConstantPoolCacheEntry(ConstantPoolCache cp, int index) {
a61af66fc99e Initial load
duke
parents:
diff changeset
66 this.cp = cp;
a61af66fc99e Initial load
duke
parents:
diff changeset
67 offset = baseOffset + index * size;
a61af66fc99e Initial load
duke
parents:
diff changeset
68 }
a61af66fc99e Initial load
duke
parents:
diff changeset
69
a61af66fc99e Initial load
duke
parents:
diff changeset
70 public int getConstantPoolIndex() {
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
71 if (Assert.ASSERTS_ENABLED) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
72 Assert.that(!isSecondaryEntry(), "must not be a secondary CP entry");
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
73 }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
74 return (int) (getIndices() & 0xFFFF);
a61af66fc99e Initial load
duke
parents:
diff changeset
75 }
a61af66fc99e Initial load
duke
parents:
diff changeset
76
1602
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
77 public boolean isSecondaryEntry() {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
78 return (getIndices() & 0xFFFF) == 0;
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
79 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
80
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
81 public int getMainEntryIndex() {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
82 if (Assert.ASSERTS_ENABLED) {
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
83 Assert.that(isSecondaryEntry(), "must be a secondary CP entry");
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
84 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
85 return (int) (getIndices() >>> 16);
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
86 }
136b78722a08 6939203: JSR 292 needs method handle constants
jrose
parents: 1552
diff changeset
87
0
a61af66fc99e Initial load
duke
parents:
diff changeset
88 private long getIndices() {
a61af66fc99e Initial load
duke
parents:
diff changeset
89 return cp.getHandle().getCIntegerAt(indices.getOffset() + offset, indices.getSize(), indices.isUnsigned());
a61af66fc99e Initial load
duke
parents:
diff changeset
90 }
a61af66fc99e Initial load
duke
parents:
diff changeset
91
a61af66fc99e Initial load
duke
parents:
diff changeset
92 public Oop getF1() {
a61af66fc99e Initial load
duke
parents:
diff changeset
93 return cp.getHeap().newOop(cp.getHandle().getOopHandleAt(f1.getOffset() + offset));
a61af66fc99e Initial load
duke
parents:
diff changeset
94 }
a61af66fc99e Initial load
duke
parents:
diff changeset
95
a61af66fc99e Initial load
duke
parents:
diff changeset
96 public int getF2() {
a61af66fc99e Initial load
duke
parents:
diff changeset
97 return cp.getHandle().getJIntAt(f1.getOffset() + offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
98 }
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100 public int getFlags() {
a61af66fc99e Initial load
duke
parents:
diff changeset
101 return cp.getHandle().getJIntAt(flags.getOffset() + offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
102 }
a61af66fc99e Initial load
duke
parents:
diff changeset
103
a61af66fc99e Initial load
duke
parents:
diff changeset
104 static NamedFieldIdentifier f1FieldName = new NamedFieldIdentifier("_f1");
a61af66fc99e Initial load
duke
parents:
diff changeset
105 static NamedFieldIdentifier f2FieldName = new NamedFieldIdentifier("_f2");
a61af66fc99e Initial load
duke
parents:
diff changeset
106 static NamedFieldIdentifier flagsFieldName = new NamedFieldIdentifier("_flags");
a61af66fc99e Initial load
duke
parents:
diff changeset
107
a61af66fc99e Initial load
duke
parents:
diff changeset
108 public void iterateFields(OopVisitor visitor) {
a61af66fc99e Initial load
duke
parents:
diff changeset
109 visitor.doOop(new OopField(f1FieldName, f1.getOffset() + offset, true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
110 visitor.doInt(new IntField(f2FieldName, f2.getOffset() + offset, true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
111 visitor.doInt(new IntField(flagsFieldName, flags.getOffset() + offset, true), true);
a61af66fc99e Initial load
duke
parents:
diff changeset
112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
113 }