• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //===-- NVPTX.h - Top-level interface for NVPTX representation --*- 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 // This file contains the entry points for global functions defined in
11 // the LLVM NVPTX back-end.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #ifndef LLVM_TARGET_NVPTX_H
16 #define LLVM_TARGET_NVPTX_H
17 
18 #include "llvm/Value.h"
19 #include "llvm/Module.h"
20 #include "llvm/Support/ErrorHandling.h"
21 #include "llvm/Target/TargetMachine.h"
22 #include "MCTargetDesc/NVPTXBaseInfo.h"
23 #include <cassert>
24 #include <iosfwd>
25 
26 namespace llvm {
27 class NVPTXTargetMachine;
28 class FunctionPass;
29 class formatted_raw_ostream;
30 
31 namespace NVPTXCC {
32 enum CondCodes {
33   EQ,
34   NE,
35   LT,
36   LE,
37   GT,
38   GE
39 };
40 }
41 
NVPTXCondCodeToString(NVPTXCC::CondCodes CC)42 inline static const char *NVPTXCondCodeToString(NVPTXCC::CondCodes CC) {
43   switch (CC) {
44   case NVPTXCC::NE:  return "ne";
45   case NVPTXCC::EQ:   return "eq";
46   case NVPTXCC::LT:   return "lt";
47   case NVPTXCC::LE:  return "le";
48   case NVPTXCC::GT:  return "gt";
49   case NVPTXCC::GE:   return "ge";
50   }
51   llvm_unreachable("Unknown condition code");
52 }
53 
54 FunctionPass *createNVPTXISelDag(NVPTXTargetMachine &TM,
55                                  llvm::CodeGenOpt::Level OptLevel);
56 FunctionPass *createVectorElementizePass(NVPTXTargetMachine &);
57 FunctionPass *createLowerStructArgsPass(NVPTXTargetMachine &);
58 FunctionPass *createNVPTXReMatPass(NVPTXTargetMachine &);
59 FunctionPass *createNVPTXReMatBlockPass(NVPTXTargetMachine &);
60 
61 bool isImageOrSamplerVal(const Value *, const Module *);
62 
63 extern Target TheNVPTXTarget32;
64 extern Target TheNVPTXTarget64;
65 
66 namespace NVPTX
67 {
68 enum DrvInterface {
69   NVCL,
70   CUDA,
71   TEST
72 };
73 
74 // A field inside TSFlags needs a shift and a mask. The usage is
75 // always as follows :
76 // ((TSFlags & fieldMask) >> fieldShift)
77 // The enum keeps the mask, the shift, and all valid values of the
78 // field in one place.
79 enum VecInstType {
80   VecInstTypeShift = 0,
81   VecInstTypeMask = 0xF,
82 
83   VecNOP = 0,
84   VecLoad = 1,
85   VecStore = 2,
86   VecBuild = 3,
87   VecShuffle = 4,
88   VecExtract = 5,
89   VecInsert = 6,
90   VecDest = 7,
91   VecOther = 15
92 };
93 
94 enum SimpleMove {
95   SimpleMoveMask = 0x10,
96   SimpleMoveShift = 4
97 };
98 enum LoadStore {
99   isLoadMask = 0x20,
100   isLoadShift = 5,
101   isStoreMask = 0x40,
102   isStoreShift = 6
103 };
104 
105 namespace PTXLdStInstCode {
106 enum AddressSpace{
107   GENERIC = 0,
108   GLOBAL = 1,
109   CONSTANT = 2,
110   SHARED = 3,
111   PARAM = 4,
112   LOCAL = 5
113 };
114 enum FromType {
115   Unsigned = 0,
116   Signed,
117   Float
118 };
119 enum VecType {
120   Scalar = 1,
121   V2 = 2,
122   V4 = 4
123 };
124 }
125 }
126 } // end namespace llvm;
127 
128 // Defines symbolic names for NVPTX registers.  This defines a mapping from
129 // register name to register number.
130 #define GET_REGINFO_ENUM
131 #include "NVPTXGenRegisterInfo.inc"
132 
133 // Defines symbolic names for the NVPTX instructions.
134 #define GET_INSTRINFO_ENUM
135 #include "NVPTXGenInstrInfo.inc"
136 
137 #endif
138