003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/lib/Target/Hexagon
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
lib
/
Target
/
Hexagon
/
📁
..
📁
AsmParser
📄
BitTracker.cpp
(35.36 KB)
📄
BitTracker.h
(17.25 KB)
📁
Disassembler
📄
Hexagon.h
(1004 B)
📄
Hexagon.td
(17.33 KB)
📄
HexagonArch.h
(1.2 KB)
📄
HexagonAsmPrinter.cpp
(26.65 KB)
📄
HexagonAsmPrinter.h
(2.03 KB)
📄
HexagonBitSimplify.cpp
(107.45 KB)
📄
HexagonBitTracker.cpp
(39.88 KB)
📄
HexagonBitTracker.h
(2.5 KB)
📄
HexagonBlockRanges.cpp
(15.85 KB)
📄
HexagonBlockRanges.h
(6.97 KB)
📄
HexagonBranchRelaxation.cpp
(7.78 KB)
📄
HexagonCFGOptimizer.cpp
(8.4 KB)
📄
HexagonCallingConv.td
(4.46 KB)
📄
HexagonCommonGEP.cpp
(41.47 KB)
📄
HexagonConstExtenders.cpp
(70.64 KB)
📄
HexagonConstPropagation.cpp
(97.75 KB)
📄
HexagonCopyToCombine.cpp
(32.2 KB)
📄
HexagonDepArch.h
(2.04 KB)
📄
HexagonDepArch.td
(1.87 KB)
📄
HexagonDepDecoders.inc
(2.55 KB)
📄
HexagonDepIICHVX.td
(113.05 KB)
📄
HexagonDepIICScalar.td
(224.12 KB)
📄
HexagonDepITypes.h
(1.51 KB)
📄
HexagonDepITypes.td
(1.91 KB)
📄
HexagonDepInstrFormats.td
(91.89 KB)
📄
HexagonDepInstrInfo.td
(1021.44 KB)
📄
HexagonDepMapAsm2Intrin.td
(255.17 KB)
📄
HexagonDepMappings.td
(64.27 KB)
📄
HexagonDepMask.h
(51.94 KB)
📄
HexagonDepOperands.td
(12.12 KB)
📄
HexagonDepTimingClasses.h
(4.69 KB)
📄
HexagonEarlyIfConv.cpp
(37.36 KB)
📄
HexagonExpandCondsets.cpp
(48.55 KB)
📄
HexagonFixupHwLoops.cpp
(6.54 KB)
📄
HexagonFrameLowering.cpp
(97.16 KB)
📄
HexagonFrameLowering.h
(7.85 KB)
📄
HexagonGenExtract.cpp
(8.61 KB)
📄
HexagonGenInsert.cpp
(53.24 KB)
📄
HexagonGenMux.cpp
(12.71 KB)
📄
HexagonGenPredicate.cpp
(16.25 KB)
📄
HexagonHardwareLoops.cpp
(70.32 KB)
📄
HexagonHazardRecognizer.cpp
(5.85 KB)
📄
HexagonHazardRecognizer.h
(3.58 KB)
📄
HexagonIICHVX.td
(1.21 KB)
📄
HexagonIICScalar.td
(1.34 KB)
📄
HexagonISelDAGToDAG.cpp
(78.63 KB)
📄
HexagonISelDAGToDAG.h
(5.88 KB)
📄
HexagonISelDAGToDAGHVX.cpp
(68.26 KB)
📄
HexagonISelLowering.cpp
(134.65 KB)
📄
HexagonISelLowering.h
(22.5 KB)
📄
HexagonISelLoweringHVX.cpp
(70.57 KB)
📄
HexagonInstrFormats.td
(12.04 KB)
📄
HexagonInstrFormatsV60.td
(1.03 KB)
📄
HexagonInstrFormatsV65.td
(1.54 KB)
📄
HexagonInstrInfo.cpp
(161.08 KB)
📄
HexagonInstrInfo.h
(25.31 KB)
📄
HexagonIntrinsics.td
(19.21 KB)
📄
HexagonIntrinsicsV5.td
(16.8 KB)
📄
HexagonIntrinsicsV60.td
(28.9 KB)
📄
HexagonLoopIdiomRecognition.cpp
(79.16 KB)
📄
HexagonMCInstLower.cpp
(6.25 KB)
📄
HexagonMachineFunctionInfo.cpp
(507 B)
📄
HexagonMachineFunctionInfo.h
(3.32 KB)
📄
HexagonMachineScheduler.cpp
(34.25 KB)
📄
HexagonMachineScheduler.h
(8.66 KB)
📄
HexagonMapAsm2IntrinV62.gen.td
(8.71 KB)
📄
HexagonMapAsm2IntrinV65.gen.td
(12.43 KB)
📄
HexagonNewValueJump.cpp
(25.57 KB)
📄
HexagonOperands.td
(1.62 KB)
📄
HexagonOptAddrMode.cpp
(29.37 KB)
📄
HexagonOptimizeSZextends.cpp
(4.74 KB)
📄
HexagonPatterns.td
(142.35 KB)
📄
HexagonPatternsHVX.td
(22.06 KB)
📄
HexagonPatternsV65.td
(2.96 KB)
📄
HexagonPeephole.cpp
(10.18 KB)
📄
HexagonPseudo.td
(21.62 KB)
📄
HexagonRDFOpt.cpp
(9.94 KB)
📄
HexagonRegisterInfo.cpp
(12.03 KB)
📄
HexagonRegisterInfo.h
(2.88 KB)
📄
HexagonRegisterInfo.td
(20.42 KB)
📄
HexagonSchedule.td
(2.33 KB)
📄
HexagonScheduleV5.td
(1.73 KB)
📄
HexagonScheduleV55.td
(1.81 KB)
📄
HexagonScheduleV60.td
(4.31 KB)
📄
HexagonScheduleV62.td
(1.53 KB)
📄
HexagonScheduleV65.td
(1.57 KB)
📄
HexagonScheduleV66.td
(1.57 KB)
📄
HexagonScheduleV67.td
(1.57 KB)
📄
HexagonScheduleV67T.td
(2.51 KB)
📄
HexagonSelectionDAGInfo.cpp
(2.35 KB)
📄
HexagonSelectionDAGInfo.h
(1.24 KB)
📄
HexagonSplitConst32AndConst64.cpp
(4.15 KB)
📄
HexagonSplitDouble.cpp
(37.86 KB)
📄
HexagonStoreWidening.cpp
(20.47 KB)
📄
HexagonSubtarget.cpp
(20.97 KB)
📄
HexagonSubtarget.h
(10.59 KB)
📄
HexagonTargetMachine.cpp
(16 KB)
📄
HexagonTargetMachine.h
(1.77 KB)
📄
HexagonTargetObjectFile.cpp
(16.8 KB)
📄
HexagonTargetObjectFile.h
(2.17 KB)
📄
HexagonTargetStreamer.h
(1.2 KB)
📄
HexagonTargetTransformInfo.cpp
(13.11 KB)
📄
HexagonTargetTransformInfo.h
(6.27 KB)
📄
HexagonVExtract.cpp
(6.64 KB)
📄
HexagonVLIWPacketizer.cpp
(67.01 KB)
📄
HexagonVLIWPacketizer.h
(6.09 KB)
📄
HexagonVectorLoopCarriedReuse.cpp
(23.99 KB)
📄
HexagonVectorPrint.cpp
(7.06 KB)
📁
MCTargetDesc
📄
RDFCopy.cpp
(6.37 KB)
📄
RDFCopy.h
(1.69 KB)
📄
RDFDeadCode.cpp
(7.5 KB)
📄
RDFDeadCode.h
(2.33 KB)
📁
TargetInfo
Editing: HexagonRDFOpt.cpp
//===- HexagonRDFOpt.cpp --------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "HexagonInstrInfo.h" #include "HexagonSubtarget.h" #include "MCTargetDesc/HexagonBaseInfo.h" #include "RDFCopy.h" #include "RDFDeadCode.h" #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/SetVector.h" #include "llvm/CodeGen/MachineDominanceFrontier.h" #include "llvm/CodeGen/MachineDominators.h" #include "llvm/CodeGen/MachineFunction.h" #include "llvm/CodeGen/MachineFunctionPass.h" #include "llvm/CodeGen/MachineInstr.h" #include "llvm/CodeGen/MachineOperand.h" #include "llvm/CodeGen/MachineRegisterInfo.h" #include "llvm/CodeGen/RDFGraph.h" #include "llvm/CodeGen/RDFLiveness.h" #include "llvm/CodeGen/RDFRegisters.h" #include "llvm/InitializePasses.h" #include "llvm/Pass.h" #include "llvm/Support/CommandLine.h" #include "llvm/Support/Compiler.h" #include "llvm/Support/Debug.h" #include "llvm/Support/ErrorHandling.h" #include "llvm/Support/raw_ostream.h" #include <cassert> #include <limits> #include <utility> using namespace llvm; using namespace rdf; namespace llvm { void initializeHexagonRDFOptPass(PassRegistry&); FunctionPass *createHexagonRDFOpt(); } // end namespace llvm static unsigned RDFCount = 0; static cl::opt<unsigned> RDFLimit("rdf-limit", cl::init(std::numeric_limits<unsigned>::max())); static cl::opt<bool> RDFDump("rdf-dump", cl::init(false)); namespace { class HexagonRDFOpt : public MachineFunctionPass { public: HexagonRDFOpt() : MachineFunctionPass(ID) {} void getAnalysisUsage(AnalysisUsage &AU) const override { AU.addRequired<MachineDominatorTree>(); AU.addRequired<MachineDominanceFrontier>(); AU.setPreservesAll(); MachineFunctionPass::getAnalysisUsage(AU); } StringRef getPassName() const override { return "Hexagon RDF optimizations"; } bool runOnMachineFunction(MachineFunction &MF) override; MachineFunctionProperties getRequiredProperties() const override { return MachineFunctionProperties().set( MachineFunctionProperties::Property::NoVRegs); } static char ID; private: MachineDominatorTree *MDT; MachineRegisterInfo *MRI; }; struct HexagonCP : public CopyPropagation { HexagonCP(DataFlowGraph &G) : CopyPropagation(G) {} bool interpretAsCopy(const MachineInstr *MI, EqualityMap &EM) override; }; struct HexagonDCE : public DeadCodeElimination { HexagonDCE(DataFlowGraph &G, MachineRegisterInfo &MRI) : DeadCodeElimination(G, MRI) {} bool rewrite(NodeAddr<InstrNode*> IA, SetVector<NodeId> &Remove); void removeOperand(NodeAddr<InstrNode*> IA, unsigned OpNum); bool run(); }; } // end anonymous namespace char HexagonRDFOpt::ID = 0; INITIALIZE_PASS_BEGIN(HexagonRDFOpt, "hexagon-rdf-opt", "Hexagon RDF optimizations", false, false) INITIALIZE_PASS_DEPENDENCY(MachineDominatorTree) INITIALIZE_PASS_DEPENDENCY(MachineDominanceFrontier) INITIALIZE_PASS_END(HexagonRDFOpt, "hexagon-rdf-opt", "Hexagon RDF optimizations", false, false) bool HexagonCP::interpretAsCopy(const MachineInstr *MI, EqualityMap &EM) { auto mapRegs = [&EM] (RegisterRef DstR, RegisterRef SrcR) -> void { EM.insert(std::make_pair(DstR, SrcR)); }; DataFlowGraph &DFG = getDFG(); unsigned Opc = MI->getOpcode(); switch (Opc) { case Hexagon::A2_combinew: { const MachineOperand &DstOp = MI->getOperand(0); const MachineOperand &HiOp = MI->getOperand(1); const MachineOperand &LoOp = MI->getOperand(2); assert(DstOp.getSubReg() == 0 && "Unexpected subregister"); mapRegs(DFG.makeRegRef(DstOp.getReg(), Hexagon::isub_hi), DFG.makeRegRef(HiOp.getReg(), HiOp.getSubReg())); mapRegs(DFG.makeRegRef(DstOp.getReg(), Hexagon::isub_lo), DFG.makeRegRef(LoOp.getReg(), LoOp.getSubReg())); return true; } case Hexagon::A2_addi: { const MachineOperand &A = MI->getOperand(2); if (!A.isImm() || A.getImm() != 0) return false; LLVM_FALLTHROUGH; } case Hexagon::A2_tfr: { const MachineOperand &DstOp = MI->getOperand(0); const MachineOperand &SrcOp = MI->getOperand(1); mapRegs(DFG.makeRegRef(DstOp.getReg(), DstOp.getSubReg()), DFG.makeRegRef(SrcOp.getReg(), SrcOp.getSubReg())); return true; } } return CopyPropagation::interpretAsCopy(MI, EM); } bool HexagonDCE::run() { bool Collected = collect(); if (!Collected) return false; const SetVector<NodeId> &DeadNodes = getDeadNodes(); const SetVector<NodeId> &DeadInstrs = getDeadInstrs(); using RefToInstrMap = DenseMap<NodeId, NodeId>; RefToInstrMap R2I; SetVector<NodeId> PartlyDead; DataFlowGraph &DFG = getDFG(); for (NodeAddr<BlockNode*> BA : DFG.getFunc().Addr->members(DFG)) { for (auto TA : BA.Addr->members_if(DFG.IsCode<NodeAttrs::Stmt>, DFG)) { NodeAddr<StmtNode*> SA = TA; for (NodeAddr<RefNode*> RA : SA.Addr->members(DFG)) { R2I.insert(std::make_pair(RA.Id, SA.Id)); if (DFG.IsDef(RA) && DeadNodes.count(RA.Id)) if (!DeadInstrs.count(SA.Id)) PartlyDead.insert(SA.Id); } } } // Nodes to remove. SetVector<NodeId> Remove = DeadInstrs; bool Changed = false; for (NodeId N : PartlyDead) { auto SA = DFG.addr<StmtNode*>(N); if (trace()) dbgs() << "Partly dead: " << *SA.Addr->getCode(); Changed |= rewrite(SA, Remove); } return erase(Remove) || Changed; } void HexagonDCE::removeOperand(NodeAddr<InstrNode*> IA, unsigned OpNum) { MachineInstr *MI = NodeAddr<StmtNode*>(IA).Addr->getCode(); auto getOpNum = [MI] (MachineOperand &Op) -> unsigned { for (unsigned i = 0, n = MI->getNumOperands(); i != n; ++i) if (&MI->getOperand(i) == &Op) return i; llvm_unreachable("Invalid operand"); }; DenseMap<NodeId,unsigned> OpMap; DataFlowGraph &DFG = getDFG(); NodeList Refs = IA.Addr->members(DFG); for (NodeAddr<RefNode*> RA : Refs) OpMap.insert(std::make_pair(RA.Id, getOpNum(RA.Addr->getOp()))); MI->RemoveOperand(OpNum); for (NodeAddr<RefNode*> RA : Refs) { unsigned N = OpMap[RA.Id]; if (N < OpNum) RA.Addr->setRegRef(&MI->getOperand(N), DFG); else if (N > OpNum) RA.Addr->setRegRef(&MI->getOperand(N-1), DFG); } } bool HexagonDCE::rewrite(NodeAddr<InstrNode*> IA, SetVector<NodeId> &Remove) { if (!getDFG().IsCode<NodeAttrs::Stmt>(IA)) return false; DataFlowGraph &DFG = getDFG(); MachineInstr &MI = *NodeAddr<StmtNode*>(IA).Addr->getCode(); auto &HII = static_cast<const HexagonInstrInfo&>(DFG.getTII()); if (HII.getAddrMode(MI) != HexagonII::PostInc) return false; unsigned Opc = MI.getOpcode(); unsigned OpNum, NewOpc; switch (Opc) { case Hexagon::L2_loadri_pi: NewOpc = Hexagon::L2_loadri_io; OpNum = 1; break; case Hexagon::L2_loadrd_pi: NewOpc = Hexagon::L2_loadrd_io; OpNum = 1; break; case Hexagon::V6_vL32b_pi: NewOpc = Hexagon::V6_vL32b_ai; OpNum = 1; break; case Hexagon::S2_storeri_pi: NewOpc = Hexagon::S2_storeri_io; OpNum = 0; break; case Hexagon::S2_storerd_pi: NewOpc = Hexagon::S2_storerd_io; OpNum = 0; break; case Hexagon::V6_vS32b_pi: NewOpc = Hexagon::V6_vS32b_ai; OpNum = 0; break; default: return false; } auto IsDead = [this] (NodeAddr<DefNode*> DA) -> bool { return getDeadNodes().count(DA.Id); }; NodeList Defs; MachineOperand &Op = MI.getOperand(OpNum); for (NodeAddr<DefNode*> DA : IA.Addr->members_if(DFG.IsDef, DFG)) { if (&DA.Addr->getOp() != &Op) continue; Defs = DFG.getRelatedRefs(IA, DA); if (!llvm::all_of(Defs, IsDead)) return false; break; } // Mark all nodes in Defs for removal. for (auto D : Defs) Remove.insert(D.Id); if (trace()) dbgs() << "Rewriting: " << MI; MI.setDesc(HII.get(NewOpc)); MI.getOperand(OpNum+2).setImm(0); removeOperand(IA, OpNum); if (trace()) dbgs() << " to: " << MI; return true; } bool HexagonRDFOpt::runOnMachineFunction(MachineFunction &MF) { if (skipFunction(MF.getFunction())) return false; if (RDFLimit.getPosition()) { if (RDFCount >= RDFLimit) return false; RDFCount++; } MDT = &getAnalysis<MachineDominatorTree>(); const auto &MDF = getAnalysis<MachineDominanceFrontier>(); const auto &HII = *MF.getSubtarget<HexagonSubtarget>().getInstrInfo(); const auto &HRI = *MF.getSubtarget<HexagonSubtarget>().getRegisterInfo(); MRI = &MF.getRegInfo(); bool Changed; if (RDFDump) MF.print(dbgs() << "Before " << getPassName() << "\n", nullptr); TargetOperandInfo TOI(HII); DataFlowGraph G(MF, HII, HRI, *MDT, MDF, TOI); // Dead phi nodes are necessary for copy propagation: we can add a use // of a register in a block where it would need a phi node, but which // was dead (and removed) during the graph build time. G.build(BuildOptions::KeepDeadPhis); if (RDFDump) dbgs() << "Starting copy propagation on: " << MF.getName() << '\n' << PrintNode<FuncNode*>(G.getFunc(), G) << '\n'; HexagonCP CP(G); CP.trace(RDFDump); Changed = CP.run(); if (RDFDump) dbgs() << "Starting dead code elimination on: " << MF.getName() << '\n' << PrintNode<FuncNode*>(G.getFunc(), G) << '\n'; HexagonDCE DCE(G, *MRI); DCE.trace(RDFDump); Changed |= DCE.run(); if (Changed) { if (RDFDump) dbgs() << "Starting liveness recomputation on: " << MF.getName() << '\n'; Liveness LV(*MRI, G); LV.trace(RDFDump); LV.computeLiveIns(); LV.resetLiveIns(); LV.resetKills(); } if (RDFDump) MF.print(dbgs() << "After " << getPassName() << "\n", nullptr); return false; } FunctionPass *llvm::createHexagonRDFOpt() { return new HexagonRDFOpt(); }
Upload File
Create Folder