diff options
Diffstat (limited to 'contrib/llvm-project/clang/include/clang/Sema/RISCVIntrinsicManager.h')
-rw-r--r-- | contrib/llvm-project/clang/include/clang/Sema/RISCVIntrinsicManager.h | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/contrib/llvm-project/clang/include/clang/Sema/RISCVIntrinsicManager.h b/contrib/llvm-project/clang/include/clang/Sema/RISCVIntrinsicManager.h new file mode 100644 index 000000000000..2a3dd1e7c469 --- /dev/null +++ b/contrib/llvm-project/clang/include/clang/Sema/RISCVIntrinsicManager.h @@ -0,0 +1,41 @@ +//===- RISCVIntrinsicManager.h - RISC-V Intrinsic Handler -------*- 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 the RISCVIntrinsicManager, which handles RISC-V vector +// intrinsic functions. +// +//===----------------------------------------------------------------------===// + +#ifndef LLVM_CLANG_SEMA_RISCVINTRINSICMANAGER_H +#define LLVM_CLANG_SEMA_RISCVINTRINSICMANAGER_H + +#include <cstdint> + +namespace clang { +class LookupResult; +class IdentifierInfo; +class Preprocessor; + +namespace sema { +class RISCVIntrinsicManager { +public: + enum class IntrinsicKind : uint8_t { RVV, SIFIVE_VECTOR }; + + virtual ~RISCVIntrinsicManager() = default; + + virtual void InitIntrinsicList() = 0; + + // Create RISC-V intrinsic and insert into symbol table and return true if + // found, otherwise return false. + virtual bool CreateIntrinsicIfFound(LookupResult &LR, IdentifierInfo *II, + Preprocessor &PP) = 0; +}; +} // end namespace sema +} // end namespace clang + +#endif |