aboutsummaryrefslogtreecommitdiff
path: root/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp
diff options
context:
space:
mode:
authorDimitry Andric <dim@FreeBSD.org>2022-07-24 15:11:41 +0000
committerDimitry Andric <dim@FreeBSD.org>2023-02-08 19:04:38 +0000
commitfcaf7f8644a9988098ac6be2165bce3ea4786e91 (patch)
tree08a554363df16b968a623d651c09d82a5a0b1c65 /contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp
parent753f127f3ace09432b2baeffd71a308760641a62 (diff)
parent4b4fe385e49bd883fd183b5f21c1ea486c722e61 (diff)
downloadsrc-fcaf7f8644a9988098ac6be2165bce3ea4786e91.tar.gz
src-fcaf7f8644a9988098ac6be2165bce3ea4786e91.zip
Diffstat (limited to 'contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp')
-rw-r--r--contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp b/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp
index 8e4ab973bf07..8aaac50c94d7 100644
--- a/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp
+++ b/contrib/llvm-project/llvm/lib/Target/SPIRV/SPIRVMCInstLower.cpp
@@ -45,7 +45,12 @@ void SPIRVMCInstLower::lower(const MachineInstr *MI, MCInst &OutMI,
break;
}
case MachineOperand::MO_Immediate:
- MCOp = MCOperand::createImm(MO.getImm());
+ if (MI->getOpcode() == SPIRV::OpExtInst && i == 2) {
+ Register Reg = MAI->getExtInstSetReg(MO.getImm());
+ MCOp = MCOperand::createReg(Reg);
+ } else {
+ MCOp = MCOperand::createImm(MO.getImm());
+ }
break;
case MachineOperand::MO_FPImmediate:
MCOp = MCOperand::createDFPImm(