aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp')
-rw-r--r--llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp8
1 files changed, 6 insertions, 2 deletions
diff --git a/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp b/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp
index f4934f0bc20b..4bd820e98f05 100644
--- a/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp
+++ b/llvm/lib/Target/NVPTX/NVPTXReplaceImageHandles.cpp
@@ -64,8 +64,12 @@ bool NVPTXReplaceImageHandles::runOnMachineFunction(MachineFunction &MF) {
// 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)
- MI->eraseFromParent();
+ 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;
}