mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-31 16:14:15 +00:00
LI can only take signed values, so values > 32767 can only be loaded with ORI
llvm-svn: 15299
This commit is contained in:
parent
ac63bc04f8
commit
8c293deaad
@ -555,7 +555,13 @@ void ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R+1).addReg(Temp).addImm(Val & 0xFFFF);
|
||||
} else if (Val < (1ULL << 48)) {
|
||||
unsigned Temp = makeAnotherReg(Type::IntTy);
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, R).addSImm((Val >> 32) & 0xFFFF);
|
||||
int HiBits = (Val >> 32) & 0xFFFF;
|
||||
if (HiBits > 32767) {
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, PPC32::R0).addImm(0);
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R).addReg(PPC32::R0).addSImm(HiBits);
|
||||
} else {
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, R).addSImm(HiBits);
|
||||
}
|
||||
BuildMI(*MBB, IP, PPC32::LIS, 1, Temp).addSImm((Val >> 16) & 0xFFFF);
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R+1).addReg(Temp).addImm(Val & 0xFFFF);
|
||||
} else {
|
||||
|
@ -555,7 +555,13 @@ void ISel::copyConstantToRegister(MachineBasicBlock *MBB,
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R+1).addReg(Temp).addImm(Val & 0xFFFF);
|
||||
} else if (Val < (1ULL << 48)) {
|
||||
unsigned Temp = makeAnotherReg(Type::IntTy);
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, R).addSImm((Val >> 32) & 0xFFFF);
|
||||
int HiBits = (Val >> 32) & 0xFFFF;
|
||||
if (HiBits > 32767) {
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, PPC32::R0).addImm(0);
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R).addReg(PPC32::R0).addSImm(HiBits);
|
||||
} else {
|
||||
BuildMI(*MBB, IP, PPC32::LI, 1, R).addSImm(HiBits);
|
||||
}
|
||||
BuildMI(*MBB, IP, PPC32::LIS, 1, Temp).addSImm((Val >> 16) & 0xFFFF);
|
||||
BuildMI(*MBB, IP, PPC32::ORI, 2, R+1).addReg(Temp).addImm(Val & 0xFFFF);
|
||||
} else {
|
||||
|
Loading…
Reference in New Issue
Block a user