annotate src/share/vm/code/compiledIC.hpp @ 1721:413ad0331a0c

6977924: Changes for 6975078 produce build error with certain gcc versions Summary: The changes introduced for 6975078 assign badHeapOopVal to the _allocation field in the ResourceObj class. In 32 bit linux builds with certain versions of gcc this assignment will be flagged as an error while compiling allocation.cpp. In 32 bit builds the constant value badHeapOopVal (which is cast to an intptr_t) is negative. The _allocation field is typed as an unsigned intptr_t and gcc catches this as an error. Reviewed-by: jcoomes, ysr, phh
author johnc
date Wed, 18 Aug 2010 10:59:06 -0700
parents c18cbe5936b8
children f95d63e2154a
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) 1997, 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 //-----------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
26 // The CompiledIC represents a compiled inline cache.
a61af66fc99e Initial load
duke
parents:
diff changeset
27 //
a61af66fc99e Initial load
duke
parents:
diff changeset
28 // In order to make patching of the inline cache MT-safe, we only allow the following
a61af66fc99e Initial load
duke
parents:
diff changeset
29 // transitions (when not at a safepoint):
a61af66fc99e Initial load
duke
parents:
diff changeset
30 //
a61af66fc99e Initial load
duke
parents:
diff changeset
31 //
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // [1] --<-- Clean -->--- [1]
a61af66fc99e Initial load
duke
parents:
diff changeset
33 // / (null) \
a61af66fc99e Initial load
duke
parents:
diff changeset
34 // / \ /-<-\
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // / [2] \ / \
a61af66fc99e Initial load
duke
parents:
diff changeset
36 // Interpreted ---------> Monomorphic | [3]
a61af66fc99e Initial load
duke
parents:
diff changeset
37 // (compiledICHolderOop) (klassOop) |
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // \ / \ /
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // [4] \ / [4] \->-/
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // \->- Megamorphic -<-/
a61af66fc99e Initial load
duke
parents:
diff changeset
41 // (methodOop)
a61af66fc99e Initial load
duke
parents:
diff changeset
42 //
a61af66fc99e Initial load
duke
parents:
diff changeset
43 // The text in paranteses () refere to the value of the inline cache receiver (mov instruction)
a61af66fc99e Initial load
duke
parents:
diff changeset
44 //
a61af66fc99e Initial load
duke
parents:
diff changeset
45 // The numbers in square brackets refere to the kind of transition:
a61af66fc99e Initial load
duke
parents:
diff changeset
46 // [1]: Initial fixup. Receiver it found from debug information
a61af66fc99e Initial load
duke
parents:
diff changeset
47 // [2]: Compilation of a method
a61af66fc99e Initial load
duke
parents:
diff changeset
48 // [3]: Recompilation of a method (note: only entry is changed. The klassOop must stay the same)
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // [4]: Inline cache miss. We go directly to megamorphic call.
a61af66fc99e Initial load
duke
parents:
diff changeset
50 //
a61af66fc99e Initial load
duke
parents:
diff changeset
51 // The class automatically inserts transition stubs (using the InlineCacheBuffer) when an MT-unsafe
a61af66fc99e Initial load
duke
parents:
diff changeset
52 // transition is made to a stub.
a61af66fc99e Initial load
duke
parents:
diff changeset
53 //
a61af66fc99e Initial load
duke
parents:
diff changeset
54 class CompiledIC;
a61af66fc99e Initial load
duke
parents:
diff changeset
55
a61af66fc99e Initial load
duke
parents:
diff changeset
56 class CompiledICInfo {
a61af66fc99e Initial load
duke
parents:
diff changeset
57 friend class CompiledIC;
a61af66fc99e Initial load
duke
parents:
diff changeset
58 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
59 address _entry; // entry point for call
a61af66fc99e Initial load
duke
parents:
diff changeset
60 Handle _cached_oop; // Value of cached_oop (either in stub or inline cache)
a61af66fc99e Initial load
duke
parents:
diff changeset
61 bool _is_optimized; // it is an optimized virtual call (i.e., can be statically bound)
a61af66fc99e Initial load
duke
parents:
diff changeset
62 bool _to_interpreter; // Call it to interpreter
a61af66fc99e Initial load
duke
parents:
diff changeset
63 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
64 address entry() const { return _entry; }
a61af66fc99e Initial load
duke
parents:
diff changeset
65 Handle cached_oop() const { return _cached_oop; }
a61af66fc99e Initial load
duke
parents:
diff changeset
66 bool is_optimized() const { return _is_optimized; }
a61af66fc99e Initial load
duke
parents:
diff changeset
67 };
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 class CompiledIC: public ResourceObj {
a61af66fc99e Initial load
duke
parents:
diff changeset
70 friend class InlineCacheBuffer;
a61af66fc99e Initial load
duke
parents:
diff changeset
71 friend class ICStub;
a61af66fc99e Initial load
duke
parents:
diff changeset
72
a61af66fc99e Initial load
duke
parents:
diff changeset
73
a61af66fc99e Initial load
duke
parents:
diff changeset
74 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
75 NativeCall* _ic_call; // the call instruction
a61af66fc99e Initial load
duke
parents:
diff changeset
76 oop* _oop_addr; // patchable oop cell for this IC
a61af66fc99e Initial load
duke
parents:
diff changeset
77 RelocIterator _oops; // iteration over any and all set-oop instructions
a61af66fc99e Initial load
duke
parents:
diff changeset
78 bool _is_optimized; // an optimized virtual call (i.e., no compiled IC)
a61af66fc99e Initial load
duke
parents:
diff changeset
79
a61af66fc99e Initial load
duke
parents:
diff changeset
80 CompiledIC(NativeCall* ic_call);
a61af66fc99e Initial load
duke
parents:
diff changeset
81 CompiledIC(Relocation* ic_reloc); // Must be of virtual_call_type/opt_virtual_call_type
a61af66fc99e Initial load
duke
parents:
diff changeset
82
a61af66fc99e Initial load
duke
parents:
diff changeset
83 // low-level inline-cache manipulation. Cannot be accessed directly, since it might not be MT-safe
a61af66fc99e Initial load
duke
parents:
diff changeset
84 // to change an inline-cache. These changes the underlying inline-cache directly. They *newer* make
a61af66fc99e Initial load
duke
parents:
diff changeset
85 // changes to a transition stub.
a61af66fc99e Initial load
duke
parents:
diff changeset
86 void set_ic_destination(address entry_point);
a61af66fc99e Initial load
duke
parents:
diff changeset
87 void set_cached_oop(oop cache);
a61af66fc99e Initial load
duke
parents:
diff changeset
88
a61af66fc99e Initial load
duke
parents:
diff changeset
89 // Reads the location of the transition stub. This will fail with an assertion, if no transition stub is
a61af66fc99e Initial load
duke
parents:
diff changeset
90 // associated with the inline cache.
a61af66fc99e Initial load
duke
parents:
diff changeset
91 address stub_address() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
92 bool is_in_transition_state() const; // Use InlineCacheBuffer
a61af66fc99e Initial load
duke
parents:
diff changeset
93
a61af66fc99e Initial load
duke
parents:
diff changeset
94 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
95 // conversion (machine PC to CompiledIC*)
a61af66fc99e Initial load
duke
parents:
diff changeset
96 friend CompiledIC* CompiledIC_before(address return_addr);
a61af66fc99e Initial load
duke
parents:
diff changeset
97 friend CompiledIC* CompiledIC_at(address call_site);
a61af66fc99e Initial load
duke
parents:
diff changeset
98 friend CompiledIC* CompiledIC_at(Relocation* call_site);
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100 // Return the cached_oop/destination associated with this inline cache. If the cache currently points
a61af66fc99e Initial load
duke
parents:
diff changeset
101 // to a transition stub, it will read the values from the transition stub.
a61af66fc99e Initial load
duke
parents:
diff changeset
102 oop cached_oop() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
103 address ic_destination() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
104
a61af66fc99e Initial load
duke
parents:
diff changeset
105 bool is_optimized() const { return _is_optimized; }
a61af66fc99e Initial load
duke
parents:
diff changeset
106
a61af66fc99e Initial load
duke
parents:
diff changeset
107 // State
a61af66fc99e Initial load
duke
parents:
diff changeset
108 bool is_clean() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
109 bool is_megamorphic() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
110 bool is_call_to_compiled() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
111 bool is_call_to_interpreted() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 address end_of_call() { return _ic_call->return_address(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 // MT-safe patching of inline caches. Note: Only safe to call is_xxx when holding the CompiledIC_ock
a61af66fc99e Initial load
duke
parents:
diff changeset
116 // so you are guaranteed that no patching takes place. The same goes for verify.
a61af66fc99e Initial load
duke
parents:
diff changeset
117 //
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // Note: We do not provide any direct access to the stub code, to prevent parts of the code
a61af66fc99e Initial load
duke
parents:
diff changeset
119 // to manipulate the inline cache in MT-unsafe ways.
a61af66fc99e Initial load
duke
parents:
diff changeset
120 //
a61af66fc99e Initial load
duke
parents:
diff changeset
121 // They all takes a TRAP argument, since they can cause a GC if the inline-cache buffer is full.
a61af66fc99e Initial load
duke
parents:
diff changeset
122 //
a61af66fc99e Initial load
duke
parents:
diff changeset
123 void set_to_clean(); // Can only be called during a safepoint operation
a61af66fc99e Initial load
duke
parents:
diff changeset
124 void set_to_monomorphic(const CompiledICInfo& info);
a61af66fc99e Initial load
duke
parents:
diff changeset
125 void set_to_megamorphic(CallInfo* call_info, Bytecodes::Code bytecode, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
126
a61af66fc99e Initial load
duke
parents:
diff changeset
127 static void compute_monomorphic_entry(methodHandle method, KlassHandle receiver_klass,
a61af66fc99e Initial load
duke
parents:
diff changeset
128 bool is_optimized, bool static_bound, CompiledICInfo& info, TRAPS);
a61af66fc99e Initial load
duke
parents:
diff changeset
129
a61af66fc99e Initial load
duke
parents:
diff changeset
130 // Location
a61af66fc99e Initial load
duke
parents:
diff changeset
131 address instruction_address() const { return _ic_call->instruction_address(); }
a61af66fc99e Initial load
duke
parents:
diff changeset
132
a61af66fc99e Initial load
duke
parents:
diff changeset
133 // Misc
a61af66fc99e Initial load
duke
parents:
diff changeset
134 void print() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
135 void print_compiled_ic() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
136 void verify() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
137 };
a61af66fc99e Initial load
duke
parents:
diff changeset
138
a61af66fc99e Initial load
duke
parents:
diff changeset
139 inline CompiledIC* CompiledIC_before(address return_addr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
140 CompiledIC* c_ic = new CompiledIC(nativeCall_before(return_addr));
a61af66fc99e Initial load
duke
parents:
diff changeset
141 c_ic->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
142 return c_ic;
a61af66fc99e Initial load
duke
parents:
diff changeset
143 }
a61af66fc99e Initial load
duke
parents:
diff changeset
144
a61af66fc99e Initial load
duke
parents:
diff changeset
145 inline CompiledIC* CompiledIC_at(address call_site) {
a61af66fc99e Initial load
duke
parents:
diff changeset
146 CompiledIC* c_ic = new CompiledIC(nativeCall_at(call_site));
a61af66fc99e Initial load
duke
parents:
diff changeset
147 c_ic->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
148 return c_ic;
a61af66fc99e Initial load
duke
parents:
diff changeset
149 }
a61af66fc99e Initial load
duke
parents:
diff changeset
150
a61af66fc99e Initial load
duke
parents:
diff changeset
151 inline CompiledIC* CompiledIC_at(Relocation* call_site) {
a61af66fc99e Initial load
duke
parents:
diff changeset
152 CompiledIC* c_ic = new CompiledIC(call_site);
a61af66fc99e Initial load
duke
parents:
diff changeset
153 c_ic->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
154 return c_ic;
a61af66fc99e Initial load
duke
parents:
diff changeset
155 }
a61af66fc99e Initial load
duke
parents:
diff changeset
156
a61af66fc99e Initial load
duke
parents:
diff changeset
157
a61af66fc99e Initial load
duke
parents:
diff changeset
158 //-----------------------------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
159 // The CompiledStaticCall represents a call to a static method in the compiled
a61af66fc99e Initial load
duke
parents:
diff changeset
160 //
a61af66fc99e Initial load
duke
parents:
diff changeset
161 // Transition diagram of a static call site is somewhat simpler than for an inlined cache:
a61af66fc99e Initial load
duke
parents:
diff changeset
162 //
a61af66fc99e Initial load
duke
parents:
diff changeset
163 //
a61af66fc99e Initial load
duke
parents:
diff changeset
164 // -----<----- Clean ----->-----
a61af66fc99e Initial load
duke
parents:
diff changeset
165 // / \
a61af66fc99e Initial load
duke
parents:
diff changeset
166 // / \
a61af66fc99e Initial load
duke
parents:
diff changeset
167 // compilled code <------------> interpreted code
a61af66fc99e Initial load
duke
parents:
diff changeset
168 //
a61af66fc99e Initial load
duke
parents:
diff changeset
169 // Clean: Calls directly to runtime method for fixup
a61af66fc99e Initial load
duke
parents:
diff changeset
170 // Compiled code: Calls directly to compiled code
a61af66fc99e Initial load
duke
parents:
diff changeset
171 // Interpreted code: Calls to stub that set methodOop reference
a61af66fc99e Initial load
duke
parents:
diff changeset
172 //
a61af66fc99e Initial load
duke
parents:
diff changeset
173 //
a61af66fc99e Initial load
duke
parents:
diff changeset
174 class CompiledStaticCall;
a61af66fc99e Initial load
duke
parents:
diff changeset
175
a61af66fc99e Initial load
duke
parents:
diff changeset
176 class StaticCallInfo {
a61af66fc99e Initial load
duke
parents:
diff changeset
177 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
178 address _entry; // Entrypoint
a61af66fc99e Initial load
duke
parents:
diff changeset
179 methodHandle _callee; // Callee (used when calling interpreter)
a61af66fc99e Initial load
duke
parents:
diff changeset
180 bool _to_interpreter; // call to interpreted method (otherwise compiled)
a61af66fc99e Initial load
duke
parents:
diff changeset
181
a61af66fc99e Initial load
duke
parents:
diff changeset
182 friend class CompiledStaticCall;
a61af66fc99e Initial load
duke
parents:
diff changeset
183 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
184 address entry() const { return _entry; }
a61af66fc99e Initial load
duke
parents:
diff changeset
185 methodHandle callee() const { return _callee; }
a61af66fc99e Initial load
duke
parents:
diff changeset
186 };
a61af66fc99e Initial load
duke
parents:
diff changeset
187
a61af66fc99e Initial load
duke
parents:
diff changeset
188
a61af66fc99e Initial load
duke
parents:
diff changeset
189 class CompiledStaticCall: public NativeCall {
a61af66fc99e Initial load
duke
parents:
diff changeset
190 friend class CompiledIC;
a61af66fc99e Initial load
duke
parents:
diff changeset
191
a61af66fc99e Initial load
duke
parents:
diff changeset
192 // Also used by CompiledIC
a61af66fc99e Initial load
duke
parents:
diff changeset
193 void set_to_interpreted(methodHandle callee, address entry);
a61af66fc99e Initial load
duke
parents:
diff changeset
194 bool is_optimized_virtual();
a61af66fc99e Initial load
duke
parents:
diff changeset
195
a61af66fc99e Initial load
duke
parents:
diff changeset
196 public:
a61af66fc99e Initial load
duke
parents:
diff changeset
197 friend CompiledStaticCall* compiledStaticCall_before(address return_addr);
a61af66fc99e Initial load
duke
parents:
diff changeset
198 friend CompiledStaticCall* compiledStaticCall_at(address native_call);
a61af66fc99e Initial load
duke
parents:
diff changeset
199 friend CompiledStaticCall* compiledStaticCall_at(Relocation* call_site);
a61af66fc99e Initial load
duke
parents:
diff changeset
200
a61af66fc99e Initial load
duke
parents:
diff changeset
201 // State
a61af66fc99e Initial load
duke
parents:
diff changeset
202 bool is_clean() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
203 bool is_call_to_compiled() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
204 bool is_call_to_interpreted() const;
a61af66fc99e Initial load
duke
parents:
diff changeset
205
a61af66fc99e Initial load
duke
parents:
diff changeset
206 // Clean static call (will force resolving on next use)
a61af66fc99e Initial load
duke
parents:
diff changeset
207 void set_to_clean();
a61af66fc99e Initial load
duke
parents:
diff changeset
208
a61af66fc99e Initial load
duke
parents:
diff changeset
209 // Set state. The entry must be the same, as computed by compute_entry.
a61af66fc99e Initial load
duke
parents:
diff changeset
210 // Computation and setting is split up, since the actions are separate during
a61af66fc99e Initial load
duke
parents:
diff changeset
211 // a OptoRuntime::resolve_xxx.
a61af66fc99e Initial load
duke
parents:
diff changeset
212 void set(const StaticCallInfo& info);
a61af66fc99e Initial load
duke
parents:
diff changeset
213
a61af66fc99e Initial load
duke
parents:
diff changeset
214 // Compute entry point given a method
a61af66fc99e Initial load
duke
parents:
diff changeset
215 static void compute_entry(methodHandle m, StaticCallInfo& info);
a61af66fc99e Initial load
duke
parents:
diff changeset
216
a61af66fc99e Initial load
duke
parents:
diff changeset
217 // Stub support
a61af66fc99e Initial load
duke
parents:
diff changeset
218 address find_stub();
a61af66fc99e Initial load
duke
parents:
diff changeset
219 static void set_stub_to_clean(static_stub_Relocation* static_stub);
a61af66fc99e Initial load
duke
parents:
diff changeset
220
a61af66fc99e Initial load
duke
parents:
diff changeset
221 // Misc.
a61af66fc99e Initial load
duke
parents:
diff changeset
222 void print() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
223 void verify() PRODUCT_RETURN;
a61af66fc99e Initial load
duke
parents:
diff changeset
224 };
a61af66fc99e Initial load
duke
parents:
diff changeset
225
a61af66fc99e Initial load
duke
parents:
diff changeset
226
a61af66fc99e Initial load
duke
parents:
diff changeset
227 inline CompiledStaticCall* compiledStaticCall_before(address return_addr) {
a61af66fc99e Initial load
duke
parents:
diff changeset
228 CompiledStaticCall* st = (CompiledStaticCall*)nativeCall_before(return_addr);
a61af66fc99e Initial load
duke
parents:
diff changeset
229 st->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
230 return st;
a61af66fc99e Initial load
duke
parents:
diff changeset
231 }
a61af66fc99e Initial load
duke
parents:
diff changeset
232
a61af66fc99e Initial load
duke
parents:
diff changeset
233 inline CompiledStaticCall* compiledStaticCall_at(address native_call) {
a61af66fc99e Initial load
duke
parents:
diff changeset
234 CompiledStaticCall* st = (CompiledStaticCall*)native_call;
a61af66fc99e Initial load
duke
parents:
diff changeset
235 st->verify();
a61af66fc99e Initial load
duke
parents:
diff changeset
236 return st;
a61af66fc99e Initial load
duke
parents:
diff changeset
237 }
a61af66fc99e Initial load
duke
parents:
diff changeset
238
a61af66fc99e Initial load
duke
parents:
diff changeset
239 inline CompiledStaticCall* compiledStaticCall_at(Relocation* call_site) {
a61af66fc99e Initial load
duke
parents:
diff changeset
240 return compiledStaticCall_at(call_site->addr());
a61af66fc99e Initial load
duke
parents:
diff changeset
241 }