mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-25 04:39:44 +00:00
GlobalISel: Add a note about how we're being a bit loose with memory operands
The logic in r292461 is conservatively correct, but we should revisit this later. Add a TODO so we don't forget. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@292553 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c4512366a3
commit
91e5a47341
@ -177,6 +177,8 @@ LegalizerHelper::LegalizeResult LegalizerHelper::narrowScalar(MachineInstr &MI,
|
||||
|
||||
MIRBuilder.buildConstant(Offset, i * NarrowSize / 8);
|
||||
MIRBuilder.buildGEP(SrcReg, MI.getOperand(1).getReg(), Offset);
|
||||
// TODO: This is conservatively correct, but we probably want to split the
|
||||
// memory operands in the future.
|
||||
MIRBuilder.buildLoad(DstReg, SrcReg, **MI.memoperands_begin());
|
||||
|
||||
DstRegs.push_back(DstReg);
|
||||
@ -202,6 +204,8 @@ LegalizerHelper::LegalizeResult LegalizerHelper::narrowScalar(MachineInstr &MI,
|
||||
unsigned Offset = MRI.createGenericVirtualRegister(LLT::scalar(64));
|
||||
MIRBuilder.buildConstant(Offset, i * NarrowSize / 8);
|
||||
MIRBuilder.buildGEP(DstReg, MI.getOperand(1).getReg(), Offset);
|
||||
// TODO: This is conservatively correct, but we probably want to split the
|
||||
// memory operands in the future.
|
||||
MIRBuilder.buildStore(SrcRegs[i], DstReg, **MI.memoperands_begin());
|
||||
}
|
||||
MI.eraseFromParent();
|
||||
|
Loading…
Reference in New Issue
Block a user