1 /*
 2  * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved.
 3  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
 4  *
 5  * This code is free software; you can redistribute it and/or modify it
 6  * under the terms of the GNU General Public License version 2 only, as
 7  * published by the Free Software Foundation.
 8  *
 9  * This code is distributed in the hope that it will be useful, but WITHOUT
10  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
12  * version 2 for more details (a copy is included in the LICENSE file that
13  * accompanied this code).
14  *
15  * You should have received a copy of the GNU General Public License version
16  * 2 along with this work; if not, write to the Free Software Foundation,
17  * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18  *
19  * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20  * or visit www.oracle.com if you need additional information or have any
21  * questions.
22  *
23  */
24 
25 #ifndef SHARE_GC_SHARED_C2_G1BARRIERSETC2_HPP
26 #define SHARE_GC_SHARED_C2_G1BARRIERSETC2_HPP
27 
28 #include "gc/shared/c2/cardTableBarrierSetC2.hpp"
29 
30 class PhaseTransform;
31 class Type;
32 class TypeFunc;
33 
34 class G1BarrierSetC2: public CardTableBarrierSetC2 {
35 protected:
36   virtual void pre_barrier(GraphKit* kit,
37                            bool do_load,
38                            Node* ctl,
39                            Node* obj,
40                            Node* adr,
41                            uint adr_idx,
42                            Node* val,
43                            const TypeOopPtr* val_type,
44                            Node* pre_val,
45                            BasicType bt) const;
46 
47   virtual void post_barrier(GraphKit* kit,
48                             Node* ctl,
49                             Node* store,
50                             Node* obj,
51                             Node* adr,
52                             uint adr_idx,
53                             Node* val,
54                             BasicType bt,
55                             bool use_precise) const;
56 
57   bool g1_can_remove_pre_barrier(GraphKit* kit,
58                                  PhaseTransform* phase,
59                                  Node* adr,
60                                  BasicType bt,
61                                  uint adr_idx) const;
62 
63   bool g1_can_remove_post_barrier(GraphKit* kit,
64                                   PhaseTransform* phase, Node* store,
65                                   Node* adr) const;
66 
67   void g1_mark_card(GraphKit* kit,
68                     IdealKit& ideal,
69                     Node* card_adr,
70                     Node* oop_store,
71                     uint oop_alias_idx,
72                     Node* index,
73                     Node* index_adr,
74                     Node* buffer,
75                     const TypeFunc* tf) const;
76 
77   // Helper for unsafe accesses, that may or may not be on the referent field.
78   // Generates the guards that check whether the result of
79   // Unsafe.getObject should be recorded in an SATB log buffer.
80   void insert_pre_barrier(GraphKit* kit, Node* base_oop, Node* offset, Node* pre_val, bool need_mem_bar) const;
81 
82   static const TypeFunc* g1_wb_pre_Type();
83   static const TypeFunc* g1_wb_post_Type();
84 
85   virtual Node* load_at_resolved(C2Access& access, const Type* val_type) const;
86 
87  public:
88   virtual bool is_gc_barrier_node(Node* node) const;
89   virtual void eliminate_gc_barrier(PhaseMacroExpand* macro, Node* node) const;
90   virtual Node* step_over_gc_barrier(Node* c) const;
91 };
92 
93 #endif // SHARE_GC_SHARED_C2_G1BARRIERSETC2_HPP