author | coleenp |
Wed, 14 Aug 2019 10:07:00 -0400 | |
changeset 57745 | 789e967c2731 |
parent 57514 | 9b6d4e64778c |
child 58679 | 9c3209ff7550 |
child 59014 | 36fde8064316 |
permissions | -rw-r--r-- |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
1 |
/* |
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52760
diff
changeset
|
2 |
* Copyright (c) 2002, 2019, Oracle and/or its affiliates. All rights reserved. |
53408
e17d7ffad9e3
8216060: [PPC64] Vector CRC implementation should be used by interpreter and be faster for short arrays
mdoerr
parents:
53244
diff
changeset
|
3 |
* Copyright (c) 2012, 2019, SAP SE. All rights reserved. |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
4 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
5 |
* |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
6 |
* This code is free software; you can redistribute it and/or modify it |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
7 |
* under the terms of the GNU General Public License version 2 only, as |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
8 |
* published by the Free Software Foundation. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
9 |
* |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
10 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
11 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
12 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
13 |
* version 2 for more details (a copy is included in the LICENSE file that |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
14 |
* accompanied this code). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
15 |
* |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
16 |
* You should have received a copy of the GNU General Public License version |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
17 |
* 2 along with this work; if not, write to the Free Software Foundation, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
18 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
19 |
* |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
20 |
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
21 |
* or visit www.oracle.com if you need additional information or have any |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
22 |
* questions. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
23 |
* |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
24 |
*/ |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
25 |
|
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52760
diff
changeset
|
26 |
#ifndef CPU_PPC_MACROASSEMBLER_PPC_HPP |
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52760
diff
changeset
|
27 |
#define CPU_PPC_MACROASSEMBLER_PPC_HPP |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
28 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
29 |
#include "asm/assembler.hpp" |
50162
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
30 |
#include "oops/accessDecorators.hpp" |
30303 | 31 |
#include "runtime/rtmLocking.hpp" |
27684
e0391b2bf625
8064581: Move INCLUDE_ALL_GCS include section to the end of the include list
stefank
parents:
23492
diff
changeset
|
32 |
#include "utilities/macros.hpp" |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
33 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
34 |
// MacroAssembler extends Assembler by a few frequently used macros. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
35 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
36 |
class ciTypeArray; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
37 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
38 |
class MacroAssembler: public Assembler { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
39 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
40 |
MacroAssembler(CodeBuffer* code) : Assembler(code) {} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
41 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
42 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
43 |
// Optimized instruction emitters |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
44 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
45 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
46 |
inline static int largeoffset_si16_si16_hi(int si31) { return (si31 + (1<<15)) >> 16; } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
47 |
inline static int largeoffset_si16_si16_lo(int si31) { return si31 - (((si31 + (1<<15)) >> 16) << 16); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
48 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
49 |
// load d = *[a+si31] |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
50 |
// Emits several instructions if the offset is not encodable in one instruction. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
51 |
void ld_largeoffset_unchecked(Register d, int si31, Register a, int emit_filler_nop); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
52 |
void ld_largeoffset (Register d, int si31, Register a, int emit_filler_nop); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
53 |
inline static bool is_ld_largeoffset(address a); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
54 |
inline static int get_ld_largeoffset_offset(address a); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
55 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
56 |
inline void round_to(Register r, int modulus); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
57 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
58 |
// Load/store with type given by parameter. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
59 |
void load_sized_value( Register dst, RegisterOrConstant offs, Register base, size_t size_in_bytes, bool is_signed); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
60 |
void store_sized_value(Register dst, RegisterOrConstant offs, Register base, size_t size_in_bytes); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
61 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
62 |
// Move register if destination register and target register are different |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
63 |
inline void mr_if_needed(Register rd, Register rs); |
22861 | 64 |
inline void fmr_if_needed(FloatRegister rd, FloatRegister rs); |
65 |
// This is dedicated for emitting scheduled mach nodes. For better |
|
66 |
// readability of the ad file I put it here. |
|
67 |
// Endgroups are not needed if |
|
68 |
// - the scheduler is off |
|
69 |
// - the scheduler found that there is a natural group end, in that |
|
70 |
// case it reduced the size of the instruction used in the test |
|
71 |
// yielding 'needed'. |
|
72 |
inline void endgroup_if_needed(bool needed); |
|
73 |
||
74 |
// Memory barriers. |
|
75 |
inline void membar(int bits); |
|
76 |
inline void release(); |
|
77 |
inline void acquire(); |
|
78 |
inline void fence(); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
79 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
80 |
// nop padding |
22861 | 81 |
void align(int modulus, int max = 252, int rem = 0); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
82 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
83 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
84 |
// Constants, loading constants, TOC support |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
85 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
86 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
87 |
// Address of the global TOC. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
88 |
inline static address global_toc(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
89 |
// Offset of given address to the global TOC. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
90 |
inline static int offset_to_global_toc(const address addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
91 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
92 |
// Address of TOC of the current method. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
93 |
inline address method_toc(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
94 |
// Offset of given address to TOC of the current method. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
95 |
inline int offset_to_method_toc(const address addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
96 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
97 |
// Global TOC. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
98 |
void calculate_address_from_global_toc(Register dst, address addr, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
99 |
bool hi16 = true, bool lo16 = true, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
100 |
bool add_relocation = true, bool emit_dummy_addr = false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
101 |
inline void calculate_address_from_global_toc_hi16only(Register dst, address addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
102 |
calculate_address_from_global_toc(dst, addr, true, false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
103 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
104 |
inline void calculate_address_from_global_toc_lo16only(Register dst, address addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
105 |
calculate_address_from_global_toc(dst, addr, false, true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
106 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
107 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
108 |
inline static bool is_calculate_address_from_global_toc_at(address a, address bound); |
47520
50790528dd25
8187547: PPC64: icache invalidation is incorrect in some places
goetz
parents:
47216
diff
changeset
|
109 |
// Returns address of first instruction in sequence. |
50790528dd25
8187547: PPC64: icache invalidation is incorrect in some places
goetz
parents:
47216
diff
changeset
|
110 |
static address patch_calculate_address_from_global_toc_at(address a, address bound, address addr); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
111 |
static address get_address_of_calculate_address_from_global_toc_at(address a, address addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
112 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
113 |
#ifdef _LP64 |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
114 |
// Patch narrow oop constant. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
115 |
inline static bool is_set_narrow_oop(address a, address bound); |
47520
50790528dd25
8187547: PPC64: icache invalidation is incorrect in some places
goetz
parents:
47216
diff
changeset
|
116 |
// Returns address of first instruction in sequence. |
50790528dd25
8187547: PPC64: icache invalidation is incorrect in some places
goetz
parents:
47216
diff
changeset
|
117 |
static address patch_set_narrow_oop(address a, address bound, narrowOop data); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
118 |
static narrowOop get_narrow_oop(address a, address bound); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
119 |
#endif |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
120 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
121 |
inline static bool is_load_const_at(address a); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
122 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
123 |
// Emits an oop const to the constant pool, loads the constant, and |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
124 |
// sets a relocation info with address current_pc. |
35085 | 125 |
// Returns true if successful. |
126 |
bool load_const_from_method_toc(Register dst, AddressLiteral& a, Register toc, bool fixed_size = false); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
127 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
128 |
static bool is_load_const_from_method_toc_at(address a); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
129 |
static int get_offset_of_load_const_from_method_toc_at(address a); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
130 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
131 |
// Get the 64 bit constant from a `load_const' sequence. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
132 |
static long get_const(address load_const); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
133 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
134 |
// Patch the 64 bit constant of a `load_const' sequence. This is a |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
135 |
// low level procedure. It neither flushes the instruction cache nor |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
136 |
// is it atomic. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
137 |
static void patch_const(address load_const, long x); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
138 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
139 |
// Metadata in code that we have to keep track of. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
140 |
AddressLiteral allocate_metadata_address(Metadata* obj); // allocate_index |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
141 |
AddressLiteral constant_metadata_address(Metadata* obj); // find_index |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
142 |
// Oops used directly in compiled code are stored in the constant pool, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
143 |
// and loaded from there. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
144 |
// Allocate new entry for oop in constant pool. Generate relocation. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
145 |
AddressLiteral allocate_oop_address(jobject obj); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
146 |
// Find oop obj in constant pool. Return relocation with it's index. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
147 |
AddressLiteral constant_oop_address(jobject obj); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
148 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
149 |
// Find oop in constant pool and emit instructions to load it. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
150 |
// Uses constant_oop_address. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
151 |
inline void set_oop_constant(jobject obj, Register d); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
152 |
// Same as load_address. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
153 |
inline void set_oop (AddressLiteral obj_addr, Register d); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
154 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
155 |
// Read runtime constant: Issue load if constant not yet established, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
156 |
// else use real constant. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
157 |
virtual RegisterOrConstant delayed_value_impl(intptr_t* delayed_value_addr, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
158 |
Register tmp, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
159 |
int offset); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
160 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
161 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
162 |
// branch, jump |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
163 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
164 |
|
51633
21154cb84d2a
8209594: guarantee(this->is8bit(imm8)) failed: Short forward jump exceeds 8-bit offset
kvn
parents:
50162
diff
changeset
|
165 |
inline void pd_patch_instruction(address branch, address target, const char* file, int line); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
166 |
NOT_PRODUCT(static void pd_print_patched_instruction(address branch);) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
167 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
168 |
// Conditional far branch for destinations encodable in 24+2 bits. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
169 |
// Same interface as bc, e.g. no inverse boint-field. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
170 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
171 |
bc_far_optimize_not = 0, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
172 |
bc_far_optimize_on_relocate = 1 |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
173 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
174 |
// optimize: flag for telling the conditional far branch to optimize |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
175 |
// itself when relocated. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
176 |
void bc_far(int boint, int biint, Label& dest, int optimize); |
35085 | 177 |
void bc_far_optimized(int boint, int biint, Label& dest); // 1 or 2 instructions |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
178 |
// Relocation of conditional far branches. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
179 |
static bool is_bc_far_at(address instruction_addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
180 |
static address get_dest_of_bc_far_at(address instruction_addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
181 |
static void set_dest_of_bc_far_at(address instruction_addr, address dest); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
182 |
private: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
183 |
static bool inline is_bc_far_variant1_at(address instruction_addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
184 |
static bool inline is_bc_far_variant2_at(address instruction_addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
185 |
static bool inline is_bc_far_variant3_at(address instruction_addr); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
186 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
187 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
188 |
// Convenience bc_far versions. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
189 |
inline void blt_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
190 |
inline void bgt_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
191 |
inline void beq_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
192 |
inline void bso_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
193 |
inline void bge_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
194 |
inline void ble_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
195 |
inline void bne_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
196 |
inline void bns_far(ConditionRegister crx, Label& L, int optimize); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
197 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
198 |
// Emit, identify and patch a NOT mt-safe patchable 64 bit absolute call/jump. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
199 |
private: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
200 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
201 |
bxx64_patchable_instruction_count = (2/*load_codecache_const*/ + 3/*5load_const*/ + 1/*mtctr*/ + 1/*bctrl*/), |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
202 |
bxx64_patchable_size = bxx64_patchable_instruction_count * BytesPerInstWord, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
203 |
bxx64_patchable_ret_addr_offset = bxx64_patchable_size |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
204 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
205 |
void bxx64_patchable(address target, relocInfo::relocType rt, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
206 |
static bool is_bxx64_patchable_at( address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
207 |
// Does the instruction use a pc-relative encoding of the destination? |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
208 |
static bool is_bxx64_patchable_pcrelative_at( address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
209 |
static bool is_bxx64_patchable_variant1_at( address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
210 |
// Load destination relative to global toc. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
211 |
static bool is_bxx64_patchable_variant1b_at( address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
212 |
static bool is_bxx64_patchable_variant2_at( address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
213 |
static void set_dest_of_bxx64_patchable_at( address instruction_addr, address target, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
214 |
static address get_dest_of_bxx64_patchable_at(address instruction_addr, bool link); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
215 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
216 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
217 |
// call |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
218 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
219 |
bl64_patchable_instruction_count = bxx64_patchable_instruction_count, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
220 |
bl64_patchable_size = bxx64_patchable_size, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
221 |
bl64_patchable_ret_addr_offset = bxx64_patchable_ret_addr_offset |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
222 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
223 |
inline void bl64_patchable(address target, relocInfo::relocType rt) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
224 |
bxx64_patchable(target, rt, /*link=*/true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
225 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
226 |
inline static bool is_bl64_patchable_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
227 |
return is_bxx64_patchable_at(instruction_addr, /*link=*/true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
228 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
229 |
inline static bool is_bl64_patchable_pcrelative_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
230 |
return is_bxx64_patchable_pcrelative_at(instruction_addr, /*link=*/true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
231 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
232 |
inline static void set_dest_of_bl64_patchable_at(address instruction_addr, address target) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
233 |
set_dest_of_bxx64_patchable_at(instruction_addr, target, /*link=*/true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
234 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
235 |
inline static address get_dest_of_bl64_patchable_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
236 |
return get_dest_of_bxx64_patchable_at(instruction_addr, /*link=*/true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
237 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
238 |
// jump |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
239 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
240 |
b64_patchable_instruction_count = bxx64_patchable_instruction_count, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
241 |
b64_patchable_size = bxx64_patchable_size, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
242 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
243 |
inline void b64_patchable(address target, relocInfo::relocType rt) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
244 |
bxx64_patchable(target, rt, /*link=*/false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
245 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
246 |
inline static bool is_b64_patchable_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
247 |
return is_bxx64_patchable_at(instruction_addr, /*link=*/false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
248 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
249 |
inline static bool is_b64_patchable_pcrelative_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
250 |
return is_bxx64_patchable_pcrelative_at(instruction_addr, /*link=*/false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
251 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
252 |
inline static void set_dest_of_b64_patchable_at(address instruction_addr, address target) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
253 |
set_dest_of_bxx64_patchable_at(instruction_addr, target, /*link=*/false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
254 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
255 |
inline static address get_dest_of_b64_patchable_at(address instruction_addr) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
256 |
return get_dest_of_bxx64_patchable_at(instruction_addr, /*link=*/false); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
257 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
258 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
259 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
260 |
// Support for frame handling |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
261 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
262 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
263 |
// some ABI-related functions |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
264 |
void save_nonvolatile_gprs( Register dst_base, int offset); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
265 |
void restore_nonvolatile_gprs(Register src_base, int offset); |
35085 | 266 |
enum { num_volatile_regs = 11 + 14 }; // GPR + FPR |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
267 |
void save_volatile_gprs( Register dst_base, int offset); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
268 |
void restore_volatile_gprs(Register src_base, int offset); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
269 |
void save_LR_CR( Register tmp); // tmp contains LR on return. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
270 |
void restore_LR_CR(Register tmp); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
271 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
272 |
// Get current PC using bl-next-instruction trick. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
273 |
address get_PC_trash_LR(Register result); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
274 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
275 |
// Resize current frame either relatively wrt to current SP or absolute. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
276 |
void resize_frame(Register offset, Register tmp); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
277 |
void resize_frame(int offset, Register tmp); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
278 |
void resize_frame_absolute(Register addr, Register tmp1, Register tmp2); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
279 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
280 |
// Push a frame of size bytes. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
281 |
void push_frame(Register bytes, Register tmp); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
282 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
283 |
// Push a frame of size `bytes'. No abi space provided. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
284 |
void push_frame(unsigned int bytes, Register tmp); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
285 |
|
23211 | 286 |
// Push a frame of size `bytes' plus abi_reg_args on top. |
287 |
void push_frame_reg_args(unsigned int bytes, Register tmp); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
288 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
289 |
// Setup up a new C frame with a spill area for non-volatile GPRs and additional |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
290 |
// space for local variables |
23211 | 291 |
void push_frame_reg_args_nonvolatiles(unsigned int bytes, Register tmp); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
292 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
293 |
// pop current C frame |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
294 |
void pop_frame(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
295 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
296 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
297 |
// Calls |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
298 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
299 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
300 |
private: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
301 |
address _last_calls_return_pc; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
302 |
|
23211 | 303 |
#if defined(ABI_ELFv2) |
304 |
// Generic version of a call to C function. |
|
305 |
// Updates and returns _last_calls_return_pc. |
|
306 |
address branch_to(Register function_entry, bool and_link); |
|
307 |
#else |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
308 |
// Generic version of a call to C function via a function descriptor |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
309 |
// with variable support for C calling conventions (TOC, ENV, etc.). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
310 |
// updates and returns _last_calls_return_pc. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
311 |
address branch_to(Register function_descriptor, bool and_link, bool save_toc_before_call, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
312 |
bool restore_toc_after_call, bool load_toc_of_callee, bool load_env_of_callee); |
23211 | 313 |
#endif |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
314 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
315 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
316 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
317 |
// Get the pc where the last call will return to. returns _last_calls_return_pc. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
318 |
inline address last_calls_return_pc(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
319 |
|
23211 | 320 |
#if defined(ABI_ELFv2) |
321 |
// Call a C function via a function descriptor and use full C |
|
322 |
// calling conventions. Updates and returns _last_calls_return_pc. |
|
323 |
address call_c(Register function_entry); |
|
324 |
// For tail calls: only branch, don't link, so callee returns to caller of this function. |
|
325 |
address call_c_and_return_to_caller(Register function_entry); |
|
326 |
address call_c(address function_entry, relocInfo::relocType rt); |
|
327 |
#else |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
328 |
// Call a C function via a function descriptor and use full C |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
329 |
// calling conventions. Updates and returns _last_calls_return_pc. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
330 |
address call_c(Register function_descriptor); |
22861 | 331 |
// For tail calls: only branch, don't link, so callee returns to caller of this function. |
332 |
address call_c_and_return_to_caller(Register function_descriptor); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
333 |
address call_c(const FunctionDescriptor* function_descriptor, relocInfo::relocType rt); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
334 |
address call_c_using_toc(const FunctionDescriptor* function_descriptor, relocInfo::relocType rt, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
335 |
Register toc); |
23211 | 336 |
#endif |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
337 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
338 |
protected: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
339 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
340 |
// It is imperative that all calls into the VM are handled via the |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
341 |
// call_VM macros. They make sure that the stack linkage is setup |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
342 |
// correctly. call_VM's correspond to ENTRY/ENTRY_X entry points |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
343 |
// while call_VM_leaf's correspond to LEAF entry points. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
344 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
345 |
// This is the base routine called by the different versions of |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
346 |
// call_VM. The interpreter may customize this version by overriding |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
347 |
// it for its purposes (e.g., to save/restore additional registers |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
348 |
// when doing a VM call). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
349 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
350 |
// If no last_java_sp is specified (noreg) then SP will be used instead. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
351 |
virtual void call_VM_base( |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
352 |
// where an oop-result ends up if any; use noreg otherwise |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
353 |
Register oop_result, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
354 |
// to set up last_Java_frame in stubs; use noreg otherwise |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
355 |
Register last_java_sp, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
356 |
// the entry point |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
357 |
address entry_point, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
358 |
// flag which indicates if exception should be checked |
22861 | 359 |
bool check_exception = true |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
360 |
); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
361 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
362 |
// Support for VM calls. This is the base routine called by the |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
363 |
// different versions of call_VM_leaf. The interpreter may customize |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
364 |
// this version by overriding it for its purposes (e.g., to |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
365 |
// save/restore additional registers when doing a VM call). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
366 |
void call_VM_leaf_base(address entry_point); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
367 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
368 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
369 |
// Call into the VM. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
370 |
// Passes the thread pointer (in R3_ARG1) as a prepended argument. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
371 |
// Makes sure oop return values are visible to the GC. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
372 |
void call_VM(Register oop_result, address entry_point, bool check_exceptions = true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
373 |
void call_VM(Register oop_result, address entry_point, Register arg_1, bool check_exceptions = true); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
374 |
void call_VM(Register oop_result, address entry_point, Register arg_1, Register arg_2, bool check_exceptions = true); |
28187
fc19df82d6ee
8066964: ppc64: argument and return type profiling, fix problem with popframe
goetz
parents:
27684
diff
changeset
|
375 |
void call_VM(Register oop_result, address entry_point, Register arg_1, Register arg_2, Register arg3, bool check_exceptions = true); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
376 |
void call_VM_leaf(address entry_point); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
377 |
void call_VM_leaf(address entry_point, Register arg_1); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
378 |
void call_VM_leaf(address entry_point, Register arg_1, Register arg_2); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
379 |
void call_VM_leaf(address entry_point, Register arg_1, Register arg_2, Register arg_3); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
380 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
381 |
// Call a stub function via a function descriptor, but don't save |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
382 |
// TOC before call, don't setup TOC and ENV for call, and don't |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
383 |
// restore TOC after call. Updates and returns _last_calls_return_pc. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
384 |
inline address call_stub(Register function_entry); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
385 |
inline void call_stub_and_return_to(Register function_entry, Register return_pc); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
386 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
387 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
388 |
// Java utilities |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
389 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
390 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
391 |
// Read from the polling page, its address is already in a register. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
392 |
inline void load_from_polling_page(Register polling_page_address, int offset = 0); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
393 |
// Check whether instruction is a read access to the polling page |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
394 |
// which was emitted by load_from_polling_page(..). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
395 |
static bool is_load_from_polling_page(int instruction, void* ucontext/*may be NULL*/, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
396 |
address* polling_address_ptr = NULL); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
397 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
398 |
// Support for NULL-checks |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
399 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
400 |
// Generates code that causes a NULL OS exception if the content of reg is NULL. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
401 |
// If the accessed location is M[reg + offset] and the offset is known, provide the |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
402 |
// offset. No explicit code generation is needed if the offset is within a certain |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
403 |
// range (0 <= offset <= page_size). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
404 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
405 |
// Stack overflow checking |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
406 |
void bang_stack_with_offset(int offset); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
407 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
408 |
// If instruction is a stack bang of the form ld, stdu, or |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
409 |
// stdux, return the banged address. Otherwise, return 0. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
410 |
static address get_stack_bang_address(int instruction, void* ucontext); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
411 |
|
38931
3cf28d630349
8156923: [ppc] Implement "JEP 270: Reserved Stack Areas for Critical Sections".
goetz
parents:
38685
diff
changeset
|
412 |
// Check for reserved stack access in method being exited. If the reserved |
3cf28d630349
8156923: [ppc] Implement "JEP 270: Reserved Stack Areas for Critical Sections".
goetz
parents:
38685
diff
changeset
|
413 |
// stack area was accessed, protect it again and throw StackOverflowError. |
3cf28d630349
8156923: [ppc] Implement "JEP 270: Reserved Stack Areas for Critical Sections".
goetz
parents:
38685
diff
changeset
|
414 |
void reserved_stack_check(Register return_pc); |
3cf28d630349
8156923: [ppc] Implement "JEP 270: Reserved Stack Areas for Critical Sections".
goetz
parents:
38685
diff
changeset
|
415 |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
416 |
// Atomics |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
417 |
// CmpxchgX sets condition register to cmpX(current, compare). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
418 |
// (flag == ne) => (dest_current_value != compare_value), (!swapped) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
419 |
// (flag == eq) => (dest_current_value == compare_value), ( swapped) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
420 |
static inline bool cmpxchgx_hint_acquire_lock() { return true; } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
421 |
// The stxcx will probably not be succeeded by a releasing store. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
422 |
static inline bool cmpxchgx_hint_release_lock() { return false; } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
423 |
static inline bool cmpxchgx_hint_atomic_update() { return false; } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
424 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
425 |
// Cmpxchg semantics |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
426 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
427 |
MemBarNone = 0, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
428 |
MemBarRel = 1, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
429 |
MemBarAcq = 2, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
430 |
MemBarFenceAfter = 4 // use powers of 2 |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
431 |
}; |
39444
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
432 |
private: |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
433 |
// Helper functions for word/sub-word atomics. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
434 |
void atomic_get_and_modify_generic(Register dest_current_value, Register exchange_value, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
435 |
Register addr_base, Register tmp1, Register tmp2, Register tmp3, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
436 |
bool cmpxchgx_hint, bool is_add, int size); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
437 |
void cmpxchg_loop_body(ConditionRegister flag, Register dest_current_value, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
438 |
Register compare_value, Register exchange_value, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
439 |
Register addr_base, Register tmp1, Register tmp2, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
440 |
Label &retry, Label &failed, bool cmpxchgx_hint, int size); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
441 |
void cmpxchg_generic(ConditionRegister flag, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
442 |
Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
443 |
Register tmp1, Register tmp2, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
444 |
int semantics, bool cmpxchgx_hint, Register int_flag_success, bool contention_hint, bool weak, int size); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
445 |
public: |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
446 |
// Temps and addr_base are killed if processor does not support Power 8 instructions. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
447 |
// Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
448 |
void getandsetb(Register dest_current_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
449 |
Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
450 |
atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, false, 1); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
451 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
452 |
// Temps and addr_base are killed if processor does not support Power 8 instructions. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
453 |
// Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
454 |
void getandseth(Register dest_current_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
455 |
Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
456 |
atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, false, 2); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
457 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
458 |
void getandsetw(Register dest_current_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
459 |
bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
460 |
atomic_get_and_modify_generic(dest_current_value, exchange_value, addr_base, noreg, noreg, noreg, cmpxchgx_hint, false, 4); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
461 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
462 |
void getandsetd(Register dest_current_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
463 |
bool cmpxchgx_hint); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
464 |
// tmp2/3 and addr_base are killed if processor does not support Power 8 instructions (tmp1 is always needed). |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
465 |
// Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
466 |
void getandaddb(Register dest_current_value, Register inc_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
467 |
Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
468 |
atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, true, 1); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
469 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
470 |
// tmp2/3 and addr_base are killed if processor does not support Power 8 instructions (tmp1 is always needed). |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
471 |
// Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
472 |
void getandaddh(Register dest_current_value, Register inc_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
473 |
Register tmp1, Register tmp2, Register tmp3, bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
474 |
atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, tmp2, tmp3, cmpxchgx_hint, true, 2); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
475 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
476 |
void getandaddw(Register dest_current_value, Register inc_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
477 |
Register tmp1, bool cmpxchgx_hint) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
478 |
atomic_get_and_modify_generic(dest_current_value, inc_value, addr_base, tmp1, noreg, noreg, cmpxchgx_hint, true, 4); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
479 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
480 |
void getandaddd(Register dest_current_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
481 |
Register tmp, bool cmpxchgx_hint); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
482 |
// Temps, addr_base and exchange_value are killed if processor does not support Power 8 instructions. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
483 |
// compare_value must be at least 32 bit sign extended. Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
484 |
void cmpxchgb(ConditionRegister flag, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
485 |
Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
486 |
Register tmp1, Register tmp2, int semantics, bool cmpxchgx_hint = false, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
487 |
Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
488 |
cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, tmp1, tmp2, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
489 |
semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 1); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
490 |
} |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
491 |
// Temps, addr_base and exchange_value are killed if processor does not support Power 8 instructions. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
492 |
// compare_value must be at least 32 bit sign extended. Result will be sign extended. |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
493 |
void cmpxchgh(ConditionRegister flag, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
494 |
Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
495 |
Register tmp1, Register tmp2, int semantics, bool cmpxchgx_hint = false, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
496 |
Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
497 |
cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, tmp1, tmp2, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
498 |
semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 2); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
499 |
} |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
500 |
void cmpxchgw(ConditionRegister flag, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
501 |
Register dest_current_value, Register compare_value, Register exchange_value, Register addr_base, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
502 |
int semantics, bool cmpxchgx_hint = false, |
39444
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
503 |
Register int_flag_success = noreg, bool contention_hint = false, bool weak = false) { |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
504 |
cmpxchg_generic(flag, dest_current_value, compare_value, exchange_value, addr_base, noreg, noreg, |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
505 |
semantics, cmpxchgx_hint, int_flag_success, contention_hint, weak, 4); |
2eae9b74c1f3
8159976: PPC64: Add missing intrinsics for sub-word atomics
mdoerr
parents:
38931
diff
changeset
|
506 |
} |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
507 |
void cmpxchgd(ConditionRegister flag, |
30303 | 508 |
Register dest_current_value, RegisterOrConstant compare_value, Register exchange_value, |
509 |
Register addr_base, int semantics, bool cmpxchgx_hint = false, |
|
38685
e34308190947
8141635: Implement VarHandles/Unsafe intrinsics on POWER
mdoerr
parents:
38074
diff
changeset
|
510 |
Register int_flag_success = noreg, Label* failed = NULL, bool contention_hint = false, bool weak = false); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
511 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
512 |
// interface method calling |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
513 |
void lookup_interface_method(Register recv_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
514 |
Register intf_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
515 |
RegisterOrConstant itable_index, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
516 |
Register method_result, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
517 |
Register temp_reg, Register temp2_reg, |
48585
d9fcb7ba8133
8191907: PPC64 and s390 parts of JDK-8174962: Better interface invocations
mdoerr
parents:
48332
diff
changeset
|
518 |
Label& no_such_interface, |
d9fcb7ba8133
8191907: PPC64 and s390 parts of JDK-8174962: Better interface invocations
mdoerr
parents:
48332
diff
changeset
|
519 |
bool return_method = true); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
520 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
521 |
// virtual method calling |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
522 |
void lookup_virtual_method(Register recv_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
523 |
RegisterOrConstant vtable_index, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
524 |
Register method_result); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
525 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
526 |
// Test sub_klass against super_klass, with fast and slow paths. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
527 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
528 |
// The fast path produces a tri-state answer: yes / no / maybe-slow. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
529 |
// One of the three labels can be NULL, meaning take the fall-through. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
530 |
// If super_check_offset is -1, the value is loaded up from super_klass. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
531 |
// No registers are killed, except temp_reg and temp2_reg. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
532 |
// If super_check_offset is not -1, temp2_reg is not used and can be noreg. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
533 |
void check_klass_subtype_fast_path(Register sub_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
534 |
Register super_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
535 |
Register temp1_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
536 |
Register temp2_reg, |
35085 | 537 |
Label* L_success, |
538 |
Label* L_failure, |
|
539 |
Label* L_slow_path = NULL, // default fall through |
|
540 |
RegisterOrConstant super_check_offset = RegisterOrConstant(-1)); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
541 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
542 |
// The rest of the type check; must be wired to a corresponding fast path. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
543 |
// It does not repeat the fast path logic, so don't use it standalone. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
544 |
// The temp_reg can be noreg, if no temps are available. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
545 |
// It can also be sub_klass or super_klass, meaning it's OK to kill that one. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
546 |
// Updates the sub's secondary super cache as necessary. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
547 |
void check_klass_subtype_slow_path(Register sub_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
548 |
Register super_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
549 |
Register temp1_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
550 |
Register temp2_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
551 |
Label* L_success = NULL, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
552 |
Register result_reg = noreg); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
553 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
554 |
// Simplified, combined version, good for typical uses. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
555 |
// Falls through on failure. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
556 |
void check_klass_subtype(Register sub_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
557 |
Register super_klass, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
558 |
Register temp1_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
559 |
Register temp2_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
560 |
Label& L_success); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
561 |
|
55322
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
562 |
void clinit_barrier(Register klass, |
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
563 |
Register thread, |
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
564 |
Label* L_fast_path = NULL, |
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
565 |
Label* L_slow_path = NULL); |
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
566 |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
567 |
// Method handle support (JSR 292). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
568 |
RegisterOrConstant argument_offset(RegisterOrConstant arg_slot, Register temp_reg, int extra_slot_offset = 0); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
569 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
570 |
// Biased locking support |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
571 |
// Upon entry,obj_reg must contain the target object, and mark_reg |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
572 |
// must contain the target object's header. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
573 |
// Destroys mark_reg if an attempt is made to bias an anonymously |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
574 |
// biased lock. In this case a failure will go either to the slow |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
575 |
// case or fall through with the notEqual condition code set with |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
576 |
// the expectation that the slow case in the runtime will be called. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
577 |
// In the fall-through case where the CAS-based lock is done, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
578 |
// mark_reg is not destroyed. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
579 |
void biased_locking_enter(ConditionRegister cr_reg, Register obj_reg, Register mark_reg, Register temp_reg, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
580 |
Register temp2_reg, Label& done, Label* slow_case = NULL); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
581 |
// Upon entry, the base register of mark_addr must contain the oop. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
582 |
// Destroys temp_reg. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
583 |
// If allow_delay_slot_filling is set to true, the next instruction |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
584 |
// emitted after this one will go in an annulled delay slot if the |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
585 |
// biased locking exit case failed. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
586 |
void biased_locking_exit(ConditionRegister cr_reg, Register mark_addr, Register temp_reg, Label& done); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
587 |
|
35085 | 588 |
// allocation (for C1) |
589 |
void eden_allocate( |
|
590 |
Register obj, // result: pointer to object after successful allocation |
|
591 |
Register var_size_in_bytes, // object size in bytes if unknown at compile time; invalid otherwise |
|
592 |
int con_size_in_bytes, // object size in bytes if known at compile time |
|
593 |
Register t1, // temp register |
|
594 |
Register t2, // temp register |
|
595 |
Label& slow_case // continuation point if fast allocation fails |
|
596 |
); |
|
597 |
void tlab_allocate( |
|
598 |
Register obj, // result: pointer to object after successful allocation |
|
599 |
Register var_size_in_bytes, // object size in bytes if unknown at compile time; invalid otherwise |
|
600 |
int con_size_in_bytes, // object size in bytes if known at compile time |
|
601 |
Register t1, // temp register |
|
602 |
Label& slow_case // continuation point if fast allocation fails |
|
603 |
); |
|
604 |
void incr_allocated_bytes(RegisterOrConstant size_in_bytes, Register t1, Register t2); |
|
605 |
||
606 |
enum { trampoline_stub_size = 6 * 4 }; |
|
607 |
address emit_trampoline_stub(int destination_toc_offset, int insts_call_instruction_offset, Register Rtoc = noreg); |
|
608 |
||
30303 | 609 |
void atomic_inc_ptr(Register addr, Register result, int simm16 = 1); |
610 |
void atomic_ori_int(Register addr, Register result, int uimm16); |
|
611 |
||
612 |
#if INCLUDE_RTM_OPT |
|
613 |
void rtm_counters_update(Register abort_status, Register rtm_counters); |
|
614 |
void branch_on_random_using_tb(Register tmp, int count, Label& brLabel); |
|
615 |
void rtm_abort_ratio_calculation(Register rtm_counters_reg, RTMLockingCounters* rtm_counters, |
|
616 |
Metadata* method_data); |
|
617 |
void rtm_profiling(Register abort_status_Reg, Register temp_Reg, |
|
618 |
RTMLockingCounters* rtm_counters, Metadata* method_data, bool profile_rtm); |
|
619 |
void rtm_retry_lock_on_abort(Register retry_count, Register abort_status, |
|
620 |
Label& retryLabel, Label* checkRetry = NULL); |
|
621 |
void rtm_retry_lock_on_busy(Register retry_count, Register owner_addr, Label& retryLabel); |
|
622 |
void rtm_stack_locking(ConditionRegister flag, Register obj, Register mark_word, Register tmp, |
|
623 |
Register retry_on_abort_count, |
|
624 |
RTMLockingCounters* stack_rtm_counters, |
|
625 |
Metadata* method_data, bool profile_rtm, |
|
626 |
Label& DONE_LABEL, Label& IsInflated); |
|
627 |
void rtm_inflated_locking(ConditionRegister flag, Register obj, Register mark_word, Register box, |
|
628 |
Register retry_on_busy_count, Register retry_on_abort_count, |
|
629 |
RTMLockingCounters* rtm_counters, |
|
630 |
Metadata* method_data, bool profile_rtm, |
|
631 |
Label& DONE_LABEL); |
|
632 |
#endif |
|
633 |
||
634 |
void compiler_fast_lock_object(ConditionRegister flag, Register oop, Register box, |
|
635 |
Register tmp1, Register tmp2, Register tmp3, |
|
636 |
bool try_bias = UseBiasedLocking, |
|
637 |
RTMLockingCounters* rtm_counters = NULL, |
|
638 |
RTMLockingCounters* stack_rtm_counters = NULL, |
|
639 |
Metadata* method_data = NULL, |
|
640 |
bool use_rtm = false, bool profile_rtm = false); |
|
641 |
||
642 |
void compiler_fast_unlock_object(ConditionRegister flag, Register oop, Register box, |
|
643 |
Register tmp1, Register tmp2, Register tmp3, |
|
644 |
bool try_bias = UseBiasedLocking, bool use_rtm = false); |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
645 |
|
48332
651a95f30dfb
8193257: PPC64, s390 implementation for Thread-local handshakes
mdoerr
parents:
47565
diff
changeset
|
646 |
// Check if safepoint requested and if so branch |
651a95f30dfb
8193257: PPC64, s390 implementation for Thread-local handshakes
mdoerr
parents:
47565
diff
changeset
|
647 |
void safepoint_poll(Label& slow_path, Register temp_reg); |
651a95f30dfb
8193257: PPC64, s390 implementation for Thread-local handshakes
mdoerr
parents:
47565
diff
changeset
|
648 |
|
44406
a46a6c4d1dd9
8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents:
44093
diff
changeset
|
649 |
void resolve_jobject(Register value, Register tmp1, Register tmp2, bool needs_frame); |
a46a6c4d1dd9
8176100: [REDO][REDO] G1 Needs pre barrier on dereference of weak JNI handles
mgerdin
parents:
44093
diff
changeset
|
650 |
|
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
651 |
// Support for managing the JavaThread pointer (i.e.; the reference to |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
652 |
// thread-local information). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
653 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
654 |
// Support for last Java frame (but use call_VM instead where possible): |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
655 |
// access R16_thread->last_Java_sp. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
656 |
void set_last_Java_frame(Register last_java_sp, Register last_Java_pc); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
657 |
void reset_last_Java_frame(void); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
658 |
void set_top_ijava_frame_at_SP_as_last_Java_frame(Register sp, Register tmp1); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
659 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
660 |
// Read vm result from thread: oop_result = R16_thread->result; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
661 |
void get_vm_result (Register oop_result); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
662 |
void get_vm_result_2(Register metadata_result); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
663 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
664 |
static bool needs_explicit_null_check(intptr_t offset); |
52462
4ad404da0088
8213199: GC abstraction for Assembler::needs_explicit_null_check()
rkennke
parents:
52460
diff
changeset
|
665 |
static bool uses_implicit_null_check(void* address); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
666 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
667 |
// Trap-instruction-based checks. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
668 |
// Range checks can be distinguished from zero checks as they check 32 bit, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
669 |
// zero checks all 64 bits (tw, td). |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
670 |
inline void trap_null_check(Register a, trap_to_bits cmp = traptoEqual); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
671 |
static bool is_trap_null_check(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
672 |
return is_tdi(x, traptoEqual, -1/*any reg*/, 0) || |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
673 |
is_tdi(x, traptoGreaterThanUnsigned, -1/*any reg*/, 0); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
674 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
675 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
676 |
inline void trap_zombie_not_entrant(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
677 |
static bool is_trap_zombie_not_entrant(int x) { return is_tdi(x, traptoUnconditional, 0/*reg 0*/, 1); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
678 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
679 |
inline void trap_should_not_reach_here(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
680 |
static bool is_trap_should_not_reach_here(int x) { return is_tdi(x, traptoUnconditional, 0/*reg 0*/, 2); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
681 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
682 |
inline void trap_ic_miss_check(Register a, Register b); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
683 |
static bool is_trap_ic_miss_check(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
684 |
return is_td(x, traptoGreaterThanUnsigned | traptoLessThanUnsigned, -1/*any reg*/, -1/*any reg*/); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
685 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
686 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
687 |
// Implicit or explicit null check, jumps to static address exception_entry. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
688 |
inline void null_check_throw(Register a, int offset, Register temp_reg, address exception_entry); |
35085 | 689 |
inline void null_check(Register a, int offset, Label *Lis_null); // implicit only if Lis_null not provided |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
690 |
|
50162
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
691 |
// Access heap oop, handle encoding and GC barriers. |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
692 |
// Some GC barriers call C so use needs_frame = true if an extra frame is needed at the current call site. |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
693 |
private: |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
694 |
inline void access_store_at(BasicType type, DecoratorSet decorators, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
695 |
Register base, RegisterOrConstant ind_or_offs, Register val, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
696 |
Register tmp1, Register tmp2, Register tmp3, bool needs_frame); |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
697 |
inline void access_load_at(BasicType type, DecoratorSet decorators, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
698 |
Register base, RegisterOrConstant ind_or_offs, Register dst, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
699 |
Register tmp1, Register tmp2, bool needs_frame, Label *L_handle_null = NULL); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
700 |
|
50162
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
701 |
public: |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
702 |
// Specify tmp1 for better code in certain compressed oops cases. Specify Label to bail out on null oop. |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
703 |
// tmp1, tmp2 and needs_frame are used with decorators ON_PHANTOM_OOP_REF or ON_WEAK_OOP_REF. |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
704 |
inline void load_heap_oop(Register d, RegisterOrConstant offs, Register s1, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
705 |
Register tmp1, Register tmp2, bool needs_frame, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
706 |
DecoratorSet decorators = 0, Label *L_handle_null = NULL); |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
707 |
|
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
708 |
inline void store_heap_oop(Register d, RegisterOrConstant offs, Register s1, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
709 |
Register tmp1, Register tmp2, Register tmp3, bool needs_frame, |
f9fe56417050
8202713: Create a MacroAssembler::access_load/store_at wrapper for S390 and PPC
mdoerr
parents:
49748
diff
changeset
|
710 |
DecoratorSet decorators = 0); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
711 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
712 |
// Encode/decode heap oop. Oop may not be null, else en/decoding goes wrong. |
28617
12ae756253c2
8068503: ppc64: Encode/Decode nodes for disjoint cOops mode
goetz
parents:
28187
diff
changeset
|
713 |
// src == d allowed. |
23221 | 714 |
inline Register encode_heap_oop_not_null(Register d, Register src = noreg); |
28617
12ae756253c2
8068503: ppc64: Encode/Decode nodes for disjoint cOops mode
goetz
parents:
28187
diff
changeset
|
715 |
inline Register decode_heap_oop_not_null(Register d, Register src = noreg); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
716 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
717 |
// Null allowed. |
35085 | 718 |
inline Register encode_heap_oop(Register d, Register src); // Prefer null check in GC barrier! |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
719 |
inline void decode_heap_oop(Register d); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
720 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
721 |
// Load/Store klass oop from klass field. Compress. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
722 |
void load_klass(Register dst, Register src); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
723 |
void store_klass(Register dst_oop, Register klass, Register tmp = R0); |
23221 | 724 |
void store_klass_gap(Register dst_oop, Register val = noreg); // Will store 0 if val not specified. |
38074
8475fdc6dcc3
8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents:
36303
diff
changeset
|
725 |
|
46961
c9094b1e5f87
8186088: ConstantPoolCache::_resolved_references is not a JNIHandle
coleenp
parents:
46369
diff
changeset
|
726 |
void resolve_oop_handle(Register result); |
42068
18c8a4d5998e
8168083: PPC64: Cleanup template interpreter after 8154580 and 8154867
mdoerr
parents:
41334
diff
changeset
|
727 |
void load_mirror_from_const_method(Register mirror, Register const_method); |
55322
bc5baf205475
8224826: Implement fast class initialization checks on PPC64
mdoerr
parents:
53483
diff
changeset
|
728 |
void load_method_holder(Register holder, Register method); |
38074
8475fdc6dcc3
8154580: Save mirror in interpreter frame to enable cleanups of CLDClosure
coleenp
parents:
36303
diff
changeset
|
729 |
|
22843
b245fac3b6a4
8027968: Adapt PPC to 8024927: Nashorn performance regression with CompressedOops
goetz
parents:
22824
diff
changeset
|
730 |
static int instr_size_for_decode_klass_not_null(); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
731 |
void decode_klass_not_null(Register dst, Register src = noreg); |
30303 | 732 |
Register encode_klass_not_null(Register dst, Register src = noreg); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
733 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
734 |
// SIGTRAP-based range checks for arrays. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
735 |
inline void trap_range_check_l(Register a, Register b); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
736 |
inline void trap_range_check_l(Register a, int si16); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
737 |
static bool is_trap_range_check_l(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
738 |
return (is_tw (x, traptoLessThanUnsigned, -1/*any reg*/, -1/*any reg*/) || |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
739 |
is_twi(x, traptoLessThanUnsigned, -1/*any reg*/) ); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
740 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
741 |
inline void trap_range_check_le(Register a, int si16); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
742 |
static bool is_trap_range_check_le(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
743 |
return is_twi(x, traptoEqual | traptoLessThanUnsigned, -1/*any reg*/); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
744 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
745 |
inline void trap_range_check_g(Register a, int si16); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
746 |
static bool is_trap_range_check_g(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
747 |
return is_twi(x, traptoGreaterThanUnsigned, -1/*any reg*/); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
748 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
749 |
inline void trap_range_check_ge(Register a, Register b); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
750 |
inline void trap_range_check_ge(Register a, int si16); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
751 |
static bool is_trap_range_check_ge(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
752 |
return (is_tw (x, traptoEqual | traptoGreaterThanUnsigned, -1/*any reg*/, -1/*any reg*/) || |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
753 |
is_twi(x, traptoEqual | traptoGreaterThanUnsigned, -1/*any reg*/) ); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
754 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
755 |
static bool is_trap_range_check(int x) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
756 |
return is_trap_range_check_l(x) || is_trap_range_check_le(x) || |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
757 |
is_trap_range_check_g(x) || is_trap_range_check_ge(x); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
758 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
759 |
|
42661
2343dd675325
8170991: PPC64: Bad code for initialization of short arrays
mdoerr
parents:
42068
diff
changeset
|
760 |
void clear_memory_unrolled(Register base_ptr, int cnt_dwords, Register tmp = R0, int offset = 0); |
2343dd675325
8170991: PPC64: Bad code for initialization of short arrays
mdoerr
parents:
42068
diff
changeset
|
761 |
void clear_memory_constlen(Register base_ptr, int cnt_dwords, Register tmp = R0); |
2343dd675325
8170991: PPC64: Bad code for initialization of short arrays
mdoerr
parents:
42068
diff
changeset
|
762 |
void clear_memory_doubleword(Register base_ptr, Register cnt_dwords, Register tmp = R0, long const_cnt = -1); |
22861 | 763 |
|
36303
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
764 |
#ifdef COMPILER2 |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
765 |
// Intrinsics for CompactStrings |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
766 |
// Compress char[] to byte[] by compressing 16 bytes at once. |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
767 |
void string_compress_16(Register src, Register dst, Register cnt, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
768 |
Register tmp1, Register tmp2, Register tmp3, Register tmp4, Register tmp5, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
769 |
Label& Lfailure); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
770 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
771 |
// Compress char[] to byte[]. cnt must be positive int. |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
772 |
void string_compress(Register src, Register dst, Register cnt, Register tmp, Label& Lfailure); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
773 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
774 |
// Inflate byte[] to char[] by inflating 16 bytes at once. |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
775 |
void string_inflate_16(Register src, Register dst, Register cnt, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
776 |
Register tmp1, Register tmp2, Register tmp3, Register tmp4, Register tmp5); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
777 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
778 |
// Inflate byte[] to char[]. cnt must be positive int. |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
779 |
void string_inflate(Register src, Register dst, Register cnt, Register tmp); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
780 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
781 |
void string_compare(Register str1, Register str2, Register cnt1, Register cnt2, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
782 |
Register tmp1, Register result, int ae); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
783 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
784 |
void array_equals(bool is_array_equ, Register ary1, Register ary2, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
785 |
Register limit, Register tmp1, Register result, bool is_byte); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
786 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
787 |
void string_indexof(Register result, Register haystack, Register haycnt, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
788 |
Register needle, ciTypeArray* needle_values, Register needlecnt, int needlecntval, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
789 |
Register tmp1, Register tmp2, Register tmp3, Register tmp4, int ae); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
790 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
791 |
void string_indexof_char(Register result, Register haystack, Register haycnt, |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
792 |
Register needle, jchar needleChar, Register tmp1, Register tmp2, bool is_byte); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
793 |
|
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
794 |
void has_negatives(Register src, Register cnt, Register result, Register tmp1, Register tmp2); |
6241574f5982
8149655: PPC64: Implement CompactString intrinsics
mdoerr
parents:
35594
diff
changeset
|
795 |
#endif |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
796 |
|
31773 | 797 |
// Emitters for BigInteger.multiplyToLen intrinsic. |
798 |
inline void multiply64(Register dest_hi, Register dest_lo, |
|
799 |
Register x, Register y); |
|
800 |
void add2_with_carry(Register dest_hi, Register dest_lo, |
|
801 |
Register src1, Register src2); |
|
802 |
void multiply_64_x_64_loop(Register x, Register xstart, Register x_xstart, |
|
803 |
Register y, Register y_idx, Register z, |
|
804 |
Register carry, Register product_high, Register product, |
|
805 |
Register idx, Register kdx, Register tmp); |
|
806 |
void multiply_add_128_x_128(Register x_xstart, Register y, Register z, |
|
807 |
Register yz_idx, Register idx, Register carry, |
|
808 |
Register product_high, Register product, Register tmp, |
|
809 |
int offset); |
|
810 |
void multiply_128_x_128_loop(Register x_xstart, |
|
811 |
Register y, Register z, |
|
812 |
Register yz_idx, Register idx, Register carry, |
|
813 |
Register product_high, Register product, |
|
814 |
Register carry2, Register tmp); |
|
47521
122833427b36
8185976: PPC64: Implement MulAdd and SquareToLen intrinsics
goetz
parents:
47520
diff
changeset
|
815 |
void muladd(Register out, Register in, Register offset, Register len, Register k, |
122833427b36
8185976: PPC64: Implement MulAdd and SquareToLen intrinsics
goetz
parents:
47520
diff
changeset
|
816 |
Register tmp1, Register tmp2, Register carry); |
31773 | 817 |
void multiply_to_len(Register x, Register xlen, |
818 |
Register y, Register ylen, |
|
819 |
Register z, Register zlen, |
|
820 |
Register tmp1, Register tmp2, Register tmp3, Register tmp4, Register tmp5, |
|
821 |
Register tmp6, Register tmp7, Register tmp8, Register tmp9, Register tmp10, |
|
822 |
Register tmp11, Register tmp12, Register tmp13); |
|
823 |
||
46317
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
824 |
// Emitters for CRC32 calculation. |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
825 |
// A note on invertCRC: |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
826 |
// Unfortunately, internal representation of crc differs between CRC32 and CRC32C. |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
827 |
// CRC32 holds it's current crc value in the externally visible representation. |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
828 |
// CRC32C holds it's current crc value in internal format, ready for updating. |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
829 |
// Thus, the crc value must be bit-flipped before updating it in the CRC32 case. |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
830 |
// In the CRC32C case, it must be bit-flipped when it is given to the outside world (getValue()). |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
831 |
// The bool invertCRC parameter indicates whether bit-flipping is required before updates. |
31861 | 832 |
void load_reverse_32(Register dst, Register src); |
833 |
int crc32_table_columns(Register table, Register tc0, Register tc1, Register tc2, Register tc3); |
|
834 |
void fold_byte_crc32(Register crc, Register val, Register table, Register tmp); |
|
835 |
void update_byte_crc32(Register crc, Register val, Register table); |
|
836 |
void update_byteLoop_crc32(Register crc, Register buf, Register len, Register table, |
|
46317
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
837 |
Register data, bool loopAlignment); |
31861 | 838 |
void update_1word_crc32(Register crc, Register buf, Register table, int bufDisp, int bufInc, |
839 |
Register t0, Register t1, Register t2, Register t3, |
|
840 |
Register tc0, Register tc1, Register tc2, Register tc3); |
|
841 |
void kernel_crc32_1word(Register crc, Register buf, Register len, Register table, |
|
842 |
Register t0, Register t1, Register t2, Register t3, |
|
46317
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
843 |
Register tc0, Register tc1, Register tc2, Register tc3, |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
844 |
bool invertCRC); |
53483
60add902a57a
8217459: [PPC64] Cleanup non-vector version of CRC32
mdoerr
parents:
53408
diff
changeset
|
845 |
void kernel_crc32_vpmsum(Register crc, Register buf, Register len, Register constants, |
60add902a57a
8217459: [PPC64] Cleanup non-vector version of CRC32
mdoerr
parents:
53408
diff
changeset
|
846 |
Register t0, Register t1, Register t2, Register t3, Register t4, |
60add902a57a
8217459: [PPC64] Cleanup non-vector version of CRC32
mdoerr
parents:
53408
diff
changeset
|
847 |
Register t5, Register t6, bool invertCRC); |
53408
e17d7ffad9e3
8216060: [PPC64] Vector CRC implementation should be used by interpreter and be faster for short arrays
mdoerr
parents:
53244
diff
changeset
|
848 |
void kernel_crc32_vpmsum_aligned(Register crc, Register buf, Register len, Register constants, |
53483
60add902a57a
8217459: [PPC64] Cleanup non-vector version of CRC32
mdoerr
parents:
53408
diff
changeset
|
849 |
Register t0, Register t1, Register t2, Register t3, Register t4, |
60add902a57a
8217459: [PPC64] Cleanup non-vector version of CRC32
mdoerr
parents:
53408
diff
changeset
|
850 |
Register t5, Register t6); |
53408
e17d7ffad9e3
8216060: [PPC64] Vector CRC implementation should be used by interpreter and be faster for short arrays
mdoerr
parents:
53244
diff
changeset
|
851 |
// Version which internally decides what to use. |
e17d7ffad9e3
8216060: [PPC64] Vector CRC implementation should be used by interpreter and be faster for short arrays
mdoerr
parents:
53244
diff
changeset
|
852 |
void crc32(Register crc, Register buf, Register len, Register t0, Register t1, Register t2, |
e17d7ffad9e3
8216060: [PPC64] Vector CRC implementation should be used by interpreter and be faster for short arrays
mdoerr
parents:
53244
diff
changeset
|
853 |
Register t3, Register t4, Register t5, Register t6, Register t7, bool is_crc32c); |
41334 | 854 |
|
46317
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
855 |
void kernel_crc32_singleByteReg(Register crc, Register val, Register table, |
5f88747fe29e
8175369: [ppc] Provide intrinsic implementation for CRC32C
lucy
parents:
42661
diff
changeset
|
856 |
bool invertCRC); |
31861 | 857 |
|
47565 | 858 |
// SHA-2 auxiliary functions and public interfaces |
859 |
private: |
|
860 |
void sha256_deque(const VectorRegister src, |
|
861 |
const VectorRegister dst1, const VectorRegister dst2, const VectorRegister dst3); |
|
862 |
void sha256_load_h_vec(const VectorRegister a, const VectorRegister e, const Register hptr); |
|
863 |
void sha256_round(const VectorRegister* hs, const int total_hs, int& h_cnt, const VectorRegister kpw); |
|
864 |
void sha256_load_w_plus_k_vec(const Register buf_in, const VectorRegister* ws, |
|
865 |
const int total_ws, const Register k, const VectorRegister* kpws, |
|
866 |
const int total_kpws); |
|
867 |
void sha256_calc_4w(const VectorRegister w0, const VectorRegister w1, |
|
868 |
const VectorRegister w2, const VectorRegister w3, const VectorRegister kpw0, |
|
869 |
const VectorRegister kpw1, const VectorRegister kpw2, const VectorRegister kpw3, |
|
870 |
const Register j, const Register k); |
|
871 |
void sha256_update_sha_state(const VectorRegister a, const VectorRegister b, |
|
872 |
const VectorRegister c, const VectorRegister d, const VectorRegister e, |
|
873 |
const VectorRegister f, const VectorRegister g, const VectorRegister h, |
|
874 |
const Register hptr); |
|
875 |
||
876 |
void sha512_load_w_vec(const Register buf_in, const VectorRegister* ws, const int total_ws); |
|
877 |
void sha512_update_sha_state(const Register state, const VectorRegister* hs, const int total_hs); |
|
878 |
void sha512_round(const VectorRegister* hs, const int total_hs, int& h_cnt, const VectorRegister kpw); |
|
879 |
void sha512_load_h_vec(const Register state, const VectorRegister* hs, const int total_hs); |
|
880 |
void sha512_calc_2w(const VectorRegister w0, const VectorRegister w1, |
|
881 |
const VectorRegister w2, const VectorRegister w3, |
|
882 |
const VectorRegister w4, const VectorRegister w5, |
|
883 |
const VectorRegister w6, const VectorRegister w7, |
|
884 |
const VectorRegister kpw0, const VectorRegister kpw1, const Register j, |
|
885 |
const VectorRegister vRb, const Register k); |
|
886 |
||
887 |
public: |
|
888 |
void sha256(bool multi_block); |
|
889 |
void sha512(bool multi_block); |
|
890 |
||
891 |
||
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
892 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
893 |
// Debugging |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
894 |
// |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
895 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
896 |
// assert on cr0 |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
897 |
void asm_assert(bool check_equal, const char* msg, int id); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
898 |
void asm_assert_eq(const char* msg, int id) { asm_assert(true, msg, id); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
899 |
void asm_assert_ne(const char* msg, int id) { asm_assert(false, msg, id); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
900 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
901 |
private: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
902 |
void asm_assert_mems_zero(bool check_equal, int size, int mem_offset, Register mem_base, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
903 |
const char* msg, int id); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
904 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
905 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
906 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
907 |
void asm_assert_mem8_is_zero(int mem_offset, Register mem_base, const char* msg, int id) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
908 |
asm_assert_mems_zero(true, 8, mem_offset, mem_base, msg, id); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
909 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
910 |
void asm_assert_mem8_isnot_zero(int mem_offset, Register mem_base, const char* msg, int id) { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
911 |
asm_assert_mems_zero(false, 8, mem_offset, mem_base, msg, id); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
912 |
} |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
913 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
914 |
// Verify R16_thread contents. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
915 |
void verify_thread(); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
916 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
917 |
// Emit code to verify that reg contains a valid oop if +VerifyOops is set. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
918 |
void verify_oop(Register reg, const char* s = "broken oop"); |
35085 | 919 |
void verify_oop_addr(RegisterOrConstant offs, Register base, const char* s = "contains broken oop"); |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
920 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
921 |
// TODO: verify method and klass metadata (compare against vptr?) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
922 |
void _verify_method_ptr(Register reg, const char * msg, const char * file, int line) {} |
22861 | 923 |
void _verify_klass_ptr(Register reg, const char * msg, const char * file, int line) {} |
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
924 |
|
23211 | 925 |
// Convenience method returning function entry. For the ELFv1 case |
926 |
// creates function descriptor at the current address and returs |
|
927 |
// the pointer to it. For the ELFv2 case returns the current address. |
|
928 |
inline address function_entry(); |
|
929 |
||
22824
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
930 |
#define verify_method_ptr(reg) _verify_method_ptr(reg, "broken method " #reg, __FILE__, __LINE__) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
931 |
#define verify_klass_ptr(reg) _verify_klass_ptr(reg, "broken klass " #reg, __FILE__, __LINE__) |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
932 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
933 |
private: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
934 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
935 |
enum { |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
936 |
stop_stop = 0, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
937 |
stop_untested = 1, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
938 |
stop_unimplemented = 2, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
939 |
stop_shouldnotreachhere = 3, |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
940 |
stop_end = 4 |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
941 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
942 |
void stop(int type, const char* msg, int id); |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
943 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
944 |
public: |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
945 |
// Prints msg, dumps registers and stops execution. |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
946 |
void stop (const char* msg = "", int id = 0) { stop(stop_stop, msg, id); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
947 |
void untested (const char* msg = "", int id = 0) { stop(stop_untested, msg, id); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
948 |
void unimplemented(const char* msg = "", int id = 0) { stop(stop_unimplemented, msg, id); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
949 |
void should_not_reach_here() { stop(stop_shouldnotreachhere, "", -1); } |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
950 |
|
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
951 |
void zap_from_to(Register low, int before, Register high, int after, Register val, Register addr) PRODUCT_RETURN; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
952 |
}; |
28258dd5cb2e
8019972: PPC64 (part 9): platform files for interpreter only VM.
goetz
parents:
diff
changeset
|
953 |
|
23221 | 954 |
// class SkipIfEqualZero: |
955 |
// |
|
956 |
// Instantiating this class will result in assembly code being output that will |
|
957 |
// jump around any code emitted between the creation of the instance and it's |
|
958 |
// automatic destruction at the end of a scope block, depending on the value of |
|
959 |
// the flag passed to the constructor, which will be checked at run-time. |
|
960 |
class SkipIfEqualZero : public StackObj { |
|
961 |
private: |
|
962 |
MacroAssembler* _masm; |
|
963 |
Label _label; |
|
964 |
||
965 |
public: |
|
966 |
// 'Temp' is a temp register that this object can use (and trash). |
|
967 |
explicit SkipIfEqualZero(MacroAssembler*, Register temp, const bool* flag_addr); |
|
48476 | 968 |
static void skip_to_label_if_equal_zero(MacroAssembler*, Register temp, |
969 |
const bool* flag_addr, Label& label); |
|
23221 | 970 |
~SkipIfEqualZero(); |
971 |
}; |
|
972 |
||
53244
9807daeb47c4
8216167: Update include guards to reflect correct directories
coleenp
parents:
52760
diff
changeset
|
973 |
#endif // CPU_PPC_MACROASSEMBLER_PPC_HPP |