mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-25 20:14:26 +00:00
ARM: support expanding external symbols in 32-bit moves
This enhances the expansion of the mov32imm pseudo-instruction to support an external symbol reference. This is motivated by a simplification of the stack probe emission for Windows on ARM (and fixing a leak). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@207736 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
953f250789
commit
fd2fb48924
@ -705,17 +705,29 @@ void ARMExpandPseudo::ExpandMOV32BitImm(MachineBasicBlock &MBB,
|
||||
.addReg(DstReg, RegState::Define | getDeadRegState(DstIsDead))
|
||||
.addReg(DstReg);
|
||||
|
||||
if (MO.isImm()) {
|
||||
switch (MO.getType()) {
|
||||
case MachineOperand::MO_Immediate: {
|
||||
unsigned Imm = MO.getImm();
|
||||
unsigned Lo16 = Imm & 0xffff;
|
||||
unsigned Hi16 = (Imm >> 16) & 0xffff;
|
||||
LO16 = LO16.addImm(Lo16);
|
||||
HI16 = HI16.addImm(Hi16);
|
||||
} else {
|
||||
break;
|
||||
}
|
||||
case MachineOperand::MO_ExternalSymbol: {
|
||||
const char *ES = MO.getSymbolName();
|
||||
unsigned TF = MO.getTargetFlags();
|
||||
LO16 = LO16.addExternalSymbol(ES, TF | ARMII::MO_LO16);
|
||||
HI16 = HI16.addExternalSymbol(ES, TF | ARMII::MO_HI16);
|
||||
break;
|
||||
}
|
||||
default: {
|
||||
const GlobalValue *GV = MO.getGlobal();
|
||||
unsigned TF = MO.getTargetFlags();
|
||||
LO16 = LO16.addGlobalAddress(GV, MO.getOffset(), TF | ARMII::MO_LO16);
|
||||
HI16 = HI16.addGlobalAddress(GV, MO.getOffset(), TF | ARMII::MO_HI16);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
LO16->setMemRefs(MI.memoperands_begin(), MI.memoperands_end());
|
||||
|
Loading…
x
Reference in New Issue
Block a user