diff options
| author | Andrew Trick <atrick@apple.com> | 2012-06-29 07:10:41 +0000 |
|---|---|---|
| committer | Andrew Trick <atrick@apple.com> | 2012-06-29 07:10:41 +0000 |
| commit | 3e4b3b9043b1ced24e07d8d1174feeee06c6912e (patch) | |
| tree | f31c2d3c63fc1da8b3b598c433759ae8391e62ed /lib/Target/ARM/ARMBaseInstrInfo.cpp | |
| parent | 94e3b388e561ce980c861e092bf378bf40202268 (diff) | |
Revert "Make NumMicroOps a variable in the subtarget's instruction itinerary."
This reverts commit r159406. I noticed a performance regression so I'll back out for now.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159411 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/ARM/ARMBaseInstrInfo.cpp')
| -rw-r--r-- | lib/Target/ARM/ARMBaseInstrInfo.cpp | 18 |
1 files changed, 9 insertions, 9 deletions
diff --git a/lib/Target/ARM/ARMBaseInstrInfo.cpp b/lib/Target/ARM/ARMBaseInstrInfo.cpp index b3fef29093..3a180dfa27 100644 --- a/lib/Target/ARM/ARMBaseInstrInfo.cpp +++ b/lib/Target/ARM/ARMBaseInstrInfo.cpp @@ -2176,9 +2176,9 @@ ARMBaseInstrInfo::getNumMicroOps(const InstrItineraryData *ItinData, const MCInstrDesc &Desc = MI->getDesc(); unsigned Class = Desc.getSchedClass(); - int ItinUOps = ItinData->Itineraries[Class].NumMicroOps; - if (ItinUOps >= 0) - return ItinUOps; + unsigned UOps = ItinData->Itineraries[Class].NumMicroOps; + if (UOps) + return UOps; unsigned Opc = MI->getOpcode(); switch (Opc) { @@ -2252,19 +2252,19 @@ ARMBaseInstrInfo::getNumMicroOps(const InstrItineraryData *ItinData, return 2; // 4 registers would be issued: 2, 2. // 5 registers would be issued: 2, 2, 1. - int A8UOps = (NumRegs / 2); + UOps = (NumRegs / 2); if (NumRegs % 2) - ++A8UOps; - return A8UOps; + ++UOps; + return UOps; } else if (Subtarget.isCortexA9()) { - int A9UOps = (NumRegs / 2); + UOps = (NumRegs / 2); // If there are odd number of registers or if it's not 64-bit aligned, // then it takes an extra AGU (Address Generation Unit) cycle. if ((NumRegs % 2) || !MI->hasOneMemOperand() || (*MI->memoperands_begin())->getAlignment() < 8) - ++A9UOps; - return A9UOps; + ++UOps; + return UOps; } else { // Assume the worst. return NumRegs; |
