projects
/
libfirm
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
- Changed keep logic: all nodes can be keeped yet, thi is necessary to fix fehler152
[libfirm]
/
ir
/
ir
/
irflag_t.def
diff --git
a/ir/ir/irflag_t.def
b/ir/ir/irflag_t.def
index
80d06db
..
1a1cf29
100644
(file)
--- a/
ir/ir/irflag_t.def
+++ b/
ir/ir/irflag_t.def
@@
-1,5
+1,5
@@
/*
/*
- * Copyright (C) 1995-200
7
University of Karlsruhe. All right reserved.
+ * Copyright (C) 1995-200
8
University of Karlsruhe. All right reserved.
*
* This file is part of libFirm.
*
*
* This file is part of libFirm.
*
@@
-20,10
+20,17
@@
/**
* @file
* @brief Definitions for optimisation flags
/**
* @file
* @brief Definitions for optimisation flags
- * @author Michael Beck
+ * @author Michael Beck
, Sebastian Hack
* @version $Id$
*/
* @version $Id$
*/
+/*
+ * We have 3 kinds of flags:
+ * I_FLAGS are INTERNAL flags: The is only a public set_opt_<flag> function
+ * E_FLAGS are EXTERNAL flags: Public get_opt_<flag> and set_opt_<flag> fucntions exists
+ * R_FLAGS are RUNNING flags: Use only internally in libfirm to indicate running states
+ */
+
/** Turn off all optimizations. */
I_FLAG(optimize , 0, ON)
/** Turn off all optimizations. */
I_FLAG(optimize , 0, ON)
@@
-51,14
+58,8
@@
I_FLAG(control_flow_weak_simplification , 6, ON)
/** */
I_FLAG(control_flow_strong_simplification , 7, ON)
/** */
I_FLAG(control_flow_strong_simplification , 7, ON)
-/** Reclaim memory. */
-I_FLAG(dead_node_elimination , 8, ON)
-
-/** Reassociate nodes. */
-I_FLAG(reassociation , 9, ON)
-
-/** Do inlining transformation. */
-I_FLAG(inline , 10, ON)
+/** Algebraic simplifications. */
+I_FLAG(algebraic_simplification , 8, ON)
/** Remove dynamic method dispatch. */
E_FLAG(dyn_meth_dispatch , 11, ON)
/** Remove dynamic method dispatch. */
E_FLAG(dyn_meth_dispatch , 11, ON)
@@
-68,30
+69,15
@@
E_FLAG(dyn_meth_dispatch , 11, ON)
*/
I_FLAG(normalize , 12, ON)
*/
I_FLAG(normalize , 12, ON)
-/** Remove tail-recursion. */
-I_FLAG(tail_recursion , 13, ON)
-
-/** Free never called methods */
-I_FLAG(dead_method_elimination , 14, ON)
-
/** precise exception context */
I_FLAG(precise_exc_context , 15, ON)
/** precise exception context */
I_FLAG(precise_exc_context , 15, ON)
-/** Do loop unrolling */
-I_FLAG(loop_unrolling , 16, OFF) /* currently buggy, 2.1.2006 */
-
/** Do Strength reduction */
I_FLAG(strength_red , 17, ON)
/** Do Strength reduction */
I_FLAG(strength_red , 17, ON)
-/** Optimize Loads and Stores */
-I_FLAG(redundant_loadstore , 18, ON)
-
/** Optimize Fragile OPs */
I_FLAG(fragile_ops , 19, OFF)
/** Optimize Fragile OPs */
I_FLAG(fragile_ops , 19, OFF)
-/** Optimize function calls. */
-I_FLAG(function_call , 20, ON)
-
/** Optimize cast nodes. */
E_FLAG(optimize_class_casts , 21, ON)
E_FLAG(suppress_downcast_optimization , 22, OFF)
/** Optimize cast nodes. */
E_FLAG(optimize_class_casts , 21, ON)
E_FLAG(suppress_downcast_optimization , 22, OFF)
@@
-114,8
+100,13
@@
I_FLAG(auto_create_sync , 27, OFF)
/** Enable Alias-analysis. */
I_FLAG(alias_analysis , 28, ON)
/** Enable Alias-analysis. */
I_FLAG(alias_analysis , 28, ON)
-/** This flag is set while architecture dependent optimizations are running */
-I_FLAG(arch_dep_running , 29, OFF)
-
/** Closed world assumption. */
I_FLAG(closed_world , 31, OFF)
/** Closed world assumption. */
I_FLAG(closed_world , 31, OFF)
+
+/* -------------------- RUNNING flags ------------------- */
+
+/** This flag is set while the reassociation optimizations are running */
+R_FLAG(reassoc , 0)
+
+/** This flag is set while architecture dependent optimizations are running */
+R_FLAG(arch_dep , 0)