
An uninitialized variable that caused a crash (https://lab.llvm.org/buildbot/#/builders/164/builds/11004) was identified using the memory analyzer, leading to the reversion of https://github.com/llvm/llvm-project/pull/141423. This pull request reapplies the previously reverted changes and includes the fix, which has been tested locally following the steps at https://github.com/google/sanitizers/wiki/SanitizerBotReproduceBuild. Note: the fix is included as part of the second commit
81 lines
3.3 KiB
C++
81 lines
3.3 KiB
C++
//===- mlir-query.cpp - MLIR Query Driver ---------------------------------===//
|
|
//
|
|
// 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 is a command line utility that queries a file from/to MLIR using one
|
|
// of the registered queries.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "mlir/IR/Dialect.h"
|
|
#include "mlir/IR/MLIRContext.h"
|
|
#include "mlir/IR/Matchers.h"
|
|
#include "mlir/InitAllDialects.h"
|
|
#include "mlir/Query/Matcher/Registry.h"
|
|
#include "mlir/Query/Matcher/SliceMatchers.h"
|
|
#include "mlir/Tools/mlir-query/MlirQueryMain.h"
|
|
|
|
using namespace mlir;
|
|
|
|
// This is needed because these matchers are defined as overloaded functions.
|
|
using HasOpAttrName = detail::AttrOpMatcher(StringRef);
|
|
using HasOpName = detail::NameOpMatcher(StringRef);
|
|
using IsConstantOp = detail::constant_op_matcher();
|
|
|
|
namespace test {
|
|
#ifdef MLIR_INCLUDE_TESTS
|
|
void registerTestDialect(DialectRegistry &);
|
|
#endif
|
|
} // namespace test
|
|
|
|
int main(int argc, char **argv) {
|
|
|
|
DialectRegistry dialectRegistry;
|
|
registerAllDialects(dialectRegistry);
|
|
|
|
query::matcher::Registry matcherRegistry;
|
|
|
|
// Matchers registered in alphabetical order for consistency:
|
|
matcherRegistry.registerMatcher("allOf", query::matcher::internal::allOf);
|
|
matcherRegistry.registerMatcher("anyOf", query::matcher::internal::anyOf);
|
|
matcherRegistry.registerMatcher(
|
|
"getAllDefinitions",
|
|
query::matcher::m_GetAllDefinitions<query::matcher::DynMatcher>);
|
|
matcherRegistry.registerMatcher(
|
|
"getDefinitions",
|
|
query::matcher::m_GetDefinitions<query::matcher::DynMatcher>);
|
|
matcherRegistry.registerMatcher(
|
|
"getDefinitionsByPredicate",
|
|
query::matcher::m_GetDefinitionsByPredicate<query::matcher::DynMatcher,
|
|
query::matcher::DynMatcher>);
|
|
matcherRegistry.registerMatcher(
|
|
"getUsersByPredicate",
|
|
query::matcher::m_GetUsersByPredicate<query::matcher::DynMatcher,
|
|
query::matcher::DynMatcher>);
|
|
matcherRegistry.registerMatcher("hasOpAttrName",
|
|
static_cast<HasOpAttrName *>(m_Attr));
|
|
matcherRegistry.registerMatcher("hasOpName", static_cast<HasOpName *>(m_Op));
|
|
matcherRegistry.registerMatcher("isConstantOp",
|
|
static_cast<IsConstantOp *>(m_Constant));
|
|
matcherRegistry.registerMatcher("isNegInfFloat", m_NegInfFloat);
|
|
matcherRegistry.registerMatcher("isNegZeroFloat", m_NegZeroFloat);
|
|
matcherRegistry.registerMatcher("isNonZero", m_NonZero);
|
|
matcherRegistry.registerMatcher("isOne", m_One);
|
|
matcherRegistry.registerMatcher("isOneFloat", m_OneFloat);
|
|
matcherRegistry.registerMatcher("isPosInfFloat", m_PosInfFloat);
|
|
matcherRegistry.registerMatcher("isPosZeroFloat", m_PosZeroFloat);
|
|
matcherRegistry.registerMatcher("isZero", m_Zero);
|
|
matcherRegistry.registerMatcher("isZeroFloat", m_AnyZeroFloat);
|
|
|
|
#ifdef MLIR_INCLUDE_TESTS
|
|
test::registerTestDialect(dialectRegistry);
|
|
#endif
|
|
MLIRContext context(dialectRegistry);
|
|
|
|
return failed(mlirQueryMain(argc, argv, context, matcherRegistry));
|
|
}
|