//===-- NVPTXReplaceImageHandles.cpp - Replace image handles for Fermi ----===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // On Fermi, image handles are not supported. To work around this, we traverse // the machine code and replace image handles with concrete symbols. For this // to work reliably, inlining of all function call must be performed. // //===----------------------------------------------------------------------===// #include "MCTargetDesc/NVPTXBaseInfo.h" #include "NVPTX.h" #include "NVPTXMachineFunctionInfo.h" #include "NVPTXSubtarget.h" #include "NVPTXTargetMachine.h" #include "llvm/ADT/DenseSet.h" #include "llvm/CodeGen/MachineFunction.h" #include "llvm/CodeGen/MachineFunctionPass.h" #include "llvm/CodeGen/MachineRegisterInfo.h" using namespace llvm; namespace { class NVPTXReplaceImageHandles : public MachineFunctionPass { private: static char ID; DenseSet InstrsToRemove; public: NVPTXReplaceImageHandles(); bool runOnMachineFunction(MachineFunction &MF) override; StringRef getPassName() const override { return "NVPTX Replace Image Handles"; } private: bool processInstr(MachineInstr &MI); bool replaceImageHandle(MachineOperand &Op, MachineFunction &MF); }; } // namespace char NVPTXReplaceImageHandles::ID = 0; NVPTXReplaceImageHandles::NVPTXReplaceImageHandles() : MachineFunctionPass(ID) {} bool NVPTXReplaceImageHandles::runOnMachineFunction(MachineFunction &MF) { bool Changed = false; InstrsToRemove.clear(); for (MachineBasicBlock &MBB : MF) for (MachineInstr &MI : MBB) Changed |= processInstr(MI); // Now clean up any handle-access instructions // This is needed in debug mode when code cleanup passes are not executed, // but we need the handle access to be eliminated because they are not // valid instructions when image handles are disabled. for (MachineInstr *MI : InstrsToRemove) { unsigned DefReg = MI->getOperand(0).getReg(); // Only these that are not used can be removed. if (MF.getRegInfo().use_nodbg_empty(DefReg)) MI->eraseFromParent(); } return Changed; } static unsigned suldRegisterToIndexOpcode(unsigned RegOC) { switch (RegOC) { case NVPTX::SULD_1D_I8_CLAMP_R: return NVPTX::SULD_1D_I8_CLAMP_I; case NVPTX::SULD_1D_I16_CLAMP_R: return NVPTX::SULD_1D_I16_CLAMP_I; case NVPTX::SULD_1D_I32_CLAMP_R: return NVPTX::SULD_1D_I32_CLAMP_I; case NVPTX::SULD_1D_I64_CLAMP_R: return NVPTX::SULD_1D_I64_CLAMP_I; case NVPTX::SULD_1D_ARRAY_I8_CLAMP_R: return NVPTX::SULD_1D_ARRAY_I8_CLAMP_I; case NVPTX::SULD_1D_ARRAY_I16_CLAMP_R: return NVPTX::SULD_1D_ARRAY_I16_CLAMP_I; case NVPTX::SULD_1D_ARRAY_I32_CLAMP_R: return NVPTX::SULD_1D_ARRAY_I32_CLAMP_I; case NVPTX::SULD_1D_ARRAY_I64_CLAMP_R: return NVPTX::SULD_1D_ARRAY_I64_CLAMP_I; case NVPTX::SULD_2D_I8_CLAMP_R: return NVPTX::SULD_2D_I8_CLAMP_I; case NVPTX::SULD_2D_I16_CLAMP_R: return NVPTX::SULD_2D_I16_CLAMP_I; case NVPTX::SULD_2D_I32_CLAMP_R: return NVPTX::SULD_2D_I32_CLAMP_I; case NVPTX::SULD_2D_I64_CLAMP_R: return NVPTX::SULD_2D_I64_CLAMP_I; case NVPTX::SULD_2D_ARRAY_I8_CLAMP_R: return NVPTX::SULD_2D_ARRAY_I8_CLAMP_I; case NVPTX::SULD_2D_ARRAY_I16_CLAMP_R: return NVPTX::SULD_2D_ARRAY_I16_CLAMP_I; case NVPTX::SULD_2D_ARRAY_I32_CLAMP_R: return NVPTX::SULD_2D_ARRAY_I32_CLAMP_I; case NVPTX::SULD_2D_ARRAY_I64_CLAMP_R: return NVPTX::SULD_2D_ARRAY_I64_CLAMP_I; case NVPTX::SULD_3D_I8_CLAMP_R: return NVPTX::SULD_3D_I8_CLAMP_I; case NVPTX::SULD_3D_I16_CLAMP_R: return NVPTX::SULD_3D_I16_CLAMP_I; case NVPTX::SULD_3D_I32_CLAMP_R: return NVPTX::SULD_3D_I32_CLAMP_I; case NVPTX::SULD_3D_I64_CLAMP_R: return NVPTX::SULD_3D_I64_CLAMP_I; case NVPTX::SULD_1D_V2I8_CLAMP_R: return NVPTX::SULD_1D_V2I8_CLAMP_I; case NVPTX::SULD_1D_V2I16_CLAMP_R: return NVPTX::SULD_1D_V2I16_CLAMP_I; case NVPTX::SULD_1D_V2I32_CLAMP_R: return NVPTX::SULD_1D_V2I32_CLAMP_I; case NVPTX::SULD_1D_V2I64_CLAMP_R: return NVPTX::SULD_1D_V2I64_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V2I8_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V2I8_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V2I16_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V2I16_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V2I32_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V2I32_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V2I64_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V2I64_CLAMP_I; case NVPTX::SULD_2D_V2I8_CLAMP_R: return NVPTX::SULD_2D_V2I8_CLAMP_I; case NVPTX::SULD_2D_V2I16_CLAMP_R: return NVPTX::SULD_2D_V2I16_CLAMP_I; case NVPTX::SULD_2D_V2I32_CLAMP_R: return NVPTX::SULD_2D_V2I32_CLAMP_I; case NVPTX::SULD_2D_V2I64_CLAMP_R: return NVPTX::SULD_2D_V2I64_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V2I8_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V2I8_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V2I16_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V2I16_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V2I32_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V2I32_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V2I64_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V2I64_CLAMP_I; case NVPTX::SULD_3D_V2I8_CLAMP_R: return NVPTX::SULD_3D_V2I8_CLAMP_I; case NVPTX::SULD_3D_V2I16_CLAMP_R: return NVPTX::SULD_3D_V2I16_CLAMP_I; case NVPTX::SULD_3D_V2I32_CLAMP_R: return NVPTX::SULD_3D_V2I32_CLAMP_I; case NVPTX::SULD_3D_V2I64_CLAMP_R: return NVPTX::SULD_3D_V2I64_CLAMP_I; case NVPTX::SULD_1D_V4I8_CLAMP_R: return NVPTX::SULD_1D_V4I8_CLAMP_I; case NVPTX::SULD_1D_V4I16_CLAMP_R: return NVPTX::SULD_1D_V4I16_CLAMP_I; case NVPTX::SULD_1D_V4I32_CLAMP_R: return NVPTX::SULD_1D_V4I32_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V4I8_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V4I8_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V4I16_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V4I16_CLAMP_I; case NVPTX::SULD_1D_ARRAY_V4I32_CLAMP_R: return NVPTX::SULD_1D_ARRAY_V4I32_CLAMP_I; case NVPTX::SULD_2D_V4I8_CLAMP_R: return NVPTX::SULD_2D_V4I8_CLAMP_I; case NVPTX::SULD_2D_V4I16_CLAMP_R: return NVPTX::SULD_2D_V4I16_CLAMP_I; case NVPTX::SULD_2D_V4I32_CLAMP_R: return NVPTX::SULD_2D_V4I32_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V4I8_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V4I8_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V4I16_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V4I16_CLAMP_I; case NVPTX::SULD_2D_ARRAY_V4I32_CLAMP_R: return NVPTX::SULD_2D_ARRAY_V4I32_CLAMP_I; case NVPTX::SULD_3D_V4I8_CLAMP_R: return NVPTX::SULD_3D_V4I8_CLAMP_I; case NVPTX::SULD_3D_V4I16_CLAMP_R: return NVPTX::SULD_3D_V4I16_CLAMP_I; case NVPTX::SULD_3D_V4I32_CLAMP_R: return NVPTX::SULD_3D_V4I32_CLAMP_I; case NVPTX::SULD_1D_I8_TRAP_R: return NVPTX::SULD_1D_I8_TRAP_I; case NVPTX::SULD_1D_I16_TRAP_R: return NVPTX::SULD_1D_I16_TRAP_I; case NVPTX::SULD_1D_I32_TRAP_R: return NVPTX::SULD_1D_I32_TRAP_I; case NVPTX::SULD_1D_I64_TRAP_R: return NVPTX::SULD_1D_I64_TRAP_I; case NVPTX::SULD_1D_ARRAY_I8_TRAP_R: return NVPTX::SULD_1D_ARRAY_I8_TRAP_I; case NVPTX::SULD_1D_ARRAY_I16_TRAP_R: return NVPTX::SULD_1D_ARRAY_I16_TRAP_I; case NVPTX::SULD_1D_ARRAY_I32_TRAP_R: return NVPTX::SULD_1D_ARRAY_I32_TRAP_I; case NVPTX::SULD_1D_ARRAY_I64_TRAP_R: return NVPTX::SULD_1D_ARRAY_I64_TRAP_I; case NVPTX::SULD_2D_I8_TRAP_R: return NVPTX::SULD_2D_I8_TRAP_I; case NVPTX::SULD_2D_I16_TRAP_R: return NVPTX::SULD_2D_I16_TRAP_I; case NVPTX::SULD_2D_I32_TRAP_R: return NVPTX::SULD_2D_I32_TRAP_I; case NVPTX::SULD_2D_I64_TRAP_R: return NVPTX::SULD_2D_I64_TRAP_I; case NVPTX::SULD_2D_ARRAY_I8_TRAP_R: return NVPTX::SULD_2D_ARRAY_I8_TRAP_I; case NVPTX::SULD_2D_ARRAY_I16_TRAP_R: return NVPTX::SULD_2D_ARRAY_I16_TRAP_I; case NVPTX::SULD_2D_ARRAY_I32_TRAP_R: return NVPTX::SULD_2D_ARRAY_I32_TRAP_I; case NVPTX::SULD_2D_ARRAY_I64_TRAP_R: return NVPTX::SULD_2D_ARRAY_I64_TRAP_I; case NVPTX::SULD_3D_I8_TRAP_R: return NVPTX::SULD_3D_I8_TRAP_I; case NVPTX::SULD_3D_I16_TRAP_R: return NVPTX::SULD_3D_I16_TRAP_I; case NVPTX::SULD_3D_I32_TRAP_R: return NVPTX::SULD_3D_I32_TRAP_I; case NVPTX::SULD_3D_I64_TRAP_R: return NVPTX::SULD_3D_I64_TRAP_I; case NVPTX::SULD_1D_V2I8_TRAP_R: return NVPTX::SULD_1D_V2I8_TRAP_I; case NVPTX::SULD_1D_V2I16_TRAP_R: return NVPTX::SULD_1D_V2I16_TRAP_I; case NVPTX::SULD_1D_V2I32_TRAP_R: return NVPTX::SULD_1D_V2I32_TRAP_I; case NVPTX::SULD_1D_V2I64_TRAP_R: return NVPTX::SULD_1D_V2I64_TRAP_I; case NVPTX::SULD_1D_ARRAY_V2I8_TRAP_R: return NVPTX::SULD_1D_ARRAY_V2I8_TRAP_I; case NVPTX::SULD_1D_ARRAY_V2I16_TRAP_R: return NVPTX::SULD_1D_ARRAY_V2I16_TRAP_I; case NVPTX::SULD_1D_ARRAY_V2I32_TRAP_R: return NVPTX::SULD_1D_ARRAY_V2I32_TRAP_I; case NVPTX::SULD_1D_ARRAY_V2I64_TRAP_R: return NVPTX::SULD_1D_ARRAY_V2I64_TRAP_I; case NVPTX::SULD_2D_V2I8_TRAP_R: return NVPTX::SULD_2D_V2I8_TRAP_I; case NVPTX::SULD_2D_V2I16_TRAP_R: return NVPTX::SULD_2D_V2I16_TRAP_I; case NVPTX::SULD_2D_V2I32_TRAP_R: return NVPTX::SULD_2D_V2I32_TRAP_I; case NVPTX::SULD_2D_V2I64_TRAP_R: return NVPTX::SULD_2D_V2I64_TRAP_I; case NVPTX::SULD_2D_ARRAY_V2I8_TRAP_R: return NVPTX::SULD_2D_ARRAY_V2I8_TRAP_I; case NVPTX::SULD_2D_ARRAY_V2I16_TRAP_R: return NVPTX::SULD_2D_ARRAY_V2I16_TRAP_I; case NVPTX::SULD_2D_ARRAY_V2I32_TRAP_R: return NVPTX::SULD_2D_ARRAY_V2I32_TRAP_I; case NVPTX::SULD_2D_ARRAY_V2I64_TRAP_R: return NVPTX::SULD_2D_ARRAY_V2I64_TRAP_I; case NVPTX::SULD_3D_V2I8_TRAP_R: return NVPTX::SULD_3D_V2I8_TRAP_I; case NVPTX::SULD_3D_V2I16_TRAP_R: return NVPTX::SULD_3D_V2I16_TRAP_I; case NVPTX::SULD_3D_V2I32_TRAP_R: return NVPTX::SULD_3D_V2I32_TRAP_I; case NVPTX::SULD_3D_V2I64_TRAP_R: return NVPTX::SULD_3D_V2I64_TRAP_I; case NVPTX::SULD_1D_V4I8_TRAP_R: return NVPTX::SULD_1D_V4I8_TRAP_I; case NVPTX::SULD_1D_V4I16_TRAP_R: return NVPTX::SULD_1D_V4I16_TRAP_I; case NVPTX::SULD_1D_V4I32_TRAP_R: return NVPTX::SULD_1D_V4I32_TRAP_I; case NVPTX::SULD_1D_ARRAY_V4I8_TRAP_R: return NVPTX::SULD_1D_ARRAY_V4I8_TRAP_I; case NVPTX::SULD_1D_ARRAY_V4I16_TRAP_R: return NVPTX::SULD_1D_ARRAY_V4I16_TRAP_I; case NVPTX::SULD_1D_ARRAY_V4I32_TRAP_R: return NVPTX::SULD_1D_ARRAY_V4I32_TRAP_I; case NVPTX::SULD_2D_V4I8_TRAP_R: return NVPTX::SULD_2D_V4I8_TRAP_I; case NVPTX::SULD_2D_V4I16_TRAP_R: return NVPTX::SULD_2D_V4I16_TRAP_I; case NVPTX::SULD_2D_V4I32_TRAP_R: return NVPTX::SULD_2D_V4I32_TRAP_I; case NVPTX::SULD_2D_ARRAY_V4I8_TRAP_R: return NVPTX::SULD_2D_ARRAY_V4I8_TRAP_I; case NVPTX::SULD_2D_ARRAY_V4I16_TRAP_R: return NVPTX::SULD_2D_ARRAY_V4I16_TRAP_I; case NVPTX::SULD_2D_ARRAY_V4I32_TRAP_R: return NVPTX::SULD_2D_ARRAY_V4I32_TRAP_I; case NVPTX::SULD_3D_V4I8_TRAP_R: return NVPTX::SULD_3D_V4I8_TRAP_I; case NVPTX::SULD_3D_V4I16_TRAP_R: return NVPTX::SULD_3D_V4I16_TRAP_I; case NVPTX::SULD_3D_V4I32_TRAP_R: return NVPTX::SULD_3D_V4I32_TRAP_I; case NVPTX::SULD_1D_I8_ZERO_R: return NVPTX::SULD_1D_I8_ZERO_I; case NVPTX::SULD_1D_I16_ZERO_R: return NVPTX::SULD_1D_I16_ZERO_I; case NVPTX::SULD_1D_I32_ZERO_R: return NVPTX::SULD_1D_I32_ZERO_I; case NVPTX::SULD_1D_I64_ZERO_R: return NVPTX::SULD_1D_I64_ZERO_I; case NVPTX::SULD_1D_ARRAY_I8_ZERO_R: return NVPTX::SULD_1D_ARRAY_I8_ZERO_I; case NVPTX::SULD_1D_ARRAY_I16_ZERO_R: return NVPTX::SULD_1D_ARRAY_I16_ZERO_I; case NVPTX::SULD_1D_ARRAY_I32_ZERO_R: return NVPTX::SULD_1D_ARRAY_I32_ZERO_I; case NVPTX::SULD_1D_ARRAY_I64_ZERO_R: return NVPTX::SULD_1D_ARRAY_I64_ZERO_I; case NVPTX::SULD_2D_I8_ZERO_R: return NVPTX::SULD_2D_I8_ZERO_I; case NVPTX::SULD_2D_I16_ZERO_R: return NVPTX::SULD_2D_I16_ZERO_I; case NVPTX::SULD_2D_I32_ZERO_R: return NVPTX::SULD_2D_I32_ZERO_I; case NVPTX::SULD_2D_I64_ZERO_R: return NVPTX::SULD_2D_I64_ZERO_I; case NVPTX::SULD_2D_ARRAY_I8_ZERO_R: return NVPTX::SULD_2D_ARRAY_I8_ZERO_I; case NVPTX::SULD_2D_ARRAY_I16_ZERO_R: return NVPTX::SULD_2D_ARRAY_I16_ZERO_I; case NVPTX::SULD_2D_ARRAY_I32_ZERO_R: return NVPTX::SULD_2D_ARRAY_I32_ZERO_I; case NVPTX::SULD_2D_ARRAY_I64_ZERO_R: return NVPTX::SULD_2D_ARRAY_I64_ZERO_I; case NVPTX::SULD_3D_I8_ZERO_R: return NVPTX::SULD_3D_I8_ZERO_I; case NVPTX::SULD_3D_I16_ZERO_R: return NVPTX::SULD_3D_I16_ZERO_I; case NVPTX::SULD_3D_I32_ZERO_R: return NVPTX::SULD_3D_I32_ZERO_I; case NVPTX::SULD_3D_I64_ZERO_R: return NVPTX::SULD_3D_I64_ZERO_I; case NVPTX::SULD_1D_V2I8_ZERO_R: return NVPTX::SULD_1D_V2I8_ZERO_I; case NVPTX::SULD_1D_V2I16_ZERO_R: return NVPTX::SULD_1D_V2I16_ZERO_I; case NVPTX::SULD_1D_V2I32_ZERO_R: return NVPTX::SULD_1D_V2I32_ZERO_I; case NVPTX::SULD_1D_V2I64_ZERO_R: return NVPTX::SULD_1D_V2I64_ZERO_I; case NVPTX::SULD_1D_ARRAY_V2I8_ZERO_R: return NVPTX::SULD_1D_ARRAY_V2I8_ZERO_I; case NVPTX::SULD_1D_ARRAY_V2I16_ZERO_R: return NVPTX::SULD_1D_ARRAY_V2I16_ZERO_I; case NVPTX::SULD_1D_ARRAY_V2I32_ZERO_R: return NVPTX::SULD_1D_ARRAY_V2I32_ZERO_I; case NVPTX::SULD_1D_ARRAY_V2I64_ZERO_R: return NVPTX::SULD_1D_ARRAY_V2I64_ZERO_I; case NVPTX::SULD_2D_V2I8_ZERO_R: return NVPTX::SULD_2D_V2I8_ZERO_I; case NVPTX::SULD_2D_V2I16_ZERO_R: return NVPTX::SULD_2D_V2I16_ZERO_I; case NVPTX::SULD_2D_V2I32_ZERO_R: return NVPTX::SULD_2D_V2I32_ZERO_I; case NVPTX::SULD_2D_V2I64_ZERO_R: return NVPTX::SULD_2D_V2I64_ZERO_I; case NVPTX::SULD_2D_ARRAY_V2I8_ZERO_R: return NVPTX::SULD_2D_ARRAY_V2I8_ZERO_I; case NVPTX::SULD_2D_ARRAY_V2I16_ZERO_R: return NVPTX::SULD_2D_ARRAY_V2I16_ZERO_I; case NVPTX::SULD_2D_ARRAY_V2I32_ZERO_R: return NVPTX::SULD_2D_ARRAY_V2I32_ZERO_I; case NVPTX::SULD_2D_ARRAY_V2I64_ZERO_R: return NVPTX::SULD_2D_ARRAY_V2I64_ZERO_I; case NVPTX::SULD_3D_V2I8_ZERO_R: return NVPTX::SULD_3D_V2I8_ZERO_I; case NVPTX::SULD_3D_V2I16_ZERO_R: return NVPTX::SULD_3D_V2I16_ZERO_I; case NVPTX::SULD_3D_V2I32_ZERO_R: return NVPTX::SULD_3D_V2I32_ZERO_I; case NVPTX::SULD_3D_V2I64_ZERO_R: return NVPTX::SULD_3D_V2I64_ZERO_I; case NVPTX::SULD_1D_V4I8_ZERO_R: return NVPTX::SULD_1D_V4I8_ZERO_I; case NVPTX::SULD_1D_V4I16_ZERO_R: return NVPTX::SULD_1D_V4I16_ZERO_I; case NVPTX::SULD_1D_V4I32_ZERO_R: return NVPTX::SULD_1D_V4I32_ZERO_I; case NVPTX::SULD_1D_ARRAY_V4I8_ZERO_R: return NVPTX::SULD_1D_ARRAY_V4I8_ZERO_I; case NVPTX::SULD_1D_ARRAY_V4I16_ZERO_R: return NVPTX::SULD_1D_ARRAY_V4I16_ZERO_I; case NVPTX::SULD_1D_ARRAY_V4I32_ZERO_R: return NVPTX::SULD_1D_ARRAY_V4I32_ZERO_I; case NVPTX::SULD_2D_V4I8_ZERO_R: return NVPTX::SULD_2D_V4I8_ZERO_I; case NVPTX::SULD_2D_V4I16_ZERO_R: return NVPTX::SULD_2D_V4I16_ZERO_I; case NVPTX::SULD_2D_V4I32_ZERO_R: return NVPTX::SULD_2D_V4I32_ZERO_I; case NVPTX::SULD_2D_ARRAY_V4I8_ZERO_R: return NVPTX::SULD_2D_ARRAY_V4I8_ZERO_I; case NVPTX::SULD_2D_ARRAY_V4I16_ZERO_R: return NVPTX::SULD_2D_ARRAY_V4I16_ZERO_I; case NVPTX::SULD_2D_ARRAY_V4I32_ZERO_R: return NVPTX::SULD_2D_ARRAY_V4I32_ZERO_I; case NVPTX::SULD_3D_V4I8_ZERO_R: return NVPTX::SULD_3D_V4I8_ZERO_I; case NVPTX::SULD_3D_V4I16_ZERO_R: return NVPTX::SULD_3D_V4I16_ZERO_I; case NVPTX::SULD_3D_V4I32_ZERO_R: return NVPTX::SULD_3D_V4I32_ZERO_I; default: llvm_unreachable("Unhandled SULD opcode"); } } static unsigned sustRegisterToIndexOpcode(unsigned RegOC) { switch (RegOC) { case NVPTX::SUST_B_1D_I8_CLAMP_R: return NVPTX::SUST_B_1D_I8_CLAMP_I; case NVPTX::SUST_B_1D_I16_CLAMP_R: return NVPTX::SUST_B_1D_I16_CLAMP_I; case NVPTX::SUST_B_1D_I32_CLAMP_R: return NVPTX::SUST_B_1D_I32_CLAMP_I; case NVPTX::SUST_B_1D_I64_CLAMP_R: return NVPTX::SUST_B_1D_I64_CLAMP_I; case NVPTX::SUST_B_1D_V2I8_CLAMP_R: return NVPTX::SUST_B_1D_V2I8_CLAMP_I; case NVPTX::SUST_B_1D_V2I16_CLAMP_R: return NVPTX::SUST_B_1D_V2I16_CLAMP_I; case NVPTX::SUST_B_1D_V2I32_CLAMP_R: return NVPTX::SUST_B_1D_V2I32_CLAMP_I; case NVPTX::SUST_B_1D_V2I64_CLAMP_R: return NVPTX::SUST_B_1D_V2I64_CLAMP_I; case NVPTX::SUST_B_1D_V4I8_CLAMP_R: return NVPTX::SUST_B_1D_V4I8_CLAMP_I; case NVPTX::SUST_B_1D_V4I16_CLAMP_R: return NVPTX::SUST_B_1D_V4I16_CLAMP_I; case NVPTX::SUST_B_1D_V4I32_CLAMP_R: return NVPTX::SUST_B_1D_V4I32_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_I8_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_I8_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_I16_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_I16_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_I32_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_I32_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_I64_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_I64_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V2I8_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V2I8_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V2I16_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V2I16_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V2I32_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V2I32_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V2I64_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V2I64_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V4I8_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V4I8_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V4I16_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V4I16_CLAMP_I; case NVPTX::SUST_B_1D_ARRAY_V4I32_CLAMP_R: return NVPTX::SUST_B_1D_ARRAY_V4I32_CLAMP_I; case NVPTX::SUST_B_2D_I8_CLAMP_R: return NVPTX::SUST_B_2D_I8_CLAMP_I; case NVPTX::SUST_B_2D_I16_CLAMP_R: return NVPTX::SUST_B_2D_I16_CLAMP_I; case NVPTX::SUST_B_2D_I32_CLAMP_R: return NVPTX::SUST_B_2D_I32_CLAMP_I; case NVPTX::SUST_B_2D_I64_CLAMP_R: return NVPTX::SUST_B_2D_I64_CLAMP_I; case NVPTX::SUST_B_2D_V2I8_CLAMP_R: return NVPTX::SUST_B_2D_V2I8_CLAMP_I; case NVPTX::SUST_B_2D_V2I16_CLAMP_R: return NVPTX::SUST_B_2D_V2I16_CLAMP_I; case NVPTX::SUST_B_2D_V2I32_CLAMP_R: return NVPTX::SUST_B_2D_V2I32_CLAMP_I; case NVPTX::SUST_B_2D_V2I64_CLAMP_R: return NVPTX::SUST_B_2D_V2I64_CLAMP_I; case NVPTX::SUST_B_2D_V4I8_CLAMP_R: return NVPTX::SUST_B_2D_V4I8_CLAMP_I; case NVPTX::SUST_B_2D_V4I16_CLAMP_R: return NVPTX::SUST_B_2D_V4I16_CLAMP_I; case NVPTX::SUST_B_2D_V4I32_CLAMP_R: return NVPTX::SUST_B_2D_V4I32_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_I8_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_I8_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_I16_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_I16_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_I32_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_I32_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_I64_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_I64_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V2I8_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V2I8_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V2I16_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V2I16_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V2I32_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V2I32_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V2I64_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V2I64_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V4I8_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V4I8_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V4I16_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V4I16_CLAMP_I; case NVPTX::SUST_B_2D_ARRAY_V4I32_CLAMP_R: return NVPTX::SUST_B_2D_ARRAY_V4I32_CLAMP_I; case NVPTX::SUST_B_3D_I8_CLAMP_R: return NVPTX::SUST_B_3D_I8_CLAMP_I; case NVPTX::SUST_B_3D_I16_CLAMP_R: return NVPTX::SUST_B_3D_I16_CLAMP_I; case NVPTX::SUST_B_3D_I32_CLAMP_R: return NVPTX::SUST_B_3D_I32_CLAMP_I; case NVPTX::SUST_B_3D_I64_CLAMP_R: return NVPTX::SUST_B_3D_I64_CLAMP_I; case NVPTX::SUST_B_3D_V2I8_CLAMP_R: return NVPTX::SUST_B_3D_V2I8_CLAMP_I; case NVPTX::SUST_B_3D_V2I16_CLAMP_R: return NVPTX::SUST_B_3D_V2I16_CLAMP_I; case NVPTX::SUST_B_3D_V2I32_CLAMP_R: return NVPTX::SUST_B_3D_V2I32_CLAMP_I; case NVPTX::SUST_B_3D_V2I64_CLAMP_R: return NVPTX::SUST_B_3D_V2I64_CLAMP_I; case NVPTX::SUST_B_3D_V4I8_CLAMP_R: return NVPTX::SUST_B_3D_V4I8_CLAMP_I; case NVPTX::SUST_B_3D_V4I16_CLAMP_R: return NVPTX::SUST_B_3D_V4I16_CLAMP_I; case NVPTX::SUST_B_3D_V4I32_CLAMP_R: return NVPTX::SUST_B_3D_V4I32_CLAMP_I; case NVPTX::SUST_B_1D_I8_TRAP_R: return NVPTX::SUST_B_1D_I8_TRAP_I; case NVPTX::SUST_B_1D_I16_TRAP_R: return NVPTX::SUST_B_1D_I16_TRAP_I; case NVPTX::SUST_B_1D_I32_TRAP_R: return NVPTX::SUST_B_1D_I32_TRAP_I; case NVPTX::SUST_B_1D_I64_TRAP_R: return NVPTX::SUST_B_1D_I64_TRAP_I; case NVPTX::SUST_B_1D_V2I8_TRAP_R: return NVPTX::SUST_B_1D_V2I8_TRAP_I; case NVPTX::SUST_B_1D_V2I16_TRAP_R: return NVPTX::SUST_B_1D_V2I16_TRAP_I; case NVPTX::SUST_B_1D_V2I32_TRAP_R: return NVPTX::SUST_B_1D_V2I32_TRAP_I; case NVPTX::SUST_B_1D_V2I64_TRAP_R: return NVPTX::SUST_B_1D_V2I64_TRAP_I; case NVPTX::SUST_B_1D_V4I8_TRAP_R: return NVPTX::SUST_B_1D_V4I8_TRAP_I; case NVPTX::SUST_B_1D_V4I16_TRAP_R: return NVPTX::SUST_B_1D_V4I16_TRAP_I; case NVPTX::SUST_B_1D_V4I32_TRAP_R: return NVPTX::SUST_B_1D_V4I32_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_I8_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_I8_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_I16_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_I16_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_I32_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_I32_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_I64_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_I64_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V2I8_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V2I8_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V2I16_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V2I16_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V2I32_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V2I32_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V2I64_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V2I64_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V4I8_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V4I8_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V4I16_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V4I16_TRAP_I; case NVPTX::SUST_B_1D_ARRAY_V4I32_TRAP_R: return NVPTX::SUST_B_1D_ARRAY_V4I32_TRAP_I; case NVPTX::SUST_B_2D_I8_TRAP_R: return NVPTX::SUST_B_2D_I8_TRAP_I; case NVPTX::SUST_B_2D_I16_TRAP_R: return NVPTX::SUST_B_2D_I16_TRAP_I; case NVPTX::SUST_B_2D_I32_TRAP_R: return NVPTX::SUST_B_2D_I32_TRAP_I; case NVPTX::SUST_B_2D_I64_TRAP_R: return NVPTX::SUST_B_2D_I64_TRAP_I; case NVPTX::SUST_B_2D_V2I8_TRAP_R: return NVPTX::SUST_B_2D_V2I8_TRAP_I; case NVPTX::SUST_B_2D_V2I16_TRAP_R: return NVPTX::SUST_B_2D_V2I16_TRAP_I; case NVPTX::SUST_B_2D_V2I32_TRAP_R: return NVPTX::SUST_B_2D_V2I32_TRAP_I; case NVPTX::SUST_B_2D_V2I64_TRAP_R: return NVPTX::SUST_B_2D_V2I64_TRAP_I; case NVPTX::SUST_B_2D_V4I8_TRAP_R: return NVPTX::SUST_B_2D_V4I8_TRAP_I; case NVPTX::SUST_B_2D_V4I16_TRAP_R: return NVPTX::SUST_B_2D_V4I16_TRAP_I; case NVPTX::SUST_B_2D_V4I32_TRAP_R: return NVPTX::SUST_B_2D_V4I32_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_I8_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_I8_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_I16_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_I16_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_I32_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_I32_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_I64_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_I64_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V2I8_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V2I8_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V2I16_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V2I16_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V2I32_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V2I32_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V2I64_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V2I64_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V4I8_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V4I8_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V4I16_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V4I16_TRAP_I; case NVPTX::SUST_B_2D_ARRAY_V4I32_TRAP_R: return NVPTX::SUST_B_2D_ARRAY_V4I32_TRAP_I; case NVPTX::SUST_B_3D_I8_TRAP_R: return NVPTX::SUST_B_3D_I8_TRAP_I; case NVPTX::SUST_B_3D_I16_TRAP_R: return NVPTX::SUST_B_3D_I16_TRAP_I; case NVPTX::SUST_B_3D_I32_TRAP_R: return NVPTX::SUST_B_3D_I32_TRAP_I; case NVPTX::SUST_B_3D_I64_TRAP_R: return NVPTX::SUST_B_3D_I64_TRAP_I; case NVPTX::SUST_B_3D_V2I8_TRAP_R: return NVPTX::SUST_B_3D_V2I8_TRAP_I; case NVPTX::SUST_B_3D_V2I16_TRAP_R: return NVPTX::SUST_B_3D_V2I16_TRAP_I; case NVPTX::SUST_B_3D_V2I32_TRAP_R: return NVPTX::SUST_B_3D_V2I32_TRAP_I; case NVPTX::SUST_B_3D_V2I64_TRAP_R: return NVPTX::SUST_B_3D_V2I64_TRAP_I; case NVPTX::SUST_B_3D_V4I8_TRAP_R: return NVPTX::SUST_B_3D_V4I8_TRAP_I; case NVPTX::SUST_B_3D_V4I16_TRAP_R: return NVPTX::SUST_B_3D_V4I16_TRAP_I; case NVPTX::SUST_B_3D_V4I32_TRAP_R: return NVPTX::SUST_B_3D_V4I32_TRAP_I; case NVPTX::SUST_B_1D_I8_ZERO_R: return NVPTX::SUST_B_1D_I8_ZERO_I; case NVPTX::SUST_B_1D_I16_ZERO_R: return NVPTX::SUST_B_1D_I16_ZERO_I; case NVPTX::SUST_B_1D_I32_ZERO_R: return NVPTX::SUST_B_1D_I32_ZERO_I; case NVPTX::SUST_B_1D_I64_ZERO_R: return NVPTX::SUST_B_1D_I64_ZERO_I; case NVPTX::SUST_B_1D_V2I8_ZERO_R: return NVPTX::SUST_B_1D_V2I8_ZERO_I; case NVPTX::SUST_B_1D_V2I16_ZERO_R: return NVPTX::SUST_B_1D_V2I16_ZERO_I; case NVPTX::SUST_B_1D_V2I32_ZERO_R: return NVPTX::SUST_B_1D_V2I32_ZERO_I; case NVPTX::SUST_B_1D_V2I64_ZERO_R: return NVPTX::SUST_B_1D_V2I64_ZERO_I; case NVPTX::SUST_B_1D_V4I8_ZERO_R: return NVPTX::SUST_B_1D_V4I8_ZERO_I; case NVPTX::SUST_B_1D_V4I16_ZERO_R: return NVPTX::SUST_B_1D_V4I16_ZERO_I; case NVPTX::SUST_B_1D_V4I32_ZERO_R: return NVPTX::SUST_B_1D_V4I32_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_I8_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_I8_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_I16_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_I16_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_I32_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_I32_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_I64_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_I64_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V2I8_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V2I8_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V2I16_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V2I16_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V2I32_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V2I32_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V2I64_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V2I64_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V4I8_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V4I8_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V4I16_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V4I16_ZERO_I; case NVPTX::SUST_B_1D_ARRAY_V4I32_ZERO_R: return NVPTX::SUST_B_1D_ARRAY_V4I32_ZERO_I; case NVPTX::SUST_B_2D_I8_ZERO_R: return NVPTX::SUST_B_2D_I8_ZERO_I; case NVPTX::SUST_B_2D_I16_ZERO_R: return NVPTX::SUST_B_2D_I16_ZERO_I; case NVPTX::SUST_B_2D_I32_ZERO_R: return NVPTX::SUST_B_2D_I32_ZERO_I; case NVPTX::SUST_B_2D_I64_ZERO_R: return NVPTX::SUST_B_2D_I64_ZERO_I; case NVPTX::SUST_B_2D_V2I8_ZERO_R: return NVPTX::SUST_B_2D_V2I8_ZERO_I; case NVPTX::SUST_B_2D_V2I16_ZERO_R: return NVPTX::SUST_B_2D_V2I16_ZERO_I; case NVPTX::SUST_B_2D_V2I32_ZERO_R: return NVPTX::SUST_B_2D_V2I32_ZERO_I; case NVPTX::SUST_B_2D_V2I64_ZERO_R: return NVPTX::SUST_B_2D_V2I64_ZERO_I; case NVPTX::SUST_B_2D_V4I8_ZERO_R: return NVPTX::SUST_B_2D_V4I8_ZERO_I; case NVPTX::SUST_B_2D_V4I16_ZERO_R: return NVPTX::SUST_B_2D_V4I16_ZERO_I; case NVPTX::SUST_B_2D_V4I32_ZERO_R: return NVPTX::SUST_B_2D_V4I32_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_I8_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_I8_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_I16_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_I16_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_I32_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_I32_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_I64_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_I64_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V2I8_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V2I8_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V2I16_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V2I16_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V2I32_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V2I32_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V2I64_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V2I64_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V4I8_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V4I8_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V4I16_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V4I16_ZERO_I; case NVPTX::SUST_B_2D_ARRAY_V4I32_ZERO_R: return NVPTX::SUST_B_2D_ARRAY_V4I32_ZERO_I; case NVPTX::SUST_B_3D_I8_ZERO_R: return NVPTX::SUST_B_3D_I8_ZERO_I; case NVPTX::SUST_B_3D_I16_ZERO_R: return NVPTX::SUST_B_3D_I16_ZERO_I; case NVPTX::SUST_B_3D_I32_ZERO_R: return NVPTX::SUST_B_3D_I32_ZERO_I; case NVPTX::SUST_B_3D_I64_ZERO_R: return NVPTX::SUST_B_3D_I64_ZERO_I; case NVPTX::SUST_B_3D_V2I8_ZERO_R: return NVPTX::SUST_B_3D_V2I8_ZERO_I; case NVPTX::SUST_B_3D_V2I16_ZERO_R: return NVPTX::SUST_B_3D_V2I16_ZERO_I; case NVPTX::SUST_B_3D_V2I32_ZERO_R: return NVPTX::SUST_B_3D_V2I32_ZERO_I; case NVPTX::SUST_B_3D_V2I64_ZERO_R: return NVPTX::SUST_B_3D_V2I64_ZERO_I; case NVPTX::SUST_B_3D_V4I8_ZERO_R: return NVPTX::SUST_B_3D_V4I8_ZERO_I; case NVPTX::SUST_B_3D_V4I16_ZERO_R: return NVPTX::SUST_B_3D_V4I16_ZERO_I; case NVPTX::SUST_B_3D_V4I32_ZERO_R: return NVPTX::SUST_B_3D_V4I32_ZERO_I; case NVPTX::SUST_P_1D_I8_TRAP_R: return NVPTX::SUST_P_1D_I8_TRAP_I; case NVPTX::SUST_P_1D_I16_TRAP_R: return NVPTX::SUST_P_1D_I16_TRAP_I; case NVPTX::SUST_P_1D_I32_TRAP_R: return NVPTX::SUST_P_1D_I32_TRAP_I; case NVPTX::SUST_P_1D_V2I8_TRAP_R: return NVPTX::SUST_P_1D_V2I8_TRAP_I; case NVPTX::SUST_P_1D_V2I16_TRAP_R: return NVPTX::SUST_P_1D_V2I16_TRAP_I; case NVPTX::SUST_P_1D_V2I32_TRAP_R: return NVPTX::SUST_P_1D_V2I32_TRAP_I; case NVPTX::SUST_P_1D_V4I8_TRAP_R: return NVPTX::SUST_P_1D_V4I8_TRAP_I; case NVPTX::SUST_P_1D_V4I16_TRAP_R: return NVPTX::SUST_P_1D_V4I16_TRAP_I; case NVPTX::SUST_P_1D_V4I32_TRAP_R: return NVPTX::SUST_P_1D_V4I32_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_I8_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_I8_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_I16_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_I16_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_I32_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_I32_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V2I8_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V2I8_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V2I16_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V2I16_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V2I32_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V2I32_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V4I8_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V4I8_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V4I16_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V4I16_TRAP_I; case NVPTX::SUST_P_1D_ARRAY_V4I32_TRAP_R: return NVPTX::SUST_P_1D_ARRAY_V4I32_TRAP_I; case NVPTX::SUST_P_2D_I8_TRAP_R: return NVPTX::SUST_P_2D_I8_TRAP_I; case NVPTX::SUST_P_2D_I16_TRAP_R: return NVPTX::SUST_P_2D_I16_TRAP_I; case NVPTX::SUST_P_2D_I32_TRAP_R: return NVPTX::SUST_P_2D_I32_TRAP_I; case NVPTX::SUST_P_2D_V2I8_TRAP_R: return NVPTX::SUST_P_2D_V2I8_TRAP_I; case NVPTX::SUST_P_2D_V2I16_TRAP_R: return NVPTX::SUST_P_2D_V2I16_TRAP_I; case NVPTX::SUST_P_2D_V2I32_TRAP_R: return NVPTX::SUST_P_2D_V2I32_TRAP_I; case NVPTX::SUST_P_2D_V4I8_TRAP_R: return NVPTX::SUST_P_2D_V4I8_TRAP_I; case NVPTX::SUST_P_2D_V4I16_TRAP_R: return NVPTX::SUST_P_2D_V4I16_TRAP_I; case NVPTX::SUST_P_2D_V4I32_TRAP_R: return NVPTX::SUST_P_2D_V4I32_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_I8_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_I8_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_I16_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_I16_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_I32_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_I32_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V2I8_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V2I8_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V2I16_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V2I16_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V2I32_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V2I32_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V4I8_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V4I8_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V4I16_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V4I16_TRAP_I; case NVPTX::SUST_P_2D_ARRAY_V4I32_TRAP_R: return NVPTX::SUST_P_2D_ARRAY_V4I32_TRAP_I; case NVPTX::SUST_P_3D_I8_TRAP_R: return NVPTX::SUST_P_3D_I8_TRAP_I; case NVPTX::SUST_P_3D_I16_TRAP_R: return NVPTX::SUST_P_3D_I16_TRAP_I; case NVPTX::SUST_P_3D_I32_TRAP_R: return NVPTX::SUST_P_3D_I32_TRAP_I; case NVPTX::SUST_P_3D_V2I8_TRAP_R: return NVPTX::SUST_P_3D_V2I8_TRAP_I; case NVPTX::SUST_P_3D_V2I16_TRAP_R: return NVPTX::SUST_P_3D_V2I16_TRAP_I; case NVPTX::SUST_P_3D_V2I32_TRAP_R: return NVPTX::SUST_P_3D_V2I32_TRAP_I; case NVPTX::SUST_P_3D_V4I8_TRAP_R: return NVPTX::SUST_P_3D_V4I8_TRAP_I; case NVPTX::SUST_P_3D_V4I16_TRAP_R: return NVPTX::SUST_P_3D_V4I16_TRAP_I; case NVPTX::SUST_P_3D_V4I32_TRAP_R: return NVPTX::SUST_P_3D_V4I32_TRAP_I; default: llvm_unreachable("Unhandled SUST opcode"); } } static unsigned texRegisterToIndexOpcode(unsigned RegOC) { switch (RegOC) { case NVPTX::TEX_1D_F32_S32_RR: return NVPTX::TEX_1D_F32_S32_IR; case NVPTX::TEX_1D_F32_S32_RI: return NVPTX::TEX_1D_F32_S32_II; case NVPTX::TEX_1D_F32_F32_RR: return NVPTX::TEX_1D_F32_F32_IR; case NVPTX::TEX_1D_F32_F32_RI: return NVPTX::TEX_1D_F32_F32_II; case NVPTX::TEX_1D_F32_F32_LEVEL_RR: return NVPTX::TEX_1D_F32_F32_LEVEL_IR; case NVPTX::TEX_1D_F32_F32_LEVEL_RI: return NVPTX::TEX_1D_F32_F32_LEVEL_II; case NVPTX::TEX_1D_F32_F32_GRAD_RR: return NVPTX::TEX_1D_F32_F32_GRAD_IR; case NVPTX::TEX_1D_F32_F32_GRAD_RI: return NVPTX::TEX_1D_F32_F32_GRAD_II; case NVPTX::TEX_1D_S32_S32_RR: return NVPTX::TEX_1D_S32_S32_IR; case NVPTX::TEX_1D_S32_S32_RI: return NVPTX::TEX_1D_S32_S32_II; case NVPTX::TEX_1D_S32_F32_RR: return NVPTX::TEX_1D_S32_F32_IR; case NVPTX::TEX_1D_S32_F32_RI: return NVPTX::TEX_1D_S32_F32_II; case NVPTX::TEX_1D_S32_F32_LEVEL_RR: return NVPTX::TEX_1D_S32_F32_LEVEL_IR; case NVPTX::TEX_1D_S32_F32_LEVEL_RI: return NVPTX::TEX_1D_S32_F32_LEVEL_II; case NVPTX::TEX_1D_S32_F32_GRAD_RR: return NVPTX::TEX_1D_S32_F32_GRAD_IR; case NVPTX::TEX_1D_S32_F32_GRAD_RI: return NVPTX::TEX_1D_S32_F32_GRAD_II; case NVPTX::TEX_1D_U32_S32_RR: return NVPTX::TEX_1D_U32_S32_IR; case NVPTX::TEX_1D_U32_S32_RI: return NVPTX::TEX_1D_U32_S32_II; case NVPTX::TEX_1D_U32_F32_RR: return NVPTX::TEX_1D_U32_F32_IR; case NVPTX::TEX_1D_U32_F32_RI: return NVPTX::TEX_1D_U32_F32_II; case NVPTX::TEX_1D_U32_F32_LEVEL_RR: return NVPTX::TEX_1D_U32_F32_LEVEL_IR; case NVPTX::TEX_1D_U32_F32_LEVEL_RI: return NVPTX::TEX_1D_U32_F32_LEVEL_II; case NVPTX::TEX_1D_U32_F32_GRAD_RR: return NVPTX::TEX_1D_U32_F32_GRAD_IR; case NVPTX::TEX_1D_U32_F32_GRAD_RI: return NVPTX::TEX_1D_U32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_F32_S32_RR: return NVPTX::TEX_1D_ARRAY_F32_S32_IR; case NVPTX::TEX_1D_ARRAY_F32_S32_RI: return NVPTX::TEX_1D_ARRAY_F32_S32_II; case NVPTX::TEX_1D_ARRAY_F32_F32_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_IR; case NVPTX::TEX_1D_ARRAY_F32_F32_RI: return NVPTX::TEX_1D_ARRAY_F32_F32_II; case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_IR; case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RI: return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_IR; case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RI: return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_S32_S32_RR: return NVPTX::TEX_1D_ARRAY_S32_S32_IR; case NVPTX::TEX_1D_ARRAY_S32_S32_RI: return NVPTX::TEX_1D_ARRAY_S32_S32_II; case NVPTX::TEX_1D_ARRAY_S32_F32_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_IR; case NVPTX::TEX_1D_ARRAY_S32_F32_RI: return NVPTX::TEX_1D_ARRAY_S32_F32_II; case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_IR; case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RI: return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_IR; case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RI: return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_U32_S32_RR: return NVPTX::TEX_1D_ARRAY_U32_S32_IR; case NVPTX::TEX_1D_ARRAY_U32_S32_RI: return NVPTX::TEX_1D_ARRAY_U32_S32_II; case NVPTX::TEX_1D_ARRAY_U32_F32_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_IR; case NVPTX::TEX_1D_ARRAY_U32_F32_RI: return NVPTX::TEX_1D_ARRAY_U32_F32_II; case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_IR; case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RI: return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_IR; case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RI: return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_II; case NVPTX::TEX_2D_F32_S32_RR: return NVPTX::TEX_2D_F32_S32_IR; case NVPTX::TEX_2D_F32_S32_RI: return NVPTX::TEX_2D_F32_S32_II; case NVPTX::TEX_2D_F32_F32_RR: return NVPTX::TEX_2D_F32_F32_IR; case NVPTX::TEX_2D_F32_F32_RI: return NVPTX::TEX_2D_F32_F32_II; case NVPTX::TEX_2D_F32_F32_LEVEL_RR: return NVPTX::TEX_2D_F32_F32_LEVEL_IR; case NVPTX::TEX_2D_F32_F32_LEVEL_RI: return NVPTX::TEX_2D_F32_F32_LEVEL_II; case NVPTX::TEX_2D_F32_F32_GRAD_RR: return NVPTX::TEX_2D_F32_F32_GRAD_IR; case NVPTX::TEX_2D_F32_F32_GRAD_RI: return NVPTX::TEX_2D_F32_F32_GRAD_II; case NVPTX::TEX_2D_S32_S32_RR: return NVPTX::TEX_2D_S32_S32_IR; case NVPTX::TEX_2D_S32_S32_RI: return NVPTX::TEX_2D_S32_S32_II; case NVPTX::TEX_2D_S32_F32_RR: return NVPTX::TEX_2D_S32_F32_IR; case NVPTX::TEX_2D_S32_F32_RI: return NVPTX::TEX_2D_S32_F32_II; case NVPTX::TEX_2D_S32_F32_LEVEL_RR: return NVPTX::TEX_2D_S32_F32_LEVEL_IR; case NVPTX::TEX_2D_S32_F32_LEVEL_RI: return NVPTX::TEX_2D_S32_F32_LEVEL_II; case NVPTX::TEX_2D_S32_F32_GRAD_RR: return NVPTX::TEX_2D_S32_F32_GRAD_IR; case NVPTX::TEX_2D_S32_F32_GRAD_RI: return NVPTX::TEX_2D_S32_F32_GRAD_II; case NVPTX::TEX_2D_U32_S32_RR: return NVPTX::TEX_2D_U32_S32_IR; case NVPTX::TEX_2D_U32_S32_RI: return NVPTX::TEX_2D_U32_S32_II; case NVPTX::TEX_2D_U32_F32_RR: return NVPTX::TEX_2D_U32_F32_IR; case NVPTX::TEX_2D_U32_F32_RI: return NVPTX::TEX_2D_U32_F32_II; case NVPTX::TEX_2D_U32_F32_LEVEL_RR: return NVPTX::TEX_2D_U32_F32_LEVEL_IR; case NVPTX::TEX_2D_U32_F32_LEVEL_RI: return NVPTX::TEX_2D_U32_F32_LEVEL_II; case NVPTX::TEX_2D_U32_F32_GRAD_RR: return NVPTX::TEX_2D_U32_F32_GRAD_IR; case NVPTX::TEX_2D_U32_F32_GRAD_RI: return NVPTX::TEX_2D_U32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_F32_S32_RR: return NVPTX::TEX_2D_ARRAY_F32_S32_IR; case NVPTX::TEX_2D_ARRAY_F32_S32_RI: return NVPTX::TEX_2D_ARRAY_F32_S32_II; case NVPTX::TEX_2D_ARRAY_F32_F32_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_IR; case NVPTX::TEX_2D_ARRAY_F32_F32_RI: return NVPTX::TEX_2D_ARRAY_F32_F32_II; case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_IR; case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RI: return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_IR; case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RI: return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_S32_S32_RR: return NVPTX::TEX_2D_ARRAY_S32_S32_IR; case NVPTX::TEX_2D_ARRAY_S32_S32_RI: return NVPTX::TEX_2D_ARRAY_S32_S32_II; case NVPTX::TEX_2D_ARRAY_S32_F32_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_IR; case NVPTX::TEX_2D_ARRAY_S32_F32_RI: return NVPTX::TEX_2D_ARRAY_S32_F32_II; case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_IR; case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RI: return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_IR; case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RI: return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_U32_S32_RR: return NVPTX::TEX_2D_ARRAY_U32_S32_IR; case NVPTX::TEX_2D_ARRAY_U32_S32_RI: return NVPTX::TEX_2D_ARRAY_U32_S32_II; case NVPTX::TEX_2D_ARRAY_U32_F32_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_IR; case NVPTX::TEX_2D_ARRAY_U32_F32_RI: return NVPTX::TEX_2D_ARRAY_U32_F32_II; case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_IR; case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RI: return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_IR; case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RI: return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_II; case NVPTX::TEX_3D_F32_S32_RR: return NVPTX::TEX_3D_F32_S32_IR; case NVPTX::TEX_3D_F32_S32_RI: return NVPTX::TEX_3D_F32_S32_II; case NVPTX::TEX_3D_F32_F32_RR: return NVPTX::TEX_3D_F32_F32_IR; case NVPTX::TEX_3D_F32_F32_RI: return NVPTX::TEX_3D_F32_F32_II; case NVPTX::TEX_3D_F32_F32_LEVEL_RR: return NVPTX::TEX_3D_F32_F32_LEVEL_IR; case NVPTX::TEX_3D_F32_F32_LEVEL_RI: return NVPTX::TEX_3D_F32_F32_LEVEL_II; case NVPTX::TEX_3D_F32_F32_GRAD_RR: return NVPTX::TEX_3D_F32_F32_GRAD_IR; case NVPTX::TEX_3D_F32_F32_GRAD_RI: return NVPTX::TEX_3D_F32_F32_GRAD_II; case NVPTX::TEX_3D_S32_S32_RR: return NVPTX::TEX_3D_S32_S32_IR; case NVPTX::TEX_3D_S32_S32_RI: return NVPTX::TEX_3D_S32_S32_II; case NVPTX::TEX_3D_S32_F32_RR: return NVPTX::TEX_3D_S32_F32_IR; case NVPTX::TEX_3D_S32_F32_RI: return NVPTX::TEX_3D_S32_F32_II; case NVPTX::TEX_3D_S32_F32_LEVEL_RR: return NVPTX::TEX_3D_S32_F32_LEVEL_IR; case NVPTX::TEX_3D_S32_F32_LEVEL_RI: return NVPTX::TEX_3D_S32_F32_LEVEL_II; case NVPTX::TEX_3D_S32_F32_GRAD_RR: return NVPTX::TEX_3D_S32_F32_GRAD_IR; case NVPTX::TEX_3D_S32_F32_GRAD_RI: return NVPTX::TEX_3D_S32_F32_GRAD_II; case NVPTX::TEX_3D_U32_S32_RR: return NVPTX::TEX_3D_U32_S32_IR; case NVPTX::TEX_3D_U32_S32_RI: return NVPTX::TEX_3D_U32_S32_II; case NVPTX::TEX_3D_U32_F32_RR: return NVPTX::TEX_3D_U32_F32_IR; case NVPTX::TEX_3D_U32_F32_RI: return NVPTX::TEX_3D_U32_F32_II; case NVPTX::TEX_3D_U32_F32_LEVEL_RR: return NVPTX::TEX_3D_U32_F32_LEVEL_IR; case NVPTX::TEX_3D_U32_F32_LEVEL_RI: return NVPTX::TEX_3D_U32_F32_LEVEL_II; case NVPTX::TEX_3D_U32_F32_GRAD_RR: return NVPTX::TEX_3D_U32_F32_GRAD_IR; case NVPTX::TEX_3D_U32_F32_GRAD_RI: return NVPTX::TEX_3D_U32_F32_GRAD_II; case NVPTX::TEX_CUBE_F32_F32_RR: return NVPTX::TEX_CUBE_F32_F32_IR; case NVPTX::TEX_CUBE_F32_F32_RI: return NVPTX::TEX_CUBE_F32_F32_II; case NVPTX::TEX_CUBE_F32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_F32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_F32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_F32_F32_LEVEL_II; case NVPTX::TEX_CUBE_S32_F32_RR: return NVPTX::TEX_CUBE_S32_F32_IR; case NVPTX::TEX_CUBE_S32_F32_RI: return NVPTX::TEX_CUBE_S32_F32_II; case NVPTX::TEX_CUBE_S32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_S32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_S32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_S32_F32_LEVEL_II; case NVPTX::TEX_CUBE_U32_F32_RR: return NVPTX::TEX_CUBE_U32_F32_IR; case NVPTX::TEX_CUBE_U32_F32_RI: return NVPTX::TEX_CUBE_U32_F32_II; case NVPTX::TEX_CUBE_U32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_U32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_U32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_U32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_F32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_IR; case NVPTX::TEX_CUBE_ARRAY_F32_F32_RI: return NVPTX::TEX_CUBE_ARRAY_F32_F32_II; case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_S32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_IR; case NVPTX::TEX_CUBE_ARRAY_S32_F32_RI: return NVPTX::TEX_CUBE_ARRAY_S32_F32_II; case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_U32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_IR; case NVPTX::TEX_CUBE_ARRAY_U32_F32_RI: return NVPTX::TEX_CUBE_ARRAY_U32_F32_II; case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_IR; case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RI: return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_II; case NVPTX::TLD4_R_2D_F32_F32_RR: return NVPTX::TLD4_R_2D_F32_F32_IR; case NVPTX::TLD4_R_2D_F32_F32_RI: return NVPTX::TLD4_R_2D_F32_F32_II; case NVPTX::TLD4_G_2D_F32_F32_RR: return NVPTX::TLD4_G_2D_F32_F32_IR; case NVPTX::TLD4_G_2D_F32_F32_RI: return NVPTX::TLD4_G_2D_F32_F32_II; case NVPTX::TLD4_B_2D_F32_F32_RR: return NVPTX::TLD4_B_2D_F32_F32_IR; case NVPTX::TLD4_B_2D_F32_F32_RI: return NVPTX::TLD4_B_2D_F32_F32_II; case NVPTX::TLD4_A_2D_F32_F32_RR: return NVPTX::TLD4_A_2D_F32_F32_IR; case NVPTX::TLD4_A_2D_F32_F32_RI: return NVPTX::TLD4_A_2D_F32_F32_II; case NVPTX::TLD4_R_2D_S32_F32_RR: return NVPTX::TLD4_R_2D_S32_F32_IR; case NVPTX::TLD4_R_2D_S32_F32_RI: return NVPTX::TLD4_R_2D_S32_F32_II; case NVPTX::TLD4_G_2D_S32_F32_RR: return NVPTX::TLD4_G_2D_S32_F32_IR; case NVPTX::TLD4_G_2D_S32_F32_RI: return NVPTX::TLD4_G_2D_S32_F32_II; case NVPTX::TLD4_B_2D_S32_F32_RR: return NVPTX::TLD4_B_2D_S32_F32_IR; case NVPTX::TLD4_B_2D_S32_F32_RI: return NVPTX::TLD4_B_2D_S32_F32_II; case NVPTX::TLD4_A_2D_S32_F32_RR: return NVPTX::TLD4_A_2D_S32_F32_IR; case NVPTX::TLD4_A_2D_S32_F32_RI: return NVPTX::TLD4_A_2D_S32_F32_II; case NVPTX::TLD4_R_2D_U32_F32_RR: return NVPTX::TLD4_R_2D_U32_F32_IR; case NVPTX::TLD4_R_2D_U32_F32_RI: return NVPTX::TLD4_R_2D_U32_F32_II; case NVPTX::TLD4_G_2D_U32_F32_RR: return NVPTX::TLD4_G_2D_U32_F32_IR; case NVPTX::TLD4_G_2D_U32_F32_RI: return NVPTX::TLD4_G_2D_U32_F32_II; case NVPTX::TLD4_B_2D_U32_F32_RR: return NVPTX::TLD4_B_2D_U32_F32_IR; case NVPTX::TLD4_B_2D_U32_F32_RI: return NVPTX::TLD4_B_2D_U32_F32_II; case NVPTX::TLD4_A_2D_U32_F32_RR: return NVPTX::TLD4_A_2D_U32_F32_IR; case NVPTX::TLD4_A_2D_U32_F32_RI: return NVPTX::TLD4_A_2D_U32_F32_II; case NVPTX::TEX_UNIFIED_1D_F32_S32_R: return NVPTX::TEX_UNIFIED_1D_F32_S32_I; case NVPTX::TEX_UNIFIED_1D_F32_F32_R: return NVPTX::TEX_UNIFIED_1D_F32_F32_I; case NVPTX::TEX_UNIFIED_1D_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_1D_S32_S32_R: return NVPTX::TEX_UNIFIED_1D_S32_S32_I; case NVPTX::TEX_UNIFIED_1D_S32_F32_R: return NVPTX::TEX_UNIFIED_1D_S32_F32_I; case NVPTX::TEX_UNIFIED_1D_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_1D_U32_S32_R: return NVPTX::TEX_UNIFIED_1D_U32_S32_I; case NVPTX::TEX_UNIFIED_1D_U32_F32_R: return NVPTX::TEX_UNIFIED_1D_U32_F32_I; case NVPTX::TEX_UNIFIED_1D_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_S32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_S32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_S32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_S32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_S32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_S32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_1D_ARRAY_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_F32_S32_R: return NVPTX::TEX_UNIFIED_2D_F32_S32_I; case NVPTX::TEX_UNIFIED_2D_F32_F32_R: return NVPTX::TEX_UNIFIED_2D_F32_F32_I; case NVPTX::TEX_UNIFIED_2D_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_S32_S32_R: return NVPTX::TEX_UNIFIED_2D_S32_S32_I; case NVPTX::TEX_UNIFIED_2D_S32_F32_R: return NVPTX::TEX_UNIFIED_2D_S32_F32_I; case NVPTX::TEX_UNIFIED_2D_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_U32_S32_R: return NVPTX::TEX_UNIFIED_2D_U32_S32_I; case NVPTX::TEX_UNIFIED_2D_U32_F32_R: return NVPTX::TEX_UNIFIED_2D_U32_F32_I; case NVPTX::TEX_UNIFIED_2D_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_S32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_S32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_S32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_S32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_S32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_S32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_2D_ARRAY_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_3D_F32_S32_R: return NVPTX::TEX_UNIFIED_3D_F32_S32_I; case NVPTX::TEX_UNIFIED_3D_F32_F32_R: return NVPTX::TEX_UNIFIED_3D_F32_F32_I; case NVPTX::TEX_UNIFIED_3D_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_3D_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_3D_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_3D_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_3D_S32_S32_R: return NVPTX::TEX_UNIFIED_3D_S32_S32_I; case NVPTX::TEX_UNIFIED_3D_S32_F32_R: return NVPTX::TEX_UNIFIED_3D_S32_F32_I; case NVPTX::TEX_UNIFIED_3D_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_3D_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_3D_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_3D_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_3D_U32_S32_R: return NVPTX::TEX_UNIFIED_3D_U32_S32_I; case NVPTX::TEX_UNIFIED_3D_U32_F32_R: return NVPTX::TEX_UNIFIED_3D_U32_F32_I; case NVPTX::TEX_UNIFIED_3D_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_3D_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_3D_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_3D_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_F32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_F32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_S32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_S32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_U32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_U32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_LEVEL_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_LEVEL_I; case NVPTX::TEX_UNIFIED_CUBE_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_U32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_F32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_S32_F32_GRAD_I; case NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_GRAD_R: return NVPTX::TEX_UNIFIED_CUBE_ARRAY_U32_F32_GRAD_I; case NVPTX::TLD4_UNIFIED_R_2D_F32_F32_R: return NVPTX::TLD4_UNIFIED_R_2D_F32_F32_I; case NVPTX::TLD4_UNIFIED_G_2D_F32_F32_R: return NVPTX::TLD4_UNIFIED_G_2D_F32_F32_I; case NVPTX::TLD4_UNIFIED_B_2D_F32_F32_R: return NVPTX::TLD4_UNIFIED_B_2D_F32_F32_I; case NVPTX::TLD4_UNIFIED_A_2D_F32_F32_R: return NVPTX::TLD4_UNIFIED_A_2D_F32_F32_I; case NVPTX::TLD4_UNIFIED_R_2D_S32_F32_R: return NVPTX::TLD4_UNIFIED_R_2D_S32_F32_I; case NVPTX::TLD4_UNIFIED_G_2D_S32_F32_R: return NVPTX::TLD4_UNIFIED_G_2D_S32_F32_I; case NVPTX::TLD4_UNIFIED_B_2D_S32_F32_R: return NVPTX::TLD4_UNIFIED_B_2D_S32_F32_I; case NVPTX::TLD4_UNIFIED_A_2D_S32_F32_R: return NVPTX::TLD4_UNIFIED_A_2D_S32_F32_I; case NVPTX::TLD4_UNIFIED_R_2D_U32_F32_R: return NVPTX::TLD4_UNIFIED_R_2D_U32_F32_I; case NVPTX::TLD4_UNIFIED_G_2D_U32_F32_R: return NVPTX::TLD4_UNIFIED_G_2D_U32_F32_I; case NVPTX::TLD4_UNIFIED_B_2D_U32_F32_R: return NVPTX::TLD4_UNIFIED_B_2D_U32_F32_I; case NVPTX::TLD4_UNIFIED_A_2D_U32_F32_R: return NVPTX::TLD4_UNIFIED_A_2D_U32_F32_I; default: llvm_unreachable("Unhandled TEX opcode"); }; } static unsigned samplerRegisterToIndexOpcode(unsigned RegOC) { switch (RegOC) { case NVPTX::TEX_1D_F32_S32_RR: return NVPTX::TEX_1D_F32_S32_RI; case NVPTX::TEX_1D_F32_S32_IR: return NVPTX::TEX_1D_F32_S32_II; case NVPTX::TEX_1D_F32_F32_RR: return NVPTX::TEX_1D_F32_F32_RI; case NVPTX::TEX_1D_F32_F32_IR: return NVPTX::TEX_1D_F32_F32_II; case NVPTX::TEX_1D_F32_F32_LEVEL_RR: return NVPTX::TEX_1D_F32_F32_LEVEL_RI; case NVPTX::TEX_1D_F32_F32_LEVEL_IR: return NVPTX::TEX_1D_F32_F32_LEVEL_II; case NVPTX::TEX_1D_F32_F32_GRAD_RR: return NVPTX::TEX_1D_F32_F32_GRAD_RI; case NVPTX::TEX_1D_F32_F32_GRAD_IR: return NVPTX::TEX_1D_F32_F32_GRAD_II; case NVPTX::TEX_1D_S32_S32_RR: return NVPTX::TEX_1D_S32_S32_RI; case NVPTX::TEX_1D_S32_S32_IR: return NVPTX::TEX_1D_S32_S32_II; case NVPTX::TEX_1D_S32_F32_RR: return NVPTX::TEX_1D_S32_F32_RI; case NVPTX::TEX_1D_S32_F32_IR: return NVPTX::TEX_1D_S32_F32_II; case NVPTX::TEX_1D_S32_F32_LEVEL_RR: return NVPTX::TEX_1D_S32_F32_LEVEL_RI; case NVPTX::TEX_1D_S32_F32_LEVEL_IR: return NVPTX::TEX_1D_S32_F32_LEVEL_II; case NVPTX::TEX_1D_S32_F32_GRAD_RR: return NVPTX::TEX_1D_S32_F32_GRAD_RI; case NVPTX::TEX_1D_S32_F32_GRAD_IR: return NVPTX::TEX_1D_S32_F32_GRAD_II; case NVPTX::TEX_1D_U32_S32_RR: return NVPTX::TEX_1D_U32_S32_RI; case NVPTX::TEX_1D_U32_S32_IR: return NVPTX::TEX_1D_U32_S32_II; case NVPTX::TEX_1D_U32_F32_RR: return NVPTX::TEX_1D_U32_F32_RI; case NVPTX::TEX_1D_U32_F32_IR: return NVPTX::TEX_1D_U32_F32_II; case NVPTX::TEX_1D_U32_F32_LEVEL_RR: return NVPTX::TEX_1D_U32_F32_LEVEL_RI; case NVPTX::TEX_1D_U32_F32_LEVEL_IR: return NVPTX::TEX_1D_U32_F32_LEVEL_II; case NVPTX::TEX_1D_U32_F32_GRAD_RR: return NVPTX::TEX_1D_U32_F32_GRAD_RI; case NVPTX::TEX_1D_U32_F32_GRAD_IR: return NVPTX::TEX_1D_U32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_F32_S32_RR: return NVPTX::TEX_1D_ARRAY_F32_S32_RI; case NVPTX::TEX_1D_ARRAY_F32_S32_IR: return NVPTX::TEX_1D_ARRAY_F32_S32_II; case NVPTX::TEX_1D_ARRAY_F32_F32_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_RI; case NVPTX::TEX_1D_ARRAY_F32_F32_IR: return NVPTX::TEX_1D_ARRAY_F32_F32_II; case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_RI; case NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_IR: return NVPTX::TEX_1D_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_RI; case NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_IR: return NVPTX::TEX_1D_ARRAY_F32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_S32_S32_RR: return NVPTX::TEX_1D_ARRAY_S32_S32_RI; case NVPTX::TEX_1D_ARRAY_S32_S32_IR: return NVPTX::TEX_1D_ARRAY_S32_S32_II; case NVPTX::TEX_1D_ARRAY_S32_F32_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_RI; case NVPTX::TEX_1D_ARRAY_S32_F32_IR: return NVPTX::TEX_1D_ARRAY_S32_F32_II; case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_RI; case NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_IR: return NVPTX::TEX_1D_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_RI; case NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_IR: return NVPTX::TEX_1D_ARRAY_S32_F32_GRAD_II; case NVPTX::TEX_1D_ARRAY_U32_S32_RR: return NVPTX::TEX_1D_ARRAY_U32_S32_RI; case NVPTX::TEX_1D_ARRAY_U32_S32_IR: return NVPTX::TEX_1D_ARRAY_U32_S32_II; case NVPTX::TEX_1D_ARRAY_U32_F32_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_RI; case NVPTX::TEX_1D_ARRAY_U32_F32_IR: return NVPTX::TEX_1D_ARRAY_U32_F32_II; case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_RI; case NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_IR: return NVPTX::TEX_1D_ARRAY_U32_F32_LEVEL_II; case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RR: return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_RI; case NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_IR: return NVPTX::TEX_1D_ARRAY_U32_F32_GRAD_II; case NVPTX::TEX_2D_F32_S32_RR: return NVPTX::TEX_2D_F32_S32_RI; case NVPTX::TEX_2D_F32_S32_IR: return NVPTX::TEX_2D_F32_S32_II; case NVPTX::TEX_2D_F32_F32_RR: return NVPTX::TEX_2D_F32_F32_RI; case NVPTX::TEX_2D_F32_F32_IR: return NVPTX::TEX_2D_F32_F32_II; case NVPTX::TEX_2D_F32_F32_LEVEL_RR: return NVPTX::TEX_2D_F32_F32_LEVEL_RI; case NVPTX::TEX_2D_F32_F32_LEVEL_IR: return NVPTX::TEX_2D_F32_F32_LEVEL_II; case NVPTX::TEX_2D_F32_F32_GRAD_RR: return NVPTX::TEX_2D_F32_F32_GRAD_RI; case NVPTX::TEX_2D_F32_F32_GRAD_IR: return NVPTX::TEX_2D_F32_F32_GRAD_II; case NVPTX::TEX_2D_S32_S32_RR: return NVPTX::TEX_2D_S32_S32_RI; case NVPTX::TEX_2D_S32_S32_IR: return NVPTX::TEX_2D_S32_S32_II; case NVPTX::TEX_2D_S32_F32_RR: return NVPTX::TEX_2D_S32_F32_RI; case NVPTX::TEX_2D_S32_F32_IR: return NVPTX::TEX_2D_S32_F32_II; case NVPTX::TEX_2D_S32_F32_LEVEL_RR: return NVPTX::TEX_2D_S32_F32_LEVEL_RI; case NVPTX::TEX_2D_S32_F32_LEVEL_IR: return NVPTX::TEX_2D_S32_F32_LEVEL_II; case NVPTX::TEX_2D_S32_F32_GRAD_RR: return NVPTX::TEX_2D_S32_F32_GRAD_RI; case NVPTX::TEX_2D_S32_F32_GRAD_IR: return NVPTX::TEX_2D_S32_F32_GRAD_II; case NVPTX::TEX_2D_U32_S32_RR: return NVPTX::TEX_2D_U32_S32_RI; case NVPTX::TEX_2D_U32_S32_IR: return NVPTX::TEX_2D_U32_S32_II; case NVPTX::TEX_2D_U32_F32_RR: return NVPTX::TEX_2D_U32_F32_RI; case NVPTX::TEX_2D_U32_F32_IR: return NVPTX::TEX_2D_U32_F32_II; case NVPTX::TEX_2D_U32_F32_LEVEL_RR: return NVPTX::TEX_2D_U32_F32_LEVEL_RI; case NVPTX::TEX_2D_U32_F32_LEVEL_IR: return NVPTX::TEX_2D_U32_F32_LEVEL_II; case NVPTX::TEX_2D_U32_F32_GRAD_RR: return NVPTX::TEX_2D_U32_F32_GRAD_RI; case NVPTX::TEX_2D_U32_F32_GRAD_IR: return NVPTX::TEX_2D_U32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_F32_S32_RR: return NVPTX::TEX_2D_ARRAY_F32_S32_RI; case NVPTX::TEX_2D_ARRAY_F32_S32_IR: return NVPTX::TEX_2D_ARRAY_F32_S32_II; case NVPTX::TEX_2D_ARRAY_F32_F32_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_RI; case NVPTX::TEX_2D_ARRAY_F32_F32_IR: return NVPTX::TEX_2D_ARRAY_F32_F32_II; case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_RI; case NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_IR: return NVPTX::TEX_2D_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_RI; case NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_IR: return NVPTX::TEX_2D_ARRAY_F32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_S32_S32_RR: return NVPTX::TEX_2D_ARRAY_S32_S32_RI; case NVPTX::TEX_2D_ARRAY_S32_S32_IR: return NVPTX::TEX_2D_ARRAY_S32_S32_II; case NVPTX::TEX_2D_ARRAY_S32_F32_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_RI; case NVPTX::TEX_2D_ARRAY_S32_F32_IR: return NVPTX::TEX_2D_ARRAY_S32_F32_II; case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_RI; case NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_IR: return NVPTX::TEX_2D_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_RI; case NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_IR: return NVPTX::TEX_2D_ARRAY_S32_F32_GRAD_II; case NVPTX::TEX_2D_ARRAY_U32_S32_RR: return NVPTX::TEX_2D_ARRAY_U32_S32_RI; case NVPTX::TEX_2D_ARRAY_U32_S32_IR: return NVPTX::TEX_2D_ARRAY_U32_S32_II; case NVPTX::TEX_2D_ARRAY_U32_F32_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_RI; case NVPTX::TEX_2D_ARRAY_U32_F32_IR: return NVPTX::TEX_2D_ARRAY_U32_F32_II; case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_RI; case NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_IR: return NVPTX::TEX_2D_ARRAY_U32_F32_LEVEL_II; case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RR: return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_RI; case NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_IR: return NVPTX::TEX_2D_ARRAY_U32_F32_GRAD_II; case NVPTX::TEX_3D_F32_S32_RR: return NVPTX::TEX_3D_F32_S32_RI; case NVPTX::TEX_3D_F32_S32_IR: return NVPTX::TEX_3D_F32_S32_II; case NVPTX::TEX_3D_F32_F32_RR: return NVPTX::TEX_3D_F32_F32_RI; case NVPTX::TEX_3D_F32_F32_IR: return NVPTX::TEX_3D_F32_F32_II; case NVPTX::TEX_3D_F32_F32_LEVEL_RR: return NVPTX::TEX_3D_F32_F32_LEVEL_RI; case NVPTX::TEX_3D_F32_F32_LEVEL_IR: return NVPTX::TEX_3D_F32_F32_LEVEL_II; case NVPTX::TEX_3D_F32_F32_GRAD_RR: return NVPTX::TEX_3D_F32_F32_GRAD_RI; case NVPTX::TEX_3D_F32_F32_GRAD_IR: return NVPTX::TEX_3D_F32_F32_GRAD_II; case NVPTX::TEX_3D_S32_S32_RR: return NVPTX::TEX_3D_S32_S32_RI; case NVPTX::TEX_3D_S32_S32_IR: return NVPTX::TEX_3D_S32_S32_II; case NVPTX::TEX_3D_S32_F32_RR: return NVPTX::TEX_3D_S32_F32_RI; case NVPTX::TEX_3D_S32_F32_IR: return NVPTX::TEX_3D_S32_F32_II; case NVPTX::TEX_3D_S32_F32_LEVEL_RR: return NVPTX::TEX_3D_S32_F32_LEVEL_RI; case NVPTX::TEX_3D_S32_F32_LEVEL_IR: return NVPTX::TEX_3D_S32_F32_LEVEL_II; case NVPTX::TEX_3D_S32_F32_GRAD_RR: return NVPTX::TEX_3D_S32_F32_GRAD_RI; case NVPTX::TEX_3D_S32_F32_GRAD_IR: return NVPTX::TEX_3D_S32_F32_GRAD_II; case NVPTX::TEX_3D_U32_S32_RR: return NVPTX::TEX_3D_U32_S32_RI; case NVPTX::TEX_3D_U32_S32_IR: return NVPTX::TEX_3D_U32_S32_II; case NVPTX::TEX_3D_U32_F32_RR: return NVPTX::TEX_3D_U32_F32_RI; case NVPTX::TEX_3D_U32_F32_IR: return NVPTX::TEX_3D_U32_F32_II; case NVPTX::TEX_3D_U32_F32_LEVEL_RR: return NVPTX::TEX_3D_U32_F32_LEVEL_RI; case NVPTX::TEX_3D_U32_F32_LEVEL_IR: return NVPTX::TEX_3D_U32_F32_LEVEL_II; case NVPTX::TEX_3D_U32_F32_GRAD_RR: return NVPTX::TEX_3D_U32_F32_GRAD_RI; case NVPTX::TEX_3D_U32_F32_GRAD_IR: return NVPTX::TEX_3D_U32_F32_GRAD_II; case NVPTX::TEX_CUBE_F32_F32_RR: return NVPTX::TEX_CUBE_F32_F32_RI; case NVPTX::TEX_CUBE_F32_F32_IR: return NVPTX::TEX_CUBE_F32_F32_II; case NVPTX::TEX_CUBE_F32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_F32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_F32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_F32_F32_LEVEL_II; case NVPTX::TEX_CUBE_S32_F32_RR: return NVPTX::TEX_CUBE_S32_F32_RI; case NVPTX::TEX_CUBE_S32_F32_IR: return NVPTX::TEX_CUBE_S32_F32_II; case NVPTX::TEX_CUBE_S32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_S32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_S32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_S32_F32_LEVEL_II; case NVPTX::TEX_CUBE_U32_F32_RR: return NVPTX::TEX_CUBE_U32_F32_RI; case NVPTX::TEX_CUBE_U32_F32_IR: return NVPTX::TEX_CUBE_U32_F32_II; case NVPTX::TEX_CUBE_U32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_U32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_U32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_U32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_F32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_RI; case NVPTX::TEX_CUBE_ARRAY_F32_F32_IR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_II; case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_ARRAY_F32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_S32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_RI; case NVPTX::TEX_CUBE_ARRAY_S32_F32_IR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_II; case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_ARRAY_S32_F32_LEVEL_II; case NVPTX::TEX_CUBE_ARRAY_U32_F32_RR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_RI; case NVPTX::TEX_CUBE_ARRAY_U32_F32_IR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_II; case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_RI; case NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_IR: return NVPTX::TEX_CUBE_ARRAY_U32_F32_LEVEL_II; case NVPTX::TLD4_R_2D_F32_F32_RR: return NVPTX::TLD4_R_2D_F32_F32_RI; case NVPTX::TLD4_R_2D_F32_F32_IR: return NVPTX::TLD4_R_2D_F32_F32_II; case NVPTX::TLD4_G_2D_F32_F32_RR: return NVPTX::TLD4_G_2D_F32_F32_RI; case NVPTX::TLD4_G_2D_F32_F32_IR: return NVPTX::TLD4_G_2D_F32_F32_II; case NVPTX::TLD4_B_2D_F32_F32_RR: return NVPTX::TLD4_B_2D_F32_F32_RI; case NVPTX::TLD4_B_2D_F32_F32_IR: return NVPTX::TLD4_B_2D_F32_F32_II; case NVPTX::TLD4_A_2D_F32_F32_RR: return NVPTX::TLD4_A_2D_F32_F32_RI; case NVPTX::TLD4_A_2D_F32_F32_IR: return NVPTX::TLD4_A_2D_F32_F32_II; case NVPTX::TLD4_R_2D_S32_F32_RR: return NVPTX::TLD4_R_2D_S32_F32_RI; case NVPTX::TLD4_R_2D_S32_F32_IR: return NVPTX::TLD4_R_2D_S32_F32_II; case NVPTX::TLD4_G_2D_S32_F32_RR: return NVPTX::TLD4_G_2D_S32_F32_RI; case NVPTX::TLD4_G_2D_S32_F32_IR: return NVPTX::TLD4_G_2D_S32_F32_II; case NVPTX::TLD4_B_2D_S32_F32_RR: return NVPTX::TLD4_B_2D_S32_F32_RI; case NVPTX::TLD4_B_2D_S32_F32_IR: return NVPTX::TLD4_B_2D_S32_F32_II; case NVPTX::TLD4_A_2D_S32_F32_RR: return NVPTX::TLD4_A_2D_S32_F32_RI; case NVPTX::TLD4_A_2D_S32_F32_IR: return NVPTX::TLD4_A_2D_S32_F32_II; case NVPTX::TLD4_R_2D_U32_F32_RR: return NVPTX::TLD4_R_2D_U32_F32_RI; case NVPTX::TLD4_R_2D_U32_F32_IR: return NVPTX::TLD4_R_2D_U32_F32_II; case NVPTX::TLD4_G_2D_U32_F32_RR: return NVPTX::TLD4_G_2D_U32_F32_RI; case NVPTX::TLD4_G_2D_U32_F32_IR: return NVPTX::TLD4_G_2D_U32_F32_II; case NVPTX::TLD4_B_2D_U32_F32_RR: return NVPTX::TLD4_B_2D_U32_F32_RI; case NVPTX::TLD4_B_2D_U32_F32_IR: return NVPTX::TLD4_B_2D_U32_F32_II; case NVPTX::TLD4_A_2D_U32_F32_RR: return NVPTX::TLD4_A_2D_U32_F32_RI; case NVPTX::TLD4_A_2D_U32_F32_IR: return NVPTX::TLD4_A_2D_U32_F32_II; default: llvm_unreachable("Unhandled TEX opcode"); }; } static unsigned queryRegisterToIndexOpcode(unsigned RegOC) { switch (RegOC) { case NVPTX::TXQ_CHANNEL_ORDER_R: return NVPTX::TXQ_CHANNEL_ORDER_I; case NVPTX::TXQ_CHANNEL_DATA_TYPE_R: return NVPTX::TXQ_CHANNEL_DATA_TYPE_I; case NVPTX::TXQ_WIDTH_R: return NVPTX::TXQ_WIDTH_I; case NVPTX::TXQ_HEIGHT_R: return NVPTX::TXQ_HEIGHT_I; case NVPTX::TXQ_DEPTH_R: return NVPTX::TXQ_DEPTH_I; case NVPTX::TXQ_ARRAY_SIZE_R: return NVPTX::TXQ_ARRAY_SIZE_I; case NVPTX::TXQ_NUM_SAMPLES_R: return NVPTX::TXQ_NUM_SAMPLES_I; case NVPTX::TXQ_NUM_MIPMAP_LEVELS_R: return NVPTX::TXQ_NUM_MIPMAP_LEVELS_I; case NVPTX::SUQ_CHANNEL_ORDER_R: return NVPTX::SUQ_CHANNEL_ORDER_I; case NVPTX::SUQ_CHANNEL_DATA_TYPE_R: return NVPTX::SUQ_CHANNEL_DATA_TYPE_I; case NVPTX::SUQ_WIDTH_R: return NVPTX::SUQ_WIDTH_I; case NVPTX::SUQ_HEIGHT_R: return NVPTX::SUQ_HEIGHT_I; case NVPTX::SUQ_DEPTH_R: return NVPTX::SUQ_DEPTH_I; case NVPTX::SUQ_ARRAY_SIZE_R: return NVPTX::SUQ_ARRAY_SIZE_I; default: llvm_unreachable("Unhandled TXQ/SUQ opcode"); }; } bool NVPTXReplaceImageHandles::processInstr(MachineInstr &MI) { MachineFunction &MF = *MI.getParent()->getParent(); const MCInstrDesc &MCID = MI.getDesc(); const NVPTXInstrInfo *TII = MF.getSubtarget().getInstrInfo(); if (MCID.TSFlags & NVPTXII::IsTexFlag) { // This is a texture fetch, so operand 4 is a texref and operand 5 is // a samplerref MachineOperand &TexHandle = MI.getOperand(4); if (replaceImageHandle(TexHandle, MF)) MI.setDesc(TII->get(texRegisterToIndexOpcode(MI.getOpcode()))); if (!(MCID.TSFlags & NVPTXII::IsTexModeUnifiedFlag)) { MachineOperand &SampHandle = MI.getOperand(5); if (replaceImageHandle(SampHandle, MF)) MI.setDesc(TII->get(samplerRegisterToIndexOpcode(MI.getOpcode()))); } return true; } if (MCID.TSFlags & NVPTXII::IsSuldMask) { unsigned VecSize = 1 << (((MCID.TSFlags & NVPTXII::IsSuldMask) >> NVPTXII::IsSuldShift) - 1); // For a surface load of vector size N, the Nth operand will be the surfref MachineOperand &SurfHandle = MI.getOperand(VecSize); if (replaceImageHandle(SurfHandle, MF)) MI.setDesc(TII->get(suldRegisterToIndexOpcode(MI.getOpcode()))); return true; } if (MCID.TSFlags & NVPTXII::IsSustFlag) { // This is a surface store, so operand 0 is a surfref MachineOperand &SurfHandle = MI.getOperand(0); if (replaceImageHandle(SurfHandle, MF)) MI.setDesc(TII->get(sustRegisterToIndexOpcode(MI.getOpcode()))); return true; } if (MCID.TSFlags & NVPTXII::IsSurfTexQueryFlag) { // This is a query, so operand 1 is a surfref/texref MachineOperand &Handle = MI.getOperand(1); if (replaceImageHandle(Handle, MF)) MI.setDesc(TII->get(queryRegisterToIndexOpcode(MI.getOpcode()))); return true; } return false; } bool NVPTXReplaceImageHandles::replaceImageHandle(MachineOperand &Op, MachineFunction &MF) { const MachineRegisterInfo &MRI = MF.getRegInfo(); NVPTXMachineFunctionInfo *MFI = MF.getInfo(); assert(Op.isReg() && "Handle is not in a reg?"); // Which instruction defines the handle? MachineInstr &TexHandleDef = *MRI.getVRegDef(Op.getReg()); switch (TexHandleDef.getOpcode()) { case NVPTX::LD_i64: { // The handle is a parameter value being loaded, replace with the // parameter symbol const auto &TM = static_cast(MF.getTarget()); if (TM.getDrvInterface() == NVPTX::CUDA) // For CUDA, we preserve the param loads coming from function arguments return false; assert(TexHandleDef.getOperand(6).isSymbol() && "Load is not a symbol!"); StringRef Sym = TexHandleDef.getOperand(6).getSymbolName(); InstrsToRemove.insert(&TexHandleDef); Op.ChangeToES(Sym.data()); MFI->getImageHandleSymbolIndex(Sym); return true; } case NVPTX::texsurf_handles: { // The handle is a global variable, replace with the global variable name assert(TexHandleDef.getOperand(1).isGlobal() && "Load is not a global!"); const GlobalValue *GV = TexHandleDef.getOperand(1).getGlobal(); assert(GV->hasName() && "Global sampler must be named!"); InstrsToRemove.insert(&TexHandleDef); Op.ChangeToGA(GV, 0); return true; } case NVPTX::nvvm_move_i64: case TargetOpcode::COPY: { bool Res = replaceImageHandle(TexHandleDef.getOperand(1), MF); if (Res) InstrsToRemove.insert(&TexHandleDef); return Res; } default: llvm_unreachable("Unknown instruction operating on handle"); } } MachineFunctionPass *llvm::createNVPTXReplaceImageHandlesPass() { return new NVPTXReplaceImageHandles(); }