annotate src/share/vm/c1/c1_FrameMap.cpp @ 20543:e7d0505c8a30

8059758: Footprint regressions with JDK-8038423 Summary: Changes in JDK-8038423 always initialize (zero out) virtual memory used for auxiliary data structures. This causes a footprint regression for G1 in startup benchmarks. This is because they do not touch that memory at all, so the operating system does not actually commit these pages. The fix is to, if the initialization value of the data structures matches the default value of just committed memory (=0), do not do anything. Reviewed-by: jwilhelm, brutisso
author tschatzl
date Fri, 10 Oct 2014 15:51:58 +0200
parents a9becfeecd1b
children 4ca6dc0799b6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
17467
55fb97c4c58d 8029233: Update copyright year to match last edit in jdk8 hotspot repository for 2013
mikael
parents: 8668
diff changeset
2 * Copyright (c) 2000, 2013, 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: 337
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 337
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: 337
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
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
26 #include "c1/c1_FrameMap.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
27 #include "c1/c1_LIR.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
28 #include "runtime/sharedRuntime.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
29 #ifdef TARGET_ARCH_x86
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
30 # include "vmreg_x86.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
31 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
32 #ifdef TARGET_ARCH_sparc
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
33 # include "vmreg_sparc.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
34 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
35 #ifdef TARGET_ARCH_zero
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
36 # include "vmreg_zero.inline.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1681
diff changeset
37 #endif
2192
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
38 #ifdef TARGET_ARCH_arm
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
39 # include "vmreg_arm.inline.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
40 #endif
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
41 #ifdef TARGET_ARCH_ppc
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
42 # include "vmreg_ppc.inline.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 2093
diff changeset
43 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
44
a61af66fc99e Initial load
duke
parents:
diff changeset
45
a61af66fc99e Initial load
duke
parents:
diff changeset
46
a61af66fc99e Initial load
duke
parents:
diff changeset
47 //-----------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 // Convert method signature into an array of BasicTypes for the arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
50 BasicTypeArray* FrameMap::signature_type_array_for(const ciMethod* method) {
a61af66fc99e Initial load
duke
parents:
diff changeset
51 ciSignature* sig = method->signature();
a61af66fc99e Initial load
duke
parents:
diff changeset
52 BasicTypeList* sta = new BasicTypeList(method->arg_size());
a61af66fc99e Initial load
duke
parents:
diff changeset
53 // add receiver, if any
a61af66fc99e Initial load
duke
parents:
diff changeset
54 if (!method->is_static()) sta->append(T_OBJECT);
a61af66fc99e Initial load
duke
parents:
diff changeset
55 // add remaining arguments
a61af66fc99e Initial load
duke
parents:
diff changeset
56 for (int i = 0; i < sig->count(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
57 ciType* type = sig->type_at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
58 BasicType t = type->basic_type();
a61af66fc99e Initial load
duke
parents:
diff changeset
59 if (t == T_ARRAY) {
a61af66fc99e Initial load
duke
parents:
diff changeset
60 t = T_OBJECT;
a61af66fc99e Initial load
duke
parents:
diff changeset
61 }
a61af66fc99e Initial load
duke
parents:
diff changeset
62 sta->append(t);
a61af66fc99e Initial load
duke
parents:
diff changeset
63 }
a61af66fc99e Initial load
duke
parents:
diff changeset
64 // done
a61af66fc99e Initial load
duke
parents:
diff changeset
65 return sta;
a61af66fc99e Initial load
duke
parents:
diff changeset
66 }
a61af66fc99e Initial load
duke
parents:
diff changeset
67
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 CallingConvention* FrameMap::java_calling_convention(const BasicTypeArray* signature, bool outgoing) {
a61af66fc99e Initial load
duke
parents:
diff changeset
70 // compute the size of the arguments first. The signature array
a61af66fc99e Initial load
duke
parents:
diff changeset
71 // that java_calling_convention takes includes a T_VOID after double
a61af66fc99e Initial load
duke
parents:
diff changeset
72 // work items but our signatures do not.
a61af66fc99e Initial load
duke
parents:
diff changeset
73 int i;
a61af66fc99e Initial load
duke
parents:
diff changeset
74 int sizeargs = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
75 for (i = 0; i < signature->length(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
76 sizeargs += type2size[signature->at(i)];
a61af66fc99e Initial load
duke
parents:
diff changeset
77 }
a61af66fc99e Initial load
duke
parents:
diff changeset
78
a61af66fc99e Initial load
duke
parents:
diff changeset
79 BasicType* sig_bt = NEW_RESOURCE_ARRAY(BasicType, sizeargs);
a61af66fc99e Initial load
duke
parents:
diff changeset
80 VMRegPair* regs = NEW_RESOURCE_ARRAY(VMRegPair, sizeargs);
a61af66fc99e Initial load
duke
parents:
diff changeset
81 int sig_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
82 for (i = 0; i < sizeargs; i++, sig_index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
83 sig_bt[i] = signature->at(sig_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
84 if (sig_bt[i] == T_LONG || sig_bt[i] == T_DOUBLE) {
a61af66fc99e Initial load
duke
parents:
diff changeset
85 sig_bt[i + 1] = T_VOID;
a61af66fc99e Initial load
duke
parents:
diff changeset
86 i++;
a61af66fc99e Initial load
duke
parents:
diff changeset
87 }
a61af66fc99e Initial load
duke
parents:
diff changeset
88 }
a61af66fc99e Initial load
duke
parents:
diff changeset
89
a61af66fc99e Initial load
duke
parents:
diff changeset
90 intptr_t out_preserve = SharedRuntime::java_calling_convention(sig_bt, regs, sizeargs, outgoing);
a61af66fc99e Initial load
duke
parents:
diff changeset
91 LIR_OprList* args = new LIR_OprList(signature->length());
a61af66fc99e Initial load
duke
parents:
diff changeset
92 for (i = 0; i < sizeargs;) {
a61af66fc99e Initial load
duke
parents:
diff changeset
93 BasicType t = sig_bt[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
94 assert(t != T_VOID, "should be skipping these");
a61af66fc99e Initial load
duke
parents:
diff changeset
95 LIR_Opr opr = map_to_opr(t, regs + i, outgoing);
a61af66fc99e Initial load
duke
parents:
diff changeset
96 args->append(opr);
a61af66fc99e Initial load
duke
parents:
diff changeset
97 if (opr->is_address()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
98 LIR_Address* addr = opr->as_address_ptr();
a61af66fc99e Initial load
duke
parents:
diff changeset
99 assert(addr->disp() == (int)addr->disp(), "out of range value");
2093
7514897db238 7009849: C1: Incorrect frame size computation
iveresov
parents: 1972
diff changeset
100 out_preserve = MAX2(out_preserve, (intptr_t)(addr->disp() - STACK_BIAS) / 4);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
101 }
a61af66fc99e Initial load
duke
parents:
diff changeset
102 i += type2size[t];
a61af66fc99e Initial load
duke
parents:
diff changeset
103 }
a61af66fc99e Initial load
duke
parents:
diff changeset
104 assert(args->length() == signature->length(), "size mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
105 out_preserve += SharedRuntime::out_preserve_stack_slots();
a61af66fc99e Initial load
duke
parents:
diff changeset
106
a61af66fc99e Initial load
duke
parents:
diff changeset
107 if (outgoing) {
a61af66fc99e Initial load
duke
parents:
diff changeset
108 // update the space reserved for arguments.
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1584
diff changeset
109 update_reserved_argument_area_size(out_preserve * BytesPerWord);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
110 }
a61af66fc99e Initial load
duke
parents:
diff changeset
111 return new CallingConvention(args, out_preserve);
a61af66fc99e Initial load
duke
parents:
diff changeset
112 }
a61af66fc99e Initial load
duke
parents:
diff changeset
113
a61af66fc99e Initial load
duke
parents:
diff changeset
114
a61af66fc99e Initial load
duke
parents:
diff changeset
115 CallingConvention* FrameMap::c_calling_convention(const BasicTypeArray* signature) {
a61af66fc99e Initial load
duke
parents:
diff changeset
116 // compute the size of the arguments first. The signature array
a61af66fc99e Initial load
duke
parents:
diff changeset
117 // that java_calling_convention takes includes a T_VOID after double
a61af66fc99e Initial load
duke
parents:
diff changeset
118 // work items but our signatures do not.
a61af66fc99e Initial load
duke
parents:
diff changeset
119 int i;
a61af66fc99e Initial load
duke
parents:
diff changeset
120 int sizeargs = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
121 for (i = 0; i < signature->length(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
122 sizeargs += type2size[signature->at(i)];
a61af66fc99e Initial load
duke
parents:
diff changeset
123 }
a61af66fc99e Initial load
duke
parents:
diff changeset
124
a61af66fc99e Initial load
duke
parents:
diff changeset
125 BasicType* sig_bt = NEW_RESOURCE_ARRAY(BasicType, sizeargs);
a61af66fc99e Initial load
duke
parents:
diff changeset
126 VMRegPair* regs = NEW_RESOURCE_ARRAY(VMRegPair, sizeargs);
a61af66fc99e Initial load
duke
parents:
diff changeset
127 int sig_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
128 for (i = 0; i < sizeargs; i++, sig_index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
129 sig_bt[i] = signature->at(sig_index);
a61af66fc99e Initial load
duke
parents:
diff changeset
130 if (sig_bt[i] == T_LONG || sig_bt[i] == T_DOUBLE) {
a61af66fc99e Initial load
duke
parents:
diff changeset
131 sig_bt[i + 1] = T_VOID;
a61af66fc99e Initial load
duke
parents:
diff changeset
132 i++;
a61af66fc99e Initial load
duke
parents:
diff changeset
133 }
a61af66fc99e Initial load
duke
parents:
diff changeset
134 }
a61af66fc99e Initial load
duke
parents:
diff changeset
135
14416
6a936747b569 8024344: PPC64 (part 112): C argument in register AND stack slot.
goetz
parents: 8668
diff changeset
136 intptr_t out_preserve = SharedRuntime::c_calling_convention(sig_bt, regs, NULL, sizeargs);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
137 LIR_OprList* args = new LIR_OprList(signature->length());
a61af66fc99e Initial load
duke
parents:
diff changeset
138 for (i = 0; i < sizeargs;) {
a61af66fc99e Initial load
duke
parents:
diff changeset
139 BasicType t = sig_bt[i];
a61af66fc99e Initial load
duke
parents:
diff changeset
140 assert(t != T_VOID, "should be skipping these");
a61af66fc99e Initial load
duke
parents:
diff changeset
141
a61af66fc99e Initial load
duke
parents:
diff changeset
142 // C calls are always outgoing
a61af66fc99e Initial load
duke
parents:
diff changeset
143 bool outgoing = true;
a61af66fc99e Initial load
duke
parents:
diff changeset
144 LIR_Opr opr = map_to_opr(t, regs + i, outgoing);
a61af66fc99e Initial load
duke
parents:
diff changeset
145 // they might be of different types if for instance floating point
a61af66fc99e Initial load
duke
parents:
diff changeset
146 // values are passed in cpu registers, but the sizes must match.
a61af66fc99e Initial load
duke
parents:
diff changeset
147 assert(type2size[opr->type()] == type2size[t], "type mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
148 args->append(opr);
a61af66fc99e Initial load
duke
parents:
diff changeset
149 if (opr->is_address()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
150 LIR_Address* addr = opr->as_address_ptr();
2093
7514897db238 7009849: C1: Incorrect frame size computation
iveresov
parents: 1972
diff changeset
151 out_preserve = MAX2(out_preserve, (intptr_t)(addr->disp() - STACK_BIAS) / 4);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
152 }
a61af66fc99e Initial load
duke
parents:
diff changeset
153 i += type2size[t];
a61af66fc99e Initial load
duke
parents:
diff changeset
154 }
a61af66fc99e Initial load
duke
parents:
diff changeset
155 assert(args->length() == signature->length(), "size mismatch");
a61af66fc99e Initial load
duke
parents:
diff changeset
156 out_preserve += SharedRuntime::out_preserve_stack_slots();
1681
126ea7725993 6953477: Increase portability and flexibility of building Hotspot
bobv
parents: 1584
diff changeset
157 update_reserved_argument_area_size(out_preserve * BytesPerWord);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
158 return new CallingConvention(args, out_preserve);
a61af66fc99e Initial load
duke
parents:
diff changeset
159 }
a61af66fc99e Initial load
duke
parents:
diff changeset
160
a61af66fc99e Initial load
duke
parents:
diff changeset
161
a61af66fc99e Initial load
duke
parents:
diff changeset
162 //--------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
163 // FrameMap
a61af66fc99e Initial load
duke
parents:
diff changeset
164 //--------------------------------------------------------
a61af66fc99e Initial load
duke
parents:
diff changeset
165
a61af66fc99e Initial load
duke
parents:
diff changeset
166 bool FrameMap::_init_done = false;
a61af66fc99e Initial load
duke
parents:
diff changeset
167 Register FrameMap::_cpu_rnr2reg [FrameMap::nof_cpu_regs];
a61af66fc99e Initial load
duke
parents:
diff changeset
168 int FrameMap::_cpu_reg2rnr [FrameMap::nof_cpu_regs];
a61af66fc99e Initial load
duke
parents:
diff changeset
169
a61af66fc99e Initial load
duke
parents:
diff changeset
170
a61af66fc99e Initial load
duke
parents:
diff changeset
171 FrameMap::FrameMap(ciMethod* method, int monitors, int reserved_argument_area_size) {
1584
b812ff5abc73 6958292: C1: Enable parallel compilation
iveresov
parents: 1552
diff changeset
172 assert(_init_done, "should already be completed");
0
a61af66fc99e Initial load
duke
parents:
diff changeset
173
a61af66fc99e Initial load
duke
parents:
diff changeset
174 _framesize = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
175 _num_spills = -1;
a61af66fc99e Initial load
duke
parents:
diff changeset
176
a61af66fc99e Initial load
duke
parents:
diff changeset
177 assert(monitors >= 0, "not set");
a61af66fc99e Initial load
duke
parents:
diff changeset
178 _num_monitors = monitors;
a61af66fc99e Initial load
duke
parents:
diff changeset
179 assert(reserved_argument_area_size >= 0, "not set");
a61af66fc99e Initial load
duke
parents:
diff changeset
180 _reserved_argument_area_size = MAX2(4, reserved_argument_area_size) * BytesPerWord;
a61af66fc99e Initial load
duke
parents:
diff changeset
181
a61af66fc99e Initial load
duke
parents:
diff changeset
182 _argcount = method->arg_size();
a61af66fc99e Initial load
duke
parents:
diff changeset
183 _argument_locations = new intArray(_argcount, -1);
a61af66fc99e Initial load
duke
parents:
diff changeset
184 _incoming_arguments = java_calling_convention(signature_type_array_for(method), false);
a61af66fc99e Initial load
duke
parents:
diff changeset
185 _oop_map_arg_count = _incoming_arguments->reserved_stack_slots();
a61af66fc99e Initial load
duke
parents:
diff changeset
186
a61af66fc99e Initial load
duke
parents:
diff changeset
187 int java_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
188 for (int i = 0; i < _incoming_arguments->length(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
189 LIR_Opr opr = _incoming_arguments->at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
190 if (opr->is_address()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
191 LIR_Address* address = opr->as_address_ptr();
a61af66fc99e Initial load
duke
parents:
diff changeset
192 _argument_locations->at_put(java_index, address->disp() - STACK_BIAS);
a61af66fc99e Initial load
duke
parents:
diff changeset
193 _incoming_arguments->args()->at_put(i, LIR_OprFact::stack(java_index, as_BasicType(as_ValueType(address->type()))));
a61af66fc99e Initial load
duke
parents:
diff changeset
194 }
a61af66fc99e Initial load
duke
parents:
diff changeset
195 java_index += type2size[opr->type()];
a61af66fc99e Initial load
duke
parents:
diff changeset
196 }
a61af66fc99e Initial load
duke
parents:
diff changeset
197
a61af66fc99e Initial load
duke
parents:
diff changeset
198 }
a61af66fc99e Initial load
duke
parents:
diff changeset
199
a61af66fc99e Initial load
duke
parents:
diff changeset
200
a61af66fc99e Initial load
duke
parents:
diff changeset
201 bool FrameMap::finalize_frame(int nof_slots) {
a61af66fc99e Initial load
duke
parents:
diff changeset
202 assert(nof_slots >= 0, "must be positive");
a61af66fc99e Initial load
duke
parents:
diff changeset
203 assert(_num_spills == -1, "can only be set once");
a61af66fc99e Initial load
duke
parents:
diff changeset
204 _num_spills = nof_slots;
a61af66fc99e Initial load
duke
parents:
diff changeset
205 assert(_framesize == -1, "should only be calculated once");
a61af66fc99e Initial load
duke
parents:
diff changeset
206 _framesize = round_to(in_bytes(sp_offset_for_monitor_base(0)) +
a61af66fc99e Initial load
duke
parents:
diff changeset
207 _num_monitors * sizeof(BasicObjectLock) +
a61af66fc99e Initial load
duke
parents:
diff changeset
208 sizeof(intptr_t) + // offset of deopt orig pc
a61af66fc99e Initial load
duke
parents:
diff changeset
209 frame_pad_in_bytes,
a61af66fc99e Initial load
duke
parents:
diff changeset
210 StackAlignmentInBytes) / 4;
a61af66fc99e Initial load
duke
parents:
diff changeset
211 int java_index = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
212 for (int i = 0; i < _incoming_arguments->length(); i++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
213 LIR_Opr opr = _incoming_arguments->at(i);
a61af66fc99e Initial load
duke
parents:
diff changeset
214 if (opr->is_stack()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
215 _argument_locations->at_put(java_index, in_bytes(framesize_in_bytes()) +
a61af66fc99e Initial load
duke
parents:
diff changeset
216 _argument_locations->at(java_index));
a61af66fc99e Initial load
duke
parents:
diff changeset
217 }
a61af66fc99e Initial load
duke
parents:
diff changeset
218 java_index += type2size[opr->type()];
a61af66fc99e Initial load
duke
parents:
diff changeset
219 }
a61af66fc99e Initial load
duke
parents:
diff changeset
220 // make sure it's expressible on the platform
a61af66fc99e Initial load
duke
parents:
diff changeset
221 return validate_frame();
a61af66fc99e Initial load
duke
parents:
diff changeset
222 }
a61af66fc99e Initial load
duke
parents:
diff changeset
223
a61af66fc99e Initial load
duke
parents:
diff changeset
224 VMReg FrameMap::sp_offset2vmreg(ByteSize offset) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
225 int offset_in_bytes = in_bytes(offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
226 assert(offset_in_bytes % 4 == 0, "must be multiple of 4 bytes");
a61af66fc99e Initial load
duke
parents:
diff changeset
227 assert(offset_in_bytes / 4 < framesize() + oop_map_arg_count(), "out of range");
a61af66fc99e Initial load
duke
parents:
diff changeset
228 return VMRegImpl::stack2reg(offset_in_bytes / 4);
a61af66fc99e Initial load
duke
parents:
diff changeset
229 }
a61af66fc99e Initial load
duke
parents:
diff changeset
230
a61af66fc99e Initial load
duke
parents:
diff changeset
231
a61af66fc99e Initial load
duke
parents:
diff changeset
232 bool FrameMap::location_for_sp_offset(ByteSize byte_offset_from_sp,
a61af66fc99e Initial load
duke
parents:
diff changeset
233 Location::Type loc_type,
a61af66fc99e Initial load
duke
parents:
diff changeset
234 Location* loc) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
235 int offset = in_bytes(byte_offset_from_sp);
a61af66fc99e Initial load
duke
parents:
diff changeset
236 assert(offset >= 0, "incorrect offset");
a61af66fc99e Initial load
duke
parents:
diff changeset
237 if (!Location::legal_offset_in_bytes(offset)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
238 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
239 }
a61af66fc99e Initial load
duke
parents:
diff changeset
240 Location tmp_loc = Location::new_stk_loc(loc_type, offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
241 *loc = tmp_loc;
a61af66fc99e Initial load
duke
parents:
diff changeset
242 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
243 }
a61af66fc99e Initial load
duke
parents:
diff changeset
244
a61af66fc99e Initial load
duke
parents:
diff changeset
245
a61af66fc99e Initial load
duke
parents:
diff changeset
246 bool FrameMap::locations_for_slot (int index, Location::Type loc_type,
a61af66fc99e Initial load
duke
parents:
diff changeset
247 Location* loc, Location* second) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
248 ByteSize offset_from_sp = sp_offset_for_slot(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
249 if (!location_for_sp_offset(offset_from_sp, loc_type, loc)) {
a61af66fc99e Initial load
duke
parents:
diff changeset
250 return false;
a61af66fc99e Initial load
duke
parents:
diff changeset
251 }
a61af66fc99e Initial load
duke
parents:
diff changeset
252 if (second != NULL) {
a61af66fc99e Initial load
duke
parents:
diff changeset
253 // two word item
a61af66fc99e Initial load
duke
parents:
diff changeset
254 offset_from_sp = offset_from_sp + in_ByteSize(4);
a61af66fc99e Initial load
duke
parents:
diff changeset
255 return location_for_sp_offset(offset_from_sp, loc_type, second);
a61af66fc99e Initial load
duke
parents:
diff changeset
256 }
a61af66fc99e Initial load
duke
parents:
diff changeset
257 return true;
a61af66fc99e Initial load
duke
parents:
diff changeset
258 }
a61af66fc99e Initial load
duke
parents:
diff changeset
259
a61af66fc99e Initial load
duke
parents:
diff changeset
260 //////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
261 // Public accessors //
a61af66fc99e Initial load
duke
parents:
diff changeset
262 //////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
263
a61af66fc99e Initial load
duke
parents:
diff changeset
264
a61af66fc99e Initial load
duke
parents:
diff changeset
265 ByteSize FrameMap::sp_offset_for_slot(const int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
266 if (index < argcount()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
267 int offset = _argument_locations->at(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
268 assert(offset != -1, "not a memory argument");
a61af66fc99e Initial load
duke
parents:
diff changeset
269 assert(offset >= framesize() * 4, "argument inside of frame");
a61af66fc99e Initial load
duke
parents:
diff changeset
270 return in_ByteSize(offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
271 }
a61af66fc99e Initial load
duke
parents:
diff changeset
272 ByteSize offset = sp_offset_for_spill(index - argcount());
a61af66fc99e Initial load
duke
parents:
diff changeset
273 assert(in_bytes(offset) < framesize() * 4, "spill outside of frame");
a61af66fc99e Initial load
duke
parents:
diff changeset
274 return offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
275 }
a61af66fc99e Initial load
duke
parents:
diff changeset
276
a61af66fc99e Initial load
duke
parents:
diff changeset
277
a61af66fc99e Initial load
duke
parents:
diff changeset
278 ByteSize FrameMap::sp_offset_for_double_slot(const int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
279 ByteSize offset = sp_offset_for_slot(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
280 if (index >= argcount()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
281 assert(in_bytes(offset) + 4 < framesize() * 4, "spill outside of frame");
a61af66fc99e Initial load
duke
parents:
diff changeset
282 }
a61af66fc99e Initial load
duke
parents:
diff changeset
283 return offset;
a61af66fc99e Initial load
duke
parents:
diff changeset
284 }
a61af66fc99e Initial load
duke
parents:
diff changeset
285
a61af66fc99e Initial load
duke
parents:
diff changeset
286
a61af66fc99e Initial load
duke
parents:
diff changeset
287 ByteSize FrameMap::sp_offset_for_spill(const int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
288 assert(index >= 0 && index < _num_spills, "out of range");
a61af66fc99e Initial load
duke
parents:
diff changeset
289 int offset = round_to(first_available_sp_in_frame + _reserved_argument_area_size, sizeof(double)) +
a61af66fc99e Initial load
duke
parents:
diff changeset
290 index * spill_slot_size_in_bytes;
a61af66fc99e Initial load
duke
parents:
diff changeset
291 return in_ByteSize(offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
292 }
a61af66fc99e Initial load
duke
parents:
diff changeset
293
a61af66fc99e Initial load
duke
parents:
diff changeset
294 ByteSize FrameMap::sp_offset_for_monitor_base(const int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
295 int end_of_spills = round_to(first_available_sp_in_frame + _reserved_argument_area_size, sizeof(double)) +
a61af66fc99e Initial load
duke
parents:
diff changeset
296 _num_spills * spill_slot_size_in_bytes;
304
dc7f315e41f7 5108146: Merge i486 and amd64 cpu directories
never
parents: 0
diff changeset
297 int offset = (int) round_to(end_of_spills, HeapWordSize) + index * sizeof(BasicObjectLock);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
298 return in_ByteSize(offset);
a61af66fc99e Initial load
duke
parents:
diff changeset
299 }
a61af66fc99e Initial load
duke
parents:
diff changeset
300
a61af66fc99e Initial load
duke
parents:
diff changeset
301 ByteSize FrameMap::sp_offset_for_monitor_lock(int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
302 check_monitor_index(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
303 return sp_offset_for_monitor_base(index) + in_ByteSize(BasicObjectLock::lock_offset_in_bytes());;
a61af66fc99e Initial load
duke
parents:
diff changeset
304 }
a61af66fc99e Initial load
duke
parents:
diff changeset
305
a61af66fc99e Initial load
duke
parents:
diff changeset
306 ByteSize FrameMap::sp_offset_for_monitor_object(int index) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
307 check_monitor_index(index);
a61af66fc99e Initial load
duke
parents:
diff changeset
308 return sp_offset_for_monitor_base(index) + in_ByteSize(BasicObjectLock::obj_offset_in_bytes());
a61af66fc99e Initial load
duke
parents:
diff changeset
309 }
a61af66fc99e Initial load
duke
parents:
diff changeset
310
a61af66fc99e Initial load
duke
parents:
diff changeset
311
a61af66fc99e Initial load
duke
parents:
diff changeset
312 // For OopMaps, map a local variable or spill index to an VMReg.
a61af66fc99e Initial load
duke
parents:
diff changeset
313 // This is the offset from sp() in the frame of the slot for the index,
a61af66fc99e Initial load
duke
parents:
diff changeset
314 // skewed by SharedInfo::stack0 to indicate a stack location (vs.a register.)
a61af66fc99e Initial load
duke
parents:
diff changeset
315 //
a61af66fc99e Initial load
duke
parents:
diff changeset
316 // C ABI size +
a61af66fc99e Initial load
duke
parents:
diff changeset
317 // framesize + framesize +
a61af66fc99e Initial load
duke
parents:
diff changeset
318 // stack0 stack0 stack0 0 <- VMReg->value()
a61af66fc99e Initial load
duke
parents:
diff changeset
319 // | | | <registers> |
a61af66fc99e Initial load
duke
parents:
diff changeset
320 // ..........|..............|..............|.............|
a61af66fc99e Initial load
duke
parents:
diff changeset
321 // 0 1 2 3 | <C ABI area> | 4 5 6 ...... | <- local indices
a61af66fc99e Initial load
duke
parents:
diff changeset
322 // ^ ^ sp()
a61af66fc99e Initial load
duke
parents:
diff changeset
323 // | |
a61af66fc99e Initial load
duke
parents:
diff changeset
324 // arguments non-argument locals
a61af66fc99e Initial load
duke
parents:
diff changeset
325
a61af66fc99e Initial load
duke
parents:
diff changeset
326
a61af66fc99e Initial load
duke
parents:
diff changeset
327 VMReg FrameMap::regname(LIR_Opr opr) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
328 if (opr->is_single_cpu()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
329 assert(!opr->is_virtual(), "should not see virtual registers here");
a61af66fc99e Initial load
duke
parents:
diff changeset
330 return opr->as_register()->as_VMReg();
a61af66fc99e Initial load
duke
parents:
diff changeset
331 } else if (opr->is_single_stack()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
332 return sp_offset2vmreg(sp_offset_for_slot(opr->single_stack_ix()));
a61af66fc99e Initial load
duke
parents:
diff changeset
333 } else if (opr->is_address()) {
a61af66fc99e Initial load
duke
parents:
diff changeset
334 LIR_Address* addr = opr->as_address_ptr();
a61af66fc99e Initial load
duke
parents:
diff changeset
335 assert(addr->base() == stack_pointer(), "sp based addressing only");
a61af66fc99e Initial load
duke
parents:
diff changeset
336 return sp_offset2vmreg(in_ByteSize(addr->index()->as_jint()));
a61af66fc99e Initial load
duke
parents:
diff changeset
337 }
a61af66fc99e Initial load
duke
parents:
diff changeset
338 ShouldNotReachHere();
a61af66fc99e Initial load
duke
parents:
diff changeset
339 return VMRegImpl::Bad();
a61af66fc99e Initial load
duke
parents:
diff changeset
340 }
a61af66fc99e Initial load
duke
parents:
diff changeset
341
a61af66fc99e Initial load
duke
parents:
diff changeset
342
a61af66fc99e Initial load
duke
parents:
diff changeset
343
a61af66fc99e Initial load
duke
parents:
diff changeset
344
a61af66fc99e Initial load
duke
parents:
diff changeset
345 // ------------ extra spill slots ---------------