+ if (value)
+ libFIRM_opt |= OPT_UNREACHABLE_CODE;
+ else
+ libFIRM_opt &= ~OPT_UNREACHABLE_CODE;
+}
+
+void set_opt_control_flow(int value)
+{
+ set_opt_control_flow_straightening(value);
+ set_opt_control_flow_weak_simplification(value);
+ set_opt_control_flow_strong_simplification(value);
+ set_opt_critical_edges(value);
+}
+
+/* Performs Straightening */
+void set_opt_control_flow_straightening(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_CONTROL_FLOW_STRAIGHTENING;
+ else
+ libFIRM_opt &= ~OPT_CONTROL_FLOW_STRAIGHTENING;
+}
+
+/* Performs if simplifications in local optimizations. */
+void set_opt_control_flow_weak_simplification(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION;
+ else
+ libFIRM_opt &= ~OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION;
+}
+
+/* Performs strong if and loop simplification (in optimize_cf). */
+void set_opt_control_flow_strong_simplification(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION;
+ else
+ libFIRM_opt &= ~OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION;
+}
+
+void set_opt_critical_edges(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_CRITICAL_EDGES;
+ else
+ libFIRM_opt &= ~OPT_CRITICAL_EDGES;
+}
+
+void set_opt_reassociation(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_REASSOCIATION;
+ else
+ libFIRM_opt &= ~OPT_REASSOCIATION;
+}
+
+void set_opt_dead_node_elimination(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_DEAD_NODE_ELIMINATION;
+ else
+ libFIRM_opt &= ~OPT_DEAD_NODE_ELIMINATION;
+}
+
+void set_opt_dead_method_elimination (int value) {
+ if (value)
+ libFIRM_opt |= OPT_DEAD_METHOD_ELIMINATION;
+ else
+ libFIRM_opt &= ~OPT_DEAD_METHOD_ELIMINATION;
+}
+
+void set_opt_dead_method_elimination_verbose (int value) {
+ if (value)
+ libFIRM_verb |= OPT_DEAD_METHOD_ELIMINATION;
+ else
+ libFIRM_verb &= ~OPT_DEAD_METHOD_ELIMINATION;
+}
+
+void set_optimize(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_OPTIMIZED;
+ else
+ libFIRM_opt &= ~OPT_OPTIMIZED;
+}
+
+int get_optimize(void)
+{
+ return get_opt_optimize();
+}
+
+
+void set_firm_verbosity (int value) {
+ firm_verbosity_level = value;
+}
+
+int (get_firm_verbosity) (void) {
+ return _get_firm_verbosity();
+}
+
+
+
+/* Enable/Disables inlining. */
+void set_opt_inline(int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_INLINE;
+ else
+ libFIRM_opt &= ~OPT_INLINE;
+}
+
+/* Enable/Disable optimization of dynamic method dispatch */
+void set_opt_dyn_meth_dispatch (int value)
+{
+ if (value)
+ libFIRM_opt |= OPT_DYN_METH_DISPATCH;
+ else
+ libFIRM_opt &= ~OPT_DYN_METH_DISPATCH;