xref: /freebsd/contrib/llvm-project/llvm/lib/Target/NVPTX/NVPTX.h (revision 4b50c451720d8b427757a6da1dd2bb4c52cd9e35)
1 //===-- NVPTX.h - Top-level interface for NVPTX representation --*- C++ -*-===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 //
9 // This file contains the entry points for global functions defined in
10 // the LLVM NVPTX back-end.
11 //
12 //===----------------------------------------------------------------------===//
13 
14 #ifndef LLVM_LIB_TARGET_NVPTX_NVPTX_H
15 #define LLVM_LIB_TARGET_NVPTX_NVPTX_H
16 
17 #include "llvm/Pass.h"
18 #include "llvm/Support/CodeGen.h"
19 
20 namespace llvm {
21 class NVPTXTargetMachine;
22 class FunctionPass;
23 class MachineFunctionPass;
24 class formatted_raw_ostream;
25 
26 namespace NVPTXCC {
27 enum CondCodes {
28   EQ,
29   NE,
30   LT,
31   LE,
32   GT,
33   GE
34 };
35 }
36 
37 FunctionPass *createNVPTXISelDag(NVPTXTargetMachine &TM,
38                                  llvm::CodeGenOpt::Level OptLevel);
39 ModulePass *createNVPTXAssignValidGlobalNamesPass();
40 ModulePass *createGenericToNVVMPass();
41 FunctionPass *createNVVMIntrRangePass(unsigned int SmVersion);
42 FunctionPass *createNVVMReflectPass(unsigned int SmVersion);
43 MachineFunctionPass *createNVPTXPrologEpilogPass();
44 MachineFunctionPass *createNVPTXReplaceImageHandlesPass();
45 FunctionPass *createNVPTXImageOptimizerPass();
46 FunctionPass *createNVPTXLowerArgsPass(const NVPTXTargetMachine *TM);
47 BasicBlockPass *createNVPTXLowerAllocaPass();
48 MachineFunctionPass *createNVPTXPeephole();
49 MachineFunctionPass *createNVPTXProxyRegErasurePass();
50 
51 namespace NVPTX {
52 enum DrvInterface {
53   NVCL,
54   CUDA
55 };
56 
57 // A field inside TSFlags needs a shift and a mask. The usage is
58 // always as follows :
59 // ((TSFlags & fieldMask) >> fieldShift)
60 // The enum keeps the mask, the shift, and all valid values of the
61 // field in one place.
62 enum VecInstType {
63   VecInstTypeShift = 0,
64   VecInstTypeMask = 0xF,
65 
66   VecNOP = 0,
67   VecLoad = 1,
68   VecStore = 2,
69   VecBuild = 3,
70   VecShuffle = 4,
71   VecExtract = 5,
72   VecInsert = 6,
73   VecDest = 7,
74   VecOther = 15
75 };
76 
77 enum SimpleMove {
78   SimpleMoveMask = 0x10,
79   SimpleMoveShift = 4
80 };
81 enum LoadStore {
82   isLoadMask = 0x20,
83   isLoadShift = 5,
84   isStoreMask = 0x40,
85   isStoreShift = 6
86 };
87 
88 namespace PTXLdStInstCode {
89 enum AddressSpace {
90   GENERIC = 0,
91   GLOBAL = 1,
92   CONSTANT = 2,
93   SHARED = 3,
94   PARAM = 4,
95   LOCAL = 5
96 };
97 enum FromType {
98   Unsigned = 0,
99   Signed,
100   Float,
101   Untyped
102 };
103 enum VecType {
104   Scalar = 1,
105   V2 = 2,
106   V4 = 4
107 };
108 }
109 
110 /// PTXCvtMode - Conversion code enumeration
111 namespace PTXCvtMode {
112 enum CvtMode {
113   NONE = 0,
114   RNI,
115   RZI,
116   RMI,
117   RPI,
118   RN,
119   RZ,
120   RM,
121   RP,
122 
123   BASE_MASK = 0x0F,
124   FTZ_FLAG = 0x10,
125   SAT_FLAG = 0x20
126 };
127 }
128 
129 /// PTXCmpMode - Comparison mode enumeration
130 namespace PTXCmpMode {
131 enum CmpMode {
132   EQ = 0,
133   NE,
134   LT,
135   LE,
136   GT,
137   GE,
138   LO,
139   LS,
140   HI,
141   HS,
142   EQU,
143   NEU,
144   LTU,
145   LEU,
146   GTU,
147   GEU,
148   NUM,
149   // NAN is a MACRO
150   NotANumber,
151 
152   BASE_MASK = 0xFF,
153   FTZ_FLAG = 0x100
154 };
155 }
156 }
157 } // end namespace llvm;
158 
159 // Defines symbolic names for NVPTX registers.  This defines a mapping from
160 // register name to register number.
161 #define GET_REGINFO_ENUM
162 #include "NVPTXGenRegisterInfo.inc"
163 
164 // Defines symbolic names for the NVPTX instructions.
165 #define GET_INSTRINFO_ENUM
166 #include "NVPTXGenInstrInfo.inc"
167 
168 #endif
169