annotate src/share/vm/runtime/stackValueCollection.cpp @ 3979:4dfb2df418f2

6484982: G1: process references during evacuation pauses Summary: G1 now uses two reference processors - one is used by concurrent marking and the other is used by STW GCs (both full and incremental evacuation pauses). In an evacuation pause, the reference processor is embedded into the closures used to scan objects. Doing so causes causes reference objects to be 'discovered' by the reference processor. At the end of the evacuation pause, these discovered reference objects are processed - preserving (and copying) referent objects (and their reachable graphs) as appropriate. Reviewed-by: ysr, jwilhelm, brutisso, stefank, tonyp
author johnc
date Thu, 22 Sep 2011 10:57:37 -0700
parents 1d1603768966
children 78bbf4d43a14
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
2426
1d1603768966 7010070: Update all 2010 Oracle-changed OpenJDK files to have the proper copyright dates - second pass
trims
parents: 2192
diff changeset
2 * Copyright (c) 2001, 2011, 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
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
25 #include "precompiled.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
26 #include "runtime/stackValueCollection.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
27 #ifdef TARGET_ARCH_x86
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
28 # include "jniTypes_x86.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
29 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
30 #ifdef TARGET_ARCH_sparc
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
31 # include "jniTypes_sparc.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
32 #endif
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
33 #ifdef TARGET_ARCH_zero
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
34 # include "jniTypes_zero.hpp"
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1552
diff changeset
35 #endif
2192
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
36 #ifdef TARGET_ARCH_arm
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
37 # include "jniTypes_arm.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
38 #endif
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
39 #ifdef TARGET_ARCH_ppc
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
40 # include "jniTypes_ppc.hpp"
b92c45f2bc75 7016023: Enable building ARM and PPC from src/closed repository
bobv
parents: 1972
diff changeset
41 #endif
0
a61af66fc99e Initial load
duke
parents:
diff changeset
42
a61af66fc99e Initial load
duke
parents:
diff changeset
43 jint StackValueCollection::int_at(int slot) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
44 intptr_t val = at(slot)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
45 jint ival = *((jint*) (&val));
a61af66fc99e Initial load
duke
parents:
diff changeset
46 return ival;
a61af66fc99e Initial load
duke
parents:
diff changeset
47 }
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 jlong StackValueCollection::long_at(int slot) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
50 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
51 return at(slot+1)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
52 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
53 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
54 jlong jl;
a61af66fc99e Initial load
duke
parents:
diff changeset
55 jint array[2];
a61af66fc99e Initial load
duke
parents:
diff changeset
56 } value;
a61af66fc99e Initial load
duke
parents:
diff changeset
57 // Interpreter stack is reversed in memory:
a61af66fc99e Initial load
duke
parents:
diff changeset
58 // low memory location is in higher java local slot.
a61af66fc99e Initial load
duke
parents:
diff changeset
59 value.array[0] = at(slot+1)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
60 value.array[1] = at(slot )->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
61 return value.jl;
a61af66fc99e Initial load
duke
parents:
diff changeset
62 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
63 }
a61af66fc99e Initial load
duke
parents:
diff changeset
64
a61af66fc99e Initial load
duke
parents:
diff changeset
65 Handle StackValueCollection::obj_at(int slot) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
66 return at(slot)->get_obj();
a61af66fc99e Initial load
duke
parents:
diff changeset
67 }
a61af66fc99e Initial load
duke
parents:
diff changeset
68
a61af66fc99e Initial load
duke
parents:
diff changeset
69 jfloat StackValueCollection::float_at(int slot) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
70 intptr_t res = at(slot)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
71 return *((jfloat*) (&res));
a61af66fc99e Initial load
duke
parents:
diff changeset
72 }
a61af66fc99e Initial load
duke
parents:
diff changeset
73
a61af66fc99e Initial load
duke
parents:
diff changeset
74 jdouble StackValueCollection::double_at(int slot) const {
a61af66fc99e Initial load
duke
parents:
diff changeset
75 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
76 intptr_t res = at(slot+1)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
77 return *((jdouble*) (&res));
a61af66fc99e Initial load
duke
parents:
diff changeset
78 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
79 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
80 jdouble jd;
a61af66fc99e Initial load
duke
parents:
diff changeset
81 jint array[2];
a61af66fc99e Initial load
duke
parents:
diff changeset
82 } value;
a61af66fc99e Initial load
duke
parents:
diff changeset
83 // Interpreter stack is reversed in memory:
a61af66fc99e Initial load
duke
parents:
diff changeset
84 // low memory location is in higher java local slot.
a61af66fc99e Initial load
duke
parents:
diff changeset
85 value.array[0] = at(slot+1)->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
86 value.array[1] = at(slot )->get_int();
a61af66fc99e Initial load
duke
parents:
diff changeset
87 return value.jd;
a61af66fc99e Initial load
duke
parents:
diff changeset
88 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
89 }
a61af66fc99e Initial load
duke
parents:
diff changeset
90
a61af66fc99e Initial load
duke
parents:
diff changeset
91 void StackValueCollection::set_int_at(int slot, jint value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
92 intptr_t val;
a61af66fc99e Initial load
duke
parents:
diff changeset
93 *((jint*) (&val)) = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
94 at(slot)->set_int(val);
a61af66fc99e Initial load
duke
parents:
diff changeset
95 }
a61af66fc99e Initial load
duke
parents:
diff changeset
96
a61af66fc99e Initial load
duke
parents:
diff changeset
97 void StackValueCollection::set_long_at(int slot, jlong value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
98 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
99 at(slot+1)->set_int(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
100 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
101 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
102 jlong jl;
a61af66fc99e Initial load
duke
parents:
diff changeset
103 jint array[2];
a61af66fc99e Initial load
duke
parents:
diff changeset
104 } x;
a61af66fc99e Initial load
duke
parents:
diff changeset
105 // Interpreter stack is reversed in memory:
a61af66fc99e Initial load
duke
parents:
diff changeset
106 // low memory location is in higher java local slot.
a61af66fc99e Initial load
duke
parents:
diff changeset
107 x.jl = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
108 at(slot+1)->set_int(x.array[0]);
a61af66fc99e Initial load
duke
parents:
diff changeset
109 at(slot+0)->set_int(x.array[1]);
a61af66fc99e Initial load
duke
parents:
diff changeset
110 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
111 }
a61af66fc99e Initial load
duke
parents:
diff changeset
112
a61af66fc99e Initial load
duke
parents:
diff changeset
113 void StackValueCollection::set_obj_at(int slot, Handle value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
114 at(slot)->set_obj(value);
a61af66fc99e Initial load
duke
parents:
diff changeset
115 }
a61af66fc99e Initial load
duke
parents:
diff changeset
116
a61af66fc99e Initial load
duke
parents:
diff changeset
117 void StackValueCollection::set_float_at(int slot, jfloat value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
118 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
119 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
120 intptr_t jd;
a61af66fc99e Initial load
duke
parents:
diff changeset
121 jint array[2];
a61af66fc99e Initial load
duke
parents:
diff changeset
122 } val;
a61af66fc99e Initial load
duke
parents:
diff changeset
123 // Interpreter stores 32 bit floats in first half of 64 bit word.
a61af66fc99e Initial load
duke
parents:
diff changeset
124 val.array[0] = *(jint*)(&value);
a61af66fc99e Initial load
duke
parents:
diff changeset
125 val.array[1] = 0;
a61af66fc99e Initial load
duke
parents:
diff changeset
126 at(slot)->set_int(val.jd);
a61af66fc99e Initial load
duke
parents:
diff changeset
127 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
128 at(slot)->set_int(*(jint*)(&value));
a61af66fc99e Initial load
duke
parents:
diff changeset
129 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
130 }
a61af66fc99e Initial load
duke
parents:
diff changeset
131
a61af66fc99e Initial load
duke
parents:
diff changeset
132 void StackValueCollection::set_double_at(int slot, jdouble value) {
a61af66fc99e Initial load
duke
parents:
diff changeset
133 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
134 at(slot+1)->set_int(*(intptr_t*)(&value));
a61af66fc99e Initial load
duke
parents:
diff changeset
135 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
136 union {
a61af66fc99e Initial load
duke
parents:
diff changeset
137 jdouble jd;
a61af66fc99e Initial load
duke
parents:
diff changeset
138 jint array[2];
a61af66fc99e Initial load
duke
parents:
diff changeset
139 } x;
a61af66fc99e Initial load
duke
parents:
diff changeset
140 // Interpreter stack is reversed in memory:
a61af66fc99e Initial load
duke
parents:
diff changeset
141 // low memory location is in higher java local slot.
a61af66fc99e Initial load
duke
parents:
diff changeset
142 x.jd = value;
a61af66fc99e Initial load
duke
parents:
diff changeset
143 at(slot+1)->set_int(x.array[0]);
a61af66fc99e Initial load
duke
parents:
diff changeset
144 at(slot+0)->set_int(x.array[1]);
a61af66fc99e Initial load
duke
parents:
diff changeset
145 #endif
a61af66fc99e Initial load
duke
parents:
diff changeset
146 }
a61af66fc99e Initial load
duke
parents:
diff changeset
147
a61af66fc99e Initial load
duke
parents:
diff changeset
148 #ifndef PRODUCT
a61af66fc99e Initial load
duke
parents:
diff changeset
149 void StackValueCollection::print() {
a61af66fc99e Initial load
duke
parents:
diff changeset
150 for(int index = 0; index < size(); index++) {
a61af66fc99e Initial load
duke
parents:
diff changeset
151 tty->print("\t %2d ", index);
a61af66fc99e Initial load
duke
parents:
diff changeset
152 at(index)->print_on(tty);
a61af66fc99e Initial load
duke
parents:
diff changeset
153 if( at(index )->type() == T_INT &&
a61af66fc99e Initial load
duke
parents:
diff changeset
154 index+1 < size() &&
a61af66fc99e Initial load
duke
parents:
diff changeset
155 at(index+1)->type() == T_INT ) {
a61af66fc99e Initial load
duke
parents:
diff changeset
156 tty->print(" " INT64_FORMAT " (long)", long_at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
157 tty->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
158 tty->print("\t %.15e (double)", double_at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
159 tty->print(" " PTR64_FORMAT " (longhex)", long_at(index));
a61af66fc99e Initial load
duke
parents:
diff changeset
160 }
a61af66fc99e Initial load
duke
parents:
diff changeset
161 tty->cr();
a61af66fc99e Initial load
duke
parents:
diff changeset
162 }
a61af66fc99e Initial load
duke
parents:
diff changeset
163 }
a61af66fc99e Initial load
duke
parents:
diff changeset
164 #endif