[llvm] 319e775 - [ARM] Verify addressing immediates
David Green via llvm-commits
llvm-commits at lists.llvm.org
Sat Jan 1 12:08:49 PST 2022
Author: David Green
Date: 2022-01-01T20:08:45Z
New Revision: 319e77592f02ae479d92d47c691343e8aabfb714
URL: https://github.com/llvm/llvm-project/commit/319e77592f02ae479d92d47c691343e8aabfb714
DIFF: https://github.com/llvm/llvm-project/commit/319e77592f02ae479d92d47c691343e8aabfb714.diff
LOG: [ARM] Verify addressing immediates
This adds at extra check into ARMBaseInstrInfo::verifyInstruction to
verify the offsets used in addressing mode immediates using
isLegalAddressImm. Some tests needed fixing up as a result, adjusting
the opcode created from CMSE stack adjustments.
Differential Revision: https://reviews.llvm.org/D114939
Added:
Modified:
llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp
llvm/lib/Target/ARM/ARMExpandPseudoInsts.cpp
Removed:
################################################################################
diff --git a/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp b/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp
index 884f38ff6c588..cde7158803765 100644
--- a/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp
+++ b/llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp
@@ -4868,6 +4868,36 @@ bool ARMBaseInstrInfo::verifyInstruction(const MachineInstr &MI,
return false;
}
}
+
+ // Check the address model by taking the first Imm operand and checking it is
+ // legal for that addressing mode.
+ ARMII::AddrMode AddrMode =
+ (ARMII::AddrMode)(MI.getDesc().TSFlags & ARMII::AddrModeMask);
+ switch (AddrMode) {
+ default:
+ break;
+ case ARMII::AddrModeT2_i7:
+ case ARMII::AddrModeT2_i7s2:
+ case ARMII::AddrModeT2_i7s4:
+ case ARMII::AddrModeT2_i8:
+ case ARMII::AddrModeT2_i8pos:
+ case ARMII::AddrModeT2_i8neg:
+ case ARMII::AddrModeT2_i8s4:
+ case ARMII::AddrModeT2_i12: {
+ uint32_t Imm = 0;
+ for (auto Op : MI.operands()) {
+ if (Op.isImm()) {
+ Imm = Op.getImm();
+ break;
+ }
+ }
+ if (!isLegalAddressImm(MI.getOpcode(), Imm, this)) {
+ ErrInfo = "Incorrect AddrMode Imm for instruction";
+ return false;
+ }
+ break;
+ }
+ }
return true;
}
diff --git a/llvm/lib/Target/ARM/ARMExpandPseudoInsts.cpp b/llvm/lib/Target/ARM/ARMExpandPseudoInsts.cpp
index fa244786a80df..663eceae6ee76 100644
--- a/llvm/lib/Target/ARM/ARMExpandPseudoInsts.cpp
+++ b/llvm/lib/Target/ARM/ARMExpandPseudoInsts.cpp
@@ -1451,9 +1451,9 @@ void ARMExpandPseudo::CMSESaveClearFPRegsV8(
// restore FPSCR from stack and clear bits 0-4, 7, 28-31
// The other bits are program global according to the AAPCS
if (passesFPReg) {
- BuildMI(MBB, MBBI, DL, TII->get(ARM::t2LDRi8), SpareReg)
+ BuildMI(MBB, MBBI, DL, TII->get(ARM::tLDRspi), SpareReg)
.addReg(ARM::SP)
- .addImm(0x40)
+ .addImm(0x10)
.add(predOps(ARMCC::AL));
BuildMI(MBB, MBBI, DL, TII->get(ARM::t2BICri), SpareReg)
.addReg(SpareReg)
More information about the llvm-commits
mailing list