libFirm
Loading...
Searching...
No Matches

Functions

void add_Sync_pred (ir_node *node, ir_node *pred)
 Adds pred to predecessor list of Sync node node.
 
void remove_Sync_n (ir_node *n, int i)
 Removes predecessor i from Sync n.
 
ir_nodenew_rd_Sync (dbg_info *dbgi, ir_node *block, int arity, ir_node *const *in)
 Construct a Sync node.
 
ir_nodenew_r_Sync (ir_node *block, int arity, ir_node *const *in)
 Construct a Sync node.
 
ir_nodenew_d_Sync (dbg_info *dbgi, int arity, ir_node *const *in)
 Construct a Sync node.
 
ir_nodenew_Sync (int arity, ir_node *const *in)
 Construct a Sync node.
 
int is_Sync (const ir_node *node)
 Test if node is a Sync.
 
int get_Sync_n_preds (ir_node const *node)
 Get the number of Sync preds.
 
ir_nodeget_Sync_pred (ir_node const *node, int pos)
 Get the Sync pred with index pos.
 
void set_Sync_pred (ir_node *node, int pos, ir_node *pred)
 Set the Sync pred with index pos.
 
ir_node ** get_Sync_pred_arr (ir_node *node)
 Get an array of all Sync preds.
 
ir_opget_op_Sync (void)
 Returns opcode for Sync nodes.
 

Variables

ir_opop_Sync
 Sync opcode.
 

Detailed Description

The Sync operation unifies several partial memory blocks. These blocks have to be pairwise disjunct or the values in common locations have to be identical. This operation allows to specify all operations that eventually need several partial memory blocks as input with a single entrance by unifying the memories with a preceding Sync operation.

Function Documentation

◆ add_Sync_pred()

void add_Sync_pred ( ir_node * node,
ir_node * pred )

Adds pred to predecessor list of Sync node node.

◆ get_op_Sync()

ir_op * get_op_Sync ( void )

Returns opcode for Sync nodes.

◆ get_Sync_n_preds()

int get_Sync_n_preds ( ir_node const * node)

Get the number of Sync preds.

◆ get_Sync_pred()

ir_node * get_Sync_pred ( ir_node const * node,
int pos )

Get the Sync pred with index pos.

◆ get_Sync_pred_arr()

ir_node ** get_Sync_pred_arr ( ir_node * node)

Get an array of all Sync preds.

◆ is_Sync()

int is_Sync ( const ir_node * node)

Test if node is a Sync.

Returns
1 if the node is a Sync node, 0 otherwise

◆ new_d_Sync()

ir_node * new_d_Sync ( dbg_info * dbgi,
int arity,
ir_node *const * in )

Construct a Sync node.

Parameters
dbgiA pointer to debug information.
aritysize of additional inputs array
inadditional inputs

◆ new_r_Sync()

ir_node * new_r_Sync ( ir_node * block,
int arity,
ir_node *const * in )

Construct a Sync node.

Parameters
blockThe IR block the node belongs to.
aritysize of additional inputs array
inadditional inputs

◆ new_rd_Sync()

ir_node * new_rd_Sync ( dbg_info * dbgi,
ir_node * block,
int arity,
ir_node *const * in )

Construct a Sync node.

Parameters
dbgiA pointer to debug information.
blockThe IR block the node belongs to.
aritysize of additional inputs array
inadditional inputs

◆ new_Sync()

ir_node * new_Sync ( int arity,
ir_node *const * in )

Construct a Sync node.

Parameters
aritysize of additional inputs array
inadditional inputs

◆ remove_Sync_n()

void remove_Sync_n ( ir_node * n,
int i )

Removes predecessor i from Sync n.

◆ set_Sync_pred()

void set_Sync_pred ( ir_node * node,
int pos,
ir_node * pred )

Set the Sync pred with index pos.

Variable Documentation

◆ op_Sync

ir_op* op_Sync

Sync opcode.

Definition at line 4166 of file nodes.h.