xref: /freebsd/contrib/llvm-project/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp (revision 04eeddc0aa8e0a417a16eaf9d7d095207f4a8623)
1 //===-- NVPTXReplaceImageHandles.cpp - Replace image handles for Fermi ----===//
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 // On Fermi, image handles are not supported. To work around this, we traverse
10 // the machine code and replace image handles with concrete symbols. For this
11 // to work reliably, inlining of all function call must be performed.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #include "NVPTX.h"
16 #include "NVPTXMachineFunctionInfo.h"
17 #include "NVPTXSubtarget.h"
18 #include "NVPTXTargetMachine.h"
19 #include "MCTargetDesc/NVPTXBaseInfo.h"
20 #include "llvm/ADT/DenseSet.h"
21 #include "llvm/CodeGen/MachineFunction.h"
22 #include "llvm/CodeGen/MachineFunctionPass.h"
23 #include "llvm/CodeGen/MachineRegisterInfo.h"
24 #include "llvm/Support/raw_ostream.h"
25 
26 using namespace llvm;
27 
28 namespace {
29 class NVPTXReplaceImageHandles : public MachineFunctionPass {
30 private:
31   static char ID;
32   DenseSet<MachineInstr *> InstrsToRemove;
33 
34 public:
35   NVPTXReplaceImageHandles();
36 
37   bool runOnMachineFunction(MachineFunction &MF) override;
38 
39   StringRef getPassName() const override {
40     return "NVPTX Replace Image Handles";
41   }
42 private:
43   bool processInstr(MachineInstr &MI);
44   bool replaceImageHandle(MachineOperand &Op, MachineFunction &MF);
45   bool findIndexForHandle(MachineOperand &Op, MachineFunction &MF,
46                           unsigned &Idx);
47 };
48 }
49 
50 char NVPTXReplaceImageHandles::ID = 0;
51 
52 NVPTXReplaceImageHandles::NVPTXReplaceImageHandles()
53   : MachineFunctionPass(ID) {}
54 
55 bool NVPTXReplaceImageHandles::runOnMachineFunction(MachineFunction &MF) {
56   bool Changed = false;
57   InstrsToRemove.clear();
58 
59   for (MachineBasicBlock &MBB : MF)
60     for (MachineInstr &MI : MBB)
61       Changed |= processInstr(MI);
62 
63   // Now clean up any handle-access instructions
64   // This is needed in debug mode when code cleanup passes are not executed,
65   // but we need the handle access to be eliminated because they are not
66   // valid instructions when image handles are disabled.
67   for (MachineInstr *MI : InstrsToRemove)
68     MI->eraseFromParent();
69   return Changed;
70 }
71 
72 static unsigned suldRegisterToIndexOpcode(unsigned RegOC) {
73   switch (RegOC) {
74   case NVPTX::SULD_1D_I8_CLAMP_R:
75     return NVPTX::SULD_1D_I8_CLAMP_I;
76   case NVPTX::SULD_1D_I16_CLAMP_R:
77     return NVPTX::SULD_1D_I16_CLAMP_I;
78   case NVPTX::SULD_1D_I32_CLAMP_R:
79     return NVPTX::SULD_1D_I32_CLAMP_I;
80   case NVPTX::SULD_1D_I64_CLAMP_R:
81     return NVPTX::SULD_1D_I64_CLAMP_I;
82   case NVPTX::SULD_1D_ARRAY_I8_CLAMP_R:
83     return NVPTX::SULD_1D_ARRAY_I8_CLAMP_I;
84   case NVPTX::SULD_1D_ARRAY_I16_CLAMP_R:
85     return NVPTX::SULD_1D_ARRAY_I16_CLAMP_I;
86   case NVPTX::SULD_1D_ARRAY_I32_CLAMP_R:
87     return NVPTX::SULD_1D_ARRAY_I32_CLAMP_I;
88   case NVPTX::SULD_1D_ARRAY_I64_CLAMP_R:
89     return NVPTX::SULD_1D_ARRAY_I64_CLAMP_I;
90   case NVPTX::SULD_2D_I8_CLAMP_R:
91     return NVPTX::SULD_2D_I8_CLAMP_I;
92   case NVPTX::SULD_2D_I16_CLAMP_R:
93     return NVPTX::SULD_2D_I16_CLAMP_I;
94   case NVPTX::SULD_2D_I32_CLAMP_R:
95     return NVPTX::SULD_2D_I32_CLAMP_I;
96   case NVPTX::SULD_2D_I64_CLAMP_R:
97     return NVPTX::SULD_2D_I64_CLAMP_I;
98   case NVPTX::SULD_2D_ARRAY_I8_CLAMP_R:
99     return NVPTX::SULD_2D_ARRAY_I8_CLAMP_I;
100   case NVPTX::SULD_2D_ARRAY_I16_CLAMP_R:
101     return NVPTX::SULD_2D_ARRAY_I16_CLAMP_I;
102   case NVPTX::SULD_2D_ARRAY_I32_CLAMP_R:
103     return NVPTX::SULD_2D_ARRAY_I32_CLAMP_I;
104   case NVPTX::SULD_2D_ARRAY_I64_CLAMP_R:
105     return NVPTX::SULD_2D_ARRAY_I64_CLAMP_I;
106   case NVPTX::SULD_3D_I8_CLAMP_R:
107     return NVPTX::SULD_3D_I8_CLAMP_I;
108   case NVPTX::SULD_3D_I16_CLAMP_R:
109     return NVPTX::SULD_3D_I16_CLAMP_I;
110   case NVPTX::SULD_3D_I32_CLAMP_R:
111     return NVPTX::SULD_3D_I32_CLAMP_I;
112   case NVPTX::SULD_3D_I64_CLAMP_R:
113     return NVPTX::SULD_3D_I64_CLAMP_I;
114   case NVPTX::SULD_1D_V2I8_CLAMP_R:
115     return NVPTX::SULD_1D_V2I8_CLAMP_I;
116   case NVPTX::SULD_1D_V2I16_CLAMP_R:
117     return NVPTX::SULD_1D_V2I16_CLAMP_I;
118   case NVPTX::SULD_1D_V2I32_CLAMP_R:
119     return NVPTX::SULD_1D_V2I32_CLAMP_I;
120   case NVPTX::SULD_1D_V2I64_CLAMP_R:
121     return NVPTX::SULD_1D_V2I64_CLAMP_I;
122   case NVPTX::SULD_1D_ARRAY_V2I8_CLAMP_R:
123     return NVPTX::SULD_1D_ARRAY_V2I8_CLAMP_I;
124   case NVPTX::SULD_1D_ARRAY_V2I16_CLAMP_R:
125     return NVPTX::SULD_1D_ARRAY_V2I16_CLAMP_I;
126   case NVPTX::SULD_1D_ARRAY_V2I32_CLAMP_R:
127     return NVPTX::SULD_1D_ARRAY_V2I32_CLAMP_I;
128   case NVPTX::SULD_1D_ARRAY_V2I64_CLAMP_R:
129     return NVPTX::SULD_1D_ARRAY_V2I64_CLAMP_I;
130   case NVPTX::SULD_2D_V2I8_CLAMP_R:
131     return NVPTX::SULD_2D_V2I8_CLAMP_I;
132   case NVPTX::SULD_2D_V2I16_CLAMP_R:
133     return NVPTX::SULD_2D_V2I16_CLAMP_I;
134   case NVPTX::SULD_2D_V2I32_CLAMP_R:
135     return NVPTX::SULD_2D_V2I32_CLAMP_I;
136   case NVPTX::SULD_2D_V2I64_CLAMP_R:
137     return NVPTX::SULD_2D_V2I64_CLAMP_I;
138   case NVPTX::SULD_2D_ARRAY_V2I8_CLAMP_R:
139     return NVPTX::SULD_2D_ARRAY_V2I8_CLAMP_I;
140   case NVPTX::SULD_2D_ARRAY_V2I16_CLAMP_R:
141     return NVPTX::SULD_2D_ARRAY_V2I16_CLAMP_I;
142   case NVPTX::SULD_2D_ARRAY_V2I32_CLAMP_R:
143     return NVPTX::SULD_2D_ARRAY_V2I32_CLAMP_I;
144   case NVPTX::SULD_2D_ARRAY_V2I64_CLAMP_R:
145     return NVPTX::SULD_2D_ARRAY_V2I64_CLAMP_I;
146   case NVPTX::SULD_3D_V2I8_CLAMP_R:
147     return NVPTX::SULD_3D_V2I8_CLAMP_I;
148   case NVPTX::SULD_3D_V2I16_CLAMP_R:
149     return NVPTX::SULD_3D_V2I16_CLAMP_I;
150   case NVPTX::SULD_3D_V2I32_CLAMP_R:
151     return NVPTX::SULD_3D_V2I32_CLAMP_I;
152   case NVPTX::SULD_3D_V2I64_CLAMP_R:
153     return NVPTX::SULD_3D_V2I64_CLAMP_I;
154   case NVPTX::SULD_1D_V4I8_CLAMP_R:
155     return NVPTX::SULD_1D_V4I8_CLAMP_I;
156   case NVPTX::SULD_1D_V4I16_CLAMP_R:
157     return NVPTX::SULD_1D_V4I16_CLAMP_I;
158   case NVPTX::SULD_1D_V4I32_CLAMP_R:
159     return NVPTX::SULD_1D_V4I32_CLAMP_I;
160   case NVPTX::SULD_1D_ARRAY_V4I8_CLAMP_R:
161     return NVPTX::SULD_1D_ARRAY_V4I8_CLAMP_I;
162   case NVPTX::SULD_1D_ARRAY_V4I16_CLAMP_R:
163     return NVPTX::SULD_1D_ARRAY_V4I16_CLAMP_I;
164   case NVPTX::SULD_1D_ARRAY_V4I32_CLAMP_R:
165     return NVPTX::SULD_1D_ARRAY_V4I32_CLAMP_I;
166   case NVPTX::SULD_2D_V4I8_CLAMP_R:
167     return NVPTX::SULD_2D_V4I8_CLAMP_I;
168   case NVPTX::SULD_2D_V4I16_CLAMP_R:
169     return NVPTX::SULD_2D_V4I16_CLAMP_I;
170   case NVPTX::SULD_2D_V4I32_CLAMP_R:
171     return NVPTX::SULD_2D_V4I32_CLAMP_I;
172   case NVPTX::SULD_2D_ARRAY_V4I8_CLAMP_R:
173     return NVPTX::SULD_2D_ARRAY_V4I8_CLAMP_I;
174   case NVPTX::SULD_2D_ARRAY_V4I16_CLAMP_R:
175     return NVPTX::SULD_2D_ARRAY_V4I16_CLAMP_I;
176   case NVPTX::SULD_2D_ARRAY_V4I32_CLAMP_R:
177     return NVPTX::SULD_2D_ARRAY_V4I32_CLAMP_I;
178   case NVPTX::SULD_3D_V4I8_CLAMP_R:
179     return NVPTX::SULD_3D_V4I8_CLAMP_I;
180   case NVPTX::SULD_3D_V4I16_CLAMP_R:
181     return NVPTX::SULD_3D_V4I16_CLAMP_I;
182   case NVPTX::SULD_3D_V4I32_CLAMP_R:
183     return NVPTX::SULD_3D_V4I32_CLAMP_I;
184   case NVPTX::SULD_1D_I8_TRAP_R:
185     return NVPTX::SULD_1D_I8_TRAP_I;
186   case NVPTX::SULD_1D_I16_TRAP_R:
187     return NVPTX::SULD_1D_I16_TRAP_I;
188   case NVPTX::SULD_1D_I32_TRAP_R:
189     return NVPTX::SULD_1D_I32_TRAP_I;
190   case NVPTX::SULD_1D_I64_TRAP_R:
191     return NVPTX::SULD_1D_I64_TRAP_I;
192   case NVPTX::SULD_1D_ARRAY_I8_TRAP_R:
193     return NVPTX::SULD_1D_ARRAY_I8_TRAP_I;
194   case NVPTX::SULD_1D_ARRAY_I16_TRAP_R:
195     return NVPTX::SULD_1D_ARRAY_I16_TRAP_I;
196   case NVPTX::SULD_1D_ARRAY_I32_TRAP_R:
197     return NVPTX::SULD_1D_ARRAY_I32_TRAP_I;
198   case NVPTX::SULD_1D_ARRAY_I64_TRAP_R:
199     return NVPTX::SULD_1D_ARRAY_I64_TRAP_I;
200   case NVPTX::SULD_2D_I8_TRAP_R:
201     return NVPTX::SULD_2D_I8_TRAP_I;
202   case NVPTX::SULD_2D_I16_TRAP_R:
203     return NVPTX::SULD_2D_I16_TRAP_I;
204   case NVPTX::SULD_2D_I32_TRAP_R:
205     return NVPTX::SULD_2D_I32_TRAP_I;
206   case NVPTX::SULD_2D_I64_TRAP_R:
207     return NVPTX::SULD_2D_I64_TRAP_I;
208   case NVPTX::SULD_2D_ARRAY_I8_TRAP_R:
209     return NVPTX::SULD_2D_ARRAY_I8_TRAP_I;
210   case NVPTX::SULD_2D_ARRAY_I16_TRAP_R:
211     return NVPTX::SULD_2D_ARRAY_I16_TRAP_I;
212   case NVPTX::SULD_2D_ARRAY_I32_TRAP_R:
213     return NVPTX::SULD_2D_ARRAY_I32_TRAP_I;
214   case NVPTX::SULD_2D_ARRAY_I64_TRAP_R:
215     return NVPTX::SULD_2D_ARRAY_I64_TRAP_I;
216   case NVPTX::SULD_3D_I8_TRAP_R:
217     return NVPTX::SULD_3D_I8_TRAP_I;
218   case NVPTX::SULD_3D_I16_TRAP_R:
219     return NVPTX::SULD_3D_I16_TRAP_I;
220   case NVPTX::SULD_3D_I32_TRAP_R:
221     return NVPTX::SULD_3D_I32_TRAP_I;
222   case NVPTX::SULD_3D_I64_TRAP_R:
223     return NVPTX::SULD_3D_I64_TRAP_I;
224   case NVPTX::SULD_1D_V2I8_TRAP_R:
225     return NVPTX::SULD_1D_V2I8_TRAP_I;
226   case NVPTX::SULD_1D_V2I16_TRAP_R:
227     return NVPTX::SULD_1D_V2I16_TRAP_I;
228   case NVPTX::SULD_1D_V2I32_TRAP_R:
229     return NVPTX::SULD_1D_V2I32_TRAP_I;
230   case NVPTX::SULD_1D_V2I64_TRAP_R:
231     return NVPTX::SULD_1D_V2I64_TRAP_I;
232   case NVPTX::SULD_1D_ARRAY_V2I8_TRAP_R:
233     return NVPTX::SULD_1D_ARRAY_V2I8_TRAP_I;
234   case NVPTX::SULD_1D_ARRAY_V2I16_TRAP_R:
235     return NVPTX::SULD_1D_ARRAY_V2I16_TRAP_I;
236   case NVPTX::SULD_1D_ARRAY_V2I32_TRAP_R:
237     return NVPTX::SULD_1D_ARRAY_V2I32_TRAP_I;
238   case NVPTX::SULD_1D_ARRAY_V2I64_TRAP_R:
239     return NVPTX::SULD_1D_ARRAY_V2I64_TRAP_I;
240   case NVPTX::SULD_2D_V2I8_TRAP_R:
241     return NVPTX::SULD_2D_V2I8_TRAP_I;
242   case NVPTX::SULD_2D_V2I16_TRAP_R:
243     return NVPTX::SULD_2D_V2I16_TRAP_I;
244   case NVPTX::SULD_2D_V2I32_TRAP_R:
245     return NVPTX::SULD_2D_V2I32_TRAP_I;
246   case NVPTX::SULD_2D_V2I64_TRAP_R:
247     return NVPTX::SULD_2D_V2I64_TRAP_I;
248   case NVPTX::SULD_2D_ARRAY_V2I8_TRAP_R:
249     return NVPTX::SULD_2D_ARRAY_V2I8_TRAP_I;
250   case NVPTX::SULD_2D_ARRAY_V2I16_TRAP_R:
251     return NVPTX::SULD_2D_ARRAY_V2I16_TRAP_I;
252   case NVPTX::SULD_2D_ARRAY_V2I32_TRAP_R:
253     return NVPTX::SULD_2D_ARRAY_V2I32_TRAP_I;
254   case NVPTX::SULD_2D_ARRAY_V2I64_TRAP_R:
255     return NVPTX::SULD_2D_ARRAY_V2I64_TRAP_I;
256   case NVPTX::SULD_3D_V2I8_TRAP_R:
257     return NVPTX::SULD_3D_V2I8_TRAP_I;
258   case NVPTX::SULD_3D_V2I16_TRAP_R:
259     return NVPTX::SULD_3D_V2I16_TRAP_I;
260   case NVPTX::SULD_3D_V2I32_TRAP_R:
261     return NVPTX::SULD_3D_V2I32_TRAP_I;
262   case NVPTX::SULD_3D_V2I64_TRAP_R:
263     return NVPTX::SULD_3D_V2I64_TRAP_I;
264   case NVPTX::SULD_1D_V4I8_TRAP_R:
265     return NVPTX::SULD_1D_V4I8_TRAP_I;
266   case NVPTX::SULD_1D_V4I16_TRAP_R:
267     return NVPTX::SULD_1D_V4I16_TRAP_I;
268   case NVPTX::SULD_1D_V4I32_TRAP_R:
269     return NVPTX::SULD_1D_V4I32_TRAP_I;
270   case NVPTX::SULD_1D_ARRAY_V4I8_TRAP_R:
271     return NVPTX::SULD_1D_ARRAY_V4I8_TRAP_I;
272   case NVPTX::SULD_1D_ARRAY_V4I16_TRAP_R:
273     return NVPTX::SULD_1D_ARRAY_V4I16_TRAP_I;
274   case NVPTX::SULD_1D_ARRAY_V4I32_TRAP_R:
275     return NVPTX::SULD_1D_ARRAY_V4I32_TRAP_I;
276   case NVPTX::SULD_2D_V4I8_TRAP_R:
277     return NVPTX::SULD_2D_V4I8_TRAP_I;
278   case NVPTX::SULD_2D_V4I16_TRAP_R:
279     return NVPTX::SULD_2D_V4I16_TRAP_I;
280   case NVPTX::SULD_2D_V4I32_TRAP_R:
281     return NVPTX::SULD_2D_V4I32_TRAP_I;
282   case NVPTX::SULD_2D_ARRAY_V4I8_TRAP_R:
283     return NVPTX::SULD_2D_ARRAY_V4I8_TRAP_I;
284   case NVPTX::SULD_2D_ARRAY_V4I16_TRAP_R:
285     return NVPTX::SULD_2D_ARRAY_V4I16_TRAP_I;
286   case NVPTX::SULD_2D_ARRAY_V4I32_TRAP_R:
287     return NVPTX::SULD_2D_ARRAY_V4I32_TRAP_I;
288   case NVPTX::SULD_3D_V4I8_TRAP_R:
289     return NVPTX::SULD_3D_V4I8_TRAP_I;
290   case NVPTX::SULD_3D_V4I16_TRAP_R:
291     return NVPTX::SULD_3D_V4I16_TRAP_I;
292   case NVPTX::SULD_3D_V4I32_TRAP_R:
293     return NVPTX::SULD_3D_V4I32_TRAP_I;
294   case NVPTX::SULD_1D_I8_ZERO_R:
295     return NVPTX::SULD_1D_I8_ZERO_I;
296   case NVPTX::SULD_1D_I16_ZERO_R:
297     return NVPTX::SULD_1D_I16_ZERO_I;
298   case NVPTX::SULD_1D_I32_ZERO_R:
299     return NVPTX::SULD_1D_I32_ZERO_I;
300   case NVPTX::SULD_1D_I64_ZERO_R:
301     return NVPTX::SULD_1D_I64_ZERO_I;
302   case NVPTX::SULD_1D_ARRAY_I8_ZERO_R:
303     return NVPTX::SULD_1D_ARRAY_I8_ZERO_I;
304   case NVPTX::SULD_1D_ARRAY_I16_ZERO_R:
305     return NVPTX::SULD_1D_ARRAY_I16_ZERO_I;
306   case NVPTX::SULD_1D_ARRAY_I32_ZERO_R:
307     return NVPTX::SULD_1D_ARRAY_I32_ZERO_I;
308   case NVPTX::SULD_1D_ARRAY_I64_ZERO_R:
309     return NVPTX::SULD_1D_ARRAY_I64_ZERO_I;
310   case NVPTX::SULD_2D_I8_ZERO_R:
311     return NVPTX::SULD_2D_I8_ZERO_I;
312   case NVPTX::SULD_2D_I16_ZERO_R:
313     return NVPTX::SULD_2D_I16_ZERO_I;
314   case NVPTX::SULD_2D_I32_ZERO_R:
315     return NVPTX::SULD_2D_I32_ZERO_I;
316   case NVPTX::SULD_2D_I64_ZERO_R:
317     return NVPTX::SULD_2D_I64_ZERO_I;
318   case NVPTX::SULD_2D_ARRAY_I8_ZERO_R:
319     return NVPTX::SULD_2D_ARRAY_I8_ZERO_I;
320   case NVPTX::SULD_2D_ARRAY_I16_ZERO_R:
321     return NVPTX::SULD_2D_ARRAY_I16_ZERO_I;
322   case NVPTX::SULD_2D_ARRAY_I32_ZERO_R:
323     return NVPTX::SULD_2D_ARRAY_I32_ZERO_I;
324   case NVPTX::SULD_2D_ARRAY_I64_ZERO_R:
325     return NVPTX::SULD_2D_ARRAY_I64_ZERO_I;
326   case NVPTX::SULD_3D_I8_ZERO_R:
327     return NVPTX::SULD_3D_I8_ZERO_I;
328   case NVPTX::SULD_3D_I16_ZERO_R:
329     return NVPTX::SULD_3D_I16_ZERO_I;
330   case NVPTX::SULD_3D_I32_ZERO_R:
331     return NVPTX::SULD_3D_I32_ZERO_I;
332   case NVPTX::SULD_3D_I64_ZERO_R:
333     return NVPTX::SULD_3D_I64_ZERO_I;
334   case NVPTX::SULD_1D_V2I8_ZERO_R:
335     return NVPTX::SULD_1D_V2I8_ZERO_I;
336   case NVPTX::SULD_1D_V2I16_ZERO_R:
337     return NVPTX::SULD_1D_V2I16_ZERO_I;
338   case NVPTX::SULD_1D_V2I32_ZERO_R:
339     return NVPTX::SULD_1D_V2I32_ZERO_I;
340   case NVPTX::SULD_1D_V2I64_ZERO_R:
341     return NVPTX::SULD_1D_V2I64_ZERO_I;
342   case NVPTX::SULD_1D_ARRAY_V2I8_ZERO_R:
343     return NVPTX::SULD_1D_ARRAY_V2I8_ZERO_I;
344   case NVPTX::SULD_1D_ARRAY_V2I16_ZERO_R:
345     return NVPTX::SULD_1D_ARRAY_V2I16_ZERO_I;
346   case NVPTX::SULD_1D_ARRAY_V2I32_ZERO_R:
347     return NVPTX::SULD_1D_ARRAY_V2I32_ZERO_I;
348   case NVPTX::SULD_1D_ARRAY_V2I64_ZERO_R:
349     return NVPTX::SULD_1D_ARRAY_V2I64_ZERO_I;
350   case NVPTX::SULD_2D_V2I8_ZERO_R:
351     return NVPTX::SULD_2D_V2I8_ZERO_I;
352   case NVPTX::SULD_2D_V2I16_ZERO_R:
353     return NVPTX::SULD_2D_V2I16_ZERO_I;
354   case NVPTX::SULD_2D_V2I32_ZERO_R:
355     return NVPTX::SULD_2D_V2I32_ZERO_I;
356   case NVPTX::SULD_2D_V2I64_ZERO_R:
357     return NVPTX::SULD_2D_V2I64_ZERO_I;
358   case NVPTX::SULD_2D_ARRAY_V2I8_ZERO_R:
359     return NVPTX::SULD_2D_ARRAY_V2I8_ZERO_I;
360   case NVPTX::SULD_2D_ARRAY_V2I16_ZERO_R:
361     return NVPTX::SULD_2D_ARRAY_V2I16_ZERO_I;
362   case NVPTX::SULD_2D_ARRAY_V2I32_ZERO_R:
363     return NVPTX::SULD_2D_ARRAY_V2I32_ZERO_I;
364   case NVPTX::SULD_2D_ARRAY_V2I64_ZERO_R:
365     return NVPTX::SULD_2D_ARRAY_V2I64_ZERO_I;
366   case NVPTX::SULD_3D_V2I8_ZERO_R:
367     return NVPTX::SULD_3D_V2I8_ZERO_I;
368   case NVPTX::SULD_3D_V2I16_ZERO_R:
369     return NVPTX::SULD_3D_V2I16_ZERO_I;
370   case NVPTX::SULD_3D_V2I32_ZERO_R:
371     return NVPTX::SULD_3D_V2I32_ZERO_I;
372   case NVPTX::SULD_3D_V2I64_ZERO_R:
373     return NVPTX::SULD_3D_V2I64_ZERO_I;
374   case NVPTX::SULD_1D_V4I8_ZERO_R:
375     return NVPTX::SULD_1D_V4I8_ZERO_I;
376   case NVPTX::SULD_1D_V4I16_ZERO_R:
377     return NVPTX::SULD_1D_V4I16_ZERO_I;
378   case NVPTX::SULD_1D_V4I32_ZERO_R:
379     return NVPTX::SULD_1D_V4I32_ZERO_I;
380   case NVPTX::SULD_1D_ARRAY_V4I8_ZERO_R:
381     return NVPTX::SULD_1D_ARRAY_V4I8_ZERO_I;
382   case NVPTX::SULD_1D_ARRAY_V4I16_ZERO_R:
383     return NVPTX::SULD_1D_ARRAY_V4I16_ZERO_I;
384   case NVPTX::SULD_1D_ARRAY_V4I32_ZERO_R:
385     return NVPTX::SULD_1D_ARRAY_V4I32_ZERO_I;
386   case NVPTX::SULD_2D_V4I8_ZERO_R:
387     return NVPTX::SULD_2D_V4I8_ZERO_I;
388   case NVPTX::SULD_2D_V4I16_ZERO_R:
389     return NVPTX::SULD_2D_V4I16_ZERO_I;
390   case NVPTX::SULD_2D_V4I32_ZERO_R:
391     return NVPTX::SULD_2D_V4I32_ZERO_I;
392   case NVPTX::SULD_2D_ARRAY_V4I8_ZERO_R:
393     return NVPTX::SULD_2D_ARRAY_V4I8_ZERO_I;
394   case NVPTX::SULD_2D_ARRAY_V4I16_ZERO_R:
395     return NVPTX::SULD_2D_ARRAY_V4I16_ZERO_I;
396   case NVPTX::SULD_2D_ARRAY_V4I32_ZERO_R:
397     return NVPTX::SULD_2D_ARRAY_V4I32_ZERO_I;
398   case NVPTX::SULD_3D_V4I8_ZERO_R:
399     return NVPTX::SULD_3D_V4I8_ZERO_I;
400   case NVPTX::SULD_3D_V4I16_ZERO_R:
401     return NVPTX::SULD_3D_V4I16_ZERO_I;
402   case NVPTX::SULD_3D_V4I32_ZERO_R:
403     return NVPTX::SULD_3D_V4I32_ZERO_I;
404   default:
405     llvm_unreachable("Unhandled SULD opcode");
406   }
407 }
408 
409 static unsigned sustRegisterToIndexOpcode(unsigned RegOC) {
410   switch (RegOC) {
411   case NVPTX::SUST_B_1D_B8_CLAMP_R:
412     return NVPTX::SUST_B_1D_B8_CLAMP_I;
413   case NVPTX::SUST_B_1D_B16_CLAMP_R:
414     return NVPTX::SUST_B_1D_B16_CLAMP_I;
415   case NVPTX::SUST_B_1D_B32_CLAMP_R:
416     return NVPTX::SUST_B_1D_B32_CLAMP_I;
417   case NVPTX::SUST_B_1D_B64_CLAMP_R:
418     return NVPTX::SUST_B_1D_B64_CLAMP_I;
419   case NVPTX::SUST_B_1D_V2B8_CLAMP_R:
420     return NVPTX::SUST_B_1D_V2B8_CLAMP_I;
421   case NVPTX::SUST_B_1D_V2B16_CLAMP_R:
422     return NVPTX::SUST_B_1D_V2B16_CLAMP_I;
423   case NVPTX::SUST_B_1D_V2B32_CLAMP_R:
424     return NVPTX::SUST_B_1D_V2B32_CLAMP_I;
425   case NVPTX::SUST_B_1D_V2B64_CLAMP_R:
426     return NVPTX::SUST_B_1D_V2B64_CLAMP_I;
427   case NVPTX::SUST_B_1D_V4B8_CLAMP_R:
428     return NVPTX::SUST_B_1D_V4B8_CLAMP_I;
429   case NVPTX::SUST_B_1D_V4B16_CLAMP_R:
430     return NVPTX::SUST_B_1D_V4B16_CLAMP_I;
431   case NVPTX::SUST_B_1D_V4B32_CLAMP_R:
432     return NVPTX::SUST_B_1D_V4B32_CLAMP_I;
433   case NVPTX::SUST_B_1D_ARRAY_B8_CLAMP_R:
434     return NVPTX::SUST_B_1D_ARRAY_B8_CLAMP_I;
435   case NVPTX::SUST_B_1D_ARRAY_B16_CLAMP_R:
436     return NVPTX::SUST_B_1D_ARRAY_B16_CLAMP_I;
437   case NVPTX::SUST_B_1D_ARRAY_B32_CLAMP_R:
438     return NVPTX::SUST_B_1D_ARRAY_B32_CLAMP_I;
439   case NVPTX::SUST_B_1D_ARRAY_B64_CLAMP_R:
440     return NVPTX::SUST_B_1D_ARRAY_B64_CLAMP_I;
441   case NVPTX::SUST_B_1D_ARRAY_V2B8_CLAMP_R:
442     return NVPTX::SUST_B_1D_ARRAY_V2B8_CLAMP_I;
443   case NVPTX::SUST_B_1D_ARRAY_V2B16_CLAMP_R:
444     return NVPTX::SUST_B_1D_ARRAY_V2B16_CLAMP_I;
445   case NVPTX::SUST_B_1D_ARRAY_V2B32_CLAMP_R:
446     return NVPTX::SUST_B_1D_ARRAY_V2B32_CLAMP_I;
447   case NVPTX::SUST_B_1D_ARRAY_V2B64_CLAMP_R:
448     return NVPTX::SUST_B_1D_ARRAY_V2B64_CLAMP_I;
449   case NVPTX::SUST_B_1D_ARRAY_V4B8_CLAMP_R:
450     return NVPTX::SUST_B_1D_ARRAY_V4B8_CLAMP_I;
451   case NVPTX::SUST_B_1D_ARRAY_V4B16_CLAMP_R:
452     return NVPTX::SUST_B_1D_ARRAY_V4B16_CLAMP_I;
453   case NVPTX::SUST_B_1D_ARRAY_V4B32_CLAMP_R:
454     return NVPTX::SUST_B_1D_ARRAY_V4B32_CLAMP_I;
455   case NVPTX::SUST_B_2D_B8_CLAMP_R:
456     return NVPTX::SUST_B_2D_B8_CLAMP_I;
457   case NVPTX::SUST_B_2D_B16_CLAMP_R:
458     return NVPTX::SUST_B_2D_B16_CLAMP_I;
459   case NVPTX::SUST_B_2D_B32_CLAMP_R:
460     return NVPTX::SUST_B_2D_B32_CLAMP_I;
461   case NVPTX::SUST_B_2D_B64_CLAMP_R:
462     return NVPTX::SUST_B_2D_B64_CLAMP_I;
463   case NVPTX::SUST_B_2D_V2B8_CLAMP_R:
464     return NVPTX::SUST_B_2D_V2B8_CLAMP_I;
465   case NVPTX::SUST_B_2D_V2B16_CLAMP_R:
466     return NVPTX::SUST_B_2D_V2B16_CLAMP_I;
467   case NVPTX::SUST_B_2D_V2B32_CLAMP_R:
468     return NVPTX::SUST_B_2D_V2B32_CLAMP_I;
469   case NVPTX::SUST_B_2D_V2B64_CLAMP_R:
470     return NVPTX::SUST_B_2D_V2B64_CLAMP_I;
471   case NVPTX::SUST_B_2D_V4B8_CLAMP_R:
472     return NVPTX::SUST_B_2D_V4B8_CLAMP_I;
473   case NVPTX::SUST_B_2D_V4B16_CLAMP_R:
474     return NVPTX::SUST_B_2D_V4B16_CLAMP_I;
475   case NVPTX::SUST_B_2D_V4B32_CLAMP_R:
476     return NVPTX::SUST_B_2D_V4B32_CLAMP_I;
477   case NVPTX::SUST_B_2D_ARRAY_B8_CLAMP_R:
478     return NVPTX::SUST_B_2D_ARRAY_B8_CLAMP_I;
479   case NVPTX::SUST_B_2D_ARRAY_B16_CLAMP_R:
480     return NVPTX::SUST_B_2D_ARRAY_B16_CLAMP_I;
481   case NVPTX::SUST_B_2D_ARRAY_B32_CLAMP_R:
482     return NVPTX::SUST_B_2D_ARRAY_B32_CLAMP_I;
483   case NVPTX::SUST_B_2D_ARRAY_B64_CLAMP_R:
484     return NVPTX::SUST_B_2D_ARRAY_B64_CLAMP_I;
485   case NVPTX::SUST_B_2D_ARRAY_V2B8_CLAMP_R:
486     return NVPTX::SUST_B_2D_ARRAY_V2B8_CLAMP_I;
487   case NVPTX::SUST_B_2D_ARRAY_V2B16_CLAMP_R:
488     return NVPTX::SUST_B_2D_ARRAY_V2B16_CLAMP_I;
489   case NVPTX::SUST_B_2D_ARRAY_V2B32_CLAMP_R:
490     return NVPTX::SUST_B_2D_ARRAY_V2B32_CLAMP_I;
491   case NVPTX::SUST_B_2D_ARRAY_V2B64_CLAMP_R:
492     return NVPTX::SUST_B_2D_ARRAY_V2B64_CLAMP_I;
493   case NVPTX::SUST_B_2D_ARRAY_V4B8_CLAMP_R:
494     return NVPTX::SUST_B_2D_ARRAY_V4B8_CLAMP_I;
495   case NVPTX::SUST_B_2D_ARRAY_V4B16_CLAMP_R:
496     return NVPTX::SUST_B_2D_ARRAY_V4B16_CLAMP_I;
497   case NVPTX::SUST_B_2D_ARRAY_V4B32_CLAMP_R:
498     return NVPTX::SUST_B_2D_ARRAY_V4B32_CLAMP_I;
499   case NVPTX::SUST_B_3D_B8_CLAMP_R:
500     return NVPTX::SUST_B_3D_B8_CLAMP_I;
501   case NVPTX::SUST_B_3D_B16_CLAMP_R:
502     return NVPTX::SUST_B_3D_B16_CLAMP_I;
503   case NVPTX::SUST_B_3D_B32_CLAMP_R:
504     return NVPTX::SUST_B_3D_B32_CLAMP_I;
505   case NVPTX::SUST_B_3D_B64_CLAMP_R:
506     return NVPTX::SUST_B_3D_B64_CLAMP_I;
507   case NVPTX::SUST_B_3D_V2B8_CLAMP_R:
508     return NVPTX::SUST_B_3D_V2B8_CLAMP_I;
509   case NVPTX::SUST_B_3D_V2B16_CLAMP_R:
510     return NVPTX::SUST_B_3D_V2B16_CLAMP_I;
511   case NVPTX::SUST_B_3D_V2B32_CLAMP_R:
512     return NVPTX::SUST_B_3D_V2B32_CLAMP_I;
513   case NVPTX::SUST_B_3D_V2B64_CLAMP_R:
514     return NVPTX::SUST_B_3D_V2B64_CLAMP_I;
515   case NVPTX::SUST_B_3D_V4B8_CLAMP_R:
516     return NVPTX::SUST_B_3D_V4B8_CLAMP_I;
517   case NVPTX::SUST_B_3D_V4B16_CLAMP_R:
518     return NVPTX::SUST_B_3D_V4B16_CLAMP_I;
519   case NVPTX::SUST_B_3D_V4B32_CLAMP_R:
520     return NVPTX::SUST_B_3D_V4B32_CLAMP_I;
521   case NVPTX::SUST_B_1D_B8_TRAP_R:
522     return NVPTX::SUST_B_1D_B8_TRAP_I;
523   case NVPTX::SUST_B_1D_B16_TRAP_R:
524     return NVPTX::SUST_B_1D_B16_TRAP_I;
525   case NVPTX::SUST_B_1D_B32_TRAP_R:
526     return NVPTX::SUST_B_1D_B32_TRAP_I;
527   case NVPTX::SUST_B_1D_B64_TRAP_R:
528     return NVPTX::SUST_B_1D_B64_TRAP_I;
529   case NVPTX::SUST_B_1D_V2B8_TRAP_R:
530     return NVPTX::SUST_B_1D_V2B8_TRAP_I;
531   case NVPTX::SUST_B_1D_V2B16_TRAP_R:
532     return NVPTX::SUST_B_1D_V2B16_TRAP_I;
533   case NVPTX::SUST_B_1D_V2B32_TRAP_R:
534     return NVPTX::SUST_B_1D_V2B32_TRAP_I;
535   case NVPTX::SUST_B_1D_V2B64_TRAP_R:
536     return NVPTX::SUST_B_1D_V2B64_TRAP_I;
537   case NVPTX::SUST_B_1D_V4B8_TRAP_R:
538     return NVPTX::SUST_B_1D_V4B8_TRAP_I;
539   case NVPTX::SUST_B_1D_V4B16_TRAP_R:
540     return NVPTX::SUST_B_1D_V4B16_TRAP_I;
541   case NVPTX::SUST_B_1D_V4B32_TRAP_R:
542     return NVPTX::SUST_B_1D_V4B32_TRAP_I;
543   case NVPTX::SUST_B_1D_ARRAY_B8_TRAP_R:
544     return NVPTX::SUST_B_1D_ARRAY_B8_TRAP_I;
545   case NVPTX::SUST_B_1D_ARRAY_B16_TRAP_R:
546     return NVPTX::SUST_B_1D_ARRAY_B16_TRAP_I;
547   case NVPTX::SUST_B_1D_ARRAY_B32_TRAP_R:
548     return NVPTX::SUST_B_1D_ARRAY_B32_TRAP_I;
549   case NVPTX::SUST_B_1D_ARRAY_B64_TRAP_R:
550     return NVPTX::SUST_B_1D_ARRAY_B64_TRAP_I;
551   case NVPTX::SUST_B_1D_ARRAY_V2B8_TRAP_R:
552     return NVPTX::SUST_B_1D_ARRAY_V2B8_TRAP_I;
553   case NVPTX::SUST_B_1D_ARRAY_V2B16_TRAP_R:
554     return NVPTX::SUST_B_1D_ARRAY_V2B16_TRAP_I;
555   case NVPTX::SUST_B_1D_ARRAY_V2B32_TRAP_R:
556     return NVPTX::SUST_B_1D_ARRAY_V2B32_TRAP_I;
557   case NVPTX::SUST_B_1D_ARRAY_V2B64_TRAP_R:
558     return NVPTX::SUST_B_1D_ARRAY_V2B64_TRAP_I;
559   case NVPTX::SUST_B_1D_ARRAY_V4B8_TRAP_R:
560     return NVPTX::SUST_B_1D_ARRAY_V4B8_TRAP_I;
561   case NVPTX::SUST_B_1D_ARRAY_V4B16_TRAP_R:
562     return NVPTX::SUST_B_1D_ARRAY_V4B16_TRAP_I;
563   case NVPTX::SUST_B_1D_ARRAY_V4B32_TRAP_R:
564     return NVPTX::SUST_B_1D_ARRAY_V4B32_TRAP_I;
565   case NVPTX::SUST_B_2D_B8_TRAP_R:
566     return NVPTX::SUST_B_2D_B8_TRAP_I;
567   case NVPTX::SUST_B_2D_B16_TRAP_R:
568     return NVPTX::SUST_B_2D_B16_TRAP_I;
569   case NVPTX::SUST_B_2D_B32_TRAP_R:
570     return NVPTX::SUST_B_2D_B32_TRAP_I;
571   case NVPTX::SUST_B_2D_B64_TRAP_R:
572     return NVPTX::SUST_B_2D_B64_TRAP_I;
573   case NVPTX::SUST_B_2D_V2B8_TRAP_R:
574     return NVPTX::SUST_B_2D_V2B8_TRAP_I;
575   case NVPTX::SUST_B_2D_V2B16_TRAP_R:
576     return NVPTX::SUST_B_2D_V2B16_TRAP_I;
577   case NVPTX::SUST_B_2D_V2B32_TRAP_R:
578     return NVPTX::SUST_B_2D_V2B32_TRAP_I;
579   case NVPTX::SUST_B_2D_V2B64_TRAP_R:
580     return NVPTX::SUST_B_2D_V2B64_TRAP_I;
581   case NVPTX::SUST_B_2D_V4B8_TRAP_R:
582     return NVPTX::SUST_B_2D_V4B8_TRAP_I;
583   case NVPTX::SUST_B_2D_V4B16_TRAP_R:
584     return NVPTX::SUST_B_2D_V4B16_TRAP_I;
585   case NVPTX::SUST_B_2D_V4B32_TRAP_R:
586     return NVPTX::SUST_B_2D_V4B32_TRAP_I;
587   case NVPTX::SUST_B_2D_ARRAY_B8_TRAP_R:
588     return NVPTX::SUST_B_2D_ARRAY_B8_TRAP_I;
589   case NVPTX::SUST_B_2D_ARRAY_B16_TRAP_R:
590     return NVPTX::SUST_B_2D_ARRAY_B16_TRAP_I;
591   case NVPTX::SUST_B_2D_ARRAY_B32_TRAP_R:
592     return NVPTX::SUST_B_2D_ARRAY_B32_TRAP_I;
593   case NVPTX::SUST_B_2D_ARRAY_B64_TRAP_R:
594     return NVPTX::SUST_B_2D_ARRAY_B64_TRAP_I;
595   case NVPTX::SUST_B_2D_ARRAY_V2B8_TRAP_R:
596     return NVPTX::SUST_B_2D_ARRAY_V2B8_TRAP_I;
597   case NVPTX::SUST_B_2D_ARRAY_V2B16_TRAP_R:
598     return NVPTX::SUST_B_2D_ARRAY_V2B16_TRAP_I;
599   case NVPTX::SUST_B_2D_ARRAY_V2B32_TRAP_R:
600     return NVPTX::SUST_B_2D_ARRAY_V2B32_TRAP_I;
601   case NVPTX::SUST_B_2D_ARRAY_V2B64_TRAP_R:
602     return NVPTX::SUST_B_2D_ARRAY_V2B64_TRAP_I;
603   case NVPTX::SUST_B_2D_ARRAY_V4B8_TRAP_R:
604     return NVPTX::SUST_B_2D_ARRAY_V4B8_TRAP_I;
605   case NVPTX::SUST_B_2D_ARRAY_V4B16_TRAP_R:
606     return NVPTX::SUST_B_2D_ARRAY_V4B16_TRAP_I;
607   case NVPTX::SUST_B_2D_ARRAY_V4B32_TRAP_R:
608     return NVPTX::SUST_B_2D_ARRAY_V4B32_TRAP_I;
609   case NVPTX::SUST_B_3D_B8_TRAP_R:
610     return NVPTX::SUST_B_3D_B8_TRAP_I;
611   case NVPTX::SUST_B_3D_B16_TRAP_R:
612     return NVPTX::SUST_B_3D_B16_TRAP_I;
613   case NVPTX::SUST_B_3D_B32_TRAP_R:
614     return NVPTX::SUST_B_3D_B32_TRAP_I;
615   case NVPTX::SUST_B_3D_B64_TRAP_R:
616     return NVPTX::SUST_B_3D_B64_TRAP_I;
617   case NVPTX::SUST_B_3D_V2B8_TRAP_R:
618     return NVPTX::SUST_B_3D_V2B8_TRAP_I;
619   case NVPTX::SUST_B_3D_V2B16_TRAP_R:
620     return NVPTX::SUST_B_3D_V2B16_TRAP_I;
621   case NVPTX::SUST_B_3D_V2B32_TRAP_R:
622     return NVPTX::SUST_B_3D_V2B32_TRAP_I;
623   case NVPTX::SUST_B_3D_V2B64_TRAP_R:
624     return NVPTX::SUST_B_3D_V2B64_TRAP_I;
625   case NVPTX::SUST_B_3D_V4B8_TRAP_R:
626     return NVPTX::SUST_B_3D_V4B8_TRAP_I;
627   case NVPTX::SUST_B_3D_V4B16_TRAP_R:
628     return NVPTX::SUST_B_3D_V4B16_TRAP_I;
629   case NVPTX::SUST_B_3D_V4B32_TRAP_R:
630     return NVPTX::SUST_B_3D_V4B32_TRAP_I;
631   case NVPTX::SUST_B_1D_B8_ZERO_R:
632     return NVPTX::SUST_B_1D_B8_ZERO_I;
633   case NVPTX::SUST_B_1D_B16_ZERO_R:
634     return NVPTX::SUST_B_1D_B16_ZERO_I;
635   case NVPTX::SUST_B_1D_B32_ZERO_R:
636     return NVPTX::SUST_B_1D_B32_ZERO_I;
637   case NVPTX::SUST_B_1D_B64_ZERO_R:
638     return NVPTX::SUST_B_1D_B64_ZERO_I;
639   case NVPTX::SUST_B_1D_V2B8_ZERO_R:
640     return NVPTX::SUST_B_1D_V2B8_ZERO_I;
641   case NVPTX::SUST_B_1D_V2B16_ZERO_R:
642     return NVPTX::SUST_B_1D_V2B16_ZERO_I;
643   case NVPTX::SUST_B_1D_V2B32_ZERO_R:
644     return NVPTX::SUST_B_1D_V2B32_ZERO_I;
645   case NVPTX::SUST_B_1D_V2B64_ZERO_R:
646     return NVPTX::SUST_B_1D_V2B64_ZERO_I;
647   case NVPTX::SUST_B_1D_V4B8_ZERO_R:
648     return NVPTX::SUST_B_1D_V4B8_ZERO_I;
649   case NVPTX::SUST_B_1D_V4B16_ZERO_R:
650     return NVPTX::SUST_B_1D_V4B16_ZERO_I;
651   case NVPTX::SUST_B_1D_V4B32_ZERO_R:
652     return NVPTX::SUST_B_1D_V4B32_ZERO_I;
653   case NVPTX::SUST_B_1D_ARRAY_B8_ZERO_R:
654     return NVPTX::SUST_B_1D_ARRAY_B8_ZERO_I;
655   case NVPTX::SUST_B_1D_ARRAY_B16_ZERO_R:
656     return NVPTX::SUST_B_1D_ARRAY_B16_ZERO_I;
657   case NVPTX::SUST_B_1D_ARRAY_B32_ZERO_R:
658     return NVPTX::SUST_B_1D_ARRAY_B32_ZERO_I;
659   case NVPTX::SUST_B_1D_ARRAY_B64_ZERO_R:
660     return NVPTX::SUST_B_1D_ARRAY_B64_ZERO_I;
661   case NVPTX::SUST_B_1D_ARRAY_V2B8_ZERO_R:
662     return NVPTX::SUST_B_1D_ARRAY_V2B8_ZERO_I;
663   case NVPTX::SUST_B_1D_ARRAY_V2B16_ZERO_R:
664     return NVPTX::SUST_B_1D_ARRAY_V2B16_ZERO_I;
665   case NVPTX::SUST_B_1D_ARRAY_V2B32_ZERO_R:
666     return NVPTX::SUST_B_1D_ARRAY_V2B32_ZERO_I;
667   case NVPTX::SUST_B_1D_ARRAY_V2B64_ZERO_R:
668     return NVPTX::SUST_B_1D_ARRAY_V2B64_ZERO_I;
669   case NVPTX::SUST_B_1D_ARRAY_V4B8_ZERO_R:
670     return NVPTX::SUST_B_1D_ARRAY_V4B8_ZERO_I;
671   case NVPTX::SUST_B_1D_ARRAY_V4B16_ZERO_R:
672     return NVPTX::SUST_B_1D_ARRAY_V4B16_ZERO_I;
673   case NVPTX::SUST_B_1D_ARRAY_V4B32_ZERO_R:
674     return NVPTX::SUST_B_1D_ARRAY_V4B32_ZERO_I;
675   case NVPTX::SUST_B_2D_B8_ZERO_R:
676     return NVPTX::SUST_B_2D_B8_ZERO_I;
677   case NVPTX::SUST_B_2D_B16_ZERO_R:
678     return NVPTX::SUST_B_2D_B16_ZERO_I;
679   case NVPTX::SUST_B_2D_B32_ZERO_R:
680     return NVPTX::SUST_B_2D_B32_ZERO_I;
681   case NVPTX::SUST_B_2D_B64_ZERO_R:
682     return NVPTX::SUST_B_2D_B64_ZERO_I;
683   case NVPTX::SUST_B_2D_V2B8_ZERO_R:
684     return NVPTX::SUST_B_2D_V2B8_ZERO_I;
685   case NVPTX::SUST_B_2D_V2B16_ZERO_R:
686     return NVPTX::SUST_B_2D_V2B16_ZERO_I;
687   case NVPTX::SUST_B_2D_V2B32_ZERO_R:
688     return NVPTX::SUST_B_2D_V2B32_ZERO_I;
689   case NVPTX::SUST_B_2D_V2B64_ZERO_R:
690     return NVPTX::SUST_B_2D_V2B64_ZERO_I;
691   case NVPTX::SUST_B_2D_V4B8_ZERO_R:
692     return NVPTX::SUST_B_2D_V4B8_ZERO_I;
693   case NVPTX::SUST_B_2D_V4B16_ZERO_R:
694     return NVPTX::SUST_B_2D_V4B16_ZERO_I;
695   case NVPTX::SUST_B_2D_V4B32_ZERO_R:
696     return NVPTX::SUST_B_2D_V4B32_ZERO_I;
697   case NVPTX::SUST_B_2D_ARRAY_B8_ZERO_R:
698     return NVPTX::SUST_B_2D_ARRAY_B8_ZERO_I;
699   case NVPTX::SUST_B_2D_ARRAY_B16_ZERO_R:
700     return NVPTX::SUST_B_2D_ARRAY_B16_ZERO_I;
701   case NVPTX::SUST_B_2D_ARRAY_B32_ZERO_R:
702     return NVPTX::SUST_B_2D_ARRAY_B32_ZERO_I;
703   case NVPTX::SUST_B_2D_ARRAY_B64_ZERO_R:
704     return NVPTX::SUST_B_2D_ARRAY_B64_ZERO_I;
705   case NVPTX::SUST_B_2D_ARRAY_V2B8_ZERO_R:
706     return NVPTX::SUST_B_2D_ARRAY_V2B8_ZERO_I;
707   case NVPTX::SUST_B_2D_ARRAY_V2B16_ZERO_R:
708     return NVPTX::SUST_B_2D_ARRAY_V2B16_ZERO_I;
709   case NVPTX::SUST_B_2D_ARRAY_V2B32_ZERO_R:
710     return NVPTX::SUST_B_2D_ARRAY_V2B32_ZERO_I;
711   case NVPTX::SUST_B_2D_ARRAY_V2B64_ZERO_R:
712     return NVPTX::SUST_B_2D_ARRAY_V2B64_ZERO_I;
713   case NVPTX::SUST_B_2D_ARRAY_V4B8_ZERO_R:
714     return NVPTX::SUST_B_2D_ARRAY_V4B8_ZERO_I;
715   case NVPTX::SUST_B_2D_ARRAY_V4B16_ZERO_R:
716     return NVPTX::SUST_B_2D_ARRAY_V4B16_ZERO_I;
717   case NVPTX::SUST_B_2D_ARRAY_V4B32_ZERO_R:
718     return NVPTX::SUST_B_2D_ARRAY_V4B32_ZERO_I;
719   case NVPTX::SUST_B_3D_B8_ZERO_R:
720     return NVPTX::SUST_B_3D_B8_ZERO_I;
721   case NVPTX::SUST_B_3D_B16_ZERO_R:
722     return NVPTX::SUST_B_3D_B16_ZERO_I;
723   case NVPTX::SUST_B_3D_B32_ZERO_R:
724     return NVPTX::SUST_B_3D_B32_ZERO_I;
725   case NVPTX::SUST_B_3D_B64_ZERO_R:
726     return NVPTX::SUST_B_3D_B64_ZERO_I;
727   case NVPTX::SUST_B_3D_V2B8_ZERO_R:
728     return NVPTX::SUST_B_3D_V2B8_ZERO_I;
729   case NVPTX::SUST_B_3D_V2B16_ZERO_R:
730     return NVPTX::SUST_B_3D_V2B16_ZERO_I;
731   case NVPTX::SUST_B_3D_V2B32_ZERO_R:
732     return NVPTX::SUST_B_3D_V2B32_ZERO_I;
733   case NVPTX::SUST_B_3D_V2B64_ZERO_R:
734     return NVPTX::SUST_B_3D_V2B64_ZERO_I;
735   case NVPTX::SUST_B_3D_V4B8_ZERO_R:
736     return NVPTX::SUST_B_3D_V4B8_ZERO_I;
737   case NVPTX::SUST_B_3D_V4B16_ZERO_R:
738     return NVPTX::SUST_B_3D_V4B16_ZERO_I;
739   case NVPTX::SUST_B_3D_V4B32_ZERO_R:
740     return NVPTX::SUST_B_3D_V4B32_ZERO_I;
741   case NVPTX::SUST_P_1D_B8_TRAP_R:
742     return NVPTX::SUST_P_1D_B8_TRAP_I;
743   case NVPTX::SUST_P_1D_B16_TRAP_R:
744     return NVPTX::SUST_P_1D_B16_TRAP_I;
745   case NVPTX::SUST_P_1D_B32_TRAP_R:
746     return NVPTX::SUST_P_1D_B32_TRAP_I;
747   case NVPTX::SUST_P_1D_V2B8_TRAP_R:
748     return NVPTX::SUST_P_1D_V2B8_TRAP_I;
749   case NVPTX::SUST_P_1D_V2B16_TRAP_R:
750     return NVPTX::SUST_P_1D_V2B16_TRAP_I;
751   case NVPTX::SUST_P_1D_V2B32_TRAP_R:
752     return NVPTX::SUST_P_1D_V2B32_TRAP_I;
753   case NVPTX::SUST_P_1D_V4B8_TRAP_R:
754     return NVPTX::SUST_P_1D_V4B8_TRAP_I;
755   case NVPTX::SUST_P_1D_V4B16_TRAP_R:
756     return NVPTX::SUST_P_1D_V4B16_TRAP_I;
757   case NVPTX::SUST_P_1D_V4B32_TRAP_R:
758     return NVPTX::SUST_P_1D_V4B32_TRAP_I;
759   case NVPTX::SUST_P_1D_ARRAY_B8_TRAP_R:
760     return NVPTX::SUST_P_1D_ARRAY_B8_TRAP_I;
761   case NVPTX::SUST_P_1D_ARRAY_B16_TRAP_R:
762     return NVPTX::SUST_P_1D_ARRAY_B16_TRAP_I;
763   case NVPTX::SUST_P_1D_ARRAY_B32_TRAP_R:
764     return NVPTX::SUST_P_1D_ARRAY_B32_TRAP_I;
765   case NVPTX::SUST_P_1D_ARRAY_V2B8_TRAP_R:
766     return NVPTX::SUST_P_1D_ARRAY_V2B8_TRAP_I;
767   case NVPTX::SUST_P_1D_ARRAY_V2B16_TRAP_R:
768     return NVPTX::SUST_P_1D_ARRAY_V2B16_TRAP_I;
769   case NVPTX::SUST_P_1D_ARRAY_V2B32_TRAP_R:
770     return NVPTX::SUST_P_1D_ARRAY_V2B32_TRAP_I;
771   case NVPTX::SUST_P_1D_ARRAY_V4B8_TRAP_R:
772     return NVPTX::SUST_P_1D_ARRAY_V4B8_TRAP_I;
773   case NVPTX::SUST_P_1D_ARRAY_V4B16_TRAP_R:
774     return NVPTX::SUST_P_1D_ARRAY_V4B16_TRAP_I;
775   case NVPTX::SUST_P_1D_ARRAY_V4B32_TRAP_R:
776     return NVPTX::SUST_P_1D_ARRAY_V4B32_TRAP_I;
777   case NVPTX::SUST_P_2D_B8_TRAP_R:
778     return NVPTX::SUST_P_2D_B8_TRAP_I;
779   case NVPTX::SUST_P_2D_B16_TRAP_R:
780     return NVPTX::SUST_P_2D_B16_TRAP_I;
781   case NVPTX::SUST_P_2D_B32_TRAP_R:
782     return NVPTX::SUST_P_2D_B32_TRAP_I;
783   case NVPTX::SUST_P_2D_V2B8_TRAP_R:
784     return NVPTX::SUST_P_2D_V2B8_TRAP_I;
785   case NVPTX::SUST_P_2D_V2B16_TRAP_R:
786     return NVPTX::SUST_P_2D_V2B16_TRAP_I;
787   case NVPTX::SUST_P_2D_V2B32_TRAP_R:
788     return NVPTX::SUST_P_2D_V2B32_TRAP_I;
789   case NVPTX::SUST_P_2D_V4B8_TRAP_R:
790     return NVPTX::SUST_P_2D_V4B8_TRAP_I;
791   case NVPTX::SUST_P_2D_V4B16_TRAP_R:
792     return NVPTX::SUST_P_2D_V4B16_TRAP_I;
793   case NVPTX::SUST_P_2D_V4B32_TRAP_R:
794     return NVPTX::SUST_P_2D_V4B32_TRAP_I;
795   case NVPTX::SUST_P_2D_ARRAY_B8_TRAP_R:
796     return NVPTX::SUST_P_2D_ARRAY_B8_TRAP_I;
797   case NVPTX::SUST_P_2D_ARRAY_B16_TRAP_R:
798     return NVPTX::SUST_P_2D_ARRAY_B16_TRAP_I;
799   case NVPTX::SUST_P_2D_ARRAY_B32_TRAP_R:
800     return NVPTX::SUST_P_2D_ARRAY_B32_TRAP_I;
801   case NVPTX::SUST_P_2D_ARRAY_V2B8_TRAP_R:
802     return NVPTX::SUST_P_2D_ARRAY_V2B8_TRAP_I;
803   case NVPTX::SUST_P_2D_ARRAY_V2B16_TRAP_R:
804     return NVPTX::SUST_P_2D_ARRAY_V2B16_TRAP_I;
805   case NVPTX::SUST_P_2D_ARRAY_V2B32_TRAP_R:
806     return NVPTX::SUST_P_2D_ARRAY_V2B32_TRAP_I;
807   case NVPTX::SUST_P_2D_ARRAY_V4B8_TRAP_R:
808     return NVPTX::SUST_P_2D_ARRAY_V4B8_TRAP_I;
809   case NVPTX::SUST_P_2D_ARRAY_V4B16_TRAP_R:
810     return NVPTX::SUST_P_2D_ARRAY_V4B16_TRAP_I;
811   case NVPTX::SUST_P_2D_ARRAY_V4B32_TRAP_R:
812     return NVPTX::SUST_P_2D_ARRAY_V4B32_TRAP_I;
813   case NVPTX::SUST_P_3D_B8_TRAP_R:
814     return NVPTX::SUST_P_3D_B8_TRAP_I;
815   case NVPTX::SUST_P_3D_B16_TRAP_R:
816     return NVPTX::SUST_P_3D_B16_TRAP_I;
817   case NVPTX::SUST_P_3D_B32_TRAP_R:
818     return NVPTX::SUST_P_3D_B32_TRAP_I;
819   case NVPTX::SUST_P_3D_V2B8_TRAP_R:
820     return NVPTX::SUST_P_3D_V2B8_TRAP_I;
821   case NVPTX::SUST_P_3D_V2B16_TRAP_R:
822     return NVPTX::SUST_P_3D_V2B16_TRAP_I;
823   case NVPTX::SUST_P_3D_V2B32_TRAP_R:
824     return NVPTX::SUST_P_3D_V2B32_TRAP_I;
825   case NVPTX::SUST_P_3D_V4B8_TRAP_R:
826     return NVPTX::SUST_P_3D_V4B8_TRAP_I;
827   case NVPTX::SUST_P_3D_V4B16_TRAP_R:
828     return NVPTX::SUST_P_3D_V4B16_TRAP_I;
829   case NVPTX::SUST_P_3D_V4B32_TRAP_R:
830     return NVPTX::SUST_P_3D_V4B32_TRAP_I;
831   default:
832     llvm_unreachable("Unhandled SUST opcode");
833   }
834 }
835 
836 static unsigned texRegisterToIndexOpcode(unsigned RegOC) {
837   switch (RegOC) {
838   case NVPTX::TEX_1D_F32_S32_RR:
839     return NVPTX::TEX_1D_F32_S32_IR;
840   case NVPTX::TEX_1D_F32_S32_RI:
841     return NVPTX::TEX_1D_F32_S32_II;
842   case NVPTX::TEX_1D_F32_F32_RR:
843     return NVPTX::TEX_1D_F32_F32_IR;
844   case NVPTX::TEX_1D_F32_F32_RI:
845     return NVPTX::TEX_1D_F32_F32_II;
846   case NVPTX::TEX_1D_F32_F32_LEVEL_RR:
847     return NVPTX::TEX_1D_F32_F32_LEVEL_IR;
848   case NVPTX::TEX_1D_F32_F32_LEVEL_RI:
849     return NVPTX::TEX_1D_F32_F32_LEVEL_II;
850   case NVPTX::TEX_1D_F32_F32_GRAD_RR:
851     return NVPTX::TEX_1D_F32_F32_GRAD_IR;
852   case NVPTX::TEX_1D_F32_F32_GRAD_RI:
853     return NVPTX::TEX_1D_F32_F32_GRAD_II;
854   case NVPTX::TEX_1D_S32_S32_RR:
855     return NVPTX::TEX_1D_S32_S32_IR;
856   case NVPTX::TEX_1D_S32_S32_RI:
857     return NVPTX::TEX_1D_S32_S32_II;
858   case NVPTX::TEX_1D_S32_F32_RR:
859     return NVPTX::TEX_1D_S32_F32_IR;
860   case NVPTX::TEX_1D_S32_F32_RI:
861     return NVPTX::TEX_1D_S32_F32_II;
862   case NVPTX::TEX_1D_S32_F32_LEVEL_RR:
863     return NVPTX::TEX_1D_S32_F32_LEVEL_IR;
864   case NVPTX::TEX_1D_S32_F32_LEVEL_RI:
865     return NVPTX::TEX_1D_S32_F32_LEVEL_II;
866   case NVPTX::TEX_1D_S32_F32_GRAD_RR:
867     return NVPTX::TEX_1D_S32_F32_GRAD_IR;
868   case NVPTX::TEX_1D_S32_F32_GRAD_RI:
869     return NVPTX::TEX_1D_S32_F32_GRAD_II;
870   case NVPTX::TEX_1D_U32_S32_RR:
871     return NVPTX::TEX_1D_U32_S32_IR;
872   case NVPTX::TEX_1D_U32_S32_RI:
873     return NVPTX::TEX_1D_U32_S32_II;
874   case NVPTX::TEX_1D_U32_F32_RR:
875     return NVPTX::TEX_1D_U32_F32_IR;
876   case NVPTX::TEX_1D_U32_F32_RI:
877     return NVPTX::TEX_1D_U32_F32_II;
878   case NVPTX::TEX_1D_U32_F32_LEVEL_RR:
879     return NVPTX::TEX_1D_U32_F32_LEVEL_IR;
880   case NVPTX::TEX_1D_U32_F32_LEVEL_RI:
881     return NVPTX::TEX_1D_U32_F32_LEVEL_II;
882   case NVPTX::TEX_1D_U32_F32_GRAD_RR:
883     return NVPTX::TEX_1D_U32_F32_GRAD_IR;
884   case NVPTX::TEX_1D_U32_F32_GRAD_RI:
885     return NVPTX::TEX_1D_U32_F32_GRAD_II;
886   case NVPTX::TEX_1D_ARRAY_F32_S32_RR:
887     return NVPTX::TEX_1D_ARRAY_F32_S32_IR;
888   case NVPTX::TEX_1D_ARRAY_F32_S32_RI:
889     return NVPTX::TEX_1D_ARRAY_F32_S32_II;
890   case NVPTX::TEX_1D_ARRAY_F32_F32_RR:
891     return NVPTX::TEX_1D_ARRAY_F32_F32_IR;
892   case NVPTX::TEX_1D_ARRAY_F32_F32_RI:
893     return NVPTX::TEX_1D_ARRAY_F32_F32_II;
894   case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RR:
895     return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_IR;
896   case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RI:
897     return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_II;
898   case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RR:
899     return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_IR;
900   case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RI:
901     return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_II;
902   case NVPTX::TEX_1D_ARRAY_S32_S32_RR:
903     return NVPTX::TEX_1D_ARRAY_S32_S32_IR;
904   case NVPTX::TEX_1D_ARRAY_S32_S32_RI:
905     return NVPTX::TEX_1D_ARRAY_S32_S32_II;
906   case NVPTX::TEX_1D_ARRAY_S32_F32_RR:
907     return NVPTX::TEX_1D_ARRAY_S32_F32_IR;
908   case NVPTX::TEX_1D_ARRAY_S32_F32_RI:
909     return NVPTX::TEX_1D_ARRAY_S32_F32_II;
910   case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RR:
911     return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_IR;
912   case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RI:
913     return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_II;
914   case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RR:
915     return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_IR;
916   case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RI:
917     return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_II;
918   case NVPTX::TEX_1D_ARRAY_U32_S32_RR:
919     return NVPTX::TEX_1D_ARRAY_U32_S32_IR;
920   case NVPTX::TEX_1D_ARRAY_U32_S32_RI:
921     return NVPTX::TEX_1D_ARRAY_U32_S32_II;
922   case NVPTX::TEX_1D_ARRAY_U32_F32_RR:
923     return NVPTX::TEX_1D_ARRAY_U32_F32_IR;
924   case NVPTX::TEX_1D_ARRAY_U32_F32_RI:
925     return NVPTX::TEX_1D_ARRAY_U32_F32_II;
926   case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RR:
927     return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_IR;
928   case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RI:
929     return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_II;
930   case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RR:
931     return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_IR;
932   case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RI:
933     return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_II;
934   case NVPTX::TEX_2D_F32_S32_RR:
935     return NVPTX::TEX_2D_F32_S32_IR;
936   case NVPTX::TEX_2D_F32_S32_RI:
937     return NVPTX::TEX_2D_F32_S32_II;
938   case NVPTX::TEX_2D_F32_F32_RR:
939     return NVPTX::TEX_2D_F32_F32_IR;
940   case NVPTX::TEX_2D_F32_F32_RI:
941     return NVPTX::TEX_2D_F32_F32_II;
942   case NVPTX::TEX_2D_F32_F32_LEVEL_RR:
943     return NVPTX::TEX_2D_F32_F32_LEVEL_IR;
944   case NVPTX::TEX_2D_F32_F32_LEVEL_RI:
945     return NVPTX::TEX_2D_F32_F32_LEVEL_II;
946   case NVPTX::TEX_2D_F32_F32_GRAD_RR:
947     return NVPTX::TEX_2D_F32_F32_GRAD_IR;
948   case NVPTX::TEX_2D_F32_F32_GRAD_RI:
949     return NVPTX::TEX_2D_F32_F32_GRAD_II;
950   case NVPTX::TEX_2D_S32_S32_RR:
951     return NVPTX::TEX_2D_S32_S32_IR;
952   case NVPTX::TEX_2D_S32_S32_RI:
953     return NVPTX::TEX_2D_S32_S32_II;
954   case NVPTX::TEX_2D_S32_F32_RR:
955     return NVPTX::TEX_2D_S32_F32_IR;
956   case NVPTX::TEX_2D_S32_F32_RI:
957     return NVPTX::TEX_2D_S32_F32_II;
958   case NVPTX::TEX_2D_S32_F32_LEVEL_RR:
959     return NVPTX::TEX_2D_S32_F32_LEVEL_IR;
960   case NVPTX::TEX_2D_S32_F32_LEVEL_RI:
961     return NVPTX::TEX_2D_S32_F32_LEVEL_II;
962   case NVPTX::TEX_2D_S32_F32_GRAD_RR:
963     return NVPTX::TEX_2D_S32_F32_GRAD_IR;
964   case NVPTX::TEX_2D_S32_F32_GRAD_RI:
965     return NVPTX::TEX_2D_S32_F32_GRAD_II;
966   case NVPTX::TEX_2D_U32_S32_RR:
967     return NVPTX::TEX_2D_U32_S32_IR;
968   case NVPTX::TEX_2D_U32_S32_RI:
969     return NVPTX::TEX_2D_U32_S32_II;
970   case NVPTX::TEX_2D_U32_F32_RR:
971     return NVPTX::TEX_2D_U32_F32_IR;
972   case NVPTX::TEX_2D_U32_F32_RI:
973     return NVPTX::TEX_2D_U32_F32_II;
974   case NVPTX::TEX_2D_U32_F32_LEVEL_RR:
975     return NVPTX::TEX_2D_U32_F32_LEVEL_IR;
976   case NVPTX::TEX_2D_U32_F32_LEVEL_RI:
977     return NVPTX::TEX_2D_U32_F32_LEVEL_II;
978   case NVPTX::TEX_2D_U32_F32_GRAD_RR:
979     return NVPTX::TEX_2D_U32_F32_GRAD_IR;
980   case NVPTX::TEX_2D_U32_F32_GRAD_RI:
981     return NVPTX::TEX_2D_U32_F32_GRAD_II;
982   case NVPTX::TEX_2D_ARRAY_F32_S32_RR:
983     return NVPTX::TEX_2D_ARRAY_F32_S32_IR;
984   case NVPTX::TEX_2D_ARRAY_F32_S32_RI:
985     return NVPTX::TEX_2D_ARRAY_F32_S32_II;
986   case NVPTX::TEX_2D_ARRAY_F32_F32_RR:
987     return NVPTX::TEX_2D_ARRAY_F32_F32_IR;
988   case NVPTX::TEX_2D_ARRAY_F32_F32_RI:
989     return NVPTX::TEX_2D_ARRAY_F32_F32_II;
990   case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RR:
991     return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_IR;
992   case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RI:
993     return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_II;
994   case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RR:
995     return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_IR;
996   case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RI:
997     return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_II;
998   case NVPTX::TEX_2D_ARRAY_S32_S32_RR:
999     return NVPTX::TEX_2D_ARRAY_S32_S32_IR;
1000   case NVPTX::TEX_2D_ARRAY_S32_S32_RI:
1001     return NVPTX::TEX_2D_ARRAY_S32_S32_II;
1002   case NVPTX::TEX_2D_ARRAY_S32_F32_RR:
1003     return NVPTX::TEX_2D_ARRAY_S32_F32_IR;
1004   case NVPTX::TEX_2D_ARRAY_S32_F32_RI:
1005     return NVPTX::TEX_2D_ARRAY_S32_F32_II;
1006   case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RR:
1007     return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_IR;
1008   case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RI:
1009     return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_II;
1010   case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RR:
1011     return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_IR;
1012   case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RI:
1013     return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_II;
1014   case NVPTX::TEX_2D_ARRAY_U32_S32_RR:
1015     return NVPTX::TEX_2D_ARRAY_U32_S32_IR;
1016   case NVPTX::TEX_2D_ARRAY_U32_S32_RI:
1017     return NVPTX::TEX_2D_ARRAY_U32_S32_II;
1018   case NVPTX::TEX_2D_ARRAY_U32_F32_RR:
1019     return NVPTX::TEX_2D_ARRAY_U32_F32_IR;
1020   case NVPTX::TEX_2D_ARRAY_U32_F32_RI:
1021     return NVPTX::TEX_2D_ARRAY_U32_F32_II;
1022   case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RR:
1023     return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_IR;
1024   case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RI:
1025     return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_II;
1026   case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RR:
1027     return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_IR;
1028   case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RI:
1029     return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_II;
1030   case NVPTX::TEX_3D_F32_S32_RR:
1031     return NVPTX::TEX_3D_F32_S32_IR;
1032   case NVPTX::TEX_3D_F32_S32_RI:
1033     return NVPTX::TEX_3D_F32_S32_II;
1034   case NVPTX::TEX_3D_F32_F32_RR:
1035     return NVPTX::TEX_3D_F32_F32_IR;
1036   case NVPTX::TEX_3D_F32_F32_RI:
1037     return NVPTX::TEX_3D_F32_F32_II;
1038   case NVPTX::TEX_3D_F32_F32_LEVEL_RR:
1039     return NVPTX::TEX_3D_F32_F32_LEVEL_IR;
1040   case NVPTX::TEX_3D_F32_F32_LEVEL_RI:
1041     return NVPTX::TEX_3D_F32_F32_LEVEL_II;
1042   case NVPTX::TEX_3D_F32_F32_GRAD_RR:
1043     return NVPTX::TEX_3D_F32_F32_GRAD_IR;
1044   case NVPTX::TEX_3D_F32_F32_GRAD_RI:
1045     return NVPTX::TEX_3D_F32_F32_GRAD_II;
1046   case NVPTX::TEX_3D_S32_S32_RR:
1047     return NVPTX::TEX_3D_S32_S32_IR;
1048   case NVPTX::TEX_3D_S32_S32_RI:
1049     return NVPTX::TEX_3D_S32_S32_II;
1050   case NVPTX::TEX_3D_S32_F32_RR:
1051     return NVPTX::TEX_3D_S32_F32_IR;
1052   case NVPTX::TEX_3D_S32_F32_RI:
1053     return NVPTX::TEX_3D_S32_F32_II;
1054   case NVPTX::TEX_3D_S32_F32_LEVEL_RR:
1055     return NVPTX::TEX_3D_S32_F32_LEVEL_IR;
1056   case NVPTX::TEX_3D_S32_F32_LEVEL_RI:
1057     return NVPTX::TEX_3D_S32_F32_LEVEL_II;
1058   case NVPTX::TEX_3D_S32_F32_GRAD_RR:
1059     return NVPTX::TEX_3D_S32_F32_GRAD_IR;
1060   case NVPTX::TEX_3D_S32_F32_GRAD_RI:
1061     return NVPTX::TEX_3D_S32_F32_GRAD_II;
1062   case NVPTX::TEX_3D_U32_S32_RR:
1063     return NVPTX::TEX_3D_U32_S32_IR;
1064   case NVPTX::TEX_3D_U32_S32_RI:
1065     return NVPTX::TEX_3D_U32_S32_II;
1066   case NVPTX::TEX_3D_U32_F32_RR:
1067     return NVPTX::TEX_3D_U32_F32_IR;
1068   case NVPTX::TEX_3D_U32_F32_RI:
1069     return NVPTX::TEX_3D_U32_F32_II;
1070   case NVPTX::TEX_3D_U32_F32_LEVEL_RR:
1071     return NVPTX::TEX_3D_U32_F32_LEVEL_IR;
1072   case NVPTX::TEX_3D_U32_F32_LEVEL_RI:
1073     return NVPTX::TEX_3D_U32_F32_LEVEL_II;
1074   case NVPTX::TEX_3D_U32_F32_GRAD_RR:
1075     return NVPTX::TEX_3D_U32_F32_GRAD_IR;
1076   case NVPTX::TEX_3D_U32_F32_GRAD_RI:
1077     return NVPTX::TEX_3D_U32_F32_GRAD_II;
1078   case NVPTX::TEX_CUBE_F32_F32_RR:
1079     return NVPTX::TEX_CUBE_F32_F32_IR;
1080   case NVPTX::TEX_CUBE_F32_F32_RI:
1081     return NVPTX::TEX_CUBE_F32_F32_II;
1082   case NVPTX::TEX_CUBE_F32_F32_LEVEL_RR:
1083     return NVPTX::TEX_CUBE_F32_F32_LEVEL_IR;
1084   case NVPTX::TEX_CUBE_F32_F32_LEVEL_RI:
1085     return NVPTX::TEX_CUBE_F32_F32_LEVEL_II;
1086   case NVPTX::TEX_CUBE_S32_F32_RR:
1087     return NVPTX::TEX_CUBE_S32_F32_IR;
1088   case NVPTX::TEX_CUBE_S32_F32_RI:
1089     return NVPTX::TEX_CUBE_S32_F32_II;
1090   case NVPTX::TEX_CUBE_S32_F32_LEVEL_RR:
1091     return NVPTX::TEX_CUBE_S32_F32_LEVEL_IR;
1092   case NVPTX::TEX_CUBE_S32_F32_LEVEL_RI:
1093     return NVPTX::TEX_CUBE_S32_F32_LEVEL_II;
1094   case NVPTX::TEX_CUBE_U32_F32_RR:
1095     return NVPTX::TEX_CUBE_U32_F32_IR;
1096   case NVPTX::TEX_CUBE_U32_F32_RI:
1097     return NVPTX::TEX_CUBE_U32_F32_II;
1098   case NVPTX::TEX_CUBE_U32_F32_LEVEL_RR:
1099     return NVPTX::TEX_CUBE_U32_F32_LEVEL_IR;
1100   case NVPTX::TEX_CUBE_U32_F32_LEVEL_RI:
1101     return NVPTX::TEX_CUBE_U32_F32_LEVEL_II;
1102   case NVPTX::TEX_CUBE_ARRAY_F32_F32_RR:
1103     return NVPTX::TEX_CUBE_ARRAY_F32_F32_IR;
1104   case NVPTX::TEX_CUBE_ARRAY_F32_F32_RI:
1105     return NVPTX::TEX_CUBE_ARRAY_F32_F32_II;
1106   case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RR:
1107     return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_IR;
1108   case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RI:
1109     return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_II;
1110   case NVPTX::TEX_CUBE_ARRAY_S32_F32_RR:
1111     return NVPTX::TEX_CUBE_ARRAY_S32_F32_IR;
1112   case NVPTX::TEX_CUBE_ARRAY_S32_F32_RI:
1113     return NVPTX::TEX_CUBE_ARRAY_S32_F32_II;
1114   case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RR:
1115     return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_IR;
1116   case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RI:
1117     return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_II;
1118   case NVPTX::TEX_CUBE_ARRAY_U32_F32_RR:
1119     return NVPTX::TEX_CUBE_ARRAY_U32_F32_IR;
1120   case NVPTX::TEX_CUBE_ARRAY_U32_F32_RI:
1121     return NVPTX::TEX_CUBE_ARRAY_U32_F32_II;
1122   case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RR:
1123     return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_IR;
1124   case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RI:
1125     return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_II;
1126   case NVPTX::TLD4_R_2D_F32_F32_RR:
1127     return NVPTX::TLD4_R_2D_F32_F32_IR;
1128   case NVPTX::TLD4_R_2D_F32_F32_RI:
1129     return NVPTX::TLD4_R_2D_F32_F32_II;
1130   case NVPTX::TLD4_G_2D_F32_F32_RR:
1131     return NVPTX::TLD4_G_2D_F32_F32_IR;
1132   case NVPTX::TLD4_G_2D_F32_F32_RI:
1133     return NVPTX::TLD4_G_2D_F32_F32_II;
1134   case NVPTX::TLD4_B_2D_F32_F32_RR:
1135     return NVPTX::TLD4_B_2D_F32_F32_IR;
1136   case NVPTX::TLD4_B_2D_F32_F32_RI:
1137     return NVPTX::TLD4_B_2D_F32_F32_II;
1138   case NVPTX::TLD4_A_2D_F32_F32_RR:
1139     return NVPTX::TLD4_A_2D_F32_F32_IR;
1140   case NVPTX::TLD4_A_2D_F32_F32_RI:
1141     return NVPTX::TLD4_A_2D_F32_F32_II;
1142   case NVPTX::TLD4_R_2D_S32_F32_RR:
1143     return NVPTX::TLD4_R_2D_S32_F32_IR;
1144   case NVPTX::TLD4_R_2D_S32_F32_RI:
1145     return NVPTX::TLD4_R_2D_S32_F32_II;
1146   case NVPTX::TLD4_G_2D_S32_F32_RR:
1147     return NVPTX::TLD4_G_2D_S32_F32_IR;
1148   case NVPTX::TLD4_G_2D_S32_F32_RI:
1149     return NVPTX::TLD4_G_2D_S32_F32_II;
1150   case NVPTX::TLD4_B_2D_S32_F32_RR:
1151     return NVPTX::TLD4_B_2D_S32_F32_IR;
1152   case NVPTX::TLD4_B_2D_S32_F32_RI:
1153     return NVPTX::TLD4_B_2D_S32_F32_II;
1154   case NVPTX::TLD4_A_2D_S32_F32_RR:
1155     return NVPTX::TLD4_A_2D_S32_F32_IR;
1156   case NVPTX::TLD4_A_2D_S32_F32_RI:
1157     return NVPTX::TLD4_A_2D_S32_F32_II;
1158   case NVPTX::TLD4_R_2D_U32_F32_RR:
1159     return NVPTX::TLD4_R_2D_U32_F32_IR;
1160   case NVPTX::TLD4_R_2D_U32_F32_RI:
1161     return NVPTX::TLD4_R_2D_U32_F32_II;
1162   case NVPTX::TLD4_G_2D_U32_F32_RR:
1163     return NVPTX::TLD4_G_2D_U32_F32_IR;
1164   case NVPTX::TLD4_G_2D_U32_F32_RI:
1165     return NVPTX::TLD4_G_2D_U32_F32_II;
1166   case NVPTX::TLD4_B_2D_U32_F32_RR:
1167     return NVPTX::TLD4_B_2D_U32_F32_IR;
1168   case NVPTX::TLD4_B_2D_U32_F32_RI:
1169     return NVPTX::TLD4_B_2D_U32_F32_II;
1170   case NVPTX::TLD4_A_2D_U32_F32_RR:
1171     return NVPTX::TLD4_A_2D_U32_F32_IR;
1172   case NVPTX::TLD4_A_2D_U32_F32_RI:
1173     return NVPTX::TLD4_A_2D_U32_F32_II;
1174   case NVPTX::TEX_UNIFIED_1D_F32_S32_R:
1175     return NVPTX::TEX_UNIFIED_1D_F32_S32_I;
1176   case NVPTX::TEX_UNIFIED_1D_F32_F32_R:
1177     return NVPTX::TEX_UNIFIED_1D_F32_F32_I;
1178   case NVPTX::TEX_UNIFIED_1D_F32_F32_LEVEL_R:
1179     return NVPTX::TEX_UNIFIED_1D_F32_F32_LEVEL_I;
1180   case NVPTX::TEX_UNIFIED_1D_F32_F32_GRAD_R:
1181     return NVPTX::TEX_UNIFIED_1D_F32_F32_GRAD_I;
1182   case NVPTX::TEX_UNIFIED_1D_S32_S32_R:
1183     return NVPTX::TEX_UNIFIED_1D_S32_S32_I;
1184   case NVPTX::TEX_UNIFIED_1D_S32_F32_R:
1185     return NVPTX::TEX_UNIFIED_1D_S32_F32_I;
1186   case NVPTX::TEX_UNIFIED_1D_S32_F32_LEVEL_R:
1187     return NVPTX::TEX_UNIFIED_1D_S32_F32_LEVEL_I;
1188   case NVPTX::TEX_UNIFIED_1D_S32_F32_GRAD_R:
1189     return NVPTX::TEX_UNIFIED_1D_S32_F32_GRAD_I;
1190   case NVPTX::TEX_UNIFIED_1D_U32_S32_R:
1191     return NVPTX::TEX_UNIFIED_1D_U32_S32_I;
1192   case NVPTX::TEX_UNIFIED_1D_U32_F32_R:
1193     return NVPTX::TEX_UNIFIED_1D_U32_F32_I;
1194   case NVPTX::TEX_UNIFIED_1D_U32_F32_LEVEL_R:
1195     return NVPTX::TEX_UNIFIED_1D_U32_F32_LEVEL_I;
1196   case NVPTX::TEX_UNIFIED_1D_U32_F32_GRAD_R:
1197     return NVPTX::TEX_UNIFIED_1D_U32_F32_GRAD_I;
1198   case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_S32_R:
1199     return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_S32_I;
1200   case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_R:
1201     return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_I;
1202   case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_LEVEL_R:
1203     return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_LEVEL_I;
1204   case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_GRAD_R:
1205     return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_GRAD_I;
1206   case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_S32_R:
1207     return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_S32_I;
1208   case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_R:
1209     return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_I;
1210   case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_LEVEL_R:
1211     return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_LEVEL_I;
1212   case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_GRAD_R:
1213     return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_GRAD_I;
1214   case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_S32_R:
1215     return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_S32_I;
1216   case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_R:
1217     return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_I;
1218   case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_LEVEL_R:
1219     return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_LEVEL_I;
1220   case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_GRAD_R:
1221     return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_GRAD_I;
1222   case NVPTX::TEX_UNIFIED_2D_F32_S32_R:
1223     return NVPTX::TEX_UNIFIED_2D_F32_S32_I;
1224   case NVPTX::TEX_UNIFIED_2D_F32_F32_R:
1225     return NVPTX::TEX_UNIFIED_2D_F32_F32_I;
1226   case NVPTX::TEX_UNIFIED_2D_F32_F32_LEVEL_R:
1227     return NVPTX::TEX_UNIFIED_2D_F32_F32_LEVEL_I;
1228   case NVPTX::TEX_UNIFIED_2D_F32_F32_GRAD_R:
1229     return NVPTX::TEX_UNIFIED_2D_F32_F32_GRAD_I;
1230   case NVPTX::TEX_UNIFIED_2D_S32_S32_R:
1231     return NVPTX::TEX_UNIFIED_2D_S32_S32_I;
1232   case NVPTX::TEX_UNIFIED_2D_S32_F32_R:
1233     return NVPTX::TEX_UNIFIED_2D_S32_F32_I;
1234   case NVPTX::TEX_UNIFIED_2D_S32_F32_LEVEL_R:
1235     return NVPTX::TEX_UNIFIED_2D_S32_F32_LEVEL_I;
1236   case NVPTX::TEX_UNIFIED_2D_S32_F32_GRAD_R:
1237     return NVPTX::TEX_UNIFIED_2D_S32_F32_GRAD_I;
1238   case NVPTX::TEX_UNIFIED_2D_U32_S32_R:
1239     return NVPTX::TEX_UNIFIED_2D_U32_S32_I;
1240   case NVPTX::TEX_UNIFIED_2D_U32_F32_R:
1241     return NVPTX::TEX_UNIFIED_2D_U32_F32_I;
1242   case NVPTX::TEX_UNIFIED_2D_U32_F32_LEVEL_R:
1243     return NVPTX::TEX_UNIFIED_2D_U32_F32_LEVEL_I;
1244   case NVPTX::TEX_UNIFIED_2D_U32_F32_GRAD_R:
1245     return NVPTX::TEX_UNIFIED_2D_U32_F32_GRAD_I;
1246   case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_S32_R:
1247     return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_S32_I;
1248   case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_R:
1249     return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_I;
1250   case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_LEVEL_R:
1251     return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_LEVEL_I;
1252   case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_GRAD_R:
1253     return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_GRAD_I;
1254   case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_S32_R:
1255     return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_S32_I;
1256   case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_R:
1257     return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_I;
1258   case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_LEVEL_R:
1259     return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_LEVEL_I;
1260   case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_GRAD_R:
1261     return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_GRAD_I;
1262   case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_S32_R:
1263     return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_S32_I;
1264   case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_R:
1265     return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_I;
1266   case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_LEVEL_R:
1267     return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_LEVEL_I;
1268   case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_GRAD_R:
1269     return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_GRAD_I;
1270   case NVPTX::TEX_UNIFIED_3D_F32_S32_R:
1271     return NVPTX::TEX_UNIFIED_3D_F32_S32_I;
1272   case NVPTX::TEX_UNIFIED_3D_F32_F32_R:
1273     return NVPTX::TEX_UNIFIED_3D_F32_F32_I;
1274   case NVPTX::TEX_UNIFIED_3D_F32_F32_LEVEL_R:
1275     return NVPTX::TEX_UNIFIED_3D_F32_F32_LEVEL_I;
1276   case NVPTX::TEX_UNIFIED_3D_F32_F32_GRAD_R:
1277     return NVPTX::TEX_UNIFIED_3D_F32_F32_GRAD_I;
1278   case NVPTX::TEX_UNIFIED_3D_S32_S32_R:
1279     return NVPTX::TEX_UNIFIED_3D_S32_S32_I;
1280   case NVPTX::TEX_UNIFIED_3D_S32_F32_R:
1281     return NVPTX::TEX_UNIFIED_3D_S32_F32_I;
1282   case NVPTX::TEX_UNIFIED_3D_S32_F32_LEVEL_R:
1283     return NVPTX::TEX_UNIFIED_3D_S32_F32_LEVEL_I;
1284   case NVPTX::TEX_UNIFIED_3D_S32_F32_GRAD_R:
1285     return NVPTX::TEX_UNIFIED_3D_S32_F32_GRAD_I;
1286   case NVPTX::TEX_UNIFIED_3D_U32_S32_R:
1287     return NVPTX::TEX_UNIFIED_3D_U32_S32_I;
1288   case NVPTX::TEX_UNIFIED_3D_U32_F32_R:
1289     return NVPTX::TEX_UNIFIED_3D_U32_F32_I;
1290   case NVPTX::TEX_UNIFIED_3D_U32_F32_LEVEL_R:
1291     return NVPTX::TEX_UNIFIED_3D_U32_F32_LEVEL_I;
1292   case NVPTX::TEX_UNIFIED_3D_U32_F32_GRAD_R:
1293     return NVPTX::TEX_UNIFIED_3D_U32_F32_GRAD_I;
1294   case NVPTX::TEX_UNIFIED_CUBE_F32_F32_R:
1295     return NVPTX::TEX_UNIFIED_CUBE_F32_F32_I;
1296   case NVPTX::TEX_UNIFIED_CUBE_F32_F32_LEVEL_R:
1297     return NVPTX::TEX_UNIFIED_CUBE_F32_F32_LEVEL_I;
1298   case NVPTX::TEX_UNIFIED_CUBE_S32_F32_R:
1299     return NVPTX::TEX_UNIFIED_CUBE_S32_F32_I;
1300   case NVPTX::TEX_UNIFIED_CUBE_S32_F32_LEVEL_R:
1301     return NVPTX::TEX_UNIFIED_CUBE_S32_F32_LEVEL_I;
1302   case NVPTX::TEX_UNIFIED_CUBE_U32_F32_R:
1303     return NVPTX::TEX_UNIFIED_CUBE_U32_F32_I;
1304   case NVPTX::TEX_UNIFIED_CUBE_U32_F32_LEVEL_R:
1305     return NVPTX::TEX_UNIFIED_CUBE_U32_F32_LEVEL_I;
1306   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_R:
1307     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_I;
1308   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_LEVEL_R:
1309     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_LEVEL_I;
1310   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_R:
1311     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_I;
1312   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_LEVEL_R:
1313     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_LEVEL_I;
1314   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_R:
1315     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_I;
1316   case NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_LEVEL_R:
1317     return NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_LEVEL_I;
1318   case NVPTX::TLD4_UNIFIED_R_2D_F32_F32_R:
1319     return NVPTX::TLD4_UNIFIED_R_2D_F32_F32_I;
1320   case NVPTX::TLD4_UNIFIED_G_2D_F32_F32_R:
1321     return NVPTX::TLD4_UNIFIED_G_2D_F32_F32_I;
1322   case NVPTX::TLD4_UNIFIED_B_2D_F32_F32_R:
1323     return NVPTX::TLD4_UNIFIED_B_2D_F32_F32_I;
1324   case NVPTX::TLD4_UNIFIED_A_2D_F32_F32_R:
1325     return NVPTX::TLD4_UNIFIED_A_2D_F32_F32_I;
1326   case NVPTX::TLD4_UNIFIED_R_2D_S32_F32_R:
1327     return NVPTX::TLD4_UNIFIED_R_2D_S32_F32_I;
1328   case NVPTX::TLD4_UNIFIED_G_2D_S32_F32_R:
1329     return NVPTX::TLD4_UNIFIED_G_2D_S32_F32_I;
1330   case NVPTX::TLD4_UNIFIED_B_2D_S32_F32_R:
1331     return NVPTX::TLD4_UNIFIED_B_2D_S32_F32_I;
1332   case NVPTX::TLD4_UNIFIED_A_2D_S32_F32_R:
1333     return NVPTX::TLD4_UNIFIED_A_2D_S32_F32_I;
1334   case NVPTX::TLD4_UNIFIED_R_2D_U32_F32_R:
1335     return NVPTX::TLD4_UNIFIED_R_2D_U32_F32_I;
1336   case NVPTX::TLD4_UNIFIED_G_2D_U32_F32_R:
1337     return NVPTX::TLD4_UNIFIED_G_2D_U32_F32_I;
1338   case NVPTX::TLD4_UNIFIED_B_2D_U32_F32_R:
1339     return NVPTX::TLD4_UNIFIED_B_2D_U32_F32_I;
1340   case NVPTX::TLD4_UNIFIED_A_2D_U32_F32_R:
1341     return NVPTX::TLD4_UNIFIED_A_2D_U32_F32_I;
1342   default:
1343     llvm_unreachable("Unhandled TEX opcode");
1344   };
1345 }
1346 
1347 static unsigned samplerRegisterToIndexOpcode(unsigned RegOC) {
1348   switch (RegOC) {
1349   case NVPTX::TEX_1D_F32_S32_RR:
1350     return NVPTX::TEX_1D_F32_S32_RI;
1351   case NVPTX::TEX_1D_F32_S32_IR:
1352     return NVPTX::TEX_1D_F32_S32_II;
1353   case NVPTX::TEX_1D_F32_F32_RR:
1354     return NVPTX::TEX_1D_F32_F32_RI;
1355   case NVPTX::TEX_1D_F32_F32_IR:
1356     return NVPTX::TEX_1D_F32_F32_II;
1357   case NVPTX::TEX_1D_F32_F32_LEVEL_RR:
1358     return NVPTX::TEX_1D_F32_F32_LEVEL_RI;
1359   case NVPTX::TEX_1D_F32_F32_LEVEL_IR:
1360     return NVPTX::TEX_1D_F32_F32_LEVEL_II;
1361   case NVPTX::TEX_1D_F32_F32_GRAD_RR:
1362     return NVPTX::TEX_1D_F32_F32_GRAD_RI;
1363   case NVPTX::TEX_1D_F32_F32_GRAD_IR:
1364     return NVPTX::TEX_1D_F32_F32_GRAD_II;
1365   case NVPTX::TEX_1D_S32_S32_RR:
1366     return NVPTX::TEX_1D_S32_S32_RI;
1367   case NVPTX::TEX_1D_S32_S32_IR:
1368     return NVPTX::TEX_1D_S32_S32_II;
1369   case NVPTX::TEX_1D_S32_F32_RR:
1370     return NVPTX::TEX_1D_S32_F32_RI;
1371   case NVPTX::TEX_1D_S32_F32_IR:
1372     return NVPTX::TEX_1D_S32_F32_II;
1373   case NVPTX::TEX_1D_S32_F32_LEVEL_RR:
1374     return NVPTX::TEX_1D_S32_F32_LEVEL_RI;
1375   case NVPTX::TEX_1D_S32_F32_LEVEL_IR:
1376     return NVPTX::TEX_1D_S32_F32_LEVEL_II;
1377   case NVPTX::TEX_1D_S32_F32_GRAD_RR:
1378     return NVPTX::TEX_1D_S32_F32_GRAD_RI;
1379   case NVPTX::TEX_1D_S32_F32_GRAD_IR:
1380     return NVPTX::TEX_1D_S32_F32_GRAD_II;
1381   case NVPTX::TEX_1D_U32_S32_RR:
1382     return NVPTX::TEX_1D_U32_S32_RI;
1383   case NVPTX::TEX_1D_U32_S32_IR:
1384     return NVPTX::TEX_1D_U32_S32_II;
1385   case NVPTX::TEX_1D_U32_F32_RR:
1386     return NVPTX::TEX_1D_U32_F32_RI;
1387   case NVPTX::TEX_1D_U32_F32_IR:
1388     return NVPTX::TEX_1D_U32_F32_II;
1389   case NVPTX::TEX_1D_U32_F32_LEVEL_RR:
1390     return NVPTX::TEX_1D_U32_F32_LEVEL_RI;
1391   case NVPTX::TEX_1D_U32_F32_LEVEL_IR:
1392     return NVPTX::TEX_1D_U32_F32_LEVEL_II;
1393   case NVPTX::TEX_1D_U32_F32_GRAD_RR:
1394     return NVPTX::TEX_1D_U32_F32_GRAD_RI;
1395   case NVPTX::TEX_1D_U32_F32_GRAD_IR:
1396     return NVPTX::TEX_1D_U32_F32_GRAD_II;
1397   case NVPTX::TEX_1D_ARRAY_F32_S32_RR:
1398     return NVPTX::TEX_1D_ARRAY_F32_S32_RI;
1399   case NVPTX::TEX_1D_ARRAY_F32_S32_IR:
1400     return NVPTX::TEX_1D_ARRAY_F32_S32_II;
1401   case NVPTX::TEX_1D_ARRAY_F32_F32_RR:
1402     return NVPTX::TEX_1D_ARRAY_F32_F32_RI;
1403   case NVPTX::TEX_1D_ARRAY_F32_F32_IR:
1404     return NVPTX::TEX_1D_ARRAY_F32_F32_II;
1405   case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RR:
1406     return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RI;
1407   case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_IR:
1408     return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_II;
1409   case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RR:
1410     return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RI;
1411   case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_IR:
1412     return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_II;
1413   case NVPTX::TEX_1D_ARRAY_S32_S32_RR:
1414     return NVPTX::TEX_1D_ARRAY_S32_S32_RI;
1415   case NVPTX::TEX_1D_ARRAY_S32_S32_IR:
1416     return NVPTX::TEX_1D_ARRAY_S32_S32_II;
1417   case NVPTX::TEX_1D_ARRAY_S32_F32_RR:
1418     return NVPTX::TEX_1D_ARRAY_S32_F32_RI;
1419   case NVPTX::TEX_1D_ARRAY_S32_F32_IR:
1420     return NVPTX::TEX_1D_ARRAY_S32_F32_II;
1421   case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RR:
1422     return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RI;
1423   case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_IR:
1424     return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_II;
1425   case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RR:
1426     return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RI;
1427   case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_IR:
1428     return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_II;
1429   case NVPTX::TEX_1D_ARRAY_U32_S32_RR:
1430     return NVPTX::TEX_1D_ARRAY_U32_S32_RI;
1431   case NVPTX::TEX_1D_ARRAY_U32_S32_IR:
1432     return NVPTX::TEX_1D_ARRAY_U32_S32_II;
1433   case NVPTX::TEX_1D_ARRAY_U32_F32_RR:
1434     return NVPTX::TEX_1D_ARRAY_U32_F32_RI;
1435   case NVPTX::TEX_1D_ARRAY_U32_F32_IR:
1436     return NVPTX::TEX_1D_ARRAY_U32_F32_II;
1437   case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RR:
1438     return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RI;
1439   case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_IR:
1440     return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_II;
1441   case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RR:
1442     return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RI;
1443   case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_IR:
1444     return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_II;
1445   case NVPTX::TEX_2D_F32_S32_RR:
1446     return NVPTX::TEX_2D_F32_S32_RI;
1447   case NVPTX::TEX_2D_F32_S32_IR:
1448     return NVPTX::TEX_2D_F32_S32_II;
1449   case NVPTX::TEX_2D_F32_F32_RR:
1450     return NVPTX::TEX_2D_F32_F32_RI;
1451   case NVPTX::TEX_2D_F32_F32_IR:
1452     return NVPTX::TEX_2D_F32_F32_II;
1453   case NVPTX::TEX_2D_F32_F32_LEVEL_RR:
1454     return NVPTX::TEX_2D_F32_F32_LEVEL_RI;
1455   case NVPTX::TEX_2D_F32_F32_LEVEL_IR:
1456     return NVPTX::TEX_2D_F32_F32_LEVEL_II;
1457   case NVPTX::TEX_2D_F32_F32_GRAD_RR:
1458     return NVPTX::TEX_2D_F32_F32_GRAD_RI;
1459   case NVPTX::TEX_2D_F32_F32_GRAD_IR:
1460     return NVPTX::TEX_2D_F32_F32_GRAD_II;
1461   case NVPTX::TEX_2D_S32_S32_RR:
1462     return NVPTX::TEX_2D_S32_S32_RI;
1463   case NVPTX::TEX_2D_S32_S32_IR:
1464     return NVPTX::TEX_2D_S32_S32_II;
1465   case NVPTX::TEX_2D_S32_F32_RR:
1466     return NVPTX::TEX_2D_S32_F32_RI;
1467   case NVPTX::TEX_2D_S32_F32_IR:
1468     return NVPTX::TEX_2D_S32_F32_II;
1469   case NVPTX::TEX_2D_S32_F32_LEVEL_RR:
1470     return NVPTX::TEX_2D_S32_F32_LEVEL_RI;
1471   case NVPTX::TEX_2D_S32_F32_LEVEL_IR:
1472     return NVPTX::TEX_2D_S32_F32_LEVEL_II;
1473   case NVPTX::TEX_2D_S32_F32_GRAD_RR:
1474     return NVPTX::TEX_2D_S32_F32_GRAD_RI;
1475   case NVPTX::TEX_2D_S32_F32_GRAD_IR:
1476     return NVPTX::TEX_2D_S32_F32_GRAD_II;
1477   case NVPTX::TEX_2D_U32_S32_RR:
1478     return NVPTX::TEX_2D_U32_S32_RI;
1479   case NVPTX::TEX_2D_U32_S32_IR:
1480     return NVPTX::TEX_2D_U32_S32_II;
1481   case NVPTX::TEX_2D_U32_F32_RR:
1482     return NVPTX::TEX_2D_U32_F32_RI;
1483   case NVPTX::TEX_2D_U32_F32_IR:
1484     return NVPTX::TEX_2D_U32_F32_II;
1485   case NVPTX::TEX_2D_U32_F32_LEVEL_RR:
1486     return NVPTX::TEX_2D_U32_F32_LEVEL_RI;
1487   case NVPTX::TEX_2D_U32_F32_LEVEL_IR:
1488     return NVPTX::TEX_2D_U32_F32_LEVEL_II;
1489   case NVPTX::TEX_2D_U32_F32_GRAD_RR:
1490     return NVPTX::TEX_2D_U32_F32_GRAD_RI;
1491   case NVPTX::TEX_2D_U32_F32_GRAD_IR:
1492     return NVPTX::TEX_2D_U32_F32_GRAD_II;
1493   case NVPTX::TEX_2D_ARRAY_F32_S32_RR:
1494     return NVPTX::TEX_2D_ARRAY_F32_S32_RI;
1495   case NVPTX::TEX_2D_ARRAY_F32_S32_IR:
1496     return NVPTX::TEX_2D_ARRAY_F32_S32_II;
1497   case NVPTX::TEX_2D_ARRAY_F32_F32_RR:
1498     return NVPTX::TEX_2D_ARRAY_F32_F32_RI;
1499   case NVPTX::TEX_2D_ARRAY_F32_F32_IR:
1500     return NVPTX::TEX_2D_ARRAY_F32_F32_II;
1501   case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RR:
1502     return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RI;
1503   case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_IR:
1504     return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_II;
1505   case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RR:
1506     return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RI;
1507   case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_IR:
1508     return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_II;
1509   case NVPTX::TEX_2D_ARRAY_S32_S32_RR:
1510     return NVPTX::TEX_2D_ARRAY_S32_S32_RI;
1511   case NVPTX::TEX_2D_ARRAY_S32_S32_IR:
1512     return NVPTX::TEX_2D_ARRAY_S32_S32_II;
1513   case NVPTX::TEX_2D_ARRAY_S32_F32_RR:
1514     return NVPTX::TEX_2D_ARRAY_S32_F32_RI;
1515   case NVPTX::TEX_2D_ARRAY_S32_F32_IR:
1516     return NVPTX::TEX_2D_ARRAY_S32_F32_II;
1517   case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RR:
1518     return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RI;
1519   case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_IR:
1520     return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_II;
1521   case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RR:
1522     return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RI;
1523   case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_IR:
1524     return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_II;
1525   case NVPTX::TEX_2D_ARRAY_U32_S32_RR:
1526     return NVPTX::TEX_2D_ARRAY_U32_S32_RI;
1527   case NVPTX::TEX_2D_ARRAY_U32_S32_IR:
1528     return NVPTX::TEX_2D_ARRAY_U32_S32_II;
1529   case NVPTX::TEX_2D_ARRAY_U32_F32_RR:
1530     return NVPTX::TEX_2D_ARRAY_U32_F32_RI;
1531   case NVPTX::TEX_2D_ARRAY_U32_F32_IR:
1532     return NVPTX::TEX_2D_ARRAY_U32_F32_II;
1533   case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RR:
1534     return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RI;
1535   case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_IR:
1536     return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_II;
1537   case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RR:
1538     return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RI;
1539   case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_IR:
1540     return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_II;
1541   case NVPTX::TEX_3D_F32_S32_RR:
1542     return NVPTX::TEX_3D_F32_S32_RI;
1543   case NVPTX::TEX_3D_F32_S32_IR:
1544     return NVPTX::TEX_3D_F32_S32_II;
1545   case NVPTX::TEX_3D_F32_F32_RR:
1546     return NVPTX::TEX_3D_F32_F32_RI;
1547   case NVPTX::TEX_3D_F32_F32_IR:
1548     return NVPTX::TEX_3D_F32_F32_II;
1549   case NVPTX::TEX_3D_F32_F32_LEVEL_RR:
1550     return NVPTX::TEX_3D_F32_F32_LEVEL_RI;
1551   case NVPTX::TEX_3D_F32_F32_LEVEL_IR:
1552     return NVPTX::TEX_3D_F32_F32_LEVEL_II;
1553   case NVPTX::TEX_3D_F32_F32_GRAD_RR:
1554     return NVPTX::TEX_3D_F32_F32_GRAD_RI;
1555   case NVPTX::TEX_3D_F32_F32_GRAD_IR:
1556     return NVPTX::TEX_3D_F32_F32_GRAD_II;
1557   case NVPTX::TEX_3D_S32_S32_RR:
1558     return NVPTX::TEX_3D_S32_S32_RI;
1559   case NVPTX::TEX_3D_S32_S32_IR:
1560     return NVPTX::TEX_3D_S32_S32_II;
1561   case NVPTX::TEX_3D_S32_F32_RR:
1562     return NVPTX::TEX_3D_S32_F32_RI;
1563   case NVPTX::TEX_3D_S32_F32_IR:
1564     return NVPTX::TEX_3D_S32_F32_II;
1565   case NVPTX::TEX_3D_S32_F32_LEVEL_RR:
1566     return NVPTX::TEX_3D_S32_F32_LEVEL_RI;
1567   case NVPTX::TEX_3D_S32_F32_LEVEL_IR:
1568     return NVPTX::TEX_3D_S32_F32_LEVEL_II;
1569   case NVPTX::TEX_3D_S32_F32_GRAD_RR:
1570     return NVPTX::TEX_3D_S32_F32_GRAD_RI;
1571   case NVPTX::TEX_3D_S32_F32_GRAD_IR:
1572     return NVPTX::TEX_3D_S32_F32_GRAD_II;
1573   case NVPTX::TEX_3D_U32_S32_RR:
1574     return NVPTX::TEX_3D_U32_S32_RI;
1575   case NVPTX::TEX_3D_U32_S32_IR:
1576     return NVPTX::TEX_3D_U32_S32_II;
1577   case NVPTX::TEX_3D_U32_F32_RR:
1578     return NVPTX::TEX_3D_U32_F32_RI;
1579   case NVPTX::TEX_3D_U32_F32_IR:
1580     return NVPTX::TEX_3D_U32_F32_II;
1581   case NVPTX::TEX_3D_U32_F32_LEVEL_RR:
1582     return NVPTX::TEX_3D_U32_F32_LEVEL_RI;
1583   case NVPTX::TEX_3D_U32_F32_LEVEL_IR:
1584     return NVPTX::TEX_3D_U32_F32_LEVEL_II;
1585   case NVPTX::TEX_3D_U32_F32_GRAD_RR:
1586     return NVPTX::TEX_3D_U32_F32_GRAD_RI;
1587   case NVPTX::TEX_3D_U32_F32_GRAD_IR:
1588     return NVPTX::TEX_3D_U32_F32_GRAD_II;
1589   case NVPTX::TEX_CUBE_F32_F32_RR:
1590     return NVPTX::TEX_CUBE_F32_F32_RI;
1591   case NVPTX::TEX_CUBE_F32_F32_IR:
1592     return NVPTX::TEX_CUBE_F32_F32_II;
1593   case NVPTX::TEX_CUBE_F32_F32_LEVEL_RR:
1594     return NVPTX::TEX_CUBE_F32_F32_LEVEL_RI;
1595   case NVPTX::TEX_CUBE_F32_F32_LEVEL_IR:
1596     return NVPTX::TEX_CUBE_F32_F32_LEVEL_II;
1597   case NVPTX::TEX_CUBE_S32_F32_RR:
1598     return NVPTX::TEX_CUBE_S32_F32_RI;
1599   case NVPTX::TEX_CUBE_S32_F32_IR:
1600     return NVPTX::TEX_CUBE_S32_F32_II;
1601   case NVPTX::TEX_CUBE_S32_F32_LEVEL_RR:
1602     return NVPTX::TEX_CUBE_S32_F32_LEVEL_RI;
1603   case NVPTX::TEX_CUBE_S32_F32_LEVEL_IR:
1604     return NVPTX::TEX_CUBE_S32_F32_LEVEL_II;
1605   case NVPTX::TEX_CUBE_U32_F32_RR:
1606     return NVPTX::TEX_CUBE_U32_F32_RI;
1607   case NVPTX::TEX_CUBE_U32_F32_IR:
1608     return NVPTX::TEX_CUBE_U32_F32_II;
1609   case NVPTX::TEX_CUBE_U32_F32_LEVEL_RR:
1610     return NVPTX::TEX_CUBE_U32_F32_LEVEL_RI;
1611   case NVPTX::TEX_CUBE_U32_F32_LEVEL_IR:
1612     return NVPTX::TEX_CUBE_U32_F32_LEVEL_II;
1613   case NVPTX::TEX_CUBE_ARRAY_F32_F32_RR:
1614     return NVPTX::TEX_CUBE_ARRAY_F32_F32_RI;
1615   case NVPTX::TEX_CUBE_ARRAY_F32_F32_IR:
1616     return NVPTX::TEX_CUBE_ARRAY_F32_F32_II;
1617   case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RR:
1618     return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RI;
1619   case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_IR:
1620     return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_II;
1621   case NVPTX::TEX_CUBE_ARRAY_S32_F32_RR:
1622     return NVPTX::TEX_CUBE_ARRAY_S32_F32_RI;
1623   case NVPTX::TEX_CUBE_ARRAY_S32_F32_IR:
1624     return NVPTX::TEX_CUBE_ARRAY_S32_F32_II;
1625   case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RR:
1626     return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RI;
1627   case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_IR:
1628     return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_II;
1629   case NVPTX::TEX_CUBE_ARRAY_U32_F32_RR:
1630     return NVPTX::TEX_CUBE_ARRAY_U32_F32_RI;
1631   case NVPTX::TEX_CUBE_ARRAY_U32_F32_IR:
1632     return NVPTX::TEX_CUBE_ARRAY_U32_F32_II;
1633   case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RR:
1634     return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RI;
1635   case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_IR:
1636     return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_II;
1637   case NVPTX::TLD4_R_2D_F32_F32_RR:
1638     return NVPTX::TLD4_R_2D_F32_F32_RI;
1639   case NVPTX::TLD4_R_2D_F32_F32_IR:
1640     return NVPTX::TLD4_R_2D_F32_F32_II;
1641   case NVPTX::TLD4_G_2D_F32_F32_RR:
1642     return NVPTX::TLD4_G_2D_F32_F32_RI;
1643   case NVPTX::TLD4_G_2D_F32_F32_IR:
1644     return NVPTX::TLD4_G_2D_F32_F32_II;
1645   case NVPTX::TLD4_B_2D_F32_F32_RR:
1646     return NVPTX::TLD4_B_2D_F32_F32_RI;
1647   case NVPTX::TLD4_B_2D_F32_F32_IR:
1648     return NVPTX::TLD4_B_2D_F32_F32_II;
1649   case NVPTX::TLD4_A_2D_F32_F32_RR:
1650     return NVPTX::TLD4_A_2D_F32_F32_RI;
1651   case NVPTX::TLD4_A_2D_F32_F32_IR:
1652     return NVPTX::TLD4_A_2D_F32_F32_II;
1653   case NVPTX::TLD4_R_2D_S32_F32_RR:
1654     return NVPTX::TLD4_R_2D_S32_F32_RI;
1655   case NVPTX::TLD4_R_2D_S32_F32_IR:
1656     return NVPTX::TLD4_R_2D_S32_F32_II;
1657   case NVPTX::TLD4_G_2D_S32_F32_RR:
1658     return NVPTX::TLD4_G_2D_S32_F32_RI;
1659   case NVPTX::TLD4_G_2D_S32_F32_IR:
1660     return NVPTX::TLD4_G_2D_S32_F32_II;
1661   case NVPTX::TLD4_B_2D_S32_F32_RR:
1662     return NVPTX::TLD4_B_2D_S32_F32_RI;
1663   case NVPTX::TLD4_B_2D_S32_F32_IR:
1664     return NVPTX::TLD4_B_2D_S32_F32_II;
1665   case NVPTX::TLD4_A_2D_S32_F32_RR:
1666     return NVPTX::TLD4_A_2D_S32_F32_RI;
1667   case NVPTX::TLD4_A_2D_S32_F32_IR:
1668     return NVPTX::TLD4_A_2D_S32_F32_II;
1669   case NVPTX::TLD4_R_2D_U32_F32_RR:
1670     return NVPTX::TLD4_R_2D_U32_F32_RI;
1671   case NVPTX::TLD4_R_2D_U32_F32_IR:
1672     return NVPTX::TLD4_R_2D_U32_F32_II;
1673   case NVPTX::TLD4_G_2D_U32_F32_RR:
1674     return NVPTX::TLD4_G_2D_U32_F32_RI;
1675   case NVPTX::TLD4_G_2D_U32_F32_IR:
1676     return NVPTX::TLD4_G_2D_U32_F32_II;
1677   case NVPTX::TLD4_B_2D_U32_F32_RR:
1678     return NVPTX::TLD4_B_2D_U32_F32_RI;
1679   case NVPTX::TLD4_B_2D_U32_F32_IR:
1680     return NVPTX::TLD4_B_2D_U32_F32_II;
1681   case NVPTX::TLD4_A_2D_U32_F32_RR:
1682     return NVPTX::TLD4_A_2D_U32_F32_RI;
1683   case NVPTX::TLD4_A_2D_U32_F32_IR:
1684     return NVPTX::TLD4_A_2D_U32_F32_II;
1685   default:
1686     llvm_unreachable("Unhandled TEX opcode");
1687   };
1688 }
1689 
1690 static unsigned queryRegisterToIndexOpcode(unsigned RegOC) {
1691   switch (RegOC) {
1692   case NVPTX::TXQ_CHANNEL_ORDER_R:
1693     return NVPTX::TXQ_CHANNEL_ORDER_I;
1694   case NVPTX::TXQ_CHANNEL_DATA_TYPE_R:
1695     return NVPTX::TXQ_CHANNEL_DATA_TYPE_I;
1696   case NVPTX::TXQ_WIDTH_R:
1697     return NVPTX::TXQ_WIDTH_I;
1698   case NVPTX::TXQ_HEIGHT_R:
1699     return NVPTX::TXQ_HEIGHT_I;
1700   case NVPTX::TXQ_DEPTH_R:
1701     return NVPTX::TXQ_DEPTH_I;
1702   case NVPTX::TXQ_ARRAY_SIZE_R:
1703     return NVPTX::TXQ_ARRAY_SIZE_I;
1704   case NVPTX::TXQ_NUM_SAMPLES_R:
1705     return NVPTX::TXQ_NUM_SAMPLES_I;
1706   case NVPTX::TXQ_NUM_MIPMAP_LEVELS_R:
1707     return NVPTX::TXQ_NUM_MIPMAP_LEVELS_I;
1708   case NVPTX::SUQ_CHANNEL_ORDER_R:
1709     return NVPTX::SUQ_CHANNEL_ORDER_I;
1710   case NVPTX::SUQ_CHANNEL_DATA_TYPE_R:
1711     return NVPTX::SUQ_CHANNEL_DATA_TYPE_I;
1712   case NVPTX::SUQ_WIDTH_R:
1713     return NVPTX::SUQ_WIDTH_I;
1714   case NVPTX::SUQ_HEIGHT_R:
1715     return NVPTX::SUQ_HEIGHT_I;
1716   case NVPTX::SUQ_DEPTH_R:
1717     return NVPTX::SUQ_DEPTH_I;
1718   case NVPTX::SUQ_ARRAY_SIZE_R:
1719     return NVPTX::SUQ_ARRAY_SIZE_I;
1720   default:
1721     llvm_unreachable("Unhandled TXQ/SUQ opcode");
1722   };
1723 }
1724 
1725 bool NVPTXReplaceImageHandles::processInstr(MachineInstr &MI) {
1726   MachineFunction &MF = *MI.getParent()->getParent();
1727   const MCInstrDesc &MCID = MI.getDesc();
1728   const NVPTXInstrInfo *TII = MF.getSubtarget<NVPTXSubtarget>().getInstrInfo();
1729 
1730   if (MCID.TSFlags & NVPTXII::IsTexFlag) {
1731     // This is a texture fetch, so operand 4 is a texref and operand 5 is
1732     // a samplerref
1733     MachineOperand &TexHandle = MI.getOperand(4);
1734     if (replaceImageHandle(TexHandle, MF))
1735       MI.setDesc(TII->get(texRegisterToIndexOpcode(MI.getOpcode())));
1736 
1737     if (!(MCID.TSFlags & NVPTXII::IsTexModeUnifiedFlag)) {
1738       MachineOperand &SampHandle = MI.getOperand(5);
1739       if (replaceImageHandle(SampHandle, MF))
1740         MI.setDesc(TII->get(samplerRegisterToIndexOpcode(MI.getOpcode())));
1741     }
1742 
1743     return true;
1744   } else if (MCID.TSFlags & NVPTXII::IsSuldMask) {
1745     unsigned VecSize =
1746       1 << (((MCID.TSFlags & NVPTXII::IsSuldMask) >> NVPTXII::IsSuldShift) - 1);
1747 
1748     // For a surface load of vector size N, the Nth operand will be the surfref
1749     MachineOperand &SurfHandle = MI.getOperand(VecSize);
1750 
1751     if (replaceImageHandle(SurfHandle, MF))
1752       MI.setDesc(TII->get(suldRegisterToIndexOpcode(MI.getOpcode())));
1753 
1754     return true;
1755   } else if (MCID.TSFlags & NVPTXII::IsSustFlag) {
1756     // This is a surface store, so operand 0 is a surfref
1757     MachineOperand &SurfHandle = MI.getOperand(0);
1758 
1759     if (replaceImageHandle(SurfHandle, MF))
1760       MI.setDesc(TII->get(sustRegisterToIndexOpcode(MI.getOpcode())));
1761 
1762     return true;
1763   } else if (MCID.TSFlags & NVPTXII::IsSurfTexQueryFlag) {
1764     // This is a query, so operand 1 is a surfref/texref
1765     MachineOperand &Handle = MI.getOperand(1);
1766 
1767     if (replaceImageHandle(Handle, MF))
1768       MI.setDesc(TII->get(queryRegisterToIndexOpcode(MI.getOpcode())));
1769 
1770     return true;
1771   }
1772 
1773   return false;
1774 }
1775 
1776 bool NVPTXReplaceImageHandles::replaceImageHandle(MachineOperand &Op,
1777                                                   MachineFunction &MF) {
1778   unsigned Idx;
1779   if (findIndexForHandle(Op, MF, Idx)) {
1780     Op.ChangeToImmediate(Idx);
1781     return true;
1782   }
1783   return false;
1784 }
1785 
1786 bool NVPTXReplaceImageHandles::
1787 findIndexForHandle(MachineOperand &Op, MachineFunction &MF, unsigned &Idx) {
1788   const MachineRegisterInfo &MRI = MF.getRegInfo();
1789   NVPTXMachineFunctionInfo *MFI = MF.getInfo<NVPTXMachineFunctionInfo>();
1790 
1791   assert(Op.isReg() && "Handle is not in a reg?");
1792 
1793   // Which instruction defines the handle?
1794   MachineInstr &TexHandleDef = *MRI.getVRegDef(Op.getReg());
1795 
1796   switch (TexHandleDef.getOpcode()) {
1797   case NVPTX::LD_i64_avar: {
1798     // The handle is a parameter value being loaded, replace with the
1799     // parameter symbol
1800     const NVPTXTargetMachine &TM =
1801         static_cast<const NVPTXTargetMachine &>(MF.getTarget());
1802     if (TM.getDrvInterface() == NVPTX::CUDA) {
1803       // For CUDA, we preserve the param loads coming from function arguments
1804       return false;
1805     }
1806 
1807     assert(TexHandleDef.getOperand(6).isSymbol() && "Load is not a symbol!");
1808     StringRef Sym = TexHandleDef.getOperand(6).getSymbolName();
1809     std::string ParamBaseName = std::string(MF.getName());
1810     ParamBaseName += "_param_";
1811     assert(Sym.startswith(ParamBaseName) && "Invalid symbol reference");
1812     unsigned Param = atoi(Sym.data()+ParamBaseName.size());
1813     std::string NewSym;
1814     raw_string_ostream NewSymStr(NewSym);
1815     NewSymStr << MF.getName() << "_param_" << Param;
1816 
1817     InstrsToRemove.insert(&TexHandleDef);
1818     Idx = MFI->getImageHandleSymbolIndex(NewSymStr.str().c_str());
1819     return true;
1820   }
1821   case NVPTX::texsurf_handles: {
1822     // The handle is a global variable, replace with the global variable name
1823     assert(TexHandleDef.getOperand(1).isGlobal() && "Load is not a global!");
1824     const GlobalValue *GV = TexHandleDef.getOperand(1).getGlobal();
1825     assert(GV->hasName() && "Global sampler must be named!");
1826     InstrsToRemove.insert(&TexHandleDef);
1827     Idx = MFI->getImageHandleSymbolIndex(GV->getName().data());
1828     return true;
1829   }
1830   case NVPTX::nvvm_move_i64:
1831   case TargetOpcode::COPY: {
1832     bool Res = findIndexForHandle(TexHandleDef.getOperand(1), MF, Idx);
1833     if (Res) {
1834       InstrsToRemove.insert(&TexHandleDef);
1835     }
1836     return Res;
1837   }
1838   default:
1839     llvm_unreachable("Unknown instruction operating on handle");
1840   }
1841 }
1842 
1843 MachineFunctionPass *llvm::createNVPTXReplaceImageHandlesPass() {
1844   return new NVPTXReplaceImageHandles();
1845 }
1846