2020-09-08 21:35:14 +08:00
|
|
|
//===--- AlteraTidyModule.cpp - clang-tidy --------------------------------===//
|
|
|
|
//
|
|
|
|
// 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 "../ClangTidy.h"
|
|
|
|
#include "../ClangTidyModule.h"
|
|
|
|
#include "../ClangTidyModuleRegistry.h"
|
2021-05-07 05:01:39 +08:00
|
|
|
#include "IdDependentBackwardBranchCheck.h"
|
2020-11-09 22:20:35 +08:00
|
|
|
#include "KernelNameRestrictionCheck.h"
|
2020-12-18 20:49:48 +08:00
|
|
|
#include "SingleWorkItemBarrierCheck.h"
|
2020-09-08 21:35:14 +08:00
|
|
|
#include "StructPackAlignCheck.h"
|
2021-03-23 01:08:14 +08:00
|
|
|
#include "UnrollLoopsCheck.h"
|
2020-09-08 21:35:14 +08:00
|
|
|
|
|
|
|
using namespace clang::ast_matchers;
|
|
|
|
|
|
|
|
namespace clang {
|
|
|
|
namespace tidy {
|
|
|
|
namespace altera {
|
|
|
|
|
|
|
|
class AlteraModule : public ClangTidyModule {
|
|
|
|
public:
|
|
|
|
void addCheckFactories(ClangTidyCheckFactories &CheckFactories) override {
|
2021-05-07 05:01:39 +08:00
|
|
|
CheckFactories.registerCheck<IdDependentBackwardBranchCheck>(
|
|
|
|
"altera-id-dependent-backward-branch");
|
2020-11-09 22:20:35 +08:00
|
|
|
CheckFactories.registerCheck<KernelNameRestrictionCheck>(
|
|
|
|
"altera-kernel-name-restriction");
|
2020-12-18 20:49:48 +08:00
|
|
|
CheckFactories.registerCheck<SingleWorkItemBarrierCheck>(
|
|
|
|
"altera-single-work-item-barrier");
|
2020-09-08 21:35:14 +08:00
|
|
|
CheckFactories.registerCheck<StructPackAlignCheck>(
|
|
|
|
"altera-struct-pack-align");
|
2021-03-23 01:08:14 +08:00
|
|
|
CheckFactories.registerCheck<UnrollLoopsCheck>("altera-unroll-loops");
|
2020-09-08 21:35:14 +08:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace altera
|
|
|
|
|
|
|
|
// Register the AlteraTidyModule using this statically initialized variable.
|
|
|
|
static ClangTidyModuleRegistry::Add<altera::AlteraModule>
|
|
|
|
X("altera-module", "Adds Altera FPGA OpenCL lint checks.");
|
|
|
|
|
|
|
|
// This anchor is used to force the linker to link in the generated object file
|
|
|
|
// and thus register the AlteraModule.
|
|
|
|
volatile int AlteraModuleAnchorSource = 0;
|
|
|
|
|
|
|
|
} // namespace tidy
|
|
|
|
} // namespace clang
|