From 197be3de7f247e61c75d12dc1cb090c1c2c39f28 Mon Sep 17 00:00:00 2001 From: Devang Patel Date: Fri, 22 Feb 2008 02:49:49 +0000 Subject: [PATCH] Read and write getresult. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47471 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Bitcode/LLVMBitCodes.h | 3 ++- lib/Bitcode/Reader/BitcodeReader.cpp | 10 ++++++++++ lib/Bitcode/Writer/BitcodeWriter.cpp | 5 +++++ 3 files changed, 17 insertions(+), 1 deletion(-) diff --git a/include/llvm/Bitcode/LLVMBitCodes.h b/include/llvm/Bitcode/LLVMBitCodes.h index 93a81dad72f..5ef832e187c 100644 --- a/include/llvm/Bitcode/LLVMBitCodes.h +++ b/include/llvm/Bitcode/LLVMBitCodes.h @@ -201,7 +201,8 @@ namespace bitc { // This store code encodes the pointer type, rather than the value type // this is so information only available in the pointer type (e.g. address // spaces) is retained. - FUNC_CODE_INST_STORE2 = 24 // STORE: [ptrty,ptr,val, align, vol] + FUNC_CODE_INST_STORE2 = 24, // STORE: [ptrty,ptr,val, align, vol] + FUNC_CODE_INST_GETRESULT = 25 // GETRESULT: [ty, opval, n] }; } // End bitc namespace } // End llvm namespace diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp index ec71ba4e9c6..24bf978a2b0 100644 --- a/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1325,6 +1325,16 @@ bool BitcodeReader::ParseFunctionBody(Function *F) { I = new ICmpInst((ICmpInst::Predicate)Record[OpNum], LHS, RHS); break; } + case bitc::FUNC_CODE_INST_GETRESULT: { // GETRESULT: [ty, val, n] + if (Record.size() != 2) + return Error("Invalid GETRESULT record"); + unsigned OpNum = 0; + Value *Op; + getValueTypePair(Record, OpNum, NextValueNo, Op); + unsigned Index = Record[1]; + I = new GetResultInst(Op, Index); + break; + } case bitc::FUNC_CODE_INST_RET: // RET: [opty,opval] if (Record.empty()) { diff --git a/lib/Bitcode/Writer/BitcodeWriter.cpp b/lib/Bitcode/Writer/BitcodeWriter.cpp index fe013e81569..306433b1b52 100644 --- a/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -744,6 +744,11 @@ static void WriteInstruction(const Instruction &I, unsigned InstID, Vals.push_back(VE.getValueID(I.getOperand(1))); Vals.push_back(cast(I).getPredicate()); break; + case Instruction::GetResult: + Code = bitc::FUNC_CODE_INST_GETRESULT; + PushValueAndType(I.getOperand(0), InstID, Vals, VE); + Vals.push_back(Log2_32(cast(I).getIndex())+1); + break; case Instruction::Ret: Code = bitc::FUNC_CODE_INST_RET;