003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/utils/TableGen
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
utils
/
TableGen
/
📁
..
📄
AsmMatcherEmitter.cpp
(149.98 KB)
📄
AsmWriterEmitter.cpp
(46.29 KB)
📄
AsmWriterInst.cpp
(7.57 KB)
📄
AsmWriterInst.h
(3.83 KB)
📄
Attributes.cpp
(3.12 KB)
📄
CTagsEmitter.cpp
(2.52 KB)
📄
CallingConvEmitter.cpp
(11.74 KB)
📄
CodeEmitterGen.cpp
(22.5 KB)
📄
CodeGenDAGPatterns.cpp
(168.72 KB)
📄
CodeGenDAGPatterns.h
(47.85 KB)
📄
CodeGenHwModes.cpp
(3.45 KB)
📄
CodeGenHwModes.h
(1.84 KB)
📄
CodeGenInstruction.cpp
(30.97 KB)
📄
CodeGenInstruction.h
(13.7 KB)
📄
CodeGenIntrinsics.h
(6.6 KB)
📄
CodeGenMapTable.cpp
(23.38 KB)
📄
CodeGenRegisters.cpp
(90.68 KB)
📄
CodeGenRegisters.h
(29.9 KB)
📄
CodeGenSchedule.cpp
(84.92 KB)
📄
CodeGenSchedule.h
(23.14 KB)
📄
CodeGenTarget.cpp
(32.63 KB)
📄
CodeGenTarget.h
(7.22 KB)
📄
DAGISelEmitter.cpp
(6.92 KB)
📄
DAGISelMatcher.cpp
(13.53 KB)
📄
DAGISelMatcher.h
(37.72 KB)
📄
DAGISelMatcherEmitter.cpp
(37.44 KB)
📄
DAGISelMatcherGen.cpp
(44.06 KB)
📄
DAGISelMatcherOpt.cpp
(17.35 KB)
📄
DFAEmitter.cpp
(13.11 KB)
📄
DFAEmitter.h
(3.96 KB)
📄
DFAPacketizerEmitter.cpp
(13.02 KB)
📄
DirectiveEmitter.cpp
(20.15 KB)
📄
DisassemblerEmitter.cpp
(7.02 KB)
📄
ExegesisEmitter.cpp
(7.39 KB)
📄
FastISelEmitter.cpp
(30.83 KB)
📄
FixedLenDecoderEmitter.cpp
(90.04 KB)
📄
GICombinerEmitter.cpp
(40.12 KB)
📁
GlobalISel
📄
GlobalISelEmitter.cpp
(215.56 KB)
📄
InfoByHwMode.cpp
(6.69 KB)
📄
InfoByHwMode.h
(5.74 KB)
📄
InstrDocsEmitter.cpp
(7.05 KB)
📄
InstrInfoEmitter.cpp
(31.52 KB)
📄
IntrinsicEmitter.cpp
(32.87 KB)
📄
OptEmitter.cpp
(2.9 KB)
📄
OptEmitter.h
(575 B)
📄
OptParserEmitter.cpp
(15.16 KB)
📄
OptRSTEmitter.cpp
(2.71 KB)
📄
PredicateExpander.cpp
(17.39 KB)
📄
PredicateExpander.h
(5.19 KB)
📄
PseudoLoweringEmitter.cpp
(11.8 KB)
📄
RISCVCompressInstEmitter.cpp
(39.23 KB)
📄
RegisterBankEmitter.cpp
(12.52 KB)
📄
RegisterInfoEmitter.cpp
(61.32 KB)
📄
SDNodeProperties.cpp
(1.9 KB)
📄
SDNodeProperties.h
(985 B)
📄
SearchableTableEmitter.cpp
(26.81 KB)
📄
SequenceToOffsetTable.h
(8.49 KB)
📄
SubtargetEmitter.cpp
(70.77 KB)
📄
SubtargetFeatureInfo.cpp
(5.72 KB)
📄
SubtargetFeatureInfo.h
(4.05 KB)
📄
TableGen.cpp
(9.7 KB)
📄
TableGenBackends.h
(4.62 KB)
📄
Types.cpp
(1.46 KB)
📄
Types.h
(900 B)
📄
WebAssemblyDisassemblerEmitter.cpp
(6.79 KB)
📄
WebAssemblyDisassemblerEmitter.h
(980 B)
📄
X86DisassemblerShared.h
(1.88 KB)
📄
X86DisassemblerTables.cpp
(42.64 KB)
📄
X86DisassemblerTables.h
(11.7 KB)
📄
X86EVEX2VEXTablesEmitter.cpp
(8.77 KB)
📄
X86FoldTablesEmitter.cpp
(26.09 KB)
📄
X86ModRMFilters.cpp
(636 B)
📄
X86ModRMFilters.h
(4.69 KB)
📄
X86RecognizableInstr.cpp
(47.05 KB)
📄
X86RecognizableInstr.h
(14.13 KB)
Editing: ExegesisEmitter.cpp
//===- ExegesisEmitter.cpp - Generate exegesis target data ----------------===// // // 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 // //===----------------------------------------------------------------------===// // // This tablegen backend emits llvm-exegesis information. // //===----------------------------------------------------------------------===// #include "llvm/ADT/STLExtras.h" #include "llvm/ADT/SmallSet.h" #include "llvm/ADT/StringRef.h" #include "llvm/Support/Debug.h" #include "llvm/Support/Format.h" #include "llvm/Support/raw_ostream.h" #include "llvm/TableGen/Error.h" #include "llvm/TableGen/Record.h" #include "llvm/TableGen/TableGenBackend.h" #include <algorithm> #include <cassert> #include <cstdint> #include <map> #include <string> #include <vector> using namespace llvm; #define DEBUG_TYPE "exegesis-emitter" namespace { class ExegesisEmitter { public: ExegesisEmitter(RecordKeeper &RK); void run(raw_ostream &OS) const; private: unsigned getPfmCounterId(llvm::StringRef Name) const { const auto It = PfmCounterNameTable.find(Name); if (It == PfmCounterNameTable.end()) PrintFatalError("no pfm counter id for " + Name); return It->second; } // Collects all the ProcPfmCounters definitions available in this target. void emitPfmCounters(raw_ostream &OS) const; void emitPfmCountersInfo(const Record &Def, unsigned &IssueCountersTableOffset, raw_ostream &OS) const; void emitPfmCountersLookupTable(raw_ostream &OS) const; RecordKeeper &Records; std::string Target; // Table of counter name -> counter index. const std::map<llvm::StringRef, unsigned> PfmCounterNameTable; }; static std::map<llvm::StringRef, unsigned> collectPfmCounters(const RecordKeeper &Records) { std::map<llvm::StringRef, unsigned> PfmCounterNameTable; const auto AddPfmCounterName = [&PfmCounterNameTable]( const Record *PfmCounterDef) { const llvm::StringRef Counter = PfmCounterDef->getValueAsString("Counter"); if (!Counter.empty()) PfmCounterNameTable.emplace(Counter, 0); }; for (Record *Def : Records.getAllDerivedDefinitions("ProcPfmCounters")) { // Check that ResourceNames are unique. llvm::SmallSet<llvm::StringRef, 16> Seen; for (const Record *IssueCounter : Def->getValueAsListOfDefs("IssueCounters")) { const llvm::StringRef ResourceName = IssueCounter->getValueAsString("ResourceName"); if (ResourceName.empty()) PrintFatalError(IssueCounter->getLoc(), "invalid empty ResourceName"); if (!Seen.insert(ResourceName).second) PrintFatalError(IssueCounter->getLoc(), "duplicate ResourceName " + ResourceName); AddPfmCounterName(IssueCounter); } AddPfmCounterName(Def->getValueAsDef("CycleCounter")); AddPfmCounterName(Def->getValueAsDef("UopsCounter")); } unsigned Index = 0; for (auto &NameAndIndex : PfmCounterNameTable) NameAndIndex.second = Index++; return PfmCounterNameTable; } ExegesisEmitter::ExegesisEmitter(RecordKeeper &RK) : Records(RK), PfmCounterNameTable(collectPfmCounters(RK)) { std::vector<Record *> Targets = Records.getAllDerivedDefinitions("Target"); if (Targets.size() == 0) PrintFatalError("ERROR: No 'Target' subclasses defined!"); if (Targets.size() != 1) PrintFatalError("ERROR: Multiple subclasses of Target defined!"); Target = std::string(Targets[0]->getName()); } void ExegesisEmitter::emitPfmCountersInfo(const Record &Def, unsigned &IssueCountersTableOffset, raw_ostream &OS) const { const auto CycleCounter = Def.getValueAsDef("CycleCounter")->getValueAsString("Counter"); const auto UopsCounter = Def.getValueAsDef("UopsCounter")->getValueAsString("Counter"); const size_t NumIssueCounters = Def.getValueAsListOfDefs("IssueCounters").size(); OS << "\nstatic const PfmCountersInfo " << Target << Def.getName() << " = {\n"; // Cycle Counter. if (CycleCounter.empty()) OS << " nullptr, // No cycle counter.\n"; else OS << " " << Target << "PfmCounterNames[" << getPfmCounterId(CycleCounter) << "], // Cycle counter\n"; // Uops Counter. if (UopsCounter.empty()) OS << " nullptr, // No uops counter.\n"; else OS << " " << Target << "PfmCounterNames[" << getPfmCounterId(UopsCounter) << "], // Uops counter\n"; // Issue Counters if (NumIssueCounters == 0) OS << " nullptr, // No issue counters.\n 0\n"; else OS << " " << Target << "PfmIssueCounters + " << IssueCountersTableOffset << ", " << NumIssueCounters << " // Issue counters.\n"; OS << "};\n"; IssueCountersTableOffset += NumIssueCounters; } void ExegesisEmitter::emitPfmCounters(raw_ostream &OS) const { // Emit the counter name table. OS << "\nstatic const char* " << Target << "PfmCounterNames[] = {\n"; for (const auto &NameAndIndex : PfmCounterNameTable) OS << " \"" << NameAndIndex.first << "\", // " << NameAndIndex.second << "\n"; OS << "};\n\n"; // Emit the IssueCounters table. const auto PfmCounterDefs = Records.getAllDerivedDefinitions("ProcPfmCounters"); // Only emit if non-empty. const bool HasAtLeastOnePfmIssueCounter = llvm::any_of(PfmCounterDefs, [](const Record *Def) { return !Def->getValueAsListOfDefs("IssueCounters").empty(); }); if (HasAtLeastOnePfmIssueCounter) { OS << "static const PfmCountersInfo::IssueCounter " << Target << "PfmIssueCounters[] = {\n"; for (const Record *Def : PfmCounterDefs) { for (const Record *ICDef : Def->getValueAsListOfDefs("IssueCounters")) OS << " { " << Target << "PfmCounterNames[" << getPfmCounterId(ICDef->getValueAsString("Counter")) << "], \"" << ICDef->getValueAsString("ResourceName") << "\"},\n"; } OS << "};\n"; } // Now generate the PfmCountersInfo. unsigned IssueCountersTableOffset = 0; for (const Record *Def : PfmCounterDefs) emitPfmCountersInfo(*Def, IssueCountersTableOffset, OS); OS << "\n"; } // namespace void ExegesisEmitter::emitPfmCountersLookupTable(raw_ostream &OS) const { std::vector<Record *> Bindings = Records.getAllDerivedDefinitions("PfmCountersBinding"); assert(!Bindings.empty() && "there must be at least one binding"); llvm::sort(Bindings, [](const Record *L, const Record *R) { return L->getValueAsString("CpuName") < R->getValueAsString("CpuName"); }); OS << "// Sorted (by CpuName) array of pfm counters.\n" << "static const CpuAndPfmCounters " << Target << "CpuPfmCounters[] = {\n"; for (Record *Binding : Bindings) { // Emit as { "cpu", procinit }, OS << " { \"" // << Binding->getValueAsString("CpuName") << "\"," // << " &" << Target << Binding->getValueAsDef("Counters")->getName() // << " },\n"; } OS << "};\n\n"; } void ExegesisEmitter::run(raw_ostream &OS) const { emitSourceFileHeader("Exegesis Tables", OS); emitPfmCounters(OS); emitPfmCountersLookupTable(OS); } } // end anonymous namespace namespace llvm { void EmitExegesis(RecordKeeper &RK, raw_ostream &OS) { ExegesisEmitter(RK).run(OS); } } // end namespace llvm
Upload File
Create Folder