annotate src/share/vm/oops/methodOop.hpp @ 1091:6aa7255741f3

6906727: UseCompressedOops: some card-marking fixes related to object arrays Summary: Introduced a new write_ref_array(HeapWords* start, size_t count) method that does the requisite MemRegion range calculation so (some of the) clients of the erstwhile write_ref_array(MemRegion mr) do not need to worry. This removed all external uses of array_size(), which was also simplified and made private. Asserts were added to catch other possible issues. Further, less essential, fixes stemming from this investigation are deferred to CR 6904516 (to follow shortly in hs17). Reviewed-by: kvn, coleenp, jmasa
author ysr
date Thu, 03 Dec 2009 15:01:57 -0800
parents 74a5db69c1fe
children dd57230ba8fe
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
579
0fbdb4381b99 6814575: Update copyright year
xdono
parents: 518
diff changeset
2 * Copyright 1997-2009 Sun Microsystems, Inc. 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 *
a61af66fc99e Initial load
duke
parents:
diff changeset
19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara,
a61af66fc99e Initial load
duke
parents:
diff changeset
20 * CA 95054 USA or visit www.sun.com if you need additional information or
a61af66fc99e Initial load
duke
parents:
diff changeset
21 * have any questions.
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 // A methodOop represents a Java method.
a61af66fc99e Initial load
duke
parents:
diff changeset
26 //
a61af66fc99e Initial load
duke
parents:
diff changeset
27 // Memory layout (each line represents a word). Note that most applications load thousands of methods,
a61af66fc99e Initial load
duke
parents:
diff changeset
28 // so keeping the size of this structure small has a big impact on footprint.
a61af66fc99e Initial load
duke
parents:
diff changeset
29 //
a61af66fc99e Initial load
duke
parents:
diff changeset
30 // We put all oops and method_size first for better gc cache locality.
a61af66fc99e Initial load
duke
parents:
diff changeset
31 //
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // The actual bytecodes are inlined after the end of the methodOopDesc struct.
a61af66fc99e Initial load
duke
parents:
diff changeset
33 //
a61af66fc99e Initial load
duke
parents:
diff changeset
34 // There are bits in the access_flags telling whether inlined tables are present.
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // Note that accessing the line number and local variable tables is not performance critical at all.
a61af66fc99e Initial load
duke
parents:
diff changeset
36 // Accessing the checked exceptions table is used by reflection, so we put that last to make access
a61af66fc99e Initial load
duke
parents:
diff changeset
37 // to it fast.
a61af66fc99e Initial load
duke
parents:
diff changeset
38 //
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // The line number table is compressed and inlined following the byte codes. It is found as the first
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // byte following the byte codes. The checked exceptions table and the local variable table are inlined
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // after the line number table, and indexed from the end of the method. We do not compress the checked
a61af66fc99e Initial load
duke
parents:
diff changeset
42 // exceptions table since the average length is less than 2, and do not bother to compress the local
a61af66fc99e Initial load
duke
parents:
diff changeset
43 // variable table either since it is mostly absent.
a61af66fc99e Initial load
duke
parents:
diff changeset
44 //
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // Note that native_function and signature_handler has to be at fixed offsets (required by the interpreter)
a61af66fc99e Initial load
duke
parents:
diff changeset
46 //
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // | header |
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // | klass |
a61af66fc99e Initial load
duke
parents:
diff changeset
50 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
51 // | constMethodOop (oop) |
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // | constants (oop) |
a61af66fc99e Initial load
duke
parents:
diff changeset
53 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
54 // | methodData (oop) |
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // | interp_invocation_count |
a61af66fc99e Initial load
duke
parents:
diff changeset
56 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // | access_flags |
a61af66fc99e Initial load
duke
parents:
diff changeset
58 // | vtable_index |
a61af66fc99e Initial load
duke
parents:
diff changeset
59 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
60 // | result_index (C++ interpreter only) |
a61af66fc99e Initial load
duke
parents:
diff changeset
61 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
62 // | method_size | max_stack |
a61af66fc99e Initial load
duke
parents:
diff changeset
63 // | max_locals | size_of_parameters |
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
65 // | intrinsic_id, highest_tier | (unused) |
a61af66fc99e Initial load
duke
parents:
diff changeset
66 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
67 // | throwout_count | num_breakpoints |
a61af66fc99e Initial load
duke
parents:
diff changeset
68 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
69 // | invocation_counter |
a61af66fc99e Initial load
duke
parents:
diff changeset
70 // | backedge_counter |
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
72 // | code (pointer) |
a61af66fc99e Initial load
duke
parents:
diff changeset
73 // | i2i (pointer) |
a61af66fc99e Initial load
duke
parents:
diff changeset
74 // | adapter (pointer) |
a61af66fc99e Initial load
duke
parents:
diff changeset
75 // | from_compiled_entry (pointer) |
a61af66fc99e Initial load
duke
parents:
diff changeset
76 // | from_interpreted_entry (pointer) |
a61af66fc99e Initial load
duke
parents:
diff changeset
77 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
78 // | native_function (present only if native) |
a61af66fc99e Initial load
duke
parents:
diff changeset
79 // | signature_handler (present only if native) |
a61af66fc99e Initial load
duke
parents:
diff changeset
80 // |------------------------------------------------------|
a61af66fc99e Initial load
duke
parents:
diff changeset
81
a61af66fc99e Initial load
duke
parents:
diff changeset
82
a61af66fc99e Initial load
duke
parents:
diff changeset
83 class CheckedExceptionElement;
a61af66fc99e Initial load
duke
parents:
diff changeset
84 class LocalVariableTableElement;
a61af66fc99e Initial load
duke
parents:
diff changeset
85 class AdapterHandlerEntry;
a61af66fc99e Initial load
duke
parents:
diff changeset
86
a61af66fc99e Initial load
duke
parents:
diff changeset
87 class methodDataOopDesc;
a61af66fc99e Initial load
duke
parents:
diff changeset
88
a61af66fc99e Initial load
duke
parents:
diff changeset
89 class methodOopDesc : public oopDesc {
a61af66fc99e Initial load
duke
parents:
diff changeset
90 friend class methodKlass;
a61af66fc99e Initial load
duke
parents:
diff changeset
91 friend class VMStructs;
a61af66fc99e Initial load
duke
parents:
diff changeset
92 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
93 constMethodOop _constMethod; // Method read-only data.
a61af66fc99e Initial load
duke
parents:
diff changeset
94 constantPoolOop _constants; // Constant pool
a61af66fc99e Initial load
duke
parents:
diff changeset
95 methodDataOop _method_data;
a61af66fc99e Initial load
duke
parents:
diff changeset
96 int _interpreter_invocation_count; // Count of times invoked
a61af66fc99e Initial load
duke
parents:
diff changeset
97 AccessFlags _access_flags; // Access flags
a61af66fc99e Initial load
duke
parents:
diff changeset
98 int _vtable_index; // vtable index of this method (see VtableIndexFlag)
a61af66fc99e Initial load
duke
parents:
diff changeset
99 // note: can have vtables with >2**16 elements (because of inheritance)
a61af66fc99e Initial load
duke
parents:
diff changeset
100 #ifdef CC_INTERP
a61af66fc99e Initial load
duke
parents:
diff changeset
101 int _result_index; // C++ interpreter needs for converting results to/from stack
a61af66fc99e Initial load
duke
parents:
diff changeset
102 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
103 u2 _method_size; // size of this object
a61af66fc99e Initial load
duke
parents:
diff changeset
104 u2 _max_stack; // Maximum number of entries on the expression stack
a61af66fc99e Initial load
duke
parents:
diff changeset
105 u2 _max_locals; // Number of local variables used by this method
a61af66fc99e Initial load
duke
parents:
diff changeset
106 u2 _size_of_parameters; // size of the parameter block (receiver + arguments) in words
856
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
107 u1 _intrinsic_id; // vmSymbols::intrinsic_id (0 == _none)
0
a61af66fc99e Initial load
duke
parents:
diff changeset
108 u1 _highest_tier_compile; // Highest compile level this method has ever seen.
a61af66fc99e Initial load
duke
parents:
diff changeset
109 u2 _interpreter_throwout_count; // Count of times method was exited via exception while interpreting
a61af66fc99e Initial load
duke
parents:
diff changeset
110 u2 _number_of_breakpoints; // fullspeed debugging support
a61af66fc99e Initial load
duke
parents:
diff changeset
111 InvocationCounter _invocation_counter; // Incremented before each activation of the method - used to trigger frequency-based optimizations
a61af66fc99e Initial load
duke
parents:
diff changeset
112 InvocationCounter _backedge_counter; // Incremented before each backedge taken - used to trigger frequencey-based optimizations
a61af66fc99e Initial load
duke
parents:
diff changeset
113 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
114 int _compiled_invocation_count; // Number of nmethod invocations so far (for perf. debugging)
a61af66fc99e Initial load
duke
parents:
diff changeset
115 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
116 // Entry point for calling both from and to the interpreter.
a61af66fc99e Initial load
duke
parents:
diff changeset
117 address _i2i_entry; // All-args-on-stack calling convention
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // Adapter blob (i2c/c2i) for this methodOop. Set once when method is linked.
a61af66fc99e Initial load
duke
parents:
diff changeset
119 AdapterHandlerEntry* _adapter;
a61af66fc99e Initial load
duke
parents:
diff changeset
120 // Entry point for calling from compiled code, to compiled code if it exists
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // or else the interpreter.
a61af66fc99e Initial load
duke
parents:
diff changeset
122 volatile address _from_compiled_entry; // Cache of: _code ? _code->entry_point() : _adapter->c2i_entry()
a61af66fc99e Initial load
duke
parents:
diff changeset
123 // The entry point for calling both from and to compiled code is
a61af66fc99e Initial load
duke
parents:
diff changeset
124 // "_code->entry_point()". Because of tiered compilation and de-opt, this
a61af66fc99e Initial load
duke
parents:
diff changeset
125 // field can come and go. It can transition from NULL to not-null at any
a61af66fc99e Initial load
duke
parents:
diff changeset
126 // time (whenever a compile completes). It can transition from not-null to
a61af66fc99e Initial load
duke
parents:
diff changeset
127 // NULL only at safepoints (because of a de-opt).
a61af66fc99e Initial load
duke
parents:
diff changeset
128 nmethod* volatile _code; // Points to the corresponding piece of native code
a61af66fc99e Initial load
duke
parents:
diff changeset
129 volatile address _from_interpreted_entry; // Cache of _code ? _adapter->i2c_entry() : _i2i_entry
a61af66fc99e Initial load
duke
parents:
diff changeset
130
a61af66fc99e Initial load
duke
parents:
diff changeset
131 public:
518
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 196
diff changeset
132
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 196
diff changeset
133 static const bool IsUnsafeConc = false;
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 196
diff changeset
134 static const bool IsSafeConc = true;
0af8b0718fc9 6692899: CMS: many vm.parallel_class_loading tests fail with assert "missing Printezis mark"
jmasa
parents: 196
diff changeset
135
0
a61af66fc99e Initial load
duke
parents:
diff changeset
136 // accessors for instance variables
a61af66fc99e Initial load
duke
parents:
diff changeset
137 constMethodOop constMethod() const { return _constMethod; }
a61af66fc99e Initial load
duke
parents:
diff changeset
138 void set_constMethod(constMethodOop xconst) { oop_store_without_check((oop*)&_constMethod, (oop)xconst); }
a61af66fc99e Initial load
duke
parents:
diff changeset
139
a61af66fc99e Initial load
duke
parents:
diff changeset
140
a61af66fc99e Initial load
duke
parents:
diff changeset
141 static address make_adapters(methodHandle mh, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
142 volatile address from_compiled_entry() const { return (address)OrderAccess::load_ptr_acquire(&_from_compiled_entry); }
a61af66fc99e Initial load
duke
parents:
diff changeset
143 volatile address from_interpreted_entry() const{ return (address)OrderAccess::load_ptr_acquire(&_from_interpreted_entry); }
a61af66fc99e Initial load
duke
parents:
diff changeset
144
a61af66fc99e Initial load
duke
parents:
diff changeset
145 // access flag
a61af66fc99e Initial load
duke
parents:
diff changeset
146 AccessFlags access_flags() const { return _access_flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
147 void set_access_flags(AccessFlags flags) { _access_flags = flags; }
a61af66fc99e Initial load
duke
parents:
diff changeset
148
a61af66fc99e Initial load
duke
parents:
diff changeset
149 // name
a61af66fc99e Initial load
duke
parents:
diff changeset
150 symbolOop name() const { return _constants->symbol_at(name_index()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
151 int name_index() const { return constMethod()->name_index(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
152 void set_name_index(int index) { constMethod()->set_name_index(index); }
a61af66fc99e Initial load
duke
parents:
diff changeset
153
a61af66fc99e Initial load
duke
parents:
diff changeset
154 // signature
a61af66fc99e Initial load
duke
parents:
diff changeset
155 symbolOop signature() const { return _constants->symbol_at(signature_index()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
156 int signature_index() const { return constMethod()->signature_index(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
157 void set_signature_index(int index) { constMethod()->set_signature_index(index); }
a61af66fc99e Initial load
duke
parents:
diff changeset
158
a61af66fc99e Initial load
duke
parents:
diff changeset
159 // generics support
a61af66fc99e Initial load
duke
parents:
diff changeset
160 symbolOop generic_signature() const { int idx = generic_signature_index(); return ((idx != 0) ? _constants->symbol_at(idx) : (symbolOop)NULL); }
a61af66fc99e Initial load
duke
parents:
diff changeset
161 int generic_signature_index() const { return constMethod()->generic_signature_index(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
162 void set_generic_signature_index(int index) { constMethod()->set_generic_signature_index(index); }
a61af66fc99e Initial load
duke
parents:
diff changeset
163
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // annotations support
a61af66fc99e Initial load
duke
parents:
diff changeset
165 typeArrayOop annotations() const { return instanceKlass::cast(method_holder())->get_method_annotations_of(method_idnum()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
166 typeArrayOop parameter_annotations() const { return instanceKlass::cast(method_holder())->get_method_parameter_annotations_of(method_idnum()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
167 typeArrayOop annotation_default() const { return instanceKlass::cast(method_holder())->get_method_default_annotations_of(method_idnum()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169 #ifdef CC_INTERP
a61af66fc99e Initial load
duke
parents:
diff changeset
170 void set_result_index(BasicType type);
a61af66fc99e Initial load
duke
parents:
diff changeset
171 int result_index() { return _result_index; }
a61af66fc99e Initial load
duke
parents:
diff changeset
172 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
173
a61af66fc99e Initial load
duke
parents:
diff changeset
174 // Helper routine: get klass name + "." + method name + signature as
a61af66fc99e Initial load
duke
parents:
diff changeset
175 // C string, for the purpose of providing more useful NoSuchMethodErrors
a61af66fc99e Initial load
duke
parents:
diff changeset
176 // and fatal error handling. The string is allocated in resource
a61af66fc99e Initial load
duke
parents:
diff changeset
177 // area if a buffer is not provided by the caller.
a61af66fc99e Initial load
duke
parents:
diff changeset
178 char* name_and_sig_as_C_string();
a61af66fc99e Initial load
duke
parents:
diff changeset
179 char* name_and_sig_as_C_string(char* buf, int size);
a61af66fc99e Initial load
duke
parents:
diff changeset
180
a61af66fc99e Initial load
duke
parents:
diff changeset
181 // Static routine in the situations we don't have a methodOop
a61af66fc99e Initial load
duke
parents:
diff changeset
182 static char* name_and_sig_as_C_string(Klass* klass, symbolOop method_name, symbolOop signature);
a61af66fc99e Initial load
duke
parents:
diff changeset
183 static char* name_and_sig_as_C_string(Klass* klass, symbolOop method_name, symbolOop signature, char* buf, int size);
a61af66fc99e Initial load
duke
parents:
diff changeset
184
a61af66fc99e Initial load
duke
parents:
diff changeset
185 // JVMTI breakpoints
a61af66fc99e Initial load
duke
parents:
diff changeset
186 Bytecodes::Code orig_bytecode_at(int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
187 void set_orig_bytecode_at(int bci, Bytecodes::Code code);
a61af66fc99e Initial load
duke
parents:
diff changeset
188 void set_breakpoint(int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
189 void clear_breakpoint(int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
190 void clear_all_breakpoints();
a61af66fc99e Initial load
duke
parents:
diff changeset
191 // Tracking number of breakpoints, for fullspeed debugging.
a61af66fc99e Initial load
duke
parents:
diff changeset
192 // Only mutated by VM thread.
a61af66fc99e Initial load
duke
parents:
diff changeset
193 u2 number_of_breakpoints() const { return _number_of_breakpoints; }
a61af66fc99e Initial load
duke
parents:
diff changeset
194 void incr_number_of_breakpoints() { ++_number_of_breakpoints; }
a61af66fc99e Initial load
duke
parents:
diff changeset
195 void decr_number_of_breakpoints() { --_number_of_breakpoints; }
a61af66fc99e Initial load
duke
parents:
diff changeset
196 // Initialization only
a61af66fc99e Initial load
duke
parents:
diff changeset
197 void clear_number_of_breakpoints() { _number_of_breakpoints = 0; }
a61af66fc99e Initial load
duke
parents:
diff changeset
198
a61af66fc99e Initial load
duke
parents:
diff changeset
199 // index into instanceKlass methods() array
a61af66fc99e Initial load
duke
parents:
diff changeset
200 u2 method_idnum() const { return constMethod()->method_idnum(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
201 void set_method_idnum(u2 idnum) { constMethod()->set_method_idnum(idnum); }
a61af66fc99e Initial load
duke
parents:
diff changeset
202
a61af66fc99e Initial load
duke
parents:
diff changeset
203 // code size
a61af66fc99e Initial load
duke
parents:
diff changeset
204 int code_size() const { return constMethod()->code_size(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 // method size
a61af66fc99e Initial load
duke
parents:
diff changeset
207 int method_size() const { return _method_size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
208 void set_method_size(int size) {
a61af66fc99e Initial load
duke
parents:
diff changeset
209 assert(0 <= size && size < (1 << 16), "invalid method size");
a61af66fc99e Initial load
duke
parents:
diff changeset
210 _method_size = size;
a61af66fc99e Initial load
duke
parents:
diff changeset
211 }
a61af66fc99e Initial load
duke
parents:
diff changeset
212
a61af66fc99e Initial load
duke
parents:
diff changeset
213 // constant pool for klassOop holding this method
a61af66fc99e Initial load
duke
parents:
diff changeset
214 constantPoolOop constants() const { return _constants; }
a61af66fc99e Initial load
duke
parents:
diff changeset
215 void set_constants(constantPoolOop c) { oop_store_without_check((oop*)&_constants, c); }
a61af66fc99e Initial load
duke
parents:
diff changeset
216
a61af66fc99e Initial load
duke
parents:
diff changeset
217 // max stack
a61af66fc99e Initial load
duke
parents:
diff changeset
218 int max_stack() const { return _max_stack; }
a61af66fc99e Initial load
duke
parents:
diff changeset
219 void set_max_stack(int size) { _max_stack = size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
220
a61af66fc99e Initial load
duke
parents:
diff changeset
221 // max locals
a61af66fc99e Initial load
duke
parents:
diff changeset
222 int max_locals() const { return _max_locals; }
a61af66fc99e Initial load
duke
parents:
diff changeset
223 void set_max_locals(int size) { _max_locals = size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
224 int highest_tier_compile() { return _highest_tier_compile;}
a61af66fc99e Initial load
duke
parents:
diff changeset
225 void set_highest_tier_compile(int level) { _highest_tier_compile = level;}
a61af66fc99e Initial load
duke
parents:
diff changeset
226
a61af66fc99e Initial load
duke
parents:
diff changeset
227 // Count of times method was exited via exception while interpreting
a61af66fc99e Initial load
duke
parents:
diff changeset
228 void interpreter_throwout_increment() {
a61af66fc99e Initial load
duke
parents:
diff changeset
229 if (_interpreter_throwout_count < 65534) {
a61af66fc99e Initial load
duke
parents:
diff changeset
230 _interpreter_throwout_count++;
a61af66fc99e Initial load
duke
parents:
diff changeset
231 }
a61af66fc99e Initial load
duke
parents:
diff changeset
232 }
a61af66fc99e Initial load
duke
parents:
diff changeset
233
a61af66fc99e Initial load
duke
parents:
diff changeset
234 int interpreter_throwout_count() const { return _interpreter_throwout_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
235 void set_interpreter_throwout_count(int count) { _interpreter_throwout_count = count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
236
a61af66fc99e Initial load
duke
parents:
diff changeset
237 // size of parameters
a61af66fc99e Initial load
duke
parents:
diff changeset
238 int size_of_parameters() const { return _size_of_parameters; }
a61af66fc99e Initial load
duke
parents:
diff changeset
239
a61af66fc99e Initial load
duke
parents:
diff changeset
240 bool has_stackmap_table() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
241 return constMethod()->has_stackmap_table();
a61af66fc99e Initial load
duke
parents:
diff changeset
242 }
a61af66fc99e Initial load
duke
parents:
diff changeset
243
a61af66fc99e Initial load
duke
parents:
diff changeset
244 typeArrayOop stackmap_data() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
245 return constMethod()->stackmap_data();
a61af66fc99e Initial load
duke
parents:
diff changeset
246 }
a61af66fc99e Initial load
duke
parents:
diff changeset
247
a61af66fc99e Initial load
duke
parents:
diff changeset
248 // exception handler table
a61af66fc99e Initial load
duke
parents:
diff changeset
249 typeArrayOop exception_table() const
a61af66fc99e Initial load
duke
parents:
diff changeset
250 { return constMethod()->exception_table(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
251 void set_exception_table(typeArrayOop e)
a61af66fc99e Initial load
duke
parents:
diff changeset
252 { constMethod()->set_exception_table(e); }
a61af66fc99e Initial load
duke
parents:
diff changeset
253 bool has_exception_handler() const
a61af66fc99e Initial load
duke
parents:
diff changeset
254 { return constMethod()->has_exception_handler(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
255
a61af66fc99e Initial load
duke
parents:
diff changeset
256 // Finds the first entry point bci of an exception handler for an
a61af66fc99e Initial load
duke
parents:
diff changeset
257 // exception of klass ex_klass thrown at throw_bci. A value of NULL
a61af66fc99e Initial load
duke
parents:
diff changeset
258 // for ex_klass indicates that the exception klass is not known; in
a61af66fc99e Initial load
duke
parents:
diff changeset
259 // this case it matches any constraint class. Returns -1 if the
a61af66fc99e Initial load
duke
parents:
diff changeset
260 // exception cannot be handled in this method. The handler
a61af66fc99e Initial load
duke
parents:
diff changeset
261 // constraint classes are loaded if necessary. Note that this may
a61af66fc99e Initial load
duke
parents:
diff changeset
262 // throw an exception if loading of the constraint classes causes
a61af66fc99e Initial load
duke
parents:
diff changeset
263 // an IllegalAccessError (bugid 4307310) or an OutOfMemoryError.
a61af66fc99e Initial load
duke
parents:
diff changeset
264 // If an exception is thrown, returns the bci of the
a61af66fc99e Initial load
duke
parents:
diff changeset
265 // exception handler which caused the exception to be thrown, which
a61af66fc99e Initial load
duke
parents:
diff changeset
266 // is needed for proper retries. See, for example,
a61af66fc99e Initial load
duke
parents:
diff changeset
267 // InterpreterRuntime::exception_handler_for_exception.
a61af66fc99e Initial load
duke
parents:
diff changeset
268 int fast_exception_handler_bci_for(KlassHandle ex_klass, int throw_bci, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
269
a61af66fc99e Initial load
duke
parents:
diff changeset
270 // method data access
a61af66fc99e Initial load
duke
parents:
diff changeset
271 methodDataOop method_data() const {
a61af66fc99e Initial load
duke
parents:
diff changeset
272 return _method_data;
a61af66fc99e Initial load
duke
parents:
diff changeset
273 }
a61af66fc99e Initial load
duke
parents:
diff changeset
274 void set_method_data(methodDataOop data) {
a61af66fc99e Initial load
duke
parents:
diff changeset
275 oop_store_without_check((oop*)&_method_data, (oop)data);
a61af66fc99e Initial load
duke
parents:
diff changeset
276 }
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 // invocation counter
a61af66fc99e Initial load
duke
parents:
diff changeset
279 InvocationCounter* invocation_counter() { return &_invocation_counter; }
a61af66fc99e Initial load
duke
parents:
diff changeset
280 InvocationCounter* backedge_counter() { return &_backedge_counter; }
a61af66fc99e Initial load
duke
parents:
diff changeset
281 int invocation_count() const { return _invocation_counter.count(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
282 int backedge_count() const { return _backedge_counter.count(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
283 bool was_executed_more_than(int n) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
284 bool was_never_executed() const { return !was_executed_more_than(0); }
a61af66fc99e Initial load
duke
parents:
diff changeset
285
a61af66fc99e Initial load
duke
parents:
diff changeset
286 static void build_interpreter_method_data(methodHandle method, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
287
a61af66fc99e Initial load
duke
parents:
diff changeset
288 int interpreter_invocation_count() const { return _interpreter_invocation_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
289 void set_interpreter_invocation_count(int count) { _interpreter_invocation_count = count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
290 int increment_interpreter_invocation_count() { return ++_interpreter_invocation_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
291
a61af66fc99e Initial load
duke
parents:
diff changeset
292 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
293 int compiled_invocation_count() const { return _compiled_invocation_count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
294 void set_compiled_invocation_count(int count) { _compiled_invocation_count = count; }
a61af66fc99e Initial load
duke
parents:
diff changeset
295 #endif // not PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
296
605
98cb887364d3 6810672: Comment typos
twisti
parents: 518
diff changeset
297 // Clear (non-shared space) pointers which could not be relevant
0
a61af66fc99e Initial load
duke
parents:
diff changeset
298 // if this (shared) method were mapped into another JVM.
a61af66fc99e Initial load
duke
parents:
diff changeset
299 void remove_unshareable_info();
a61af66fc99e Initial load
duke
parents:
diff changeset
300
a61af66fc99e Initial load
duke
parents:
diff changeset
301 // nmethod/verified compiler entry
a61af66fc99e Initial load
duke
parents:
diff changeset
302 address verified_code_entry();
a61af66fc99e Initial load
duke
parents:
diff changeset
303 bool check_code() const; // Not inline to avoid circular ref
a61af66fc99e Initial load
duke
parents:
diff changeset
304 nmethod* volatile code() const { assert( check_code(), "" ); return (nmethod *)OrderAccess::load_ptr_acquire(&_code); }
a61af66fc99e Initial load
duke
parents:
diff changeset
305 void clear_code(); // Clear out any compiled code
a61af66fc99e Initial load
duke
parents:
diff changeset
306 void set_code(methodHandle mh, nmethod* code);
a61af66fc99e Initial load
duke
parents:
diff changeset
307 void set_adapter_entry(AdapterHandlerEntry* adapter) { _adapter = adapter; }
a61af66fc99e Initial load
duke
parents:
diff changeset
308 address get_i2c_entry();
a61af66fc99e Initial load
duke
parents:
diff changeset
309 address get_c2i_entry();
a61af66fc99e Initial load
duke
parents:
diff changeset
310 address get_c2i_unverified_entry();
a61af66fc99e Initial load
duke
parents:
diff changeset
311 AdapterHandlerEntry* adapter() { return _adapter; }
a61af66fc99e Initial load
duke
parents:
diff changeset
312 // setup entry points
a61af66fc99e Initial load
duke
parents:
diff changeset
313 void link_method(methodHandle method, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
314 // clear entry points. Used by sharing code
a61af66fc99e Initial load
duke
parents:
diff changeset
315 void unlink_method();
a61af66fc99e Initial load
duke
parents:
diff changeset
316
a61af66fc99e Initial load
duke
parents:
diff changeset
317 // vtable index
a61af66fc99e Initial load
duke
parents:
diff changeset
318 enum VtableIndexFlag {
a61af66fc99e Initial load
duke
parents:
diff changeset
319 // Valid vtable indexes are non-negative (>= 0).
a61af66fc99e Initial load
duke
parents:
diff changeset
320 // These few negative values are used as sentinels.
710
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
321 highest_unused_vtable_index_value = -5,
0
a61af66fc99e Initial load
duke
parents:
diff changeset
322 invalid_vtable_index = -4, // distinct from any valid vtable index
a61af66fc99e Initial load
duke
parents:
diff changeset
323 garbage_vtable_index = -3, // not yet linked; no vtable layout yet
a61af66fc99e Initial load
duke
parents:
diff changeset
324 nonvirtual_vtable_index = -2 // there is no need for vtable dispatch
a61af66fc99e Initial load
duke
parents:
diff changeset
325 // 6330203 Note: Do not use -1, which was overloaded with many meanings.
a61af66fc99e Initial load
duke
parents:
diff changeset
326 };
a61af66fc99e Initial load
duke
parents:
diff changeset
327 DEBUG_ONLY(bool valid_vtable_index() const { return _vtable_index >= nonvirtual_vtable_index; })
a61af66fc99e Initial load
duke
parents:
diff changeset
328 int vtable_index() const { assert(valid_vtable_index(), "");
a61af66fc99e Initial load
duke
parents:
diff changeset
329 return _vtable_index; }
a61af66fc99e Initial load
duke
parents:
diff changeset
330 void set_vtable_index(int index) { _vtable_index = index; }
a61af66fc99e Initial load
duke
parents:
diff changeset
331
a61af66fc99e Initial load
duke
parents:
diff changeset
332 // interpreter entry
a61af66fc99e Initial load
duke
parents:
diff changeset
333 address interpreter_entry() const { return _i2i_entry; }
a61af66fc99e Initial load
duke
parents:
diff changeset
334 // Only used when first initialize so we can set _i2i_entry and _from_interpreted_entry
a61af66fc99e Initial load
duke
parents:
diff changeset
335 void set_interpreter_entry(address entry) { _i2i_entry = entry; _from_interpreted_entry = entry; }
a61af66fc99e Initial load
duke
parents:
diff changeset
336 int interpreter_kind(void) {
a61af66fc99e Initial load
duke
parents:
diff changeset
337 return constMethod()->interpreter_kind();
a61af66fc99e Initial load
duke
parents:
diff changeset
338 }
a61af66fc99e Initial load
duke
parents:
diff changeset
339 void set_interpreter_kind();
a61af66fc99e Initial load
duke
parents:
diff changeset
340 void set_interpreter_kind(int kind) {
a61af66fc99e Initial load
duke
parents:
diff changeset
341 constMethod()->set_interpreter_kind(kind);
a61af66fc99e Initial load
duke
parents:
diff changeset
342 }
a61af66fc99e Initial load
duke
parents:
diff changeset
343
a61af66fc99e Initial load
duke
parents:
diff changeset
344 // native function (used for native methods only)
a61af66fc99e Initial load
duke
parents:
diff changeset
345 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
346 native_bind_event_is_interesting = true
a61af66fc99e Initial load
duke
parents:
diff changeset
347 };
a61af66fc99e Initial load
duke
parents:
diff changeset
348 address native_function() const { return *(native_function_addr()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
349 // Must specify a real function (not NULL).
a61af66fc99e Initial load
duke
parents:
diff changeset
350 // Use clear_native_function() to unregister.
a61af66fc99e Initial load
duke
parents:
diff changeset
351 void set_native_function(address function, bool post_event_flag);
a61af66fc99e Initial load
duke
parents:
diff changeset
352 bool has_native_function() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
353 void clear_native_function();
a61af66fc99e Initial load
duke
parents:
diff changeset
354
a61af66fc99e Initial load
duke
parents:
diff changeset
355 // signature handler (used for native methods only)
a61af66fc99e Initial load
duke
parents:
diff changeset
356 address signature_handler() const { return *(signature_handler_addr()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
357 void set_signature_handler(address handler);
a61af66fc99e Initial load
duke
parents:
diff changeset
358
a61af66fc99e Initial load
duke
parents:
diff changeset
359 // Interpreter oopmap support
a61af66fc99e Initial load
duke
parents:
diff changeset
360 void mask_for(int bci, InterpreterOopMap* mask);
a61af66fc99e Initial load
duke
parents:
diff changeset
361
a61af66fc99e Initial load
duke
parents:
diff changeset
362 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
363 // operations on invocation counter
a61af66fc99e Initial load
duke
parents:
diff changeset
364 void print_invocation_count() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
365 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
366
a61af66fc99e Initial load
duke
parents:
diff changeset
367 // byte codes
a61af66fc99e Initial load
duke
parents:
diff changeset
368 address code_base() const { return constMethod()->code_base(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
369 bool contains(address bcp) const { return constMethod()->contains(bcp); }
a61af66fc99e Initial load
duke
parents:
diff changeset
370
a61af66fc99e Initial load
duke
parents:
diff changeset
371 // prints byte codes
a61af66fc99e Initial load
duke
parents:
diff changeset
372 void print_codes() const { print_codes_on(tty); }
a61af66fc99e Initial load
duke
parents:
diff changeset
373 void print_codes_on(outputStream* st) const PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
374 void print_codes_on(int from, int to, outputStream* st) const PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
375
a61af66fc99e Initial load
duke
parents:
diff changeset
376 // checked exceptions
a61af66fc99e Initial load
duke
parents:
diff changeset
377 int checked_exceptions_length() const
a61af66fc99e Initial load
duke
parents:
diff changeset
378 { return constMethod()->checked_exceptions_length(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
379 CheckedExceptionElement* checked_exceptions_start() const
a61af66fc99e Initial load
duke
parents:
diff changeset
380 { return constMethod()->checked_exceptions_start(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
381
a61af66fc99e Initial load
duke
parents:
diff changeset
382 // localvariable table
a61af66fc99e Initial load
duke
parents:
diff changeset
383 bool has_localvariable_table() const
a61af66fc99e Initial load
duke
parents:
diff changeset
384 { return constMethod()->has_localvariable_table(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
385 int localvariable_table_length() const
a61af66fc99e Initial load
duke
parents:
diff changeset
386 { return constMethod()->localvariable_table_length(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
387 LocalVariableTableElement* localvariable_table_start() const
a61af66fc99e Initial load
duke
parents:
diff changeset
388 { return constMethod()->localvariable_table_start(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
389
a61af66fc99e Initial load
duke
parents:
diff changeset
390 bool has_linenumber_table() const
a61af66fc99e Initial load
duke
parents:
diff changeset
391 { return constMethod()->has_linenumber_table(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
392 u_char* compressed_linenumber_table() const
a61af66fc99e Initial load
duke
parents:
diff changeset
393 { return constMethod()->compressed_linenumber_table(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
394
a61af66fc99e Initial load
duke
parents:
diff changeset
395 // method holder (the klassOop holding this method)
a61af66fc99e Initial load
duke
parents:
diff changeset
396 klassOop method_holder() const { return _constants->pool_holder(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
397
a61af66fc99e Initial load
duke
parents:
diff changeset
398 void compute_size_of_parameters(Thread *thread); // word size of parameters (receiver if any + arguments)
a61af66fc99e Initial load
duke
parents:
diff changeset
399 symbolOop klass_name() const; // returns the name of the method holder
a61af66fc99e Initial load
duke
parents:
diff changeset
400 BasicType result_type() const; // type of the method result
a61af66fc99e Initial load
duke
parents:
diff changeset
401 int result_type_index() const; // type index of the method result
a61af66fc99e Initial load
duke
parents:
diff changeset
402 bool is_returning_oop() const { BasicType r = result_type(); return (r == T_OBJECT || r == T_ARRAY); }
a61af66fc99e Initial load
duke
parents:
diff changeset
403 bool is_returning_fp() const { BasicType r = result_type(); return (r == T_FLOAT || r == T_DOUBLE); }
a61af66fc99e Initial load
duke
parents:
diff changeset
404
a61af66fc99e Initial load
duke
parents:
diff changeset
405 // Checked exceptions thrown by this method (resolved to mirrors)
a61af66fc99e Initial load
duke
parents:
diff changeset
406 objArrayHandle resolved_checked_exceptions(TRAPS) { return resolved_checked_exceptions_impl(this, THREAD); }
a61af66fc99e Initial load
duke
parents:
diff changeset
407
a61af66fc99e Initial load
duke
parents:
diff changeset
408 // Access flags
a61af66fc99e Initial load
duke
parents:
diff changeset
409 bool is_public() const { return access_flags().is_public(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
410 bool is_private() const { return access_flags().is_private(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
411 bool is_protected() const { return access_flags().is_protected(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
412 bool is_package_private() const { return !is_public() && !is_private() && !is_protected(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
413 bool is_static() const { return access_flags().is_static(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
414 bool is_final() const { return access_flags().is_final(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
415 bool is_synchronized() const { return access_flags().is_synchronized();}
a61af66fc99e Initial load
duke
parents:
diff changeset
416 bool is_native() const { return access_flags().is_native(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
417 bool is_abstract() const { return access_flags().is_abstract(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
418 bool is_strict() const { return access_flags().is_strict(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
419 bool is_synthetic() const { return access_flags().is_synthetic(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
420
a61af66fc99e Initial load
duke
parents:
diff changeset
421 // returns true if contains only return operation
a61af66fc99e Initial load
duke
parents:
diff changeset
422 bool is_empty_method() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
423
a61af66fc99e Initial load
duke
parents:
diff changeset
424 // returns true if this is a vanilla constructor
a61af66fc99e Initial load
duke
parents:
diff changeset
425 bool is_vanilla_constructor() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
426
a61af66fc99e Initial load
duke
parents:
diff changeset
427 // checks method and its method holder
a61af66fc99e Initial load
duke
parents:
diff changeset
428 bool is_final_method() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
429 bool is_strict_method() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
430
a61af66fc99e Initial load
duke
parents:
diff changeset
431 // true if method needs no dynamic dispatch (final and/or no vtable entry)
a61af66fc99e Initial load
duke
parents:
diff changeset
432 bool can_be_statically_bound() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
433
a61af66fc99e Initial load
duke
parents:
diff changeset
434 // returns true if the method has any backward branches.
a61af66fc99e Initial load
duke
parents:
diff changeset
435 bool has_loops() {
a61af66fc99e Initial load
duke
parents:
diff changeset
436 return access_flags().loops_flag_init() ? access_flags().has_loops() : compute_has_loops_flag();
a61af66fc99e Initial load
duke
parents:
diff changeset
437 };
a61af66fc99e Initial load
duke
parents:
diff changeset
438
a61af66fc99e Initial load
duke
parents:
diff changeset
439 bool compute_has_loops_flag();
a61af66fc99e Initial load
duke
parents:
diff changeset
440
a61af66fc99e Initial load
duke
parents:
diff changeset
441 bool has_jsrs() {
a61af66fc99e Initial load
duke
parents:
diff changeset
442 return access_flags().has_jsrs();
a61af66fc99e Initial load
duke
parents:
diff changeset
443 };
a61af66fc99e Initial load
duke
parents:
diff changeset
444 void set_has_jsrs() {
a61af66fc99e Initial load
duke
parents:
diff changeset
445 _access_flags.set_has_jsrs();
a61af66fc99e Initial load
duke
parents:
diff changeset
446 }
a61af66fc99e Initial load
duke
parents:
diff changeset
447
a61af66fc99e Initial load
duke
parents:
diff changeset
448 // returns true if the method has any monitors.
a61af66fc99e Initial load
duke
parents:
diff changeset
449 bool has_monitors() const { return is_synchronized() || access_flags().has_monitor_bytecodes(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
450 bool has_monitor_bytecodes() const { return access_flags().has_monitor_bytecodes(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
451
a61af66fc99e Initial load
duke
parents:
diff changeset
452 void set_has_monitor_bytecodes() { _access_flags.set_has_monitor_bytecodes(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
453
a61af66fc99e Initial load
duke
parents:
diff changeset
454 // monitor matching. This returns a conservative estimate of whether the monitorenter/monitorexit bytecodes
a61af66fc99e Initial load
duke
parents:
diff changeset
455 // propererly nest in the method. It might return false, even though they actually nest properly, since the info.
a61af66fc99e Initial load
duke
parents:
diff changeset
456 // has not been computed yet.
a61af66fc99e Initial load
duke
parents:
diff changeset
457 bool guaranteed_monitor_matching() const { return access_flags().is_monitor_matching(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
458 void set_guaranteed_monitor_matching() { _access_flags.set_monitor_matching(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
459
a61af66fc99e Initial load
duke
parents:
diff changeset
460 // returns true if the method is an accessor function (setter/getter).
a61af66fc99e Initial load
duke
parents:
diff changeset
461 bool is_accessor() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
462
a61af66fc99e Initial load
duke
parents:
diff changeset
463 // returns true if the method is an initializer (<init> or <clinit>).
a61af66fc99e Initial load
duke
parents:
diff changeset
464 bool is_initializer() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
465
a61af66fc99e Initial load
duke
parents:
diff changeset
466 // compiled code support
a61af66fc99e Initial load
duke
parents:
diff changeset
467 // NOTE: code() is inherently racy as deopt can be clearing code
a61af66fc99e Initial load
duke
parents:
diff changeset
468 // simultaneously. Use with caution.
a61af66fc99e Initial load
duke
parents:
diff changeset
469 bool has_compiled_code() const { return code() != NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
470
a61af66fc99e Initial load
duke
parents:
diff changeset
471 // sizing
a61af66fc99e Initial load
duke
parents:
diff changeset
472 static int object_size(bool is_native);
a61af66fc99e Initial load
duke
parents:
diff changeset
473 static int header_size() { return sizeof(methodOopDesc)/HeapWordSize; }
a61af66fc99e Initial load
duke
parents:
diff changeset
474 int object_size() const { return method_size(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
475
a61af66fc99e Initial load
duke
parents:
diff changeset
476 bool object_is_parsable() const { return method_size() > 0; }
a61af66fc99e Initial load
duke
parents:
diff changeset
477
a61af66fc99e Initial load
duke
parents:
diff changeset
478 // interpreter support
a61af66fc99e Initial load
duke
parents:
diff changeset
479 static ByteSize const_offset() { return byte_offset_of(methodOopDesc, _constMethod ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
480 static ByteSize constants_offset() { return byte_offset_of(methodOopDesc, _constants ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
481 static ByteSize access_flags_offset() { return byte_offset_of(methodOopDesc, _access_flags ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
482 #ifdef CC_INTERP
a61af66fc99e Initial load
duke
parents:
diff changeset
483 static ByteSize result_index_offset() { return byte_offset_of(methodOopDesc, _result_index ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
484 #endif /* CC_INTERP */
a61af66fc99e Initial load
duke
parents:
diff changeset
485 static ByteSize size_of_locals_offset() { return byte_offset_of(methodOopDesc, _max_locals ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
486 static ByteSize size_of_parameters_offset() { return byte_offset_of(methodOopDesc, _size_of_parameters); }
a61af66fc99e Initial load
duke
parents:
diff changeset
487 static ByteSize from_compiled_offset() { return byte_offset_of(methodOopDesc, _from_compiled_entry); }
a61af66fc99e Initial load
duke
parents:
diff changeset
488 static ByteSize code_offset() { return byte_offset_of(methodOopDesc, _code); }
a61af66fc99e Initial load
duke
parents:
diff changeset
489 static ByteSize invocation_counter_offset() { return byte_offset_of(methodOopDesc, _invocation_counter); }
a61af66fc99e Initial load
duke
parents:
diff changeset
490 static ByteSize backedge_counter_offset() { return byte_offset_of(methodOopDesc, _backedge_counter); }
a61af66fc99e Initial load
duke
parents:
diff changeset
491 static ByteSize method_data_offset() {
a61af66fc99e Initial load
duke
parents:
diff changeset
492 return byte_offset_of(methodOopDesc, _method_data);
a61af66fc99e Initial load
duke
parents:
diff changeset
493 }
a61af66fc99e Initial load
duke
parents:
diff changeset
494 static ByteSize interpreter_invocation_counter_offset() { return byte_offset_of(methodOopDesc, _interpreter_invocation_count); }
a61af66fc99e Initial load
duke
parents:
diff changeset
495 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
496 static ByteSize compiled_invocation_counter_offset() { return byte_offset_of(methodOopDesc, _compiled_invocation_count); }
a61af66fc99e Initial load
duke
parents:
diff changeset
497 #endif // not PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
498 static ByteSize native_function_offset() { return in_ByteSize(sizeof(methodOopDesc)); }
a61af66fc99e Initial load
duke
parents:
diff changeset
499 static ByteSize from_interpreted_offset() { return byte_offset_of(methodOopDesc, _from_interpreted_entry ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
500 static ByteSize interpreter_entry_offset() { return byte_offset_of(methodOopDesc, _i2i_entry ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
501 static ByteSize signature_handler_offset() { return in_ByteSize(sizeof(methodOopDesc) + wordSize); }
a61af66fc99e Initial load
duke
parents:
diff changeset
502 static ByteSize max_stack_offset() { return byte_offset_of(methodOopDesc, _max_stack ); }
a61af66fc99e Initial load
duke
parents:
diff changeset
503
a61af66fc99e Initial load
duke
parents:
diff changeset
504 // for code generation
a61af66fc99e Initial load
duke
parents:
diff changeset
505 static int method_data_offset_in_bytes() { return offset_of(methodOopDesc, _method_data); }
a61af66fc99e Initial load
duke
parents:
diff changeset
506 static int interpreter_invocation_counter_offset_in_bytes()
a61af66fc99e Initial load
duke
parents:
diff changeset
507 { return offset_of(methodOopDesc, _interpreter_invocation_count); }
a61af66fc99e Initial load
duke
parents:
diff changeset
508
a61af66fc99e Initial load
duke
parents:
diff changeset
509 // Static methods that are used to implement member methods where an exposed this pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
510 // is needed due to possible GCs
a61af66fc99e Initial load
duke
parents:
diff changeset
511 static objArrayHandle resolved_checked_exceptions_impl(methodOop this_oop, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
512
a61af66fc99e Initial load
duke
parents:
diff changeset
513 // Returns the byte code index from the byte code pointer
a61af66fc99e Initial load
duke
parents:
diff changeset
514 int bci_from(address bcp) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
515 address bcp_from(int bci) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
516 int validate_bci_from_bcx(intptr_t bcx) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
517
a61af66fc99e Initial load
duke
parents:
diff changeset
518 // Returns the line number for a bci if debugging information for the method is prowided,
a61af66fc99e Initial load
duke
parents:
diff changeset
519 // -1 is returned otherwise.
a61af66fc99e Initial load
duke
parents:
diff changeset
520 int line_number_from_bci(int bci) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
521
a61af66fc99e Initial load
duke
parents:
diff changeset
522 // Reflection support
a61af66fc99e Initial load
duke
parents:
diff changeset
523 bool is_overridden_in(klassOop k) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
524
710
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
525 // JSR 292 support
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
526 bool is_method_handle_invoke() const { return access_flags().is_method_handle_invoke(); }
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
527 static methodHandle make_invoke_method(KlassHandle holder,
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
528 symbolHandle signature,
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
529 Handle method_type,
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
530 TRAPS);
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
531 // these operate only on invoke methods:
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
532 oop method_handle_type() const;
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
533 static jint* method_type_offsets_chain(); // series of pointer-offsets, terminated by -1
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
534 // presize interpreter frames for extra interpreter stack entries, if needed
726
be93aad57795 6655646: dynamic languages need dynamically linked call sites
jrose
parents: 710
diff changeset
535 // method handles want to be able to push a few extra values (e.g., a bound receiver), and
be93aad57795 6655646: dynamic languages need dynamically linked call sites
jrose
parents: 710
diff changeset
536 // invokedynamic sometimes needs to push a bootstrap method, call site, and arglist,
be93aad57795 6655646: dynamic languages need dynamically linked call sites
jrose
parents: 710
diff changeset
537 // all without checking for a stack overflow
be93aad57795 6655646: dynamic languages need dynamically linked call sites
jrose
parents: 710
diff changeset
538 static int extra_stack_entries() { return (EnableMethodHandles ? (int)MethodHandlePushLimit : 0) + (EnableInvokeDynamic ? 3 : 0); }
710
e5b0439ef4ae 6655638: dynamic languages need method handles
jrose
parents: 628
diff changeset
539 static int extra_stack_words(); // = extra_stack_entries() * Interpreter::stackElementSize()
0
a61af66fc99e Initial load
duke
parents:
diff changeset
540 // RedefineClasses() support:
a61af66fc99e Initial load
duke
parents:
diff changeset
541 bool is_old() const { return access_flags().is_old(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
542 void set_is_old() { _access_flags.set_is_old(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
543 bool is_obsolete() const { return access_flags().is_obsolete(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
544 void set_is_obsolete() { _access_flags.set_is_obsolete(); }
48
d8b3ef7ee3e5 6599425: 4/3 OopMapCache::lookup() can cause later crash or assert() failure
dcubed
parents: 0
diff changeset
545 // see the definition in methodOop.cpp for the gory details
d8b3ef7ee3e5 6599425: 4/3 OopMapCache::lookup() can cause later crash or assert() failure
dcubed
parents: 0
diff changeset
546 bool should_not_be_cached() const;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
547
a61af66fc99e Initial load
duke
parents:
diff changeset
548 // JVMTI Native method prefixing support:
a61af66fc99e Initial load
duke
parents:
diff changeset
549 bool is_prefixed_native() const { return access_flags().is_prefixed_native(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
550 void set_is_prefixed_native() { _access_flags.set_is_prefixed_native(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
551
a61af66fc99e Initial load
duke
parents:
diff changeset
552 // Rewriting support
a61af66fc99e Initial load
duke
parents:
diff changeset
553 static methodHandle clone_with_new_data(methodHandle m, u_char* new_code, int new_code_length,
a61af66fc99e Initial load
duke
parents:
diff changeset
554 u_char* new_compressed_linenumber_table, int new_compressed_linenumber_size, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
555
a61af66fc99e Initial load
duke
parents:
diff changeset
556 // Get this method's jmethodID -- allocate if it doesn't exist
a61af66fc99e Initial load
duke
parents:
diff changeset
557 jmethodID jmethod_id() { methodHandle this_h(this);
977
74a5db69c1fe 6419370: 4/4 new jmethodID code has tiny holes in synchronization
dcubed
parents: 856
diff changeset
558 return instanceKlass::get_jmethod_id(method_holder(), this_h); }
0
a61af66fc99e Initial load
duke
parents:
diff changeset
559
a61af66fc99e Initial load
duke
parents:
diff changeset
560 // Lookup the jmethodID for this method. Return NULL if not found.
a61af66fc99e Initial load
duke
parents:
diff changeset
561 // NOTE that this function can be called from a signal handler
a61af66fc99e Initial load
duke
parents:
diff changeset
562 // (see AsyncGetCallTrace support for Forte Analyzer) and this
a61af66fc99e Initial load
duke
parents:
diff changeset
563 // needs to be async-safe. No allocation should be done and
a61af66fc99e Initial load
duke
parents:
diff changeset
564 // so handles are not used to avoid deadlock.
a61af66fc99e Initial load
duke
parents:
diff changeset
565 jmethodID find_jmethod_id_or_null() { return instanceKlass::cast(method_holder())->jmethod_id_or_null(this); }
a61af66fc99e Initial load
duke
parents:
diff changeset
566
a61af66fc99e Initial load
duke
parents:
diff changeset
567 // JNI static invoke cached itable index accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
568 int cached_itable_index() { return instanceKlass::cast(method_holder())->cached_itable_index(method_idnum()); }
a61af66fc99e Initial load
duke
parents:
diff changeset
569 void set_cached_itable_index(int index) { instanceKlass::cast(method_holder())->set_cached_itable_index(method_idnum(), index); }
a61af66fc99e Initial load
duke
parents:
diff changeset
570
a61af66fc99e Initial load
duke
parents:
diff changeset
571 // Support for inlining of intrinsic methods
856
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
572 vmIntrinsics::ID intrinsic_id() const { return (vmIntrinsics::ID) _intrinsic_id; }
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
573 void set_intrinsic_id(vmIntrinsics::ID id) { _intrinsic_id = (u1) id; }
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
574
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
575 // Helper routines for intrinsic_id() and vmIntrinsics::method().
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
576 void init_intrinsic_id(); // updates from _none if a match
75596850f863 6862576: vmIntrinsics needs cleanup in order to support JSR 292 intrinsics
jrose
parents: 726
diff changeset
577 static vmSymbols::SID klass_id_for_intrinsics(klassOop holder);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
578
a61af66fc99e Initial load
duke
parents:
diff changeset
579 // On-stack replacement support
a61af66fc99e Initial load
duke
parents:
diff changeset
580 bool has_osr_nmethod() { return instanceKlass::cast(method_holder())->lookup_osr_nmethod(this, InvocationEntryBci) != NULL; }
a61af66fc99e Initial load
duke
parents:
diff changeset
581 nmethod* lookup_osr_nmethod_for(int bci) { return instanceKlass::cast(method_holder())->lookup_osr_nmethod(this, bci); }
a61af66fc99e Initial load
duke
parents:
diff changeset
582
a61af66fc99e Initial load
duke
parents:
diff changeset
583 // Inline cache support
a61af66fc99e Initial load
duke
parents:
diff changeset
584 void cleanup_inline_caches();
a61af66fc99e Initial load
duke
parents:
diff changeset
585
a61af66fc99e Initial load
duke
parents:
diff changeset
586 // Find if klass for method is loaded
a61af66fc99e Initial load
duke
parents:
diff changeset
587 bool is_klass_loaded_by_klass_index(int klass_index) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
588 bool is_klass_loaded(int refinfo_index, bool must_be_resolved = false) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
589
a61af66fc99e Initial load
duke
parents:
diff changeset
590 // Indicates whether compilation failed earlier for this method, or
a61af66fc99e Initial load
duke
parents:
diff changeset
591 // whether it is not compilable for another reason like having a
a61af66fc99e Initial load
duke
parents:
diff changeset
592 // breakpoint set in it.
a61af66fc99e Initial load
duke
parents:
diff changeset
593 bool is_not_compilable(int comp_level = CompLevel_highest_tier) const;
a61af66fc99e Initial load
duke
parents:
diff changeset
594 void set_not_compilable(int comp_level = CompLevel_highest_tier);
a61af66fc99e Initial load
duke
parents:
diff changeset
595
a61af66fc99e Initial load
duke
parents:
diff changeset
596 bool is_not_osr_compilable() const { return is_not_compilable() || access_flags().is_not_osr_compilable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
597 void set_not_osr_compilable() { _access_flags.set_not_osr_compilable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
598
a61af66fc99e Initial load
duke
parents:
diff changeset
599 bool is_not_tier1_compilable() const { return access_flags().is_not_tier1_compilable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
600 void set_not_tier1_compilable() { _access_flags.set_not_tier1_compilable(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
601
a61af66fc99e Initial load
duke
parents:
diff changeset
602 // Background compilation support
a61af66fc99e Initial load
duke
parents:
diff changeset
603 bool queued_for_compilation() const { return access_flags().queued_for_compilation(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
604 void set_queued_for_compilation() { _access_flags.set_queued_for_compilation(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
605 void clear_queued_for_compilation() { _access_flags.clear_queued_for_compilation(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
606
a61af66fc99e Initial load
duke
parents:
diff changeset
607 static methodOop method_from_bcp(address bcp);
a61af66fc99e Initial load
duke
parents:
diff changeset
608
a61af66fc99e Initial load
duke
parents:
diff changeset
609 // Resolve all classes in signature, return 'true' if successful
a61af66fc99e Initial load
duke
parents:
diff changeset
610 static bool load_signature_classes(methodHandle m, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
611
a61af66fc99e Initial load
duke
parents:
diff changeset
612 // Return if true if not all classes references in signature, including return type, has been loaded
a61af66fc99e Initial load
duke
parents:
diff changeset
613 static bool has_unloaded_classes_in_signature(methodHandle m, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
614
a61af66fc99e Initial load
duke
parents:
diff changeset
615 // Printing
a61af66fc99e Initial load
duke
parents:
diff changeset
616 void print_short_name(outputStream* st) /*PRODUCT_RETURN*/; // prints as klassname::methodname; Exposed so field engineers can debug VM
a61af66fc99e Initial load
duke
parents:
diff changeset
617 void print_name(outputStream* st) PRODUCT_RETURN; // prints as "virtual void foo(int)"
a61af66fc99e Initial load
duke
parents:
diff changeset
618
a61af66fc99e Initial load
duke
parents:
diff changeset
619 // Helper routine used for method sorting
a61af66fc99e Initial load
duke
parents:
diff changeset
620 static void sort_methods(objArrayOop methods,
a61af66fc99e Initial load
duke
parents:
diff changeset
621 objArrayOop methods_annotations,
a61af66fc99e Initial load
duke
parents:
diff changeset
622 objArrayOop methods_parameter_annotations,
a61af66fc99e Initial load
duke
parents:
diff changeset
623 objArrayOop methods_default_annotations,
a61af66fc99e Initial load
duke
parents:
diff changeset
624 bool idempotent = false);
a61af66fc99e Initial load
duke
parents:
diff changeset
625
a61af66fc99e Initial load
duke
parents:
diff changeset
626 // size of parameters
a61af66fc99e Initial load
duke
parents:
diff changeset
627 void set_size_of_parameters(int size) { _size_of_parameters = size; }
a61af66fc99e Initial load
duke
parents:
diff changeset
628 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
629
a61af66fc99e Initial load
duke
parents:
diff changeset
630 // Inlined elements
a61af66fc99e Initial load
duke
parents:
diff changeset
631 address* native_function_addr() const { assert(is_native(), "must be native"); return (address*) (this+1); }
a61af66fc99e Initial load
duke
parents:
diff changeset
632 address* signature_handler_addr() const { return native_function_addr() + 1; }
a61af66fc99e Initial load
duke
parents:
diff changeset
633
a61af66fc99e Initial load
duke
parents:
diff changeset
634 // Garbage collection support
a61af66fc99e Initial load
duke
parents:
diff changeset
635 oop* adr_constMethod() const { return (oop*)&_constMethod; }
a61af66fc99e Initial load
duke
parents:
diff changeset
636 oop* adr_constants() const { return (oop*)&_constants; }
a61af66fc99e Initial load
duke
parents:
diff changeset
637 oop* adr_method_data() const { return (oop*)&_method_data; }
a61af66fc99e Initial load
duke
parents:
diff changeset
638 };
a61af66fc99e Initial load
duke
parents:
diff changeset
639
a61af66fc99e Initial load
duke
parents:
diff changeset
640
a61af66fc99e Initial load
duke
parents:
diff changeset
641 // Utility class for compressing line number tables
a61af66fc99e Initial load
duke
parents:
diff changeset
642
a61af66fc99e Initial load
duke
parents:
diff changeset
643 class CompressedLineNumberWriteStream: public CompressedWriteStream {
a61af66fc99e Initial load
duke
parents:
diff changeset
644 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
645 int _bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
646 int _line;
a61af66fc99e Initial load
duke
parents:
diff changeset
647 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
648 // Constructor
a61af66fc99e Initial load
duke
parents:
diff changeset
649 CompressedLineNumberWriteStream(int initial_size) : CompressedWriteStream(initial_size), _bci(0), _line(0) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
650 CompressedLineNumberWriteStream(u_char* buffer, int initial_size) : CompressedWriteStream(buffer, initial_size), _bci(0), _line(0) {}
a61af66fc99e Initial load
duke
parents:
diff changeset
651
a61af66fc99e Initial load
duke
parents:
diff changeset
652 // Write (bci, line number) pair to stream
a61af66fc99e Initial load
duke
parents:
diff changeset
653 void write_pair_regular(int bci_delta, int line_delta);
a61af66fc99e Initial load
duke
parents:
diff changeset
654
a61af66fc99e Initial load
duke
parents:
diff changeset
655 inline void write_pair_inline(int bci, int line) {
a61af66fc99e Initial load
duke
parents:
diff changeset
656 int bci_delta = bci - _bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
657 int line_delta = line - _line;
a61af66fc99e Initial load
duke
parents:
diff changeset
658 _bci = bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
659 _line = line;
a61af66fc99e Initial load
duke
parents:
diff changeset
660 // Skip (0,0) deltas - they do not add information and conflict with terminator.
a61af66fc99e Initial load
duke
parents:
diff changeset
661 if (bci_delta == 0 && line_delta == 0) return;
a61af66fc99e Initial load
duke
parents:
diff changeset
662 // Check if bci is 5-bit and line number 3-bit unsigned.
a61af66fc99e Initial load
duke
parents:
diff changeset
663 if (((bci_delta & ~0x1F) == 0) && ((line_delta & ~0x7) == 0)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
664 // Compress into single byte.
a61af66fc99e Initial load
duke
parents:
diff changeset
665 jubyte value = ((jubyte) bci_delta << 3) | (jubyte) line_delta;
a61af66fc99e Initial load
duke
parents:
diff changeset
666 // Check that value doesn't match escape character.
a61af66fc99e Initial load
duke
parents:
diff changeset
667 if (value != 0xFF) {
a61af66fc99e Initial load
duke
parents:
diff changeset
668 write_byte(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
669 return;
a61af66fc99e Initial load
duke
parents:
diff changeset
670 }
a61af66fc99e Initial load
duke
parents:
diff changeset
671 }
a61af66fc99e Initial load
duke
parents:
diff changeset
672 write_pair_regular(bci_delta, line_delta);
a61af66fc99e Initial load
duke
parents:
diff changeset
673 }
a61af66fc99e Initial load
duke
parents:
diff changeset
674
a61af66fc99e Initial load
duke
parents:
diff changeset
675 // Windows AMD64 + Apr 2005 PSDK with /O2 generates bad code for write_pair.
a61af66fc99e Initial load
duke
parents:
diff changeset
676 // Disabling optimization doesn't work for methods in header files
a61af66fc99e Initial load
duke
parents:
diff changeset
677 // so we force it to call through the non-optimized version in the .cpp.
a61af66fc99e Initial load
duke
parents:
diff changeset
678 // It's gross, but it's the only way we can ensure that all callers are
a61af66fc99e Initial load
duke
parents:
diff changeset
679 // fixed. MSC_VER is defined in build/windows/makefiles/compile.make.
a61af66fc99e Initial load
duke
parents:
diff changeset
680 #if defined(_M_AMD64) && MSC_VER >= 1400
a61af66fc99e Initial load
duke
parents:
diff changeset
681 void write_pair(int bci, int line);
a61af66fc99e Initial load
duke
parents:
diff changeset
682 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
683 void write_pair(int bci, int line) { write_pair_inline(bci, line); }
a61af66fc99e Initial load
duke
parents:
diff changeset
684 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
685
a61af66fc99e Initial load
duke
parents:
diff changeset
686 // Write end-of-stream marker
a61af66fc99e Initial load
duke
parents:
diff changeset
687 void write_terminator() { write_byte(0); }
a61af66fc99e Initial load
duke
parents:
diff changeset
688 };
a61af66fc99e Initial load
duke
parents:
diff changeset
689
a61af66fc99e Initial load
duke
parents:
diff changeset
690
a61af66fc99e Initial load
duke
parents:
diff changeset
691 // Utility class for decompressing line number tables
a61af66fc99e Initial load
duke
parents:
diff changeset
692
a61af66fc99e Initial load
duke
parents:
diff changeset
693 class CompressedLineNumberReadStream: public CompressedReadStream {
a61af66fc99e Initial load
duke
parents:
diff changeset
694 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
695 int _bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
696 int _line;
a61af66fc99e Initial load
duke
parents:
diff changeset
697 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
698 // Constructor
a61af66fc99e Initial load
duke
parents:
diff changeset
699 CompressedLineNumberReadStream(u_char* buffer);
a61af66fc99e Initial load
duke
parents:
diff changeset
700 // Read (bci, line number) pair from stream. Returns false at end-of-stream.
a61af66fc99e Initial load
duke
parents:
diff changeset
701 bool read_pair();
a61af66fc99e Initial load
duke
parents:
diff changeset
702 // Accessing bci and line number (after calling read_pair)
a61af66fc99e Initial load
duke
parents:
diff changeset
703 int bci() const { return _bci; }
a61af66fc99e Initial load
duke
parents:
diff changeset
704 int line() const { return _line; }
a61af66fc99e Initial load
duke
parents:
diff changeset
705 };
a61af66fc99e Initial load
duke
parents:
diff changeset
706
a61af66fc99e Initial load
duke
parents:
diff changeset
707
a61af66fc99e Initial load
duke
parents:
diff changeset
708 /// Fast Breakpoints.
a61af66fc99e Initial load
duke
parents:
diff changeset
709
a61af66fc99e Initial load
duke
parents:
diff changeset
710 // If this structure gets more complicated (because bpts get numerous),
a61af66fc99e Initial load
duke
parents:
diff changeset
711 // move it into its own header.
a61af66fc99e Initial load
duke
parents:
diff changeset
712
a61af66fc99e Initial load
duke
parents:
diff changeset
713 // There is presently no provision for concurrent access
a61af66fc99e Initial load
duke
parents:
diff changeset
714 // to breakpoint lists, which is only OK for JVMTI because
a61af66fc99e Initial load
duke
parents:
diff changeset
715 // breakpoints are written only at safepoints, and are read
a61af66fc99e Initial load
duke
parents:
diff changeset
716 // concurrently only outside of safepoints.
a61af66fc99e Initial load
duke
parents:
diff changeset
717
a61af66fc99e Initial load
duke
parents:
diff changeset
718 class BreakpointInfo : public CHeapObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
719 friend class VMStructs;
a61af66fc99e Initial load
duke
parents:
diff changeset
720 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
721 Bytecodes::Code _orig_bytecode;
a61af66fc99e Initial load
duke
parents:
diff changeset
722 int _bci;
a61af66fc99e Initial load
duke
parents:
diff changeset
723 u2 _name_index; // of method
a61af66fc99e Initial load
duke
parents:
diff changeset
724 u2 _signature_index; // of method
a61af66fc99e Initial load
duke
parents:
diff changeset
725 BreakpointInfo* _next; // simple storage allocation
a61af66fc99e Initial load
duke
parents:
diff changeset
726
a61af66fc99e Initial load
duke
parents:
diff changeset
727 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
728 BreakpointInfo(methodOop m, int bci);
a61af66fc99e Initial load
duke
parents:
diff changeset
729
a61af66fc99e Initial load
duke
parents:
diff changeset
730 // accessors
a61af66fc99e Initial load
duke
parents:
diff changeset
731 Bytecodes::Code orig_bytecode() { return _orig_bytecode; }
a61af66fc99e Initial load
duke
parents:
diff changeset
732 void set_orig_bytecode(Bytecodes::Code code) { _orig_bytecode = code; }
a61af66fc99e Initial load
duke
parents:
diff changeset
733 int bci() { return _bci; }
a61af66fc99e Initial load
duke
parents:
diff changeset
734
a61af66fc99e Initial load
duke
parents:
diff changeset
735 BreakpointInfo* next() const { return _next; }
a61af66fc99e Initial load
duke
parents:
diff changeset
736 void set_next(BreakpointInfo* n) { _next = n; }
a61af66fc99e Initial load
duke
parents:
diff changeset
737
a61af66fc99e Initial load
duke
parents:
diff changeset
738 // helps for searchers
a61af66fc99e Initial load
duke
parents:
diff changeset
739 bool match(methodOop m, int bci) {
a61af66fc99e Initial load
duke
parents:
diff changeset
740 return bci == _bci && match(m);
a61af66fc99e Initial load
duke
parents:
diff changeset
741 }
a61af66fc99e Initial load
duke
parents:
diff changeset
742
a61af66fc99e Initial load
duke
parents:
diff changeset
743 bool match(methodOop m) {
a61af66fc99e Initial load
duke
parents:
diff changeset
744 return _name_index == m->name_index() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
745 _signature_index == m->signature_index();
a61af66fc99e Initial load
duke
parents:
diff changeset
746 }
a61af66fc99e Initial load
duke
parents:
diff changeset
747
a61af66fc99e Initial load
duke
parents:
diff changeset
748 void set(methodOop method);
a61af66fc99e Initial load
duke
parents:
diff changeset
749 void clear(methodOop method);
a61af66fc99e Initial load
duke
parents:
diff changeset
750 };