blob: 35559e23fcebdc0eebc15bdcec7b80fc53f1e5cf [file] [log] [blame]
Tom Stellard75aadc22012-12-11 21:25:42 +00001//===- AMDILIntrinsicInfo.h - AMDGPU Intrinsic Information ------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//==-----------------------------------------------------------------------===//
9//
10/// \file
11/// \brief Interface for the AMDGPU Implementation of the Intrinsic Info class.
12//
13//===-----------------------------------------------------------------------===//
14#ifndef AMDIL_INTRINSICS_H
15#define AMDIL_INTRINSICS_H
16
Chandler Carruth9fb823b2013-01-02 11:36:10 +000017#include "llvm/IR/Intrinsics.h"
Tom Stellard75aadc22012-12-11 21:25:42 +000018#include "llvm/Target/TargetIntrinsicInfo.h"
19
20namespace llvm {
21class TargetMachine;
22
23namespace AMDGPUIntrinsic {
24enum ID {
25 last_non_AMDGPU_intrinsic = Intrinsic::num_intrinsics - 1,
26#define GET_INTRINSIC_ENUM_VALUES
27#include "AMDGPUGenIntrinsics.inc"
28#undef GET_INTRINSIC_ENUM_VALUES
29 , num_AMDGPU_intrinsics
30};
31
32} // end namespace AMDGPUIntrinsic
33
34class AMDGPUIntrinsicInfo : public TargetIntrinsicInfo {
35public:
36 AMDGPUIntrinsicInfo(TargetMachine *tm);
37 std::string getName(unsigned int IntrId, Type **Tys = 0,
38 unsigned int numTys = 0) const;
39 unsigned int lookupName(const char *Name, unsigned int Len) const;
40 bool isOverloaded(unsigned int IID) const;
41 Function *getDeclaration(Module *M, unsigned int ID,
42 Type **Tys = 0,
43 unsigned int numTys = 0) const;
44};
45
46} // end namespace llvm
47
48#endif // AMDIL_INTRINSICS_H
49