projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
fixed bugs in remove_bad_predecessors.
[libfirm]
/
ir
/
ir
/
irflag_t.h
diff --git
a/ir/ir/irflag_t.h
b/ir/ir/irflag_t.h
index
6293ac1
..
05f12ff
100644
(file)
--- a/
ir/ir/irflag_t.h
+++ b/
ir/ir/irflag_t.h
@@
-78,8
+78,8
@@
typedef enum {
/** precise exception context */
OPT_PRECISE_EXC_CONTEXT = 0x00008000,
/** precise exception context */
OPT_PRECISE_EXC_CONTEXT = 0x00008000,
- /** Free never called methods */
- OPT_DEAD_METHOD_ELIMINATION_VERBOSE = 0x00010000,
+
+ /** EMPTY SLOT !!! TO BE ASSIGNED */
/** Do Strength reduction */
OPT_STRENGTH_RED = 0x00020000,
/** Do Strength reduction */
OPT_STRENGTH_RED = 0x00020000,
@@
-87,15
+87,22
@@
typedef enum {
/** Optimize Loads and Stores */
OPT_REDUNDANT_LOADSTORE = 0x00040000,
/** Optimize Loads and Stores */
OPT_REDUNDANT_LOADSTORE = 0x00040000,
+ /** Optimize Fragile OPs */
+ OPT_FRAGILE_OPS = 0x00080000,
+
/** Turn off all optimizations. */
OPT_OPTIMIZED = 0x40000000,
} libfirm_opts_t;
extern optimization_state_t libFIRM_opt;
/** Turn off all optimizations. */
OPT_OPTIMIZED = 0x40000000,
} libfirm_opts_t;
extern optimization_state_t libFIRM_opt;
+extern optimization_state_t libFIRM_verb;
+
+extern int firm_verbosity_level;
+
/** Returns constant folding optimization setting. */
/** Returns constant folding optimization setting. */
-static INLINE int get_opt_cse(void)
+static INLINE int
_
get_opt_cse(void)
{
return libFIRM_opt & OPT_CSE;
}
{
return libFIRM_opt & OPT_CSE;
}
@@
-111,6
+118,12
@@
static INLINE int get_opt_strength_red(void)
return libFIRM_opt & OPT_STRENGTH_RED;
}
return libFIRM_opt & OPT_STRENGTH_RED;
}
+/** Returns verbosity for strength reduction. */
+static INLINE int get_opt_strength_red_verbose(void)
+{
+ return libFIRM_verb & OPT_STRENGTH_RED;
+}
+
/** Returns global constant subexpression elimination setting. */
static INLINE int get_opt_constant_folding(void)
{
/** Returns global constant subexpression elimination setting. */
static INLINE int get_opt_constant_folding(void)
{
@@
-174,7
+187,7
@@
static INLINE int get_opt_dead_method_elimination(void)
/** Returns dead method elimination setting. */
static INLINE int get_opt_dead_method_elimination_verbose(void)
{
/** Returns dead method elimination setting. */
static INLINE int get_opt_dead_method_elimination_verbose(void)
{
- return libFIRM_
opt & OPT_DEAD_METHOD_ELIMINATION_VERBOSE
;
+ return libFIRM_
verb & OPT_DEAD_METHOD_ELIMINATION
;
}
/** Returns global optimization setting */
}
/** Returns global optimization setting */
@@
-183,6
+196,10
@@
static INLINE int get_opt_optimize(void)
return libFIRM_opt & OPT_OPTIMIZED;
}
return libFIRM_opt & OPT_OPTIMIZED;
}
+static INLINE int _get_firm_verbosity (void) {
+ return firm_verbosity_level;
+}
+
/** Returns inlining setting. */
static INLINE int get_opt_inline(void)
{
/** Returns inlining setting. */
static INLINE int get_opt_inline(void)
{
@@
-205,10
+222,26
@@
static INLINE int get_opt_tail_recursion(void)
return libFIRM_opt & OPT_TAIL_RECURSION;
}
return libFIRM_opt & OPT_TAIL_RECURSION;
}
+/** Returns tail-recursion setting. */
+static INLINE int get_opt_tail_recursion_verbose(void)
+{
+ return libFIRM_verb & OPT_TAIL_RECURSION;
+}
+
/** Returns precise exception context setting. */
static INLINE int get_opt_precise_exc_context(void)
{
return libFIRM_opt & OPT_PRECISE_EXC_CONTEXT;
}
/** Returns precise exception context setting. */
static INLINE int get_opt_precise_exc_context(void)
{
return libFIRM_opt & OPT_PRECISE_EXC_CONTEXT;
}
+/** Returns fragile ops setting. */
+static INLINE int get_opt_fragile_ops(void)
+{
+ return libFIRM_opt & OPT_FRAGILE_OPS;
+}
+
+
+#define get_opt_cse() _get_opt_cse()
+#define get_firm_verbosity() _get_firm_verbosity()
+
#endif /* _IRFLAG_T_H_ */
#endif /* _IRFLAG_T_H_ */