diff options
Diffstat (limited to 'lib/Target/CBackend/CBackend.cpp')
-rw-r--r-- | lib/Target/CBackend/CBackend.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/Target/CBackend/CBackend.cpp b/lib/Target/CBackend/CBackend.cpp index 721ead0..073ce19 100644 --- a/lib/Target/CBackend/CBackend.cpp +++ b/lib/Target/CBackend/CBackend.cpp @@ -117,6 +117,7 @@ namespace { void visitBranchInst(BranchInst &I); void visitSwitchInst(SwitchInst &I); void visitInvokeInst(InvokeInst &I); + void visitUnwindInst(UnwindInst &I); void visitPHINode(PHINode &I); void visitBinaryOperator(Instruction &I); @@ -980,6 +981,19 @@ void CWriter::visitInvokeInst(InvokeInst &II) { } +void CWriter::visitUnwindInst(UnwindInst &I) { + // The unwind instructions causes a control flow transfer out of the current + // function, unwinding the stack until a caller who used the invoke + // instruction is found. In this context, we code generated the invoke + // instruction to add an entry to the top of the jmpbuf_list. Thus, here we + // just have to longjmp to the specified handler. + Out << " if (__llvm_jmpbuf_list == 0) { /* llvm.unwind */\n" + << " printf(\"throw found with no handler!\\n\"); abort();\n" + << " }\n" + << " longjmp(__llvm_jmpbuf_list->buf, 1);\n"; + emittedInvoke = true; +} + static bool isGotoCodeNeccessary(BasicBlock *From, BasicBlock *To) { // If PHI nodes need copies, we need the copy code... if (isa<PHINode>(To->front()) || |