use tv_t.h instead of tv.h
[libfirm] / ir / ir / irflag.c
index 787bd69..21bc810 100644 (file)
@@ -40,11 +40,14 @@ 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 =
@@ -65,11 +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_IF_CONVERSION)                      |
+  DISABLE(OPT_REAL_FUNC_CALL)                     |
   0;
 
 /** The Firm verbosity level */
@@ -273,6 +278,38 @@ 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)
 {
@@ -319,6 +356,7 @@ 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)
@@ -327,6 +365,15 @@ void set_opt_if_conversion(int value)
     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)
 {