mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-08-05 13:26:55 +00:00
Remove redundant Thumb2 ADD/SUB SP instruction definitions.
Unlike Thumb1, Thumb2 does not have dedicated encodings for adjusting the stack pointer. It can just use the normal add-register-immediate encoding since it can use all registers as a source, not just R0-R7. The extra instruction definitions are just duplicates of the normal instructions with the (not well enforced) constraint that the source register was SP. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@134114 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -251,7 +251,7 @@ void llvm::emitT2RegPlusImmediate(MachineBasicBlock &MBB,
|
||||
}
|
||||
|
||||
// sub rd, sp, so_imm
|
||||
Opc = isSub ? ARM::t2SUBrSPi : ARM::t2ADDrSPi;
|
||||
Opc = isSub ? ARM::t2SUBri : ARM::t2ADDri;
|
||||
if (ARM_AM::getT2SOImmVal(NumBytes) != -1) {
|
||||
NumBytes = 0;
|
||||
} else {
|
||||
@@ -425,9 +425,9 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
if (Offset < 0) {
|
||||
Offset = -Offset;
|
||||
isSub = true;
|
||||
MI.setDesc(TII.get(isSP ? ARM::t2SUBrSPi : ARM::t2SUBri));
|
||||
MI.setDesc(TII.get(ARM::t2SUBri));
|
||||
} else {
|
||||
MI.setDesc(TII.get(isSP ? ARM::t2ADDrSPi : ARM::t2ADDri));
|
||||
MI.setDesc(TII.get(ARM::t2ADDri));
|
||||
}
|
||||
|
||||
// Common case: small offset, fits into instruction.
|
||||
@@ -443,9 +443,7 @@ bool llvm::rewriteT2FrameIndex(MachineInstr &MI, unsigned FrameRegIdx,
|
||||
// Another common case: imm12.
|
||||
if (Offset < 4096 &&
|
||||
(!HasCCOut || MI.getOperand(MI.getNumOperands()-1).getReg() == 0)) {
|
||||
unsigned NewOpc = isSP
|
||||
? (isSub ? ARM::t2SUBrSPi12 : ARM::t2ADDrSPi12)
|
||||
: (isSub ? ARM::t2SUBri12 : ARM::t2ADDri12);
|
||||
unsigned NewOpc = isSub ? ARM::t2SUBri12 : ARM::t2ADDri12;
|
||||
MI.setDesc(TII.get(NewOpc));
|
||||
MI.getOperand(FrameRegIdx).ChangeToRegister(FrameReg, false);
|
||||
MI.getOperand(FrameRegIdx+1).ChangeToImmediate(Offset);
|
||||
|
Reference in New Issue
Block a user