Back to home page

EIC code displayed by LXR

 
 

    


File indexing completed on 2026-05-10 08:37:04

0001 //===----- SemaMIPS.h ------ MIPS target-specific routines ----*- C++ -*---===//
0002 //
0003 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
0004 // See https://llvm.org/LICENSE.txt for license information.
0005 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
0006 //
0007 //===----------------------------------------------------------------------===//
0008 /// \file
0009 /// This file declares semantic analysis functions specific to MIPS.
0010 ///
0011 //===----------------------------------------------------------------------===//
0012 
0013 #ifndef LLVM_CLANG_SEMA_SEMAMIPS_H
0014 #define LLVM_CLANG_SEMA_SEMAMIPS_H
0015 
0016 #include "clang/AST/ASTFwd.h"
0017 #include "clang/Sema/SemaBase.h"
0018 
0019 namespace clang {
0020 class ParsedAttr;
0021 class TargetInfo;
0022 
0023 class SemaMIPS : public SemaBase {
0024 public:
0025   SemaMIPS(Sema &S);
0026 
0027   bool CheckMipsBuiltinFunctionCall(const TargetInfo &TI, unsigned BuiltinID,
0028                                     CallExpr *TheCall);
0029   bool CheckMipsBuiltinCpu(const TargetInfo &TI, unsigned BuiltinID,
0030                            CallExpr *TheCall);
0031   bool CheckMipsBuiltinArgument(unsigned BuiltinID, CallExpr *TheCall);
0032   void handleInterruptAttr(Decl *D, const ParsedAttr &AL);
0033 };
0034 } // namespace clang
0035 
0036 #endif // LLVM_CLANG_SEMA_SEMAMIPS_H