From: Wolfgang (Blub) Bumiller Date: Thu, 28 Jun 2012 13:50:51 +0000 (+0200) Subject: ir_instr can now store a list of parameters, will be used for CALLs X-Git-Tag: 0.1-rc1~472 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=2073834b9ac89a3db8e090d0cbe1c6ec0a03b1ef;p=xonotic%2Fgmqcc.git ir_instr can now store a list of parameters, will be used for CALLs --- diff --git a/ir.c b/ir.c index d81cdce..3d4db01 100644 --- a/ir.c +++ b/ir.c @@ -356,6 +356,7 @@ ir_instr* ir_instr_new(ir_block* owner, int op) self->bops[0] = NULL; self->bops[1] = NULL; MEM_VECTOR_INIT(self, phi); + MEM_VECTOR_INIT(self, params); self->eid = 0; return self; @@ -379,6 +380,14 @@ void ir_instr_delete(ir_instr *self) if (ir_value_reads_remove (self->phi[i].value, idx)) GMQCC_SUPRESS_EMPTY_BODY; } MEM_VECTOR_CLEAR(self, phi); + for (i = 0; i < self->params_count; ++i) { + size_t idx; + if (ir_value_writes_find(self->params[i], self, &idx)) + if (ir_value_writes_remove(self->params[i], idx)) GMQCC_SUPRESS_EMPTY_BODY; + if (ir_value_reads_find(self->params[i], self, &idx)) + if (ir_value_reads_remove (self->params[i], idx)) GMQCC_SUPRESS_EMPTY_BODY; + } + MEM_VECTOR_CLEAR(self, params); if (ir_instr_op(self, 0, NULL, false)) GMQCC_SUPRESS_EMPTY_BODY; if (ir_instr_op(self, 1, NULL, false)) GMQCC_SUPRESS_EMPTY_BODY; if (ir_instr_op(self, 2, NULL, false)) GMQCC_SUPRESS_EMPTY_BODY; @@ -2109,6 +2118,9 @@ tailcall: } if (instr->opcode >= INSTR_CALL0 && instr->opcode <= INSTR_CALL8) { + /* Trivial call translation: + * copy all params to OFS_PARM* + */ printf("TODO: call instruction\n"); return false; } diff --git a/ir.h b/ir.h index a611dba..8bb0789 100644 --- a/ir.h +++ b/ir.h @@ -115,6 +115,7 @@ typedef struct ir_instr_s 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;