annotate src/cpu/sparc/vm/c1_LIRAssembler_sparc.hpp @ 6812:988bf00cc564

7200261: G1: Liveness counting inconsistencies during marking verification Summary: The clipping code in the routine that sets the bits for a range of cards, in the liveness accounting verification code was incorrect. It set all the bits in the card bitmap from the given starting index which would lead to spurious marking verification failures. Reviewed-by: brutisso, jwilhelm, jmasa
author johnc
date Thu, 27 Sep 2012 15:44:01 -0700
parents 898522ae3c32
children b9a9ed0f8eeb
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
a61af66fc99e Initial load
duke
parents:
diff changeset
1 /*
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
2 * Copyright (c) 2000, 2010, Oracle and/or its affiliates. All rights reserved.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
a61af66fc99e Initial load
duke
parents:
diff changeset
4 *
a61af66fc99e Initial load
duke
parents:
diff changeset
5 * This code is free software; you can redistribute it and/or modify it
a61af66fc99e Initial load
duke
parents:
diff changeset
6 * under the terms of the GNU General Public License version 2 only, as
a61af66fc99e Initial load
duke
parents:
diff changeset
7 * published by the Free Software Foundation.
a61af66fc99e Initial load
duke
parents:
diff changeset
8 *
a61af66fc99e Initial load
duke
parents:
diff changeset
9 * This code is distributed in the hope that it will be useful, but WITHOUT
a61af66fc99e Initial load
duke
parents:
diff changeset
10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
a61af66fc99e Initial load
duke
parents:
diff changeset
11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
a61af66fc99e Initial load
duke
parents:
diff changeset
12 * version 2 for more details (a copy is included in the LICENSE file that
a61af66fc99e Initial load
duke
parents:
diff changeset
13 * accompanied this code).
a61af66fc99e Initial load
duke
parents:
diff changeset
14 *
a61af66fc99e Initial load
duke
parents:
diff changeset
15 * You should have received a copy of the GNU General Public License version
a61af66fc99e Initial load
duke
parents:
diff changeset
16 * 2 along with this work; if not, write to the Free Software Foundation,
a61af66fc99e Initial load
duke
parents:
diff changeset
17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
a61af66fc99e Initial load
duke
parents:
diff changeset
18 *
1552
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
19 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
20 * or visit www.oracle.com if you need additional information or have any
c18cbe5936b8 6941466: Oracle rebranding changes for Hotspot repositories
trims
parents: 0
diff changeset
21 * questions.
0
a61af66fc99e Initial load
duke
parents:
diff changeset
22 *
a61af66fc99e Initial load
duke
parents:
diff changeset
23 */
a61af66fc99e Initial load
duke
parents:
diff changeset
24
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1791
diff changeset
25 #ifndef CPU_SPARC_VM_C1_LIRASSEMBLER_SPARC_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1791
diff changeset
26 #define CPU_SPARC_VM_C1_LIRASSEMBLER_SPARC_HPP
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1791
diff changeset
27
0
a61af66fc99e Initial load
duke
parents:
diff changeset
28 private:
a61af66fc99e Initial load
duke
parents:
diff changeset
29
a61af66fc99e Initial load
duke
parents:
diff changeset
30 //////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
a61af66fc99e Initial load
duke
parents:
diff changeset
31 //
a61af66fc99e Initial load
duke
parents:
diff changeset
32 // Sparc load/store emission
a61af66fc99e Initial load
duke
parents:
diff changeset
33 //
a61af66fc99e Initial load
duke
parents:
diff changeset
34 // The sparc ld/st instructions cannot accomodate displacements > 13 bits long.
a61af66fc99e Initial load
duke
parents:
diff changeset
35 // The following "pseudo" sparc instructions (load/store) make it easier to use the indexed addressing mode
a61af66fc99e Initial load
duke
parents:
diff changeset
36 // by allowing 32 bit displacements:
a61af66fc99e Initial load
duke
parents:
diff changeset
37 //
a61af66fc99e Initial load
duke
parents:
diff changeset
38 // When disp <= 13 bits long, a single load or store instruction is emitted with (disp + [d]).
a61af66fc99e Initial load
duke
parents:
diff changeset
39 // When disp > 13 bits long, code is emitted to set the displacement into the O7 register,
a61af66fc99e Initial load
duke
parents:
diff changeset
40 // and then a load or store is emitted with ([O7] + [d]).
a61af66fc99e Initial load
duke
parents:
diff changeset
41 //
a61af66fc99e Initial load
duke
parents:
diff changeset
42
2002
ac637b7220d1 6985015: C1 needs to support compressed oops
iveresov
parents: 1972
diff changeset
43 int store(LIR_Opr from_reg, Register base, int offset, BasicType type, bool wide, bool unaligned);
ac637b7220d1 6985015: C1 needs to support compressed oops
iveresov
parents: 1972
diff changeset
44 int store(LIR_Opr from_reg, Register base, Register disp, BasicType type, bool wide);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
45
2002
ac637b7220d1 6985015: C1 needs to support compressed oops
iveresov
parents: 1972
diff changeset
46 int load(Register base, int offset, LIR_Opr to_reg, BasicType type, bool wide, bool unaligned);
ac637b7220d1 6985015: C1 needs to support compressed oops
iveresov
parents: 1972
diff changeset
47 int load(Register base, Register disp, LIR_Opr to_reg, BasicType type, bool wide);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
48
a61af66fc99e Initial load
duke
parents:
diff changeset
49 void monitorexit(LIR_Opr obj_opr, LIR_Opr lock_opr, Register hdr, int monitor_no);
a61af66fc99e Initial load
duke
parents:
diff changeset
50
a61af66fc99e Initial load
duke
parents:
diff changeset
51 int shift_amount(BasicType t);
a61af66fc99e Initial load
duke
parents:
diff changeset
52
a61af66fc99e Initial load
duke
parents:
diff changeset
53 static bool is_single_instruction(LIR_Op* op);
a61af66fc99e Initial load
duke
parents:
diff changeset
54
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
55 // Record the type of the receiver in ReceiverTypeData
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
56 void type_profile_helper(Register mdo, int mdo_offset_bias,
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
57 ciMethodData *md, ciProfileData *data,
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
58 Register recv, Register tmp1, Label* update_done);
1791
3a294e483abc 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 1783
diff changeset
59 // Setup pointers to MDO, MDO slot, also compute offset bias to access the slot.
3a294e483abc 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 1783
diff changeset
60 void setup_md_access(ciMethod* method, int bci,
3a294e483abc 6919069: client compiler needs to capture more profile information for tiered work
iveresov
parents: 1783
diff changeset
61 ciMethodData*& md, ciProfileData*& data, int& mdo_offset_bias);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
62 public:
1783
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
63 void pack64(LIR_Opr src, LIR_Opr dst);
d5d065957597 6953144: Tiered compilation
iveresov
parents: 1552
diff changeset
64 void unpack64(LIR_Opr src, LIR_Opr dst);
0
a61af66fc99e Initial load
duke
parents:
diff changeset
65
a61af66fc99e Initial load
duke
parents:
diff changeset
66 enum {
a61af66fc99e Initial load
duke
parents:
diff changeset
67 #ifdef _LP64
a61af66fc99e Initial load
duke
parents:
diff changeset
68 call_stub_size = 68,
a61af66fc99e Initial load
duke
parents:
diff changeset
69 #else
a61af66fc99e Initial load
duke
parents:
diff changeset
70 call_stub_size = 20,
a61af66fc99e Initial load
duke
parents:
diff changeset
71 #endif // _LP64
4808
898522ae3c32 7131288: COMPILE SKIPPED: deopt handler overflow (retry at different tier)
iveresov
parents: 2002
diff changeset
72 exception_handler_size = DEBUG_ONLY(1*K) NOT_DEBUG(128),
898522ae3c32 7131288: COMPILE SKIPPED: deopt handler overflow (retry at different tier)
iveresov
parents: 2002
diff changeset
73 deopt_handler_size = DEBUG_ONLY(1*K) NOT_DEBUG(64) };
1972
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1791
diff changeset
74
f95d63e2154a 6989984: Use standard include model for Hospot
stefank
parents: 1791
diff changeset
75 #endif // CPU_SPARC_VM_C1_LIRASSEMBLER_SPARC_HPP