#include "irtypes.h"
#include "irprog.h"
-#include "pseudo_irg.h"
#include "type_t.h"
#include "entity_t.h"
#include "iredgekinds.h"
* @param irg the IR graph
* @param n the IR node
*/
-int node_is_in_irgs_storage(ir_graph *irg, ir_node *n);
+int node_is_in_irgs_storage(const ir_graph *irg, const ir_node *n);
/*-------------------------------------------------------------------*/
/* inline functions for graphs */
/** Returns the start block of a graph. */
static inline ir_node *_get_irg_start_block(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_start_block);
+ return get_irn_n(irg->anchor, anchor_start_block);
}
static inline void _set_irg_start_block(ir_graph *irg, ir_node *node)
static inline ir_node *_get_irg_start(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_start);
+ return get_irn_n(irg->anchor, anchor_start);
}
static inline void _set_irg_start(ir_graph *irg, ir_node *node)
static inline ir_node *_get_irg_end_block(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_end_block);
+ return get_irn_n(irg->anchor, anchor_end_block);
}
static inline void _set_irg_end_block(ir_graph *irg, ir_node *node)
static inline ir_node *_get_irg_end(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_end);
+ return get_irn_n(irg->anchor, anchor_end);
}
static inline void _set_irg_end(ir_graph *irg, ir_node *node)
set_irn_n(irg->anchor, anchor_end, node);
}
-static inline ir_node *_get_irg_end_reg(const ir_graph *irg)
-{
- return get_irn_intra_n(irg->anchor, anchor_end_reg);
-}
-
-static inline void _set_irg_end_reg(ir_graph *irg, ir_node *node)
-{
- set_irn_n(irg->anchor, anchor_end_reg, node);
-}
-
-static inline ir_node *_get_irg_end_except(const ir_graph *irg)
-{
- return get_irn_intra_n(irg->anchor, anchor_end_except);
-}
-
-static inline void _set_irg_end_except(ir_graph *irg, ir_node *node)
-{
- set_irn_n(irg->anchor, anchor_end_except, node);
-}
-
static inline ir_node *_get_irg_initial_exec(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_initial_exec);
+ return get_irn_n(irg->anchor, anchor_initial_exec);
}
static inline void _set_irg_initial_exec(ir_graph *irg, ir_node *node)
static inline ir_node *_get_irg_frame(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_frame);
+ return get_irn_n(irg->anchor, anchor_frame);
}
static inline void _set_irg_frame(ir_graph *irg, ir_node *node)
set_irn_n(irg->anchor, anchor_frame, node);
}
-static inline ir_node *_get_irg_tls(const ir_graph *irg)
-{
- return get_irn_intra_n(irg->anchor, anchor_tls);
-}
-
-static inline void _set_irg_tls(ir_graph *irg, ir_node *node)
-{
- set_irn_n(irg->anchor, anchor_tls, node);
-}
-
static inline ir_node *_get_irg_initial_mem(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_initial_mem);
+ return get_irn_n(irg->anchor, anchor_initial_mem);
}
static inline void _set_irg_initial_mem(ir_graph *irg, ir_node *node)
static inline ir_node *_get_irg_args(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_args);
+ return get_irn_n(irg->anchor, anchor_args);
}
static inline void _set_irg_args(ir_graph *irg, ir_node *node)
set_irn_n(irg->anchor, anchor_args, node);
}
-static inline ir_node *_get_irg_bad(const ir_graph *irg)
-{
- return get_irn_intra_n(irg->anchor, anchor_bad);
-}
-
-static inline void _set_irg_bad(ir_graph *irg, ir_node *node)
-{
- set_irn_n(irg->anchor, anchor_bad, node);
-}
-
static inline ir_node * _get_irg_no_mem(const ir_graph *irg)
{
- return get_irn_intra_n(irg->anchor, anchor_no_mem);
+ return get_irn_n(irg->anchor, anchor_no_mem);
}
static inline void _set_irg_no_mem(ir_graph *irg, ir_node *node)
set_irn_n(irg->anchor, anchor_no_mem, node);
}
-static inline ir_node *_get_irg_current_block(const ir_graph *irg)
-{
- return irg->current_block;
-}
-
-static inline void _set_irg_current_block(ir_graph *irg, ir_node *node)
-{
- irg->current_block = node;
-}
-
static inline ir_entity *_get_irg_entity(const ir_graph *irg)
{
assert(irg);
irg->outs_state = outs_inconsistent;
}
-static inline irg_extblk_state _get_irg_extblk_state(const ir_graph *irg)
+static inline irg_extblk_info_state _get_irg_extblk_state(const ir_graph *irg)
{
- return irg->extblk_state;
+ return irg->extblk_state;
}
static inline void _set_irg_extblk_inconsistent(ir_graph *irg)
{
- if (irg->extblk_state == extblk_valid)
- irg->extblk_state = extblk_invalid;
+ if (irg->extblk_state == ir_extblk_info_valid)
+ irg->extblk_state = ir_extblk_info_invalid;
}
static inline irg_dom_state _get_irg_dom_state(const ir_graph *irg)
static inline void _set_irg_loopinfo_inconsistent(ir_graph *irg)
{
- irg->loopinfo_state &= ~loopinfo_valid;
+ irg->loopinfo_state = (irg_loopinfo_state) (irg->loopinfo_state & ~loopinfo_valid);
}
static inline void _set_irg_pinned(ir_graph *irg, op_pin_state p)
irg->inline_property = s;
}
-static inline unsigned _get_irg_additional_properties(const ir_graph *irg)
+static inline mtp_additional_properties _get_irg_additional_properties(const ir_graph *irg)
{
if (irg->additional_properties & mtp_property_inherited)
return get_method_additional_properties(get_entity_type(irg->ent));
return irg->additional_properties;
}
-static inline void _set_irg_additional_properties(ir_graph *irg, unsigned mask)
+static inline void _set_irg_additional_properties(ir_graph *irg, mtp_additional_properties mask)
{
irg->additional_properties = mask & ~mtp_property_inherited;
}
-static inline void _set_irg_additional_property(ir_graph *irg, mtp_additional_property flag)
+static inline void _add_irg_additional_properties(ir_graph *irg, mtp_additional_properties flag)
{
- unsigned prop = irg->additional_properties;
+ mtp_additional_properties prop = irg->additional_properties;
if (prop & mtp_property_inherited)
prop = get_method_additional_properties(get_entity_type(irg->ent));
static inline void _set_irg_state(ir_graph *irg, ir_graph_state_t state)
{
- irg->state |= state;
+ irg->state = (ir_graph_state_t) (irg->state | state);
}
static inline void _clear_irg_state(ir_graph *irg, ir_graph_state_t state)
{
- irg->state &= ~state;
+ irg->state = (ir_graph_state_t) (irg->state & ~state);
}
static inline int _is_irg_state(const ir_graph *irg, ir_graph_state_t state)
* @param irn The node.
* @return The index allocated for the node.
*/
-static inline unsigned irg_register_node_idx(ir_graph *irg, ir_node *irn) {
+static inline unsigned irg_register_node_idx(ir_graph *irg, ir_node *irn)
+{
unsigned idx = irg->last_node_idx++;
if (idx >= (unsigned)ARR_LEN(irg->idx_irn_map))
ARR_RESIZE(ir_node *, irg->idx_irn_map, idx + 1);
* @return The node with that index or NULL, if there is no node with that index.
* @note The node you got might be dead.
*/
-static inline ir_node *_get_idx_irn(ir_graph *irg, unsigned idx)
+static inline ir_node *_get_idx_irn(const ir_graph *irg, unsigned idx)
{
assert(idx < (unsigned) ARR_LEN(irg->idx_irn_map));
return irg->idx_irn_map[idx];
*/
static inline ir_node *get_irg_anchor(const ir_graph *irg, int idx)
{
- return get_irn_intra_n(irg->anchor, idx);
+ return get_irn_n(irg->anchor, idx);
}
/**
}
-#ifdef INTERPROCEDURAL_VIEW
-extern int firm_interprocedural_view;
-
-static inline int _get_interprocedural_view(void)
-{
- return firm_interprocedural_view;
-}
-
-#define get_interprocedural_view() _get_interprocedural_view()
-#endif
-
#define is_ir_graph(thing) _is_ir_graph(thing)
#define get_irg_start_block(irg) _get_irg_start_block(irg)
#define set_irg_start_block(irg, node) _set_irg_start_block(irg, node)
#define set_irg_end_block(irg, node) _set_irg_end_block(irg, node)
#define get_irg_end(irg) _get_irg_end(irg)
#define set_irg_end(irg, node) _set_irg_end(irg, node)
-#define get_irg_end_reg(irg) _get_irg_end_reg(irg)
-#define set_irg_end_reg(irg, node) _set_irg_end_reg(irg, node)
-#define get_irg_end_except(irg) _get_irg_end_except(irg)
-#define set_irg_end_except(irg, node) _set_irg_end_except(irg, node)
#define get_irg_initial_exec(irg) _get_irg_initial_exec(irg)
#define set_irg_initial_exec(irg, node) _set_irg_initial_exec(irg, node)
#define get_irg_frame(irg) _get_irg_frame(irg)
#define set_irg_frame(irg, node) _set_irg_frame(irg, node)
-#define get_irg_tls(irg) _get_irg_tls(irg)
-#define set_irg_tls(irg, node) _set_irg_tls(irg, node)
#define get_irg_initial_mem(irg) _get_irg_initial_mem(irg)
#define set_irg_initial_mem(irg, node) _set_irg_initial_mem(irg, node)
#define get_irg_args(irg) _get_irg_args(irg)
#define set_irg_args(irg, node) _set_irg_args(irg, node)
-#define get_irg_bad(irg) _get_irg_bad(irg)
-#define set_irg_bad(irg, node) _set_irg_bad(irg, node)
#define get_irg_no_mem(irg) _get_irg_no_mem(irg)
#define set_irn_no_mem(irg, node) _set_irn_no_mem(irg, node)
-#define get_irg_current_block(irg) _get_irg_current_block(irg)
-#define set_irg_current_block(irg, node) _set_irg_current_block(irg, node)
#define get_irg_entity(irg) _get_irg_entity(irg)
#define set_irg_entity(irg, ent) _set_irg_entity(irg, ent)
#define get_irg_frame_type(irg) _get_irg_frame_type(irg)