annotate src/os/solaris/dtrace/jhelper.d @ 113:ba764ed4b6f2

6420645: Create a vm that uses compressed oops for up to 32gb heapsizes Summary: Compressed oops in instances, arrays, and headers. Code contributors are coleenp, phh, never, swamyv Reviewed-by: jmasa, kamg, acorn, tbell, kvn, rasbold
author coleenp
date Sun, 13 Apr 2008 17:43:42 -0400
parents a61af66fc99e
children d1605aabd0a1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
2 * Copyright 2003-2006 Sun Microsystems, Inc. All Rights Reserved.
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 /* This file is auto-generated */
a61af66fc99e Initial load
duke
parents:
diff changeset
26 #include "JvmOffsetsIndex.h"
a61af66fc99e Initial load
duke
parents:
diff changeset
27
a61af66fc99e Initial load
duke
parents:
diff changeset
28 #define DEBUG
a61af66fc99e Initial load
duke
parents:
diff changeset
29
a61af66fc99e Initial load
duke
parents:
diff changeset
30 #ifdef DEBUG
a61af66fc99e Initial load
duke
parents:
diff changeset
31 #define MARK_LINE this->line = __LINE__
a61af66fc99e Initial load
duke
parents:
diff changeset
32 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
33 #define MARK_LINE
a61af66fc99e Initial load
duke
parents:
diff changeset
34 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
35
a61af66fc99e Initial load
duke
parents:
diff changeset
36 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
37 #define STACK_BIAS 0x7ff
a61af66fc99e Initial load
duke
parents:
diff changeset
38 #define pointer uint64_t
a61af66fc99e Initial load
duke
parents:
diff changeset
39 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
40 #define STACK_BIAS 0
a61af66fc99e Initial load
duke
parents:
diff changeset
41 #define pointer uint32_t
a61af66fc99e Initial load
duke
parents:
diff changeset
42 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
43
a61af66fc99e Initial load
duke
parents:
diff changeset
44 extern pointer __JvmOffsets;
a61af66fc99e Initial load
duke
parents:
diff changeset
45
a61af66fc99e Initial load
duke
parents:
diff changeset
46 extern pointer __1cJCodeCacheF_heap_;
a61af66fc99e Initial load
duke
parents:
diff changeset
47 extern pointer __1cIUniverseP_methodKlassObj_;
a61af66fc99e Initial load
duke
parents:
diff changeset
48 extern pointer __1cIUniverseO_collectedHeap_;
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
49 extern pointer __1cIUniverseK_heap_base_;
0
a61af66fc99e Initial load
duke
parents:
diff changeset
50
a61af66fc99e Initial load
duke
parents:
diff changeset
51 extern pointer __1cHnmethodG__vtbl_;
a61af66fc99e Initial load
duke
parents:
diff changeset
52 extern pointer __1cKBufferBlobG__vtbl_;
a61af66fc99e Initial load
duke
parents:
diff changeset
53
a61af66fc99e Initial load
duke
parents:
diff changeset
54 #define copyin_ptr(ADDR) *(pointer*) copyin((pointer) (ADDR), sizeof(pointer))
a61af66fc99e Initial load
duke
parents:
diff changeset
55 #define copyin_uchar(ADDR) *(uchar_t*) copyin((pointer) (ADDR), sizeof(uchar_t))
a61af66fc99e Initial load
duke
parents:
diff changeset
56 #define copyin_uint16(ADDR) *(uint16_t*) copyin((pointer) (ADDR), sizeof(uint16_t))
a61af66fc99e Initial load
duke
parents:
diff changeset
57 #define copyin_uint32(ADDR) *(uint32_t*) copyin((pointer) (ADDR), sizeof(uint32_t))
a61af66fc99e Initial load
duke
parents:
diff changeset
58 #define copyin_int32(ADDR) *(int32_t*) copyin((pointer) (ADDR), sizeof(int32_t))
a61af66fc99e Initial load
duke
parents:
diff changeset
59
a61af66fc99e Initial load
duke
parents:
diff changeset
60 #define SAME(x) x
a61af66fc99e Initial load
duke
parents:
diff changeset
61 #define copyin_offset(JVM_CONST) JVM_CONST = \
a61af66fc99e Initial load
duke
parents:
diff changeset
62 copyin_int32(JvmOffsetsPtr + SAME(IDX_)JVM_CONST * sizeof(int32_t))
a61af66fc99e Initial load
duke
parents:
diff changeset
63
a61af66fc99e Initial load
duke
parents:
diff changeset
64 int init_done;
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
67 {
a61af66fc99e Initial load
duke
parents:
diff changeset
68 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
69 this->done = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
70 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
71 * TBD:
a61af66fc99e Initial load
duke
parents:
diff changeset
72 * Here we initialize init_done, otherwise jhelper does not work.
a61af66fc99e Initial load
duke
parents:
diff changeset
73 * Therefore, copyin_offset() statements work multiple times now.
a61af66fc99e Initial load
duke
parents:
diff changeset
74 * There is a hope we could avoid it in the future, and so,
a61af66fc99e Initial load
duke
parents:
diff changeset
75 * this initialization can be removed.
a61af66fc99e Initial load
duke
parents:
diff changeset
76 */
a61af66fc99e Initial load
duke
parents:
diff changeset
77 init_done = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
78 this->error = (char *) NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
79 this->result = (char *) NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
80 this->methodOop = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
81 this->codecache = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
82 this->klass = (pointer) NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
83 this->vtbl = (pointer) NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
84 this->suffix = '\0';
a61af66fc99e Initial load
duke
parents:
diff changeset
85 }
a61af66fc99e Initial load
duke
parents:
diff changeset
86
a61af66fc99e Initial load
duke
parents:
diff changeset
87 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
88 {
a61af66fc99e Initial load
duke
parents:
diff changeset
89 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
90 /* Initialization of JvmOffsets constants */
a61af66fc99e Initial load
duke
parents:
diff changeset
91 JvmOffsetsPtr = (pointer) &``__JvmOffsets;
a61af66fc99e Initial load
duke
parents:
diff changeset
92 }
a61af66fc99e Initial load
duke
parents:
diff changeset
93
a61af66fc99e Initial load
duke
parents:
diff changeset
94 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
95 /!init_done && !this->done/
a61af66fc99e Initial load
duke
parents:
diff changeset
96 {
a61af66fc99e Initial load
duke
parents:
diff changeset
97 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
98 init_done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
99
a61af66fc99e Initial load
duke
parents:
diff changeset
100 copyin_offset(COMPILER);
a61af66fc99e Initial load
duke
parents:
diff changeset
101 copyin_offset(OFFSET_CollectedHeap_reserved);
a61af66fc99e Initial load
duke
parents:
diff changeset
102 copyin_offset(OFFSET_MemRegion_start);
a61af66fc99e Initial load
duke
parents:
diff changeset
103 copyin_offset(OFFSET_MemRegion_word_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
104 copyin_offset(SIZE_HeapWord);
a61af66fc99e Initial load
duke
parents:
diff changeset
105
a61af66fc99e Initial load
duke
parents:
diff changeset
106 copyin_offset(OFFSET_interpreter_frame_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
107 copyin_offset(OFFSET_Klass_name);
a61af66fc99e Initial load
duke
parents:
diff changeset
108 copyin_offset(OFFSET_constantPoolOopDesc_pool_holder);
a61af66fc99e Initial load
duke
parents:
diff changeset
109
a61af66fc99e Initial load
duke
parents:
diff changeset
110 copyin_offset(OFFSET_HeapBlockHeader_used);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
111 copyin_offset(OFFSET_oopDesc_metadata);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 copyin_offset(OFFSET_symbolOopDesc_length);
a61af66fc99e Initial load
duke
parents:
diff changeset
114 copyin_offset(OFFSET_symbolOopDesc_body);
a61af66fc99e Initial load
duke
parents:
diff changeset
115
a61af66fc99e Initial load
duke
parents:
diff changeset
116 copyin_offset(OFFSET_methodOopDesc_constMethod);
a61af66fc99e Initial load
duke
parents:
diff changeset
117 copyin_offset(OFFSET_methodOopDesc_constants);
a61af66fc99e Initial load
duke
parents:
diff changeset
118 copyin_offset(OFFSET_constMethodOopDesc_name_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
119 copyin_offset(OFFSET_constMethodOopDesc_signature_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
120
a61af66fc99e Initial load
duke
parents:
diff changeset
121 copyin_offset(OFFSET_CodeHeap_memory);
a61af66fc99e Initial load
duke
parents:
diff changeset
122 copyin_offset(OFFSET_CodeHeap_segmap);
a61af66fc99e Initial load
duke
parents:
diff changeset
123 copyin_offset(OFFSET_CodeHeap_log2_segment_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
124
a61af66fc99e Initial load
duke
parents:
diff changeset
125 copyin_offset(OFFSET_VirtualSpace_low);
a61af66fc99e Initial load
duke
parents:
diff changeset
126 copyin_offset(OFFSET_VirtualSpace_high);
a61af66fc99e Initial load
duke
parents:
diff changeset
127
a61af66fc99e Initial load
duke
parents:
diff changeset
128 copyin_offset(OFFSET_CodeBlob_name);
a61af66fc99e Initial load
duke
parents:
diff changeset
129
a61af66fc99e Initial load
duke
parents:
diff changeset
130 copyin_offset(OFFSET_nmethod_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
131 copyin_offset(SIZE_HeapBlockHeader);
a61af66fc99e Initial load
duke
parents:
diff changeset
132 copyin_offset(SIZE_oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
133 copyin_offset(SIZE_constantPoolOopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
134
a61af66fc99e Initial load
duke
parents:
diff changeset
135 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
136 * The PC to translate is in arg0.
a61af66fc99e Initial load
duke
parents:
diff changeset
137 */
a61af66fc99e Initial load
duke
parents:
diff changeset
138 this->pc = arg0;
a61af66fc99e Initial load
duke
parents:
diff changeset
139
a61af66fc99e Initial load
duke
parents:
diff changeset
140 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
141 * The methodOopPtr is in %l2 on SPARC. This can be found at
a61af66fc99e Initial load
duke
parents:
diff changeset
142 * offset 8 from the frame pointer on 32-bit processes.
a61af66fc99e Initial load
duke
parents:
diff changeset
143 */
a61af66fc99e Initial load
duke
parents:
diff changeset
144 #if defined(__sparc)
a61af66fc99e Initial load
duke
parents:
diff changeset
145 this->methodOopPtr = copyin_ptr(arg1 + 2 * sizeof(pointer) + STACK_BIAS);
a61af66fc99e Initial load
duke
parents:
diff changeset
146 #elif defined(__i386) || defined(__amd64)
a61af66fc99e Initial load
duke
parents:
diff changeset
147 this->methodOopPtr = copyin_ptr(arg1 + OFFSET_interpreter_frame_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
148 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
149 #error "Don't know architecture"
a61af66fc99e Initial load
duke
parents:
diff changeset
150 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
151
a61af66fc99e Initial load
duke
parents:
diff changeset
152 this->Universe_methodKlassOop = copyin_ptr(&``__1cIUniverseP_methodKlassObj_);
a61af66fc99e Initial load
duke
parents:
diff changeset
153 this->CodeCache_heap_address = copyin_ptr(&``__1cJCodeCacheF_heap_);
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
154 this->Universe_heap_base = copyin_ptr(&``__1cIUniverseK_heap_base_);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
155
a61af66fc99e Initial load
duke
parents:
diff changeset
156 /* Reading volatile values */
a61af66fc99e Initial load
duke
parents:
diff changeset
157 this->CodeCache_low = copyin_ptr(this->CodeCache_heap_address +
a61af66fc99e Initial load
duke
parents:
diff changeset
158 OFFSET_CodeHeap_memory + OFFSET_VirtualSpace_low);
a61af66fc99e Initial load
duke
parents:
diff changeset
159
a61af66fc99e Initial load
duke
parents:
diff changeset
160 this->CodeCache_high = copyin_ptr(this->CodeCache_heap_address +
a61af66fc99e Initial load
duke
parents:
diff changeset
161 OFFSET_CodeHeap_memory + OFFSET_VirtualSpace_high);
a61af66fc99e Initial load
duke
parents:
diff changeset
162
a61af66fc99e Initial load
duke
parents:
diff changeset
163 this->CodeCache_segmap_low = copyin_ptr(this->CodeCache_heap_address +
a61af66fc99e Initial load
duke
parents:
diff changeset
164 OFFSET_CodeHeap_segmap + OFFSET_VirtualSpace_low);
a61af66fc99e Initial load
duke
parents:
diff changeset
165
a61af66fc99e Initial load
duke
parents:
diff changeset
166 this->CodeCache_segmap_high = copyin_ptr(this->CodeCache_heap_address +
a61af66fc99e Initial load
duke
parents:
diff changeset
167 OFFSET_CodeHeap_segmap + OFFSET_VirtualSpace_high);
a61af66fc99e Initial load
duke
parents:
diff changeset
168
a61af66fc99e Initial load
duke
parents:
diff changeset
169 this->CodeHeap_log2_segment_size = copyin_uint32(
a61af66fc99e Initial load
duke
parents:
diff changeset
170 this->CodeCache_heap_address + OFFSET_CodeHeap_log2_segment_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
171
a61af66fc99e Initial load
duke
parents:
diff changeset
172 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
173 * Get Java heap bounds
a61af66fc99e Initial load
duke
parents:
diff changeset
174 */
a61af66fc99e Initial load
duke
parents:
diff changeset
175 this->Universe_collectedHeap = copyin_ptr(&``__1cIUniverseO_collectedHeap_);
a61af66fc99e Initial load
duke
parents:
diff changeset
176 this->heap_start = copyin_ptr(this->Universe_collectedHeap +
a61af66fc99e Initial load
duke
parents:
diff changeset
177 OFFSET_CollectedHeap_reserved +
a61af66fc99e Initial load
duke
parents:
diff changeset
178 OFFSET_MemRegion_start);
a61af66fc99e Initial load
duke
parents:
diff changeset
179 this->heap_size = SIZE_HeapWord *
a61af66fc99e Initial load
duke
parents:
diff changeset
180 copyin_ptr(this->Universe_collectedHeap +
a61af66fc99e Initial load
duke
parents:
diff changeset
181 OFFSET_CollectedHeap_reserved +
a61af66fc99e Initial load
duke
parents:
diff changeset
182 OFFSET_MemRegion_word_size
a61af66fc99e Initial load
duke
parents:
diff changeset
183 );
a61af66fc99e Initial load
duke
parents:
diff changeset
184 this->heap_end = this->heap_start + this->heap_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
185 }
a61af66fc99e Initial load
duke
parents:
diff changeset
186
a61af66fc99e Initial load
duke
parents:
diff changeset
187 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
188 /!this->done &&
a61af66fc99e Initial load
duke
parents:
diff changeset
189 this->CodeCache_low <= this->pc && this->pc < this->CodeCache_high/
a61af66fc99e Initial load
duke
parents:
diff changeset
190 {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
192 this->codecache = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
193
a61af66fc99e Initial load
duke
parents:
diff changeset
194 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
195 * Find start.
a61af66fc99e Initial load
duke
parents:
diff changeset
196 */
a61af66fc99e Initial load
duke
parents:
diff changeset
197 this->segment = (this->pc - this->CodeCache_low) >>
a61af66fc99e Initial load
duke
parents:
diff changeset
198 this->CodeHeap_log2_segment_size;
a61af66fc99e Initial load
duke
parents:
diff changeset
199 this->block = this->CodeCache_segmap_low;
a61af66fc99e Initial load
duke
parents:
diff changeset
200 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
201 "second";
a61af66fc99e Initial load
duke
parents:
diff changeset
202 }
a61af66fc99e Initial load
duke
parents:
diff changeset
203
a61af66fc99e Initial load
duke
parents:
diff changeset
204 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
205 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
206 {
a61af66fc99e Initial load
duke
parents:
diff changeset
207 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
208 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
209 this->segment = this->segment - this->tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
210 }
a61af66fc99e Initial load
duke
parents:
diff changeset
211
a61af66fc99e Initial load
duke
parents:
diff changeset
212 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
213 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
214 {
a61af66fc99e Initial load
duke
parents:
diff changeset
215 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
216 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
217 this->segment = this->segment - this->tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
218 }
a61af66fc99e Initial load
duke
parents:
diff changeset
219
a61af66fc99e Initial load
duke
parents:
diff changeset
220 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
221 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
222 {
a61af66fc99e Initial load
duke
parents:
diff changeset
223 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
224 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
225 this->segment = this->segment - this->tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
226 }
a61af66fc99e Initial load
duke
parents:
diff changeset
227
a61af66fc99e Initial load
duke
parents:
diff changeset
228 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
229 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
230 {
a61af66fc99e Initial load
duke
parents:
diff changeset
231 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
232 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
233 this->segment = this->segment - this->tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
234 }
a61af66fc99e Initial load
duke
parents:
diff changeset
235
a61af66fc99e Initial load
duke
parents:
diff changeset
236 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
237 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
238 {
a61af66fc99e Initial load
duke
parents:
diff changeset
239 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
240 this->tag = copyin_uchar(this->block + this->segment);
a61af66fc99e Initial load
duke
parents:
diff changeset
241 this->segment = this->segment - this->tag;
a61af66fc99e Initial load
duke
parents:
diff changeset
242 }
a61af66fc99e Initial load
duke
parents:
diff changeset
243
a61af66fc99e Initial load
duke
parents:
diff changeset
244 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
245 /!this->done && this->codecache && this->tag > 0/
a61af66fc99e Initial load
duke
parents:
diff changeset
246 {
a61af66fc99e Initial load
duke
parents:
diff changeset
247 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
248 this->error = "<couldn't find start>";
a61af66fc99e Initial load
duke
parents:
diff changeset
249 this->done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
250 }
a61af66fc99e Initial load
duke
parents:
diff changeset
251
a61af66fc99e Initial load
duke
parents:
diff changeset
252 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
253 /!this->done && this->codecache/
a61af66fc99e Initial load
duke
parents:
diff changeset
254 {
a61af66fc99e Initial load
duke
parents:
diff changeset
255 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
256 this->block = this->CodeCache_low +
a61af66fc99e Initial load
duke
parents:
diff changeset
257 (this->segment << this->CodeHeap_log2_segment_size);
a61af66fc99e Initial load
duke
parents:
diff changeset
258 this->used = copyin_uint32(this->block + OFFSET_HeapBlockHeader_used);
a61af66fc99e Initial load
duke
parents:
diff changeset
259 }
a61af66fc99e Initial load
duke
parents:
diff changeset
260
a61af66fc99e Initial load
duke
parents:
diff changeset
261 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
262 /!this->done && this->codecache && !this->used/
a61af66fc99e Initial load
duke
parents:
diff changeset
263 {
a61af66fc99e Initial load
duke
parents:
diff changeset
264 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
265 this->error = "<block not in use>";
a61af66fc99e Initial load
duke
parents:
diff changeset
266 this->done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
267 }
a61af66fc99e Initial load
duke
parents:
diff changeset
268
a61af66fc99e Initial load
duke
parents:
diff changeset
269 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
270 /!this->done && this->codecache/
a61af66fc99e Initial load
duke
parents:
diff changeset
271 {
a61af66fc99e Initial load
duke
parents:
diff changeset
272 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
273 this->start = this->block + SIZE_HeapBlockHeader;
a61af66fc99e Initial load
duke
parents:
diff changeset
274 this->vtbl = copyin_ptr(this->start);
a61af66fc99e Initial load
duke
parents:
diff changeset
275
a61af66fc99e Initial load
duke
parents:
diff changeset
276 this->nmethod_vtbl = (pointer) &``__1cHnmethodG__vtbl_;
a61af66fc99e Initial load
duke
parents:
diff changeset
277 this->BufferBlob_vtbl = (pointer) &``__1cKBufferBlobG__vtbl_;
a61af66fc99e Initial load
duke
parents:
diff changeset
278 }
a61af66fc99e Initial load
duke
parents:
diff changeset
279
a61af66fc99e Initial load
duke
parents:
diff changeset
280 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
281 /!this->done && this->vtbl == this->nmethod_vtbl/
a61af66fc99e Initial load
duke
parents:
diff changeset
282 {
a61af66fc99e Initial load
duke
parents:
diff changeset
283 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
284 this->methodOopPtr = copyin_ptr(this->start + OFFSET_nmethod_method);
a61af66fc99e Initial load
duke
parents:
diff changeset
285 this->suffix = '*';
a61af66fc99e Initial load
duke
parents:
diff changeset
286 this->methodOop = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
287 }
a61af66fc99e Initial load
duke
parents:
diff changeset
288
a61af66fc99e Initial load
duke
parents:
diff changeset
289 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
290 /!this->done && this->vtbl == this->BufferBlob_vtbl/
a61af66fc99e Initial load
duke
parents:
diff changeset
291 {
a61af66fc99e Initial load
duke
parents:
diff changeset
292 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
293 this->name = copyin_ptr(this->start + OFFSET_CodeBlob_name);
a61af66fc99e Initial load
duke
parents:
diff changeset
294 }
a61af66fc99e Initial load
duke
parents:
diff changeset
295
a61af66fc99e Initial load
duke
parents:
diff changeset
296 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
297 /!this->done && this->vtbl == this->BufferBlob_vtbl &&
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
298 this->Universe_heap_base == NULL &&
0
a61af66fc99e Initial load
duke
parents:
diff changeset
299 this->methodOopPtr > this->heap_start && this->methodOopPtr < this->heap_end/
a61af66fc99e Initial load
duke
parents:
diff changeset
300 {
a61af66fc99e Initial load
duke
parents:
diff changeset
301 MARK_LINE;
113
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
302 this->klass = copyin_ptr(this->methodOopPtr + OFFSET_oopDesc_metadata);
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
303 this->methodOop = this->klass == this->Universe_methodKlassOop;
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
304 this->done = !this->methodOop;
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
305 }
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
306
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
307 dtrace:helper:ustack:
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
308 /!this->done && this->vtbl == this->BufferBlob_vtbl &&
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
309 this->Universe_heap_base != NULL &&
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
310 this->methodOopPtr > this->heap_start && this->methodOopPtr < this->heap_end/
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
311 {
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
312 MARK_LINE;
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
313 /*
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
314 * Read compressed pointer and decode heap oop, same as oop.inline.hpp
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
315 */
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
316 this->cklass = copyin_uint32(this->methodOopPtr + OFFSET_oopDesc_metadata);
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
317 this->klass = (uint64_t)((uintptr_t)this->Universe_heap_base +
ba764ed4b6f2 6420645: Create a vm that uses compressed oops for up to 32gb heapsizes
coleenp
parents: 0
diff changeset
318 ((uintptr_t)this->cklass << 3));
0
a61af66fc99e Initial load
duke
parents:
diff changeset
319 this->methodOop = this->klass == this->Universe_methodKlassOop;
a61af66fc99e Initial load
duke
parents:
diff changeset
320 this->done = !this->methodOop;
a61af66fc99e Initial load
duke
parents:
diff changeset
321 }
a61af66fc99e Initial load
duke
parents:
diff changeset
322
a61af66fc99e Initial load
duke
parents:
diff changeset
323 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
324 /!this->done && !this->methodOop/
a61af66fc99e Initial load
duke
parents:
diff changeset
325 {
a61af66fc99e Initial load
duke
parents:
diff changeset
326 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
327 this->name = copyin_ptr(this->start + OFFSET_CodeBlob_name);
a61af66fc99e Initial load
duke
parents:
diff changeset
328 this->result = this->name != 0 ? copyinstr(this->name) : "<CodeBlob>";
a61af66fc99e Initial load
duke
parents:
diff changeset
329 this->done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
330 }
a61af66fc99e Initial load
duke
parents:
diff changeset
331
a61af66fc99e Initial load
duke
parents:
diff changeset
332 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
333 /!this->done && this->methodOop/
a61af66fc99e Initial load
duke
parents:
diff changeset
334 {
a61af66fc99e Initial load
duke
parents:
diff changeset
335 MARK_LINE;
a61af66fc99e Initial load
duke
parents:
diff changeset
336 this->constMethod = copyin_ptr(this->methodOopPtr +
a61af66fc99e Initial load
duke
parents:
diff changeset
337 OFFSET_methodOopDesc_constMethod);
a61af66fc99e Initial load
duke
parents:
diff changeset
338
a61af66fc99e Initial load
duke
parents:
diff changeset
339 this->nameIndex = copyin_uint16(this->constMethod +
a61af66fc99e Initial load
duke
parents:
diff changeset
340 OFFSET_constMethodOopDesc_name_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
341
a61af66fc99e Initial load
duke
parents:
diff changeset
342 this->signatureIndex = copyin_uint16(this->constMethod +
a61af66fc99e Initial load
duke
parents:
diff changeset
343 OFFSET_constMethodOopDesc_signature_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
344
a61af66fc99e Initial load
duke
parents:
diff changeset
345 this->constantPool = copyin_ptr(this->methodOopPtr +
a61af66fc99e Initial load
duke
parents:
diff changeset
346 OFFSET_methodOopDesc_constants);
a61af66fc99e Initial load
duke
parents:
diff changeset
347
a61af66fc99e Initial load
duke
parents:
diff changeset
348 this->nameSymbol = copyin_ptr(this->constantPool +
a61af66fc99e Initial load
duke
parents:
diff changeset
349 this->nameIndex * sizeof (pointer) + SIZE_constantPoolOopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
350
a61af66fc99e Initial load
duke
parents:
diff changeset
351 this->nameSymbolLength = copyin_uint16(this->nameSymbol +
a61af66fc99e Initial load
duke
parents:
diff changeset
352 OFFSET_symbolOopDesc_length);
a61af66fc99e Initial load
duke
parents:
diff changeset
353
a61af66fc99e Initial load
duke
parents:
diff changeset
354 this->signatureSymbol = copyin_ptr(this->constantPool +
a61af66fc99e Initial load
duke
parents:
diff changeset
355 this->signatureIndex * sizeof (pointer) + SIZE_constantPoolOopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
356
a61af66fc99e Initial load
duke
parents:
diff changeset
357 this->signatureSymbolLength = copyin_uint16(this->signatureSymbol +
a61af66fc99e Initial load
duke
parents:
diff changeset
358 OFFSET_symbolOopDesc_length);
a61af66fc99e Initial load
duke
parents:
diff changeset
359
a61af66fc99e Initial load
duke
parents:
diff changeset
360 this->klassPtr = copyin_ptr(this->constantPool +
a61af66fc99e Initial load
duke
parents:
diff changeset
361 OFFSET_constantPoolOopDesc_pool_holder);
a61af66fc99e Initial load
duke
parents:
diff changeset
362
a61af66fc99e Initial load
duke
parents:
diff changeset
363 this->klassSymbol = copyin_ptr(this->klassPtr +
a61af66fc99e Initial load
duke
parents:
diff changeset
364 OFFSET_Klass_name + SIZE_oopDesc);
a61af66fc99e Initial load
duke
parents:
diff changeset
365
a61af66fc99e Initial load
duke
parents:
diff changeset
366 this->klassSymbolLength = copyin_uint16(this->klassSymbol +
a61af66fc99e Initial load
duke
parents:
diff changeset
367 OFFSET_symbolOopDesc_length);
a61af66fc99e Initial load
duke
parents:
diff changeset
368
a61af66fc99e Initial load
duke
parents:
diff changeset
369 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
370 * Enough for three strings, plus the '.', plus the trailing '\0'.
a61af66fc99e Initial load
duke
parents:
diff changeset
371 */
a61af66fc99e Initial load
duke
parents:
diff changeset
372 this->result = (char *) alloca(this->klassSymbolLength +
a61af66fc99e Initial load
duke
parents:
diff changeset
373 this->nameSymbolLength +
a61af66fc99e Initial load
duke
parents:
diff changeset
374 this->signatureSymbolLength + 2 + 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
375
a61af66fc99e Initial load
duke
parents:
diff changeset
376 copyinto(this->klassSymbol + OFFSET_symbolOopDesc_body,
a61af66fc99e Initial load
duke
parents:
diff changeset
377 this->klassSymbolLength, this->result);
a61af66fc99e Initial load
duke
parents:
diff changeset
378
a61af66fc99e Initial load
duke
parents:
diff changeset
379 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
380 * Add the '.' between the class and the name.
a61af66fc99e Initial load
duke
parents:
diff changeset
381 */
a61af66fc99e Initial load
duke
parents:
diff changeset
382 this->result[this->klassSymbolLength] = '.';
a61af66fc99e Initial load
duke
parents:
diff changeset
383
a61af66fc99e Initial load
duke
parents:
diff changeset
384 copyinto(this->nameSymbol + OFFSET_symbolOopDesc_body,
a61af66fc99e Initial load
duke
parents:
diff changeset
385 this->nameSymbolLength,
a61af66fc99e Initial load
duke
parents:
diff changeset
386 this->result + this->klassSymbolLength + 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
387
a61af66fc99e Initial load
duke
parents:
diff changeset
388 copyinto(this->signatureSymbol + OFFSET_symbolOopDesc_body,
a61af66fc99e Initial load
duke
parents:
diff changeset
389 this->signatureSymbolLength,
a61af66fc99e Initial load
duke
parents:
diff changeset
390 this->result + this->klassSymbolLength +
a61af66fc99e Initial load
duke
parents:
diff changeset
391 this->nameSymbolLength + 1);
a61af66fc99e Initial load
duke
parents:
diff changeset
392
a61af66fc99e Initial load
duke
parents:
diff changeset
393 /*
a61af66fc99e Initial load
duke
parents:
diff changeset
394 * Now we need to add a trailing '\0' and possibly a tag character.
a61af66fc99e Initial load
duke
parents:
diff changeset
395 */
a61af66fc99e Initial load
duke
parents:
diff changeset
396 this->result[this->klassSymbolLength + 1 +
a61af66fc99e Initial load
duke
parents:
diff changeset
397 this->nameSymbolLength +
a61af66fc99e Initial load
duke
parents:
diff changeset
398 this->signatureSymbolLength] = this->suffix;
a61af66fc99e Initial load
duke
parents:
diff changeset
399 this->result[this->klassSymbolLength + 2 +
a61af66fc99e Initial load
duke
parents:
diff changeset
400 this->nameSymbolLength +
a61af66fc99e Initial load
duke
parents:
diff changeset
401 this->signatureSymbolLength] = '\0';
a61af66fc99e Initial load
duke
parents:
diff changeset
402
a61af66fc99e Initial load
duke
parents:
diff changeset
403 this->done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
404 }
a61af66fc99e Initial load
duke
parents:
diff changeset
405
a61af66fc99e Initial load
duke
parents:
diff changeset
406 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
407 /this->done && this->error == (char *) NULL/
a61af66fc99e Initial load
duke
parents:
diff changeset
408 {
a61af66fc99e Initial load
duke
parents:
diff changeset
409 this->result;
a61af66fc99e Initial load
duke
parents:
diff changeset
410 }
a61af66fc99e Initial load
duke
parents:
diff changeset
411
a61af66fc99e Initial load
duke
parents:
diff changeset
412 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
413 /this->done && this->error != (char *) NULL/
a61af66fc99e Initial load
duke
parents:
diff changeset
414 {
a61af66fc99e Initial load
duke
parents:
diff changeset
415 this->error;
a61af66fc99e Initial load
duke
parents:
diff changeset
416 }
a61af66fc99e Initial load
duke
parents:
diff changeset
417
a61af66fc99e Initial load
duke
parents:
diff changeset
418 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
419 /!this->done && this->codecache/
a61af66fc99e Initial load
duke
parents:
diff changeset
420 {
a61af66fc99e Initial load
duke
parents:
diff changeset
421 this->done = 1;
a61af66fc99e Initial load
duke
parents:
diff changeset
422 "error";
a61af66fc99e Initial load
duke
parents:
diff changeset
423 }
a61af66fc99e Initial load
duke
parents:
diff changeset
424
a61af66fc99e Initial load
duke
parents:
diff changeset
425
a61af66fc99e Initial load
duke
parents:
diff changeset
426 dtrace:helper:ustack:
a61af66fc99e Initial load
duke
parents:
diff changeset
427 /!this->done/
a61af66fc99e Initial load
duke
parents:
diff changeset
428 {
a61af66fc99e Initial load
duke
parents:
diff changeset
429 NULL;
a61af66fc99e Initial load
duke
parents:
diff changeset
430 }