mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-04 12:15:46 +00:00
[mlir] Hoist out getRequestedOpDefinitions helper
Enables performing the same filtering in the op doc definition as in the op definition generator. Differential Revision: https://reviews.llvm.org/D99793
This commit is contained in:
parent
b09df246ca
commit
96caf3817f
@ -15,6 +15,7 @@ add_tablegen(mlir-tblgen MLIR
|
||||
OpDefinitionsGen.cpp
|
||||
OpDocGen.cpp
|
||||
OpFormatGen.cpp
|
||||
OpGenHelpers.cpp
|
||||
OpInterfacesGen.cpp
|
||||
OpPythonBindingGen.cpp
|
||||
PassCAPIGen.cpp
|
||||
|
@ -12,6 +12,7 @@
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "OpFormatGen.h"
|
||||
#include "OpGenHelpers.h"
|
||||
#include "mlir/TableGen/CodeGenHelpers.h"
|
||||
#include "mlir/TableGen/Format.h"
|
||||
#include "mlir/TableGen/GenInfo.h"
|
||||
@ -22,8 +23,7 @@
|
||||
#include "mlir/TableGen/SideEffects.h"
|
||||
#include "llvm/ADT/Sequence.h"
|
||||
#include "llvm/ADT/StringExtras.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
#include "llvm/Support/Regex.h"
|
||||
#include "llvm/Support/Path.h"
|
||||
#include "llvm/Support/Signals.h"
|
||||
#include "llvm/TableGen/Error.h"
|
||||
#include "llvm/TableGen/Record.h"
|
||||
@ -35,17 +35,6 @@ using namespace llvm;
|
||||
using namespace mlir;
|
||||
using namespace mlir::tblgen;
|
||||
|
||||
cl::OptionCategory opDefGenCat("Options for -gen-op-defs and -gen-op-decls");
|
||||
|
||||
static cl::opt<std::string> opIncFilter(
|
||||
"op-include-regex",
|
||||
cl::desc("Regex of name of op's to include (no filter if empty)"),
|
||||
cl::cat(opDefGenCat));
|
||||
static cl::opt<std::string> opExcFilter(
|
||||
"op-exclude-regex",
|
||||
cl::desc("Regex of name of op's to exclude (no filter if empty)"),
|
||||
cl::cat(opDefGenCat));
|
||||
|
||||
static const char *const tblgenNamePrefix = "tblgen_";
|
||||
static const char *const generatedArgName = "odsArg";
|
||||
static const char *const odsBuilder = "odsBuilder";
|
||||
@ -2472,44 +2461,10 @@ static void emitOpList(const std::vector<Record *> &defs, raw_ostream &os) {
|
||||
[&os]() { os << ",\n"; });
|
||||
}
|
||||
|
||||
static std::string getOperationName(const Record &def) {
|
||||
auto prefix = def.getValueAsDef("opDialect")->getValueAsString("name");
|
||||
auto opName = def.getValueAsString("opName");
|
||||
if (prefix.empty())
|
||||
return std::string(opName);
|
||||
return std::string(llvm::formatv("{0}.{1}", prefix, opName));
|
||||
}
|
||||
|
||||
static std::vector<Record *>
|
||||
getAllDerivedDefinitions(const RecordKeeper &recordKeeper,
|
||||
StringRef className) {
|
||||
Record *classDef = recordKeeper.getClass(className);
|
||||
if (!classDef)
|
||||
PrintFatalError("ERROR: Couldn't find the `" + className + "' class!\n");
|
||||
|
||||
llvm::Regex includeRegex(opIncFilter), excludeRegex(opExcFilter);
|
||||
std::vector<Record *> defs;
|
||||
for (const auto &def : recordKeeper.getDefs()) {
|
||||
if (!def.second->isSubClassOf(classDef))
|
||||
continue;
|
||||
// Include if no include filter or include filter matches.
|
||||
if (!opIncFilter.empty() &&
|
||||
!includeRegex.match(getOperationName(*def.second)))
|
||||
continue;
|
||||
// Unless there is an exclude filter and it matches.
|
||||
if (!opExcFilter.empty() &&
|
||||
excludeRegex.match(getOperationName(*def.second)))
|
||||
continue;
|
||||
defs.push_back(def.second.get());
|
||||
}
|
||||
|
||||
return defs;
|
||||
}
|
||||
|
||||
static bool emitOpDecls(const RecordKeeper &recordKeeper, raw_ostream &os) {
|
||||
emitSourceFileHeader("Op Declarations", os);
|
||||
|
||||
const auto &defs = getAllDerivedDefinitions(recordKeeper, "Op");
|
||||
std::vector<Record *> defs = getRequestedOpDefinitions(recordKeeper);
|
||||
emitOpClasses(recordKeeper, defs, os, /*emitDecl=*/true);
|
||||
|
||||
return false;
|
||||
@ -2518,7 +2473,7 @@ static bool emitOpDecls(const RecordKeeper &recordKeeper, raw_ostream &os) {
|
||||
static bool emitOpDefs(const RecordKeeper &recordKeeper, raw_ostream &os) {
|
||||
emitSourceFileHeader("Op Definitions", os);
|
||||
|
||||
const auto &defs = getAllDerivedDefinitions(recordKeeper, "Op");
|
||||
std::vector<Record *> defs = getRequestedOpDefinitions(recordKeeper);
|
||||
emitOpList(defs, os);
|
||||
emitOpClasses(recordKeeper, defs, os, /*emitDecl=*/false);
|
||||
|
||||
|
@ -12,6 +12,7 @@
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "DocGenUtilities.h"
|
||||
#include "OpGenHelpers.h"
|
||||
#include "mlir/Support/IndentedOstream.h"
|
||||
#include "mlir/TableGen/AttrOrTypeDef.h"
|
||||
#include "mlir/TableGen/GenInfo.h"
|
||||
@ -141,7 +142,7 @@ static void emitOpDoc(Operator op, raw_ostream &os) {
|
||||
}
|
||||
|
||||
static void emitOpDoc(const RecordKeeper &recordKeeper, raw_ostream &os) {
|
||||
auto opDefs = recordKeeper.getAllDerivedDefinitions("Op");
|
||||
auto opDefs = getRequestedOpDefinitions(recordKeeper);
|
||||
|
||||
os << "<!-- Autogenerated by mlir-tblgen; don't manually edit -->\n";
|
||||
for (const llvm::Record *opDef : opDefs)
|
||||
@ -269,7 +270,7 @@ static void emitDialectDoc(const Dialect &dialect, ArrayRef<AttrDef> attrDefs,
|
||||
}
|
||||
|
||||
static void emitDialectDoc(const RecordKeeper &recordKeeper, raw_ostream &os) {
|
||||
std::vector<Record *> opDefs = recordKeeper.getAllDerivedDefinitions("Op");
|
||||
std::vector<Record *> opDefs = getRequestedOpDefinitions(recordKeeper);
|
||||
std::vector<Record *> typeDefs =
|
||||
recordKeeper.getAllDerivedDefinitions("DialectType");
|
||||
std::vector<Record *> typeDefDefs =
|
||||
|
65
mlir/tools/mlir-tblgen/OpGenHelpers.cpp
Normal file
65
mlir/tools/mlir-tblgen/OpGenHelpers.cpp
Normal file
@ -0,0 +1,65 @@
|
||||
//===- OpGenHelpers.cpp - MLIR operation generator helpers ----------------===//
|
||||
//
|
||||
// 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 file defines helpers used in the op generators.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "OpGenHelpers.h"
|
||||
#include "llvm/Support/CommandLine.h"
|
||||
#include "llvm/Support/FormatVariadic.h"
|
||||
#include "llvm/Support/Regex.h"
|
||||
#include "llvm/TableGen/Error.h"
|
||||
|
||||
using namespace llvm;
|
||||
using namespace mlir;
|
||||
using namespace mlir::tblgen;
|
||||
|
||||
cl::OptionCategory opDefGenCat("Options for op definition generators");
|
||||
|
||||
static cl::opt<std::string> opIncFilter(
|
||||
"op-include-regex",
|
||||
cl::desc("Regex of name of op's to include (no filter if empty)"),
|
||||
cl::cat(opDefGenCat));
|
||||
static cl::opt<std::string> opExcFilter(
|
||||
"op-exclude-regex",
|
||||
cl::desc("Regex of name of op's to exclude (no filter if empty)"),
|
||||
cl::cat(opDefGenCat));
|
||||
|
||||
static std::string getOperationName(const Record &def) {
|
||||
auto prefix = def.getValueAsDef("opDialect")->getValueAsString("name");
|
||||
auto opName = def.getValueAsString("opName");
|
||||
if (prefix.empty())
|
||||
return std::string(opName);
|
||||
return std::string(llvm::formatv("{0}.{1}", prefix, opName));
|
||||
}
|
||||
|
||||
std::vector<Record *>
|
||||
mlir::tblgen::getRequestedOpDefinitions(const RecordKeeper &recordKeeper) {
|
||||
Record *classDef = recordKeeper.getClass("Op");
|
||||
if (!classDef)
|
||||
PrintFatalError("ERROR: Couldn't find the 'Op' class!\n");
|
||||
|
||||
llvm::Regex includeRegex(opIncFilter), excludeRegex(opExcFilter);
|
||||
std::vector<Record *> defs;
|
||||
for (const auto &def : recordKeeper.getDefs()) {
|
||||
if (!def.second->isSubClassOf(classDef))
|
||||
continue;
|
||||
// Include if no include filter or include filter matches.
|
||||
if (!opIncFilter.empty() &&
|
||||
!includeRegex.match(getOperationName(*def.second)))
|
||||
continue;
|
||||
// Unless there is an exclude filter and it matches.
|
||||
if (!opExcFilter.empty() &&
|
||||
excludeRegex.match(getOperationName(*def.second)))
|
||||
continue;
|
||||
defs.push_back(def.second.get());
|
||||
}
|
||||
|
||||
return defs;
|
||||
}
|
30
mlir/tools/mlir-tblgen/OpGenHelpers.h
Normal file
30
mlir/tools/mlir-tblgen/OpGenHelpers.h
Normal file
@ -0,0 +1,30 @@
|
||||
//===- OpGenHelpers.h - MLIR operation generator helpers --------*- C++ -*-===//
|
||||
//
|
||||
// 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 file defines helpers used in the op generators.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#ifndef MLIR_TOOLS_MLIRTBLGEN_OPGENHELPERS_H_
|
||||
#define MLIR_TOOLS_MLIRTBLGEN_OPGENHELPERS_H_
|
||||
|
||||
#include "llvm/TableGen/Record.h"
|
||||
#include <vector>
|
||||
|
||||
namespace mlir {
|
||||
namespace tblgen {
|
||||
|
||||
/// Returns all the op definitions filtered by the user. The filtering is via
|
||||
/// command-line option "op-include-regex" and "op-exclude-regex".
|
||||
std::vector<llvm::Record *>
|
||||
getRequestedOpDefinitions(const llvm::RecordKeeper &recordKeeper);
|
||||
|
||||
} // end namespace tblgen
|
||||
} // end namespace mlir
|
||||
|
||||
#endif // MLIR_TOOLS_MLIRTBLGEN_OPGENHELPERS_H_
|
Loading…
Reference in New Issue
Block a user