if the compiler has ommited the instructions, it means we should the
argument set up there by the compiler.
This commit is contained in:
parent
7ffbfdbc77
commit
9b7d2b1cd4
46
C/amasm.c
46
C/amasm.c
@ -2407,34 +2407,24 @@ a_fetch_vv(cmp_op_info *cmp_info, int pass_no, struct intermediates *cip)
|
|||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
Ventry *ve;
|
||||||
ve = (Ventry *) p->rnd1;
|
ve = (Ventry *) p->rnd1;
|
||||||
if (ve->KindOfVE != PermVar)
|
if (ve->KindOfVE != PermVar && p->op != nop_op) {
|
||||||
|
p->rnd2 = ve->NoOfVE & MaskVarAdrs;
|
||||||
p->op = nop_op;
|
p->op = nop_op;
|
||||||
|
}
|
||||||
p = p->nextInst;
|
p = p->nextInst;
|
||||||
ve = (Ventry *) p->rnd1;
|
ve = (Ventry *) p->rnd1;
|
||||||
if (ve->KindOfVE != PermVar)
|
if (ve->KindOfVE != PermVar && p->op != nop_op) {
|
||||||
|
p->rnd2 = ve->NoOfVE & MaskVarAdrs;
|
||||||
p->op = nop_op;
|
p->op = nop_op;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
|
||||||
|
|
||||||
cmp_info->c_type = TYPE_XX;
|
cmp_info->c_type = TYPE_XX;
|
||||||
ve = (Ventry *) p->rnd1;
|
|
||||||
if (ve->KindOfVE == PermVar) {
|
|
||||||
/* don't get rid of get_val_op */
|
/* don't get rid of get_val_op */
|
||||||
cmp_info->x1_arg = emit_x(p->rnd2);
|
cmp_info->x1_arg = emit_x(p->rnd2);
|
||||||
} else {
|
|
||||||
/* and use it directly as a second argument */
|
|
||||||
cmp_info->x1_arg = emit_x(ve->NoOfVE & MaskVarAdrs);
|
|
||||||
}
|
|
||||||
p = p->nextInst;
|
p = p->nextInst;
|
||||||
ve = (Ventry *) p->rnd1;
|
|
||||||
if (ve->KindOfVE == PermVar) {
|
|
||||||
/* don't get rid of get_val_op */
|
|
||||||
cmp_info->x2_arg = emit_x(p->rnd2);
|
cmp_info->x2_arg = emit_x(p->rnd2);
|
||||||
} else {
|
|
||||||
/* and use it directly as a second argument */
|
|
||||||
cmp_info->x2_arg = emit_x(ve->NoOfVE & MaskVarAdrs);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2446,22 +2436,16 @@ a_fetch_vc(cmp_op_info *cmp_info, int pass_no, struct intermediates *cip)
|
|||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
Ventry *ve;
|
||||||
ve = (Ventry *) p->rnd1;
|
ve = (Ventry *) p->rnd1;
|
||||||
if (ve->KindOfVE != PermVar)
|
if (ve->KindOfVE != PermVar && p->op != nop_op) {
|
||||||
|
p->rnd2 = ve->NoOfVE & MaskVarAdrs;
|
||||||
p->op = nop_op;
|
p->op = nop_op;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
|
||||||
|
|
||||||
cmp_info->c_type = TYPE_XC;
|
cmp_info->c_type = TYPE_XC;
|
||||||
cmp_info->c_arg = cip->cpc->rnd1;
|
cmp_info->c_arg = cip->cpc->rnd1;
|
||||||
ve = (Ventry *) p->rnd1;
|
|
||||||
if (ve->KindOfVE == PermVar) {
|
|
||||||
/* don't get rid of get_val_op */
|
|
||||||
cmp_info->x1_arg = emit_x(p->rnd2);
|
cmp_info->x1_arg = emit_x(p->rnd2);
|
||||||
} else {
|
|
||||||
/* and use it directly as a second argument */
|
|
||||||
cmp_info->x1_arg = emit_x(ve->NoOfVE & MaskVarAdrs);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2473,22 +2457,16 @@ a_fetch_cv(cmp_op_info *cmp_info, int pass_no, struct intermediates *cip)
|
|||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
Ventry *ve;
|
||||||
ve = (Ventry *) p->rnd1;
|
ve = (Ventry *) p->rnd1;
|
||||||
if (ve->KindOfVE != PermVar)
|
if (ve->KindOfVE != PermVar && p->op != nop_op) {
|
||||||
|
p->rnd2 = ve->NoOfVE & MaskVarAdrs;
|
||||||
p->op = nop_op;
|
p->op = nop_op;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
PInstr *p = cip->cpc->nextInst;
|
PInstr *p = cip->cpc->nextInst;
|
||||||
Ventry *ve;
|
|
||||||
|
|
||||||
cmp_info->c_type = TYPE_CX;
|
cmp_info->c_type = TYPE_CX;
|
||||||
cmp_info->c_arg = cip->cpc->rnd1;
|
cmp_info->c_arg = cip->cpc->rnd1;
|
||||||
ve = (Ventry *) p->rnd1;
|
|
||||||
if (ve->KindOfVE == PermVar) {
|
|
||||||
/* don't get rid of get_val_op */
|
|
||||||
cmp_info->x1_arg = emit_x(p->rnd2);
|
cmp_info->x1_arg = emit_x(p->rnd2);
|
||||||
} else {
|
|
||||||
/* and use it directly as a second argument */
|
|
||||||
cmp_info->x1_arg = emit_x(ve->NoOfVE & MaskVarAdrs);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user