lex_ctx context;
/* even the IR knows the subtype of a field */
int fieldtype;
+ /* and the output type of a function */
+ int outtype;
MEM_VECTOR_MAKE(struct ir_instr_s*, reads);
MEM_VECTOR_MAKE(struct ir_instr_s*, writes);
int32_t globaladdr;
int32_t name;
/* filled by the local-allocator */
- int32_t slot;
+ int32_t local;
} code;
/* For the temp allocator */
void ir_value_dump(ir_value*, int (*oprintf)(const char*,...));
void ir_value_dump_life(ir_value *self, int (*oprintf)(const char*,...));
+/* A vector of IR values */
+typedef struct {
+ MEM_VECTOR_MAKE(ir_value*, v);
+} ir_value_vector;
+MEM_VECTOR_PROTO(ir_value_vector, ir_value*, v);
+
+/* PHI data */
typedef struct ir_phi_entry_s
{
ir_value *value;
struct ir_block_s* (bops[2]);
MEM_VECTOR_MAKE(ir_phi_entry_t, phi);
+ MEM_VECTOR_MAKE(ir_value*, params);
/* For the temp-allocation */
size_t eid;
MEM_VECTOR_PROTO(ir_value, ir_phi_entry_t, phi);
bool GMQCC_WARN ir_instr_op(ir_instr*, int op, ir_value *value, bool writing);
+MEM_VECTOR_PROTO(ir_value, ir_value*, params);
+
void ir_instr_dump(ir_instr* in, char *ind, int (*oprintf)(const char*,...));
/* block */
ir_instr* ir_block_create_phi(ir_block*, const char *label, int vtype);
ir_value* ir_phi_value(ir_instr*);
bool GMQCC_WARN ir_phi_add(ir_instr*, ir_block *b, ir_value *v);
+ir_instr* ir_block_create_call(ir_block*, const char *label, ir_value *func, int otype);
+ir_value* ir_call_value(ir_instr*);
+bool GMQCC_WARN ir_call_param(ir_instr*, ir_value*);
bool GMQCC_WARN ir_block_create_return(ir_block*, ir_value *opt_value);
/* locally defined variables */
MEM_VECTOR_MAKE(ir_value*, locals);
+ size_t allocated_locals;
+
ir_block* first;
ir_block* last;