forked from OSchip/llvm-project
GlobalISel: Avoid unnecessary truncation to i64
We can just directly pass through the APInt to create a new constant.
This commit is contained in:
parent
6314a72730
commit
1098acd46d
|
@ -189,7 +189,7 @@ MachineInstrBuilder CSEMIRBuilder::buildInstr(unsigned Opc,
|
|||
assert(DstOps.size() == 1 && "Invalid dsts");
|
||||
if (Optional<APInt> Cst = ConstantFoldBinOp(Opc, SrcOps[0].getReg(),
|
||||
SrcOps[1].getReg(), *getMRI()))
|
||||
return buildConstant(DstOps[0], Cst->getSExtValue());
|
||||
return buildConstant(DstOps[0], *Cst);
|
||||
break;
|
||||
}
|
||||
case TargetOpcode::G_SEXT_INREG: {
|
||||
|
@ -200,7 +200,7 @@ MachineInstrBuilder CSEMIRBuilder::buildInstr(unsigned Opc,
|
|||
const SrcOp &Src1 = SrcOps[1];
|
||||
if (auto MaybeCst =
|
||||
ConstantFoldExtOp(Opc, Src0.getReg(), Src1.getImm(), *getMRI()))
|
||||
return buildConstant(Dst, MaybeCst->getSExtValue());
|
||||
return buildConstant(Dst, *MaybeCst);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue