tail recursion flag added
[libfirm] / ir / ir / irflag_t.h
1 /*
2  * Project:     libFIRM
3  * File name:   ir/ir/irgraph.c
4  * Purpose:     Flags to control optimizations, inline implementation.
5  * Author:      Michael Beck
6  * Created:
7  * CVS-ID:      $Id$
8  * Copyright:   (c) 1998-2004 Universität Karlsruhe
9  * Licence:     This file protected by GPL -  GNU GENERAL PUBLIC LICENSE.
10  */
11
12 /**
13  * @file irflag_t.h
14  *
15  * Inline implementation of Optimization flags.
16  *
17  * @author Michael Beck
18  */
19 #ifndef _IRFLAG_T_H_
20 #define _IRFLAG_T_H_
21
22 #include "irflag.h"
23
24 /**
25  * current libFIRM optimizations
26  */
27 typedef enum {
28   /** Common subexpression eliminations: Hash the nodes. */
29   OPT_CSE                                = 0x00000001,
30
31   /** Don't use block predecessor for comparison.
32    *  Default must be zero as code placement must
33    *  be run right after a local optimize walk with
34    *  opt_global_cse on. */
35   OPT_GLOBAL_CSE                         = 0x00000002,
36
37   /** Evaluate operations. */
38   OPT_CONSTANT_FOLDING                   = 0x00000004,
39
40   /** Bad node propagation. */
41   OPT_UNREACHABLE_CODE                   = 0x00000008,
42
43   /** */
44   OPT_CONTROL_FLOW_STRAIGHTENING         = 0x00000010,
45
46   /** */
47   OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION   = 0x00000020,
48
49   /** */
50   OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION = 0x00000040,
51
52   /** */
53   OPT_CRITICAL_EDGES                     = 0x00000080,
54
55   /** Reclaim memory. */
56   OPT_DEAD_NODE_ELIMINATION              = 0x00000100,
57
58   /** Reassociate nodes. */
59   OPT_REASSOCIATION                      = 0x00000200,
60
61   /** Do inlining transformation. */
62   OPT_INLINE                             = 0x00000400,
63
64   /** Remove dynamic method dispatch. */
65   OPT_DYN_METH_DISPATCH                  = 0x00000800,
66
67   /** Transformations that normalize the firm representation
68    *  as removing Ids and Tuples, useless Phis, SymConst(id) -> Const(entity) ...
69    */
70   OPT_NORMALIZE                          = 0x00001000,
71
72   /** Remove tail-recursion. */
73   OPT_TAIL_RECURSION                     = 0x00002000,
74
75   /** Turn off all optimizations. */
76   OPT_OPTIMIZED                          = 0x40000000,
77 } libfirm_opts_t;
78
79 extern optimization_state_t libFIRM_opt;
80
81 /** Returns constant folding optimization setting. */
82 static INLINE int get_opt_cse(void)
83 {
84   return libFIRM_opt & OPT_CSE;
85 }
86
87 /** Returns constant subexpression elimination setting. */
88 static INLINE int get_opt_global_cse(void)
89 {
90   return libFIRM_opt & OPT_GLOBAL_CSE;
91 }
92
93 /** Returns global constant subexpression elimination setting. */
94 static INLINE int get_opt_constant_folding(void)
95 {
96   return libFIRM_opt & OPT_CONSTANT_FOLDING;
97 }
98
99 /** Returns unreachable code elimination setting. */
100 static INLINE int get_opt_unreachable_code(void)
101 {
102   return libFIRM_opt & OPT_UNREACHABLE_CODE;
103 }
104
105 /** Returns Straightening setting. */
106 static INLINE int get_opt_control_flow_straightening(void)
107 {
108   return libFIRM_opt & OPT_CONTROL_FLOW_STRAIGHTENING;
109 }
110
111 /** Returns if simplifications in local optimizations setting. */
112 static INLINE int get_opt_control_flow_weak_simplification(void)
113 {
114   return libFIRM_opt & OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION;
115 }
116
117 /** Returns strong if and loop simplification setting */
118 static INLINE int get_opt_control_flow_strong_simplification(void)
119 {
120   return libFIRM_opt & OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION;
121 }
122
123 /** Returns whether critical edges are removed */
124 static INLINE int get_opt_critical_edges(void)
125 {
126   return libFIRM_opt & OPT_CRITICAL_EDGES;
127 }
128
129 /** Returns reassociation setting. */
130 static INLINE int get_opt_reassociation(void)
131 {
132   return libFIRM_opt & OPT_REASSOCIATION;
133 }
134
135 /** Returns dead node elimination setting. */
136 static INLINE int get_opt_dead_node_elimination(void)
137 {
138   return libFIRM_opt & OPT_DEAD_NODE_ELIMINATION;
139 }
140
141 /** Returns global optimization setting */
142 static INLINE int get_opt_optimize(void)
143 {
144   return libFIRM_opt & OPT_OPTIMIZED;
145 }
146
147 /** Returns inlining setting. */
148 static INLINE int get_opt_inline(void)
149 {
150   return libFIRM_opt & OPT_INLINE;
151 }
152
153 static INLINE int get_opt_dyn_meth_dispatch(void)
154 {
155   return libFIRM_opt & OPT_DYN_METH_DISPATCH;
156 }
157
158 static INLINE int get_opt_normalize(void)
159 {
160   return libFIRM_opt & OPT_NORMALIZE;
161 }
162
163 /** Returns tail-recursion setting. */
164 static INLINE int get_opt_tail_recursion(void)
165 {
166   return libFIRM_opt & OPT_TAIL_RECURSION;
167 }
168
169 #endif /* _IRFLAG_T_H_ */