CACAO
NullCheckEliminationPass.hpp
Go to the documentation of this file.
1 /* src/vm/jit/compiler2/NullCheckEliminationPass.hpp - NullCheckEliminationPass
2 
3  Copyright (C) 2013
4  CACAOVM - Verein zur Foerderung der freien virtuellen Maschine CACAO
5 
6  This file is part of CACAO.
7 
8  This program is free software; you can redistribute it and/or
9  modify it under the terms of the GNU General Public License as
10  published by the Free Software Foundation; either version 2, or (at
11  your option) any later version.
12 
13  This program is distributed in the hope that it will be useful, but
14  WITHOUT ANY WARRANTY; without even the implied warranty of
15  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  General Public License for more details.
17 
18  You should have received a copy of the GNU General Public License
19  along with this program; if not, write to the Free Software
20  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
21  02110-1301, USA.
22 
23 */
24 
25 #ifndef _JIT_COMPILER2_NULLCHECKELIMINATIONPASS
26 #define _JIT_COMPILER2_NULLCHECKELIMINATIONPASS
27 
30 
31 #include <boost/dynamic_bitset.hpp>
32 
33 MM_MAKE_NAME(NullCheckEliminationPass)
34 
35 namespace cacao {
36 namespace jit {
37 namespace compiler2 {
38 
39 class Method;
40 class Value;
41 class Instruction;
42 class BeginInst;
43 
44 /**
45  * NullCheckEliminationPass
46  */
47 class NullCheckEliminationPass : public Pass, public memory::ManagerMixin<NullCheckEliminationPass> {
48 private:
49 
51 
52  /**
53  * Maps each object reference to a unique bitvector position.
54  */
56 
57  /**
58  *
59  */
61 
62  /**
63  * Holds for each BeginInst the local analysis state in the form of a
64  * bitvector.
65  */
67 
68  bool is_trivially_non_null(Value *objectref);
69 
70  void map_referenes_to_bitpositions();
71 
72  void prepare_bitvectors();
73 
74  void perform_null_check_elimination();
75 
76 #ifdef ENABLE_LOGGING
77  void print_final_results();
78 #endif
79 
80 public:
81 
83  virtual bool run(JITData &JD);
84  virtual PassUsage& get_PassUsage(PassUsage &PU) const;
85 };
86 
87 } // end namespace compiler2
88 } // end namespace jit
89 } // end namespace cacao
90 
91 #endif /* _JIT_COMPILER2_NULLCHECKELIMINATIONPASS */
92 
93 
94 /*
95  * These are local overrides for various environment variables in Emacs.
96  * Please do not remove this and leave it at the end of the file, where
97  * Emacs will automagically detect them.
98  * ---------------------------------------------------------------------
99  * Local variables:
100  * mode: c++
101  * indent-tabs-mode: t
102  * c-basic-offset: 4
103  * tab-width: 4
104  * End:
105  * vim:noexpandtab:sw=4:ts=4:
106  */
Pass superclass All compiler passes should inheritate this class.
Definition: Pass.hpp:47
Custom new/delete handler mixin.
Definition: Manager.hpp:43
alloc::unordered_map< Instruction *, int >::type bitpositions
Maps each object reference to a unique bitvector position.
#define MM_MAKE_NAME(x)
Definition: memstats.hpp:128
alloc::unordered_map< BeginInst *, boost::dynamic_bitset<> >::type non_null_references_at_entry
Holds for each BeginInst the local analysis state in the form of a bitvector.
Stores the interdependencies of a pass.
Definition: PassUsage.hpp:55
Represents the result of the addition of a certain IR-variable with a certain constant.
Definition: Value.hpp:36
alloc::unordered_map< BeginInst *, boost::dynamic_bitset<> >::type non_null_references_at_exit
std::unordered_map< Key, T, Hash, KeyEqual, Allocator< std::pair< const Key, T > > > type