use tv_t.h instead of tv.h
[libfirm] / ir / ir / irflag.c
index b01ac6f..21bc810 100644 (file)
@@ -11,7 +11,7 @@
  */
 
 #ifdef HAVE_CONFIG_H
-# include <config.h>
+# include "config.h"
 #endif
 
 #include "firm_common.h"
@@ -26,6 +26,7 @@ optimization_state_t libFIRM_opt =
   ENABLE(OPT_OPTIMIZED)                          |
   ENABLE(OPT_CSE)                                |
   DISABLE(OPT_GLOBAL_CSE)                        |
+  ENABLE(OPT_LOOP_UNROLLING)                     |
   ENABLE(OPT_STRENGTH_RED)                       |
   ENABLE(OPT_CONSTANT_FOLDING)                   |
   ENABLE(OPT_REDUNDANT_LOADSTORE)                |
@@ -39,16 +40,21 @@ optimization_state_t libFIRM_opt =
   ENABLE(OPT_REASSOCIATION)                      |
   ENABLE(OPT_INLINE)                             |
   ENABLE(OPT_DYN_METH_DISPATCH)                  |
+  ENABLE(OPT_CLASS_CASTS)                        |
+  DISABLE(OPT_SUPPRESS_DOWNCAST_OPT)             |
   ENABLE(OPT_NORMALIZE)                          |
   ENABLE(OPT_TAIL_RECURSION)                     |
   ENABLE(OPT_PRECISE_EXC_CONTEXT)                |
   DISABLE(OPT_FRAGILE_OPS)                       |
+  ENABLE(OPT_IF_CONVERSION)                      |
+  ENABLE(OPT_REAL_FUNC_CALL)                     |
   0;
 
 optimization_state_t libFIRM_verb =
   DISABLE(OPT_OPTIMIZED)                          |
   DISABLE(OPT_CSE)                                |
   DISABLE(OPT_GLOBAL_CSE)                         |
+  DISABLE(OPT_LOOP_UNROLLING)                     |
   DISABLE(OPT_STRENGTH_RED)                       |
   DISABLE(OPT_CONSTANT_FOLDING)                   |
   DISABLE(OPT_REDUNDANT_LOADSTORE)                |
@@ -62,10 +68,13 @@ optimization_state_t libFIRM_verb =
   DISABLE(OPT_REASSOCIATION)                      |
   DISABLE(OPT_INLINE)                             |
   DISABLE(OPT_DYN_METH_DISPATCH)                  |
+  DISABLE(OPT_CLASS_CASTS)                        |
   DISABLE(OPT_NORMALIZE)                          |
   DISABLE(OPT_TAIL_RECURSION)                     |
   DISABLE(OPT_PRECISE_EXC_CONTEXT)                |
-  DISABLE(OPT_FRAGILE_OPS)                       |
+  DISABLE(OPT_FRAGILE_OPS)                        |
+  DISABLE(OPT_IF_CONVERSION)                      |
+  DISABLE(OPT_REAL_FUNC_CALL)                     |
   0;
 
 /** The Firm verbosity level */
@@ -80,6 +89,10 @@ void set_opt_cse (int value)
     libFIRM_opt &= ~OPT_CSE;
 }
 
+int (get_opt_cse)(void) {
+  return _get_opt_cse();
+}
+
 void set_opt_global_cse(int value)
 {
   if (value)
@@ -88,6 +101,22 @@ void set_opt_global_cse(int value)
     libFIRM_opt &= ~OPT_GLOBAL_CSE;
 }
 
+void set_opt_loop_unrolling (int value)
+{
+  if (value)
+    libFIRM_opt |= OPT_LOOP_UNROLLING;
+  else
+    libFIRM_opt &= ~OPT_LOOP_UNROLLING;
+}
+
+void set_opt_loop_unrolling_verbose (int value)
+{
+  if (value)
+    libFIRM_verb |= OPT_LOOP_UNROLLING;
+  else
+    libFIRM_verb &= ~OPT_LOOP_UNROLLING;
+}
+
 void set_opt_strength_red (int value)
 {
   if (value)
@@ -245,6 +274,42 @@ void set_opt_dyn_meth_dispatch (int value)
     libFIRM_opt &= ~OPT_DYN_METH_DISPATCH;
 }
 
+int (get_opt_dyn_meth_dispatch)(void) {
+  return _get_opt_dyn_meth_dispatch();
+}
+
+void set_opt_optimize_class_casts (int value)
+{
+  if (value)
+    libFIRM_opt |= OPT_CLASS_CASTS;
+  else
+    libFIRM_opt &= ~OPT_CLASS_CASTS;
+}
+int  (get_opt_optimize_class_casts) (void) {
+  return _get_opt_optimize_class_casts();
+}
+void set_opt_optimize_class_casts_verbose (int value)
+{
+  if (value)
+    libFIRM_verb |= OPT_CLASS_CASTS;
+  else
+    libFIRM_verb &= ~OPT_CLASS_CASTS;
+}
+int  (get_opt_optimize_class_casts_verbose) (void) {
+  return _get_opt_optimize_class_casts_verbose();
+}
+void set_opt_suppress_downcast_optimization(int value)
+{
+  if (value)
+    libFIRM_opt |= OPT_SUPPRESS_DOWNCAST_OPT;
+  else
+    libFIRM_opt &= ~OPT_SUPPRESS_DOWNCAST_OPT;
+}
+int  (get_opt_suppress_downcast_optimization)(void) {
+  return _get_opt_suppress_downcast_optimization();
+}
+
+
 /* Enable/Disable normalizations of the firm representation. */
 void set_opt_normalize(int value)
 {
@@ -291,6 +356,24 @@ void set_opt_fragile_ops(int value)
     libFIRM_opt &= ~OPT_FRAGILE_OPS;
 }
 
+/* Enable/Disable if conversion. */
+void set_opt_if_conversion(int value)
+{
+  if (value)
+    libFIRM_opt |= OPT_IF_CONVERSION;
+  else
+    libFIRM_opt &= ~OPT_IF_CONVERSION;
+}
+
+/* Enable/Disable real function call optimization. */
+void set_opt_real_function_call(int value)
+{
+  if (value)
+    libFIRM_opt |= OPT_REAL_FUNC_CALL;
+  else
+    libFIRM_opt &= ~OPT_REAL_FUNC_CALL;
+}
+
 /* Save the current optimization state. */
 void save_optimization_state(optimization_state_t *state)
 {