diff options
Diffstat (limited to 'contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp')
-rw-r--r-- | contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp | 46 |
1 files changed, 27 insertions, 19 deletions
diff --git a/contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp b/contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp index f042baf..84af4b1 100644 --- a/contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp +++ b/contrib/llvm/lib/Target/Hexagon/HexagonBranchRelaxation.cpp @@ -12,15 +12,23 @@ #include "Hexagon.h" #include "HexagonInstrInfo.h" #include "HexagonSubtarget.h" -#include "HexagonTargetMachine.h" #include "llvm/ADT/DenseMap.h" +#include "llvm/ADT/SmallVector.h" +#include "llvm/ADT/StringRef.h" +#include "llvm/CodeGen/MachineBasicBlock.h" #include "llvm/CodeGen/MachineFunction.h" #include "llvm/CodeGen/MachineFunctionPass.h" +#include "llvm/CodeGen/MachineInstr.h" +#include "llvm/CodeGen/MachineOperand.h" #include "llvm/CodeGen/Passes.h" -#include "llvm/PassSupport.h" +#include "llvm/Pass.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/Debug.h" #include "llvm/Support/raw_ostream.h" +#include <cassert> +#include <cstdint> +#include <cstdlib> +#include <iterator> using namespace llvm; @@ -30,21 +38,25 @@ static cl::opt<uint32_t> BranchRelaxSafetyBuffer("branch-relax-safety-buffer", cl::init(200), cl::Hidden, cl::ZeroOrMore, cl::desc("safety buffer size")); namespace llvm { + FunctionPass *createHexagonBranchRelaxation(); void initializeHexagonBranchRelaxationPass(PassRegistry&); -} + +} // end namespace llvm namespace { + struct HexagonBranchRelaxation : public MachineFunctionPass { public: static char ID; + HexagonBranchRelaxation() : MachineFunctionPass(ID) { initializeHexagonBranchRelaxationPass(*PassRegistry::getPassRegistry()); } bool runOnMachineFunction(MachineFunction &MF) override; - const char *getPassName() const override { + StringRef getPassName() const override { return "Hexagon Branch Relaxation"; } @@ -67,6 +79,7 @@ namespace { }; char HexagonBranchRelaxation::ID = 0; + } // end anonymous namespace INITIALIZE_PASS(HexagonBranchRelaxation, "hexagon-brelax", @@ -76,7 +89,6 @@ FunctionPass *llvm::createHexagonBranchRelaxation() { return new HexagonBranchRelaxation(); } - bool HexagonBranchRelaxation::runOnMachineFunction(MachineFunction &MF) { DEBUG(dbgs() << "****** Hexagon Branch Relaxation ******\n"); @@ -89,7 +101,6 @@ bool HexagonBranchRelaxation::runOnMachineFunction(MachineFunction &MF) { return Changed; } - void HexagonBranchRelaxation::computeOffset(MachineFunction &MF, DenseMap<MachineBasicBlock*, unsigned> &OffsetMap) { // offset of the current instruction from the start. @@ -104,11 +115,10 @@ void HexagonBranchRelaxation::computeOffset(MachineFunction &MF, } OffsetMap[&B] = InstOffset; for (auto &MI : B.instrs()) - InstOffset += HII->getSize(&MI); + InstOffset += HII->getSize(MI); } } - /// relaxBranches - For Hexagon, if the jump target/loop label is too far from /// the jump/loop instruction then, we need to make sure that we have constant /// extenders set for jumps and loops. @@ -124,7 +134,6 @@ bool HexagonBranchRelaxation::relaxBranches(MachineFunction &MF) { return reGenerateBranch(MF, BlockToInstOffset); } - /// Check if a given instruction is: /// - a jump to a distant target /// - that exceeds its immediate range @@ -144,7 +153,7 @@ bool HexagonBranchRelaxation::isJumpOutOfRange(MachineInstr &MI, // Number of instructions times typical instruction size. InstOffset += HII->nonDbgBBSize(&B) * HEXAGON_INSTR_SIZE; - MachineBasicBlock *TBB = NULL, *FBB = NULL; + MachineBasicBlock *TBB = nullptr, *FBB = nullptr; SmallVector<MachineOperand, 4> Cond; // Try to analyze this branch. @@ -152,13 +161,13 @@ bool HexagonBranchRelaxation::isJumpOutOfRange(MachineInstr &MI, // Could not analyze it. See if this is something we can recognize. // If it is a NVJ, it should always have its target in // a fixed location. - if (HII->isNewValueJump(&*FirstTerm)) - TBB = FirstTerm->getOperand(HII->getCExtOpNum(&*FirstTerm)).getMBB(); + if (HII->isNewValueJump(*FirstTerm)) + TBB = FirstTerm->getOperand(HII->getCExtOpNum(*FirstTerm)).getMBB(); } if (TBB && &MI == &*FirstTerm) { Distance = std::abs((long long)InstOffset - BlockToInstOffset[TBB]) + BranchRelaxSafetyBuffer; - return !HII->isJumpWithinBranchRange(&*FirstTerm, Distance); + return !HII->isJumpWithinBranchRange(*FirstTerm, Distance); } if (FBB) { // Look for second terminator. @@ -171,12 +180,11 @@ bool HexagonBranchRelaxation::isJumpOutOfRange(MachineInstr &MI, // Analyze the second branch in the BB. Distance = std::abs((long long)InstOffset - BlockToInstOffset[FBB]) + BranchRelaxSafetyBuffer; - return !HII->isJumpWithinBranchRange(&*SecondTerm, Distance); + return !HII->isJumpWithinBranchRange(*SecondTerm, Distance); } return false; } - bool HexagonBranchRelaxation::reGenerateBranch(MachineFunction &MF, DenseMap<MachineBasicBlock*, unsigned> &BlockToInstOffset) { bool Changed = false; @@ -186,16 +194,16 @@ bool HexagonBranchRelaxation::reGenerateBranch(MachineFunction &MF, if (!MI.isBranch() || !isJumpOutOfRange(MI, BlockToInstOffset)) continue; DEBUG(dbgs() << "Long distance jump. isExtendable(" - << HII->isExtendable(&MI) << ") isConstExtended(" - << HII->isConstExtended(&MI) << ") " << MI); + << HII->isExtendable(MI) << ") isConstExtended(" + << HII->isConstExtended(MI) << ") " << MI); // Since we have not merged HW loops relaxation into // this code (yet), soften our approach for the moment. - if (!HII->isExtendable(&MI) && !HII->isExtended(&MI)) { + if (!HII->isExtendable(MI) && !HII->isExtended(MI)) { DEBUG(dbgs() << "\tUnderimplemented relax branch instruction.\n"); } else { // Find which operand is expandable. - int ExtOpNum = HII->getCExtOpNum(&MI); + int ExtOpNum = HII->getCExtOpNum(MI); MachineOperand &MO = MI.getOperand(ExtOpNum); // This need to be something we understand. So far we assume all // branches have only MBB address as expandable field. |