aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2008-02-22 02:49:49 +0000
committerDevang Patel <dpatel@apple.com>2008-02-22 02:49:49 +0000
commit197be3de7f247e61c75d12dc1cb090c1c2c39f28 (patch)
treec271d5c13df7431a7e3bd9ffea3cba8203bf3cc6
parent149a4e56fcd29c37c416e0ce4a5ebed7b514cbc6 (diff)
downloadexternal_llvm-197be3de7f247e61c75d12dc1cb090c1c2c39f28.zip
external_llvm-197be3de7f247e61c75d12dc1cb090c1c2c39f28.tar.gz
external_llvm-197be3de7f247e61c75d12dc1cb090c1c2c39f28.tar.bz2
Read and write getresult.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47471 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r--include/llvm/Bitcode/LLVMBitCodes.h3
-rw-r--r--lib/Bitcode/Reader/BitcodeReader.cpp10
-rw-r--r--lib/Bitcode/Writer/BitcodeWriter.cpp5
3 files changed, 17 insertions, 1 deletions
diff --git a/include/llvm/Bitcode/LLVMBitCodes.h b/include/llvm/Bitcode/LLVMBitCodes.h
index 93a81da..5ef832e 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 ec71ba4..24bf978 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<optional>]
if (Record.empty()) {
diff --git a/lib/Bitcode/Writer/BitcodeWriter.cpp b/lib/Bitcode/Writer/BitcodeWriter.cpp
index fe013e8..306433b 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<CmpInst>(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<GetResultInst>(I).getIndex())+1);
+ break;
case Instruction::Ret:
Code = bitc::FUNC_CODE_INST_RET;