Mercurial > hg > truffle
annotate src/share/vm/ci/ciSymbol.cpp @ 6972:bd7a7ce2e264
6830717: replay of compilations would help with debugging
Summary: When java process crashed in compiler thread, repeat the compilation process will help finding root cause. This is done with using SA dump application class data and replay data from core dump, then use debug version of jvm to recompile the problematic java method.
Reviewed-by: kvn, twisti, sspitsyn
Contributed-by: yumin.qi@oracle.com
author | minqi |
---|---|
date | Mon, 12 Nov 2012 14:03:53 -0800 |
parents | b9a9ed0f8eeb |
children |
rev | line source |
---|---|
0 | 1 /* |
6842
b9a9ed0f8eeb
7197424: update copyright year to match last edit in jdk8 hotspot repository
mikael
parents:
6266
diff
changeset
|
2 * Copyright (c) 1999, 2012, Oracle and/or its affiliates. All rights reserved. |
0 | 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 * | |
5 * This code is free software; you can redistribute it and/or modify it | |
6 * under the terms of the GNU General Public License version 2 only, as | |
7 * published by the Free Software Foundation. | |
8 * | |
9 * This code is distributed in the hope that it will be useful, but WITHOUT | |
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
12 * version 2 for more details (a copy is included in the LICENSE file that | |
13 * accompanied this code). | |
14 * | |
15 * You should have received a copy of the GNU General Public License version | |
16 * 2 along with this work; if not, write to the Free Software Foundation, | |
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. | |
18 * | |
1552
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1507
diff
changeset
|
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
c18cbe5936b8
6941466: Oracle rebranding changes for Hotspot repositories
trims
parents:
1507
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:
1507
diff
changeset
|
21 * questions. |
0 | 22 * |
23 */ | |
24 | |
1972 | 25 #include "precompiled.hpp" |
26 #include "ci/ciSymbol.hpp" | |
27 #include "ci/ciUtilities.hpp" | |
28 #include "memory/oopFactory.hpp" | |
0 | 29 |
30 // ------------------------------------------------------------------ | |
31 // ciSymbol::ciSymbol | |
32 // | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
33 // Preallocated symbol variant. Used with symbols from vmSymbols. |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
34 ciSymbol::ciSymbol(Symbol* s, vmSymbols::SID sid) |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
35 : _symbol(s), _sid(sid) |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
36 { |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
37 assert(_symbol != NULL, "adding null symbol"); |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
38 _symbol->increment_refcount(); // increment ref count |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
39 assert(sid_ok(), "must be in vmSymbols"); |
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
40 } |
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
41 |
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
42 // Normal case for non-famous symbols. |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
43 ciSymbol::ciSymbol(Symbol* s) |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
44 : _symbol(s), _sid(vmSymbols::NO_SID) |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
45 { |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
46 assert(_symbol != NULL, "adding null symbol"); |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
47 _symbol->increment_refcount(); // increment ref count |
1507
cd5dbf694d45
6939134: JSR 292 adjustments to method handle invocation
jrose
parents:
1138
diff
changeset
|
48 assert(sid_ok(), "must not be in vmSymbols"); |
0 | 49 } |
50 | |
51 // ciSymbol | |
52 // | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
53 // This class represents a Symbol* in the HotSpot virtual |
0 | 54 // machine. |
55 | |
56 // ------------------------------------------------------------------ | |
57 // ciSymbol::as_utf8 | |
58 // | |
59 // The text of the symbol as a null-terminated C string. | |
60 const char* ciSymbol::as_utf8() { | |
61 VM_QUICK_ENTRY_MARK; | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
62 Symbol* s = get_symbol(); |
0 | 63 return s->as_utf8(); |
64 } | |
65 | |
6972
bd7a7ce2e264
6830717: replay of compilations would help with debugging
minqi
parents:
6842
diff
changeset
|
66 // The text of the symbol as a null-terminated C string. |
bd7a7ce2e264
6830717: replay of compilations would help with debugging
minqi
parents:
6842
diff
changeset
|
67 const char* ciSymbol::as_quoted_ascii() { |
bd7a7ce2e264
6830717: replay of compilations would help with debugging
minqi
parents:
6842
diff
changeset
|
68 GUARDED_VM_QUICK_ENTRY(return get_symbol()->as_quoted_ascii();) |
bd7a7ce2e264
6830717: replay of compilations would help with debugging
minqi
parents:
6842
diff
changeset
|
69 } |
bd7a7ce2e264
6830717: replay of compilations would help with debugging
minqi
parents:
6842
diff
changeset
|
70 |
0 | 71 // ------------------------------------------------------------------ |
72 // ciSymbol::base | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
73 const jbyte* ciSymbol::base() { |
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
74 GUARDED_VM_ENTRY(return get_symbol()->base();) |
0 | 75 } |
76 | |
77 // ------------------------------------------------------------------ | |
78 // ciSymbol::byte_at | |
79 int ciSymbol::byte_at(int i) { | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
80 GUARDED_VM_ENTRY(return get_symbol()->byte_at(i);) |
0 | 81 } |
82 | |
83 // ------------------------------------------------------------------ | |
1138
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
84 // ciSymbol::starts_with |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
85 // |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
86 // Tests if the symbol starts with the given prefix. |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
87 bool ciSymbol::starts_with(const char* prefix, int len) const { |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
88 GUARDED_VM_ENTRY(return get_symbol()->starts_with(prefix, len);) |
1138
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
89 } |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
90 |
6266
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
2426
diff
changeset
|
91 bool ciSymbol::is_signature_polymorphic_name() const { |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
2426
diff
changeset
|
92 GUARDED_VM_ENTRY(return MethodHandles::is_signature_polymorphic_name(get_symbol());) |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
2426
diff
changeset
|
93 } |
1d7922586cf6
7023639: JSR 292 method handle invocation needs a fast path for compiled code
twisti
parents:
2426
diff
changeset
|
94 |
1138
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
95 // ------------------------------------------------------------------ |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
96 // ciSymbol::index_of |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
97 // |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
98 // Determines where the symbol contains the given substring. |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
99 int ciSymbol::index_of_at(int i, const char* str, int len) const { |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
100 GUARDED_VM_ENTRY(return get_symbol()->index_of_at(i, str, len);) |
1138
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
101 } |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
102 |
dd57230ba8fe
6893268: additional dynamic language related optimizations in C2
twisti
parents:
0
diff
changeset
|
103 // ------------------------------------------------------------------ |
0 | 104 // ciSymbol::utf8_length |
105 int ciSymbol::utf8_length() { | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
106 GUARDED_VM_ENTRY(return get_symbol()->utf8_length();) |
0 | 107 } |
108 | |
109 // ------------------------------------------------------------------ | |
110 // ciSymbol::print_impl | |
111 // | |
112 // Implementation of the print method | |
113 void ciSymbol::print_impl(outputStream* st) { | |
114 st->print(" value="); | |
115 print_symbol_on(st); | |
116 } | |
117 | |
118 // ------------------------------------------------------------------ | |
119 // ciSymbol::print_symbol_on | |
120 // | |
121 // Print the value of this symbol on an outputStream | |
122 void ciSymbol::print_symbol_on(outputStream *st) { | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
123 GUARDED_VM_ENTRY(get_symbol()->print_symbol_on(st);) |
0 | 124 } |
125 | |
126 // ------------------------------------------------------------------ | |
127 // ciSymbol::make_impl | |
128 // | |
129 // Make a ciSymbol from a C string (implementation). | |
130 ciSymbol* ciSymbol::make_impl(const char* s) { | |
131 EXCEPTION_CONTEXT; | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
132 TempNewSymbol sym = SymbolTable::new_symbol(s, THREAD); |
0 | 133 if (HAS_PENDING_EXCEPTION) { |
134 CLEAR_PENDING_EXCEPTION; | |
135 CURRENT_THREAD_ENV->record_out_of_memory_failure(); | |
136 return ciEnv::_unloaded_cisymbol; | |
137 } | |
2177
3582bf76420e
6990754: Use native memory and reference counting to implement SymbolTable
coleenp
parents:
1972
diff
changeset
|
138 return CURRENT_THREAD_ENV->get_symbol(sym); |
0 | 139 } |
140 | |
141 // ------------------------------------------------------------------ | |
142 // ciSymbol::make | |
143 // | |
144 // Make a ciSymbol from a C string. | |
145 ciSymbol* ciSymbol::make(const char* s) { | |
146 GUARDED_VM_ENTRY(return make_impl(s);) | |
147 } |