diff options
author | Nick Lewycky <nicholas@mxc.ca> | 2008-03-02 02:48:09 +0000 |
---|---|---|
committer | Nick Lewycky <nicholas@mxc.ca> | 2008-03-02 02:48:09 +0000 |
commit | 31f5f2403274448e782cab26853e013fd45163db (patch) | |
tree | 963a736756189f58a4bd042ddf745b895e40cbac /lib/Bitcode | |
parent | 861d43a23f96935ea6ec8e516a4115e6686abd8c (diff) | |
download | external_llvm-31f5f2403274448e782cab26853e013fd45163db.zip external_llvm-31f5f2403274448e782cab26853e013fd45163db.tar.gz external_llvm-31f5f2403274448e782cab26853e013fd45163db.tar.bz2 |
Add an unwind_to field to basic blocks, making them Users instead of Values.
This is the first checkin for PR1269, the new EH infrastructure.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@47802 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode')
-rw-r--r-- | lib/Bitcode/Reader/BitcodeReader.cpp | 9 | ||||
-rw-r--r-- | lib/Bitcode/Writer/BitcodeWriter.cpp | 9 |
2 files changed, 17 insertions, 1 deletions
diff --git a/lib/Bitcode/Reader/BitcodeReader.cpp b/lib/Bitcode/Reader/BitcodeReader.cpp index 61e0ab9..c1cfa97 100644 --- a/lib/Bitcode/Reader/BitcodeReader.cpp +++ b/lib/Bitcode/Reader/BitcodeReader.cpp @@ -1216,6 +1216,15 @@ bool BitcodeReader::ParseFunctionBody(Function *F) { CurBB = FunctionBBs[0]; continue; + case bitc::FUNC_CODE_INST_BB_UNWINDDEST: // BB_UNWINDDEST: [bb#] + if (CurBB->getUnwindDest()) + return Error("Only permit one BB_UNWINDDEST per BB"); + if (Record.size() != 1) + return Error("Invalid BB_UNWINDDEST record"); + + CurBB->setUnwindDest(getBasicBlock(Record[0])); + continue; + case bitc::FUNC_CODE_INST_BINOP: { // BINOP: [opval, ty, opval, opcode] unsigned OpNum = 0; Value *LHS, *RHS; diff --git a/lib/Bitcode/Writer/BitcodeWriter.cpp b/lib/Bitcode/Writer/BitcodeWriter.cpp index 5de38b8..67b13e3 100644 --- a/lib/Bitcode/Writer/BitcodeWriter.cpp +++ b/lib/Bitcode/Writer/BitcodeWriter.cpp @@ -969,13 +969,20 @@ static void WriteFunction(const Function &F, ValueEnumerator &VE, unsigned InstID = CstEnd; // Finally, emit all the instructions, in order. - for (Function::const_iterator BB = F.begin(), E = F.end(); BB != E; ++BB) + for (Function::const_iterator BB = F.begin(), E = F.end(); BB != E; ++BB) { + if (const BasicBlock *unwindDest = BB->getUnwindDest()) { + Vals.push_back(VE.getValueID(unwindDest)); + Stream.EmitRecord(bitc::FUNC_CODE_INST_BB_UNWINDDEST, Vals); + Vals.clear(); + } + for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I != E; ++I) { WriteInstruction(*I, InstID, VE, Stream, Vals); if (I->getType() != Type::VoidTy) ++InstID; } + } // Emit names for all the instructions etc. WriteValueSymbolTable(F.getValueSymbolTable(), VE, Stream); |