-/* Copyright (C) 1998 - 2000 by Universitaet Karlsruhe
-* All rights reserved.
-*
-* Authors: Christian Schaefer
-*
-* irflag --- optimization flags
-*/
-
-/* $Id$ */
+/*
+ * Project: libFIRM
+ * File name: ir/ir/irflag.c
+ * Purpose: Flags to control optimizations.
+ * Author: Christian Schaefer, Goetz Lindenmaier
+ * Modified by:
+ * Created:
+ * CVS-ID: $Id$
+ * Copyright: (c) 1999-2003 Universität Karlsruhe
+ * Licence: This file protected by GPL - GNU GENERAL PUBLIC LICENSE.
+ */
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif
-#include "irflag.h"
#include "firm_common.h"
+#include "irflag_t.h"
+
+/* DISABLE - don't do this optimization
+ ENABLE - lets see, if there is a better graph */
+#define ENABLE(a) a
+#define DISABLE(a) 0
+optimization_state_t libFIRM_opt =
+ ENABLE(OPT_OPTIMIZED) |
+ ENABLE(OPT_CSE) |
+ DISABLE(OPT_GLOBAL_CSE) |
+ ENABLE(OPT_STRENGTH_RED) |
+ ENABLE(OPT_CONSTANT_FOLDING) |
+ ENABLE(OPT_REDUNDANT_LOADSTORE) |
+ ENABLE(OPT_UNREACHABLE_CODE) |
+ ENABLE(OPT_CONTROL_FLOW_STRAIGHTENING) |
+ ENABLE(OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION) |
+ ENABLE(OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION) |
+ ENABLE(OPT_CRITICAL_EDGES) |
+ ENABLE(OPT_DEAD_NODE_ELIMINATION) |
+ ENABLE(OPT_DEAD_METHOD_ELIMINATION) |
+ ENABLE(OPT_REASSOCIATION) |
+ ENABLE(OPT_INLINE) |
+ ENABLE(OPT_DYN_METH_DISPATCH) |
+ ENABLE(OPT_NORMALIZE) |
+ ENABLE(OPT_TAIL_RECURSION) |
+ ENABLE(OPT_PRECISE_EXC_CONTEXT) |
+ 0;
-/* 0 - don't do this optimization
- 1 - lets see, if there is a better graph */
-int optimized = 1; /* Turn off all optimizations */
+optimization_state_t libFIRM_verb =
+ DISABLE(OPT_OPTIMIZED) |
+ DISABLE(OPT_CSE) |
+ DISABLE(OPT_GLOBAL_CSE) |
+ DISABLE(OPT_STRENGTH_RED) |
+ DISABLE(OPT_CONSTANT_FOLDING) |
+ DISABLE(OPT_REDUNDANT_LOADSTORE) |
+ DISABLE(OPT_UNREACHABLE_CODE) |
+ DISABLE(OPT_CONTROL_FLOW_STRAIGHTENING) |
+ DISABLE(OPT_CONTROL_FLOW_WEAK_SIMPLIFICATION) |
+ DISABLE(OPT_CONTROL_FLOW_STRONG_SIMPLIFICATION) |
+ DISABLE(OPT_CRITICAL_EDGES) |
+ DISABLE(OPT_DEAD_NODE_ELIMINATION) |
+ DISABLE(OPT_DEAD_METHOD_ELIMINATION) |
+ DISABLE(OPT_REASSOCIATION) |
+ DISABLE(OPT_INLINE) |
+ DISABLE(OPT_DYN_METH_DISPATCH) |
+ DISABLE(OPT_NORMALIZE) |
+ DISABLE(OPT_TAIL_RECURSION) |
+ DISABLE(OPT_PRECISE_EXC_CONTEXT) |
+ 0;
-int opt_cse = 1; /* Hash the nodes */
-int opt_global_cse = 0; /* Don't use block predecessor for comparison */
-/* @@@ 0 solage code placement fehlt */
-int opt_constant_folding = 1; /* Evaluate operations */
-int opt_unreachable_code = 1; /* Bad node propagation */
-int opt_control_flow_straightening = 1; /* */
-int opt_control_flow_weak_simplification = 1; /* */
-int opt_control_flow_strong_simplification = 1; /* */
-int opt_dead_node_elimination = 1; /* Reclaim memory */
-int opt_reassociation = 1; /* Reassociate nodes */
-int opt_inline = 1; /* Do inlining transformation */
+/** The Firm verbosity level */
+int firm_verbosity_level;
/* set the flags with set_flagname, get the flag with get_flagname */
-INLINE void
-set_opt_cse (int value)
+void set_opt_cse (int value)
{
- opt_cse = value;
+ if (value)
+ libFIRM_opt |= OPT_CSE;
+ else
+ libFIRM_opt &= ~OPT_CSE;
}
-INLINE int
-get_opt_cse (void)
+void set_opt_global_cse(int value)
{
- return opt_cse;
+ if (value)
+ libFIRM_opt |= OPT_GLOBAL_CSE;
+ else
+ libFIRM_opt &= ~OPT_GLOBAL_CSE;
}
-void set_opt_global_cse (int value)
+void set_opt_strength_red (int value)
{
- opt_global_cse = value;
+ if (value)
+ libFIRM_opt |= OPT_STRENGTH_RED;
+ else
+ libFIRM_opt &= ~OPT_STRENGTH_RED;
}
-int get_opt_global_cse (void)
+void set_opt_strength_red_verbose (int value)
{
- return opt_global_cse;
+ if (value)
+ libFIRM_verb |= OPT_STRENGTH_RED;
+ else
+ libFIRM_verb &= ~OPT_STRENGTH_RED;
}
-INLINE void
-set_opt_constant_folding (int value)
+void
+set_opt_constant_folding(int value)
{
- opt_constant_folding=value;
+ if (value)
+ libFIRM_opt |= OPT_CONSTANT_FOLDING;
+ else
+ libFIRM_opt &= ~OPT_CONSTANT_FOLDING;
}
-INLINE int
-get_opt_constant_folding (void)
-{
- return opt_constant_folding;
+void
+set_opt_redundant_LoadStore(int value) {
+ if (value)
+ libFIRM_opt |= OPT_REDUNDANT_LOADSTORE;
+ else
+ libFIRM_opt &= ~OPT_REDUNDANT_LOADSTORE;
}
-INLINE void
+void
set_opt_unreachable_code(int value)
{
- opt_unreachable_code = value;
+ if (value)
+ libFIRM_opt |= OPT_UNREACHABLE_CODE;
+ else
+ libFIRM_opt &= ~OPT_UNREACHABLE_CODE;
}
-INLINE int
-get_opt_unreachable_code(void)
+void set_opt_control_flow(int value)
{
- return opt_unreachable_code;
-}
-
-INLINE 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) {
- opt_control_flow_straightening = value;
-}
-int get_opt_control_flow_straightening(void) {
- return opt_control_flow_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) {
- opt_control_flow_weak_simplification = value;
-}
-int get_opt_control_flow_weak_simplification(void) {
- return opt_control_flow_weak_simplification;
+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) {
- opt_control_flow_strong_simplification = value;
+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;
}
-int get_opt_control_flow_strong_simplification(void) {
- return opt_control_flow_strong_simplification;
+
+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;
+}
-INLINE void
-set_opt_reassociation(int value)
+void set_optimize(int value)
{
- opt_reassociation = value;
+ if (value)
+ libFIRM_opt |= OPT_OPTIMIZED;
+ else
+ libFIRM_opt &= ~OPT_OPTIMIZED;
}
-INLINE int
-get_opt_reassociation(void)
+int get_optimize(void)
{
- return opt_reassociation;
+ return get_opt_optimize();
+}
+
+
+void set_firm_verbosity (int value) {
+ firm_verbosity_level = value;
}
-INLINE void
-set_opt_dead_node_elimination (int value)
+int (get_firm_verbosity) (void) {
+ return _get_firm_verbosity();
+}
+
+
+
+/* Enable/Disables inlining. */
+void set_opt_inline(int value)
{
- opt_dead_node_elimination = value;
+ if (value)
+ libFIRM_opt |= OPT_INLINE;
+ else
+ libFIRM_opt &= ~OPT_INLINE;
}
-INLINE int
-get_opt_dead_node_elimination (void)
+/* Enable/Disable optimization of dynamic method dispatch */
+void set_opt_dyn_meth_dispatch (int value)
{
- return opt_dead_node_elimination;
+ if (value)
+ libFIRM_opt |= OPT_DYN_METH_DISPATCH;
+ else
+ libFIRM_opt &= ~OPT_DYN_METH_DISPATCH;
}
-INLINE void
-set_optimize (int value)
+/* Enable/Disable normalizations of the firm representation. */
+void set_opt_normalize(int value)
{
- optimized = value;
+ if (value)
+ libFIRM_opt |= OPT_NORMALIZE;
+ else
+ libFIRM_opt &= ~OPT_NORMALIZE;
}
-INLINE int
-get_optimize (void)
+/* Enable/Disable optimization of tail-recursion calls. */
+void set_opt_tail_recursion(int value)
{
- return optimized;
+ if (value)
+ libFIRM_opt |= OPT_TAIL_RECURSION;
+ else
+ libFIRM_opt &= ~OPT_TAIL_RECURSION;
}
+/* Enable/Disable optimization of tail-recursion calls. */
+void set_opt_tail_recursion_verbose(int value)
+{
+ if (value)
+ libFIRM_verb |= OPT_TAIL_RECURSION;
+ else
+ libFIRM_verb &= ~OPT_TAIL_RECURSION;
+}
-INLINE void set_opt_inline (int value) {
- opt_inline = value;
+/* Enable/Disable precise exception context. */
+void set_opt_precise_exc_context(int value)
+{
+#if PRECISE_EXC_CONTEXT
+ if (value)
+ libFIRM_opt |= OPT_PRECISE_EXC_CONTEXT;
+ else
+ libFIRM_opt &= ~OPT_PRECISE_EXC_CONTEXT;
+#endif
}
-INLINE int get_opt_inline (void) {
- return opt_inline;
+/* Save the current optimization state. */
+void save_optimization_state(optimization_state_t *state)
+{
+ *state = libFIRM_opt;
+}
+
+/* Restore the current optimization state. */
+void restore_optimization_state(const optimization_state_t *state)
+{
+ libFIRM_opt = *state;
}