Index: llvm/lib/Target/ARM/ARMBaseInstrInfo.h =================================================================== --- llvm/lib/Target/ARM/ARMBaseInstrInfo.h +++ llvm/lib/Target/ARM/ARMBaseInstrInfo.h @@ -180,8 +180,6 @@ static bool isCPSRDefined(const MachineInstr &MI); bool isAddrMode3OpMinusReg(const MachineInstr &MI, unsigned Op) const; - // Load, scaled register offset - bool isLdstScaledReg(const MachineInstr &MI, unsigned Op) const; // Load, scaled register offset, not plus LSL2 bool isLdstScaledRegNotPlusLsl2(const MachineInstr &MI, unsigned Op) const; // Minus reg for ldstso addr mode Index: llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp =================================================================== --- llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp +++ llvm/lib/Target/ARM/ARMBaseInstrInfo.cpp @@ -626,13 +626,6 @@ return (isSub && Offset.getReg() != 0); } -bool ARMBaseInstrInfo::isLdstScaledReg(const MachineInstr &MI, - unsigned Op) const { - const MachineOperand &Opc = MI.getOperand(Op + 2); - unsigned OffImm = Opc.getImm(); - return ARM_AM::getAM2ShiftOpc(OffImm) != ARM_AM::no_shift; -} - // Load, scaled register offset, not plus LSL2 bool ARMBaseInstrInfo::isLdstScaledRegNotPlusLsl2(const MachineInstr &MI, unsigned Op) const { Index: llvm/lib/Target/ARM/ARMSchedule.td =================================================================== --- llvm/lib/Target/ARM/ARMSchedule.td +++ llvm/lib/Target/ARM/ARMSchedule.td @@ -164,6 +164,10 @@ def IsCPSRDefinedPred : MCSchedPredicate; +let FunctionMapper = "ARM_AM::getAM2ShiftOpc" in { + def CheckExtNoShift : CheckImmOperand_s<4, "ARM_AM::no_shift">; +} + //===----------------------------------------------------------------------===// // Instruction Itinerary classes used for ARM // Index: llvm/lib/Target/ARM/ARMScheduleA57.td =================================================================== --- llvm/lib/Target/ARM/ARMScheduleA57.td +++ llvm/lib/Target/ARM/ARMScheduleA57.td @@ -49,11 +49,7 @@ def IsLdstsoScaledNotOptimalPredX2 : SchedPredicate<[{TII->isLdstScaledRegNotPlusLsl2(*MI, 2)}]>; -// Load, scaled register offset -def IsLdstsoScaledPred : - SchedPredicate<[{TII->isLdstScaledReg(*MI, 1)}]>; -def IsLdstsoScaledPredX2 : - SchedPredicate<[{TII->isLdstScaledReg(*MI, 2)}]>; +def IsLdstsoScaledPredX2 : MCSchedPredicate>; def IsLdstsoMinusRegPredX0 : SchedPredicate<[{TII->isLdstSoMinusReg(*MI, 0)}]>; Index: llvm/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp =================================================================== --- llvm/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp +++ llvm/lib/Target/ARM/MCTargetDesc/ARMMCTargetDesc.cpp @@ -11,6 +11,7 @@ //===----------------------------------------------------------------------===// #include "ARMMCTargetDesc.h" +#include "ARMAddressingModes.h" #include "ARMBaseInfo.h" #include "ARMInstPrinter.h" #include "ARMMCAsmInfo.h" Index: llvm/test/tools/llvm-mca/ARM/cortex-a57-memory-instructions.s =================================================================== --- llvm/test/tools/llvm-mca/ARM/cortex-a57-memory-instructions.s +++ llvm/test/tools/llvm-mca/ARM/cortex-a57-memory-instructions.s @@ -237,7 +237,7 @@ # CHECK-NEXT: 1 1 1.00 * str r9, [r6, r3] # CHECK-NEXT: 1 1 1.00 * str r8, [r0, -r2] # CHECK-NEXT: 2 1 1.00 * str r7, [r1, r6]! -# CHECK-NEXT: 2 1 1.00 * str r7, [r1, r6, lsl #2]! +# CHECK-NEXT: 2 2 1.00 * str r7, [r1, r6, lsl #2]! # CHECK-NEXT: 2 1 1.00 * str r6, [sp, -r1]! # CHECK-NEXT: 2 2 1.00 * str r5, [r3], r9 # CHECK-NEXT: 2 2 1.00 * str r4, [r2], -r5 @@ -297,7 +297,7 @@ # CHECK: Resource pressure per iteration: # CHECK-NEXT: [0] [1.0] [1.1] [2] [3] [4] [5] [6] -# CHECK-NEXT: - 44.50 44.50 92.00 8.00 55.00 - - +# CHECK-NEXT: - 44.00 44.00 92.00 9.00 55.00 - - # CHECK: Resource pressure by instruction: # CHECK-NEXT: [0] [1.0] [1.1] [2] [3] [4] [5] [6] Instructions: @@ -390,7 +390,7 @@ # CHECK-NEXT: - - - - - 1.00 - - str r9, [r6, r3] # CHECK-NEXT: - - - - - 1.00 - - str r8, [r0, -r2] # CHECK-NEXT: - 0.50 0.50 - - 1.00 - - str r7, [r1, r6]! -# CHECK-NEXT: - 0.50 0.50 - - 1.00 - - str r7, [r1, r6, lsl #2]! +# CHECK-NEXT: - - - - 1.00 1.00 - - str r7, [r1, r6, lsl #2]! # CHECK-NEXT: - 0.50 0.50 - - 1.00 - - str r6, [sp, -r1]! # CHECK-NEXT: - - - - 1.00 1.00 - - str r5, [r3], r9 # CHECK-NEXT: - - - - 1.00 1.00 - - str r4, [r2], -r5