Added is_Const
[libfirm] / ir / ir / irflag.c
index ab759f2..077f2e8 100644 (file)
@@ -44,6 +44,8 @@ optimization_state_t libFIRM_opt =
   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 =
@@ -67,7 +69,9 @@ optimization_state_t libFIRM_verb =
   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 */
@@ -267,6 +271,10 @@ 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();
+}
+
 /* Enable/Disable normalizations of the firm representation. */
 void set_opt_normalize(int value)
 {
@@ -313,6 +321,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)
@@ -321,6 +330,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)
 {