[llvm] [TableGen] Code cleanup in CodeGenTarget.cpp (PR #125569)
Rahul Joshi via llvm-commits
llvm-commits at lists.llvm.org
Mon Feb 3 12:14:03 PST 2025
https://github.com/jurahul created https://github.com/llvm/llvm-project/pull/125569
- Use StringRef::str() instead of std::string(StringRef).
- Use const pointers for `Candidates` in getSuperRegForSubReg().
- Make `AsmParserCat` and `AsmWriterCat` static.
- Use enumerate() in `ComputeInstrsByEnum` to assign inst enums.
>From 50e6306d83546e9502eaac299d4e482deec6864c Mon Sep 17 00:00:00 2001
From: Rahul Joshi <rjoshi at nvidia.com>
Date: Mon, 3 Feb 2025 12:08:31 -0800
Subject: [PATCH] [TableGen] Code cleanup in CodeGenTarget.cpp
- Use StringRef::str() instead of std::string(StringRef).
- Use const pointers for `Candidates` in getSuperRegForSubReg().
- Make `AsmParserCat` and `AsmWriterCat` static.
- Use enumerate() in `ComputeInstrsByEnum` to assign inst enums.
---
.../TableGen/Common/CodeGenInstruction.h | 2 +-
llvm/utils/TableGen/Common/CodeGenTarget.cpp | 28 +++++++++----------
2 files changed, 15 insertions(+), 15 deletions(-)
diff --git a/llvm/utils/TableGen/Common/CodeGenInstruction.h b/llvm/utils/TableGen/Common/CodeGenInstruction.h
index 44c0ab70dc615dd..b5c4e671103a9c5 100644
--- a/llvm/utils/TableGen/Common/CodeGenInstruction.h
+++ b/llvm/utils/TableGen/Common/CodeGenInstruction.h
@@ -300,7 +300,7 @@ class CodeGenInstruction {
const Record *InferredFrom;
// The enum value assigned by CodeGenTarget::computeInstrsByEnum.
- mutable unsigned EnumVal = 0;
+ unsigned EnumVal = 0;
CodeGenInstruction(const Record *R);
diff --git a/llvm/utils/TableGen/Common/CodeGenTarget.cpp b/llvm/utils/TableGen/Common/CodeGenTarget.cpp
index 96829a185a30b7a..4d1e9162844c234 100644
--- a/llvm/utils/TableGen/Common/CodeGenTarget.cpp
+++ b/llvm/utils/TableGen/Common/CodeGenTarget.cpp
@@ -28,8 +28,8 @@
#include <tuple>
using namespace llvm;
-cl::OptionCategory AsmParserCat("Options for -gen-asm-parser");
-cl::OptionCategory AsmWriterCat("Options for -gen-asm-writer");
+static cl::OptionCategory AsmParserCat("Options for -gen-asm-parser");
+static cl::OptionCategory AsmWriterCat("Options for -gen-asm-writer");
static cl::opt<unsigned>
AsmParserNum("asmparsernum", cl::init(0),
@@ -64,9 +64,9 @@ StringRef llvm::getEnumName(MVT::SimpleValueType T) {
std::string llvm::getQualifiedName(const Record *R) {
std::string Namespace;
if (R->getValue("Namespace"))
- Namespace = std::string(R->getValueAsString("Namespace"));
+ Namespace = R->getValueAsString("Namespace").str();
if (Namespace.empty())
- return std::string(R->getName());
+ return R->getName().str();
return Namespace + "::" + R->getName().str();
}
@@ -166,14 +166,15 @@ CodeGenRegBank &CodeGenTarget::getRegBank() const {
const CodeGenRegisterClass *CodeGenTarget::getSuperRegForSubReg(
const ValueTypeByHwMode &ValueTy, CodeGenRegBank &RegBank,
const CodeGenSubRegIndex *SubIdx, bool MustBeAllocatable) const {
- std::vector<CodeGenRegisterClass *> Candidates;
+ std::vector<const CodeGenRegisterClass *> Candidates;
auto &RegClasses = RegBank.getRegClasses();
// Try to find a register class which supports ValueTy, and also contains
// SubIdx.
- for (CodeGenRegisterClass &RC : RegClasses) {
+ for (const CodeGenRegisterClass &RC : RegClasses) {
// Is there a subclass of this class which contains this subregister index?
- CodeGenRegisterClass *SubClassWithSubReg = RC.getSubClassWithSubReg(SubIdx);
+ const CodeGenRegisterClass *SubClassWithSubReg =
+ RC.getSubClassWithSubReg(SubIdx);
if (!SubClassWithSubReg)
continue;
@@ -268,14 +269,14 @@ void CodeGenTarget::ReadInstructions() const {
}
static const CodeGenInstruction *GetInstByName(
- const char *Name,
+ StringRef Name,
const DenseMap<const Record *, std::unique_ptr<CodeGenInstruction>> &Insts,
const RecordKeeper &Records) {
const Record *Rec = Records.getDef(Name);
const auto I = Insts.find(Rec);
if (!Rec || I == Insts.end())
- PrintFatalError(Twine("Could not find '") + Name + "' instruction!");
+ PrintFatalError("Could not find '" + Name + "' instruction!");
return I->second.get();
}
@@ -292,8 +293,8 @@ unsigned CodeGenTarget::getNumFixedInstructions() {
/// their enum value.
void CodeGenTarget::ComputeInstrsByEnum() const {
const auto &Insts = getInstructions();
- for (const char *const *p = FixedInstrs; *p; ++p) {
- const CodeGenInstruction *Instr = GetInstByName(*p, Insts, Records);
+ for (const char *Name : FixedInstrs) {
+ const CodeGenInstruction *Instr = GetInstByName(Name, Insts, Records);
assert(Instr && "Missing target independent instruction");
assert(Instr->Namespace == "TargetOpcode" && "Bad namespace");
InstrsByEnum.push_back(Instr);
@@ -324,9 +325,8 @@ void CodeGenTarget::ComputeInstrsByEnum() const {
});
// Assign an enum value to each instruction according to the sorted order.
- unsigned Num = 0;
- for (const CodeGenInstruction *Inst : InstrsByEnum)
- Inst->EnumVal = Num++;
+ for (const auto &[Idx, Inst] : enumerate(InstrsByEnum))
+ const_cast<CodeGenInstruction *>(Inst)->EnumVal = Idx;
}
/// isLittleEndianEncoding - Return whether this target encodes its instruction
More information about the llvm-commits
mailing list