* @file irprog_t.h
*/
-# ifndef _IRPROG_T_H_
-# define _IRPROG_T_H_
+#ifndef _IRPROG_T_H_
+#define _IRPROG_T_H_
#ifdef HAVE_CONFIG_H
-#include "config.h"
+#include "firm_config.h"
#endif
#include "irprog.h"
#include "irgraph.h"
+#include "pseudo_irg.h"
#include "ircgcons.h"
#include "firm_common_t.h"
#include "typegmod.h"
+#include "irtypeinfo.h"
+#include "tr_inheritance.h"
#include "callgraph.h"
+#include "field_temperature.h"
#include "array.h"
ir_graph *main_irg; /**< entry point to the compiled program
@@@ or a list, in case we compile a library or the like? */
ir_graph **graphs; /**< all graphs in the ir */
+ ir_graph **pseudo_graphs; /**< all pseudo graphs in the ir. See pseudo_irg.c */
ir_graph *const_code_irg; /**< This ir graph gives the proper environment
to allocate nodes the represent values
of constant entities. It is not meant as
type **types; /**< all types in the ir */
/* -- states of and access to generated information -- */
+ irg_phase_state phase_state; /**< State of construction. */
ip_view_state ip_view; /**< State of interprocedural view. */
- irg_outs_state outs_state; /**< Out edges. */
+ irg_outs_state outs_state; /**< State of out edges of ir nodes. */
ir_node **ip_outedges; /**< Huge Array that contains all out edges
in interprocedural view. */
+ irg_outs_state trouts_state; /**< State of out edges of type information. */
irg_callee_info_state callee_info_state; /**< Validity of callee information.
- Contains the lowest value or all irgs. */
-
+ Contains the lowest value or all irgs. */
+ ir_typeinfo_state typeinfo_state; /**< Validity of type information. */
+ inh_transitive_closure_state inh_trans_closure_state; /**< trans closure of inh relations. */
irp_callgraph_state callgraph_state; /**< State of the callgraph. */
struct ir_loop *outermost_cg_loop; /**< For callgraph analysis: entry point
to looptree over callgraph. */
- int max_callgraph_loop_depth;
- int max_callgraph_recursion_depth;
+ int max_callgraph_loop_depth; /**< needed in callgraph. */
+ int max_callgraph_recursion_depth; /**< needed in callgraph. */
+ int max_method_execution_frequency; /**< needed in callgraph. */
+ irp_temperature_state temperature_state; /**< accumulated temperatures computed? */
#ifdef DEBUG_libfirm
long max_node_nr; /**< to generate unique numbers for nodes. */
#endif
};
-INLINE void remove_irp_type_from_list (type *typ);
+void remove_irp_type_from_list (type *typ);
static INLINE type *
__get_glob_type(void) {
static INLINE int
__get_irp_n_irgs(void) {
assert (irp && irp->graphs);
- /* Strangely the first element of the array is NULL. Why?? */
+ if (get_visit_pseudo_irgs()) return get_irp_n_allirgs();
return (ARR_LEN((irp)->graphs));
}
static INLINE ir_graph *
__get_irp_irg(int pos){
- assert (irp && irp->graphs);
- /* Strangely the first element of the array is NULL. Why?? */
+ if (get_visit_pseudo_irgs()) return get_irp_allirg(pos);
+ assert(0 <= pos && pos <= get_irp_n_irgs());
return irp->graphs[pos];
}
static INLINE int
__get_irp_n_types (void) {
assert (irp && irp->types);
- /* Strangely the first element of the array is NULL. Why?? */
return (ARR_LEN((irp)->types));
}
static INLINE type *
__get_irp_type(int pos) {
assert (irp && irp->types);
- /* Strangely the first element of the array is NULL. Why?? */
/* Don't set the skip_tid result so that no double entries are generated. */
return skip_tid(irp->types[pos]);
}