diff options
| author | Anders Carlsson <andersca@mac.com> | 2009-05-31 00:33:20 +0000 | 
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2009-05-31 00:33:20 +0000 | 
| commit | f3f91cee43b3c7cce74a028c1af4783a7cb6fdc4 (patch) | |
| tree | 4d4b8b8f0ca6bfb5b08fb0bda21d3f71b0fad2fa | |
| parent | c0092ad333ef6823ced088081713e28737380e59 (diff) | |
| download | bcm5719-llvm-f3f91cee43b3c7cce74a028c1af4783a7cb6fdc4.tar.gz bcm5719-llvm-f3f91cee43b3c7cce74a028c1af4783a7cb6fdc4.zip  | |
When possible, don't emit the cleanup block. Instead, just move the instructions to the current block.
llvm-svn: 72654
| -rw-r--r-- | clang/lib/CodeGen/CodeGenFunction.cpp | 8 | 
1 files changed, 7 insertions, 1 deletions
diff --git a/clang/lib/CodeGen/CodeGenFunction.cpp b/clang/lib/CodeGen/CodeGenFunction.cpp index 1a95e619157..672f6da502b 100644 --- a/clang/lib/CodeGen/CodeGenFunction.cpp +++ b/clang/lib/CodeGen/CodeGenFunction.cpp @@ -652,7 +652,13 @@ void CodeGenFunction::EmitCleanupBlock()  {    CleanupBlockInfo Info = PopCleanupBlock(); -  EmitBlock(Info.CleanupBlock); +  llvm::BasicBlock *CurBB = Builder.GetInsertBlock(); +  if (CurBB && !CurBB->getTerminator() &&  +      Info.CleanupBlock->getNumUses() == 0) { +    CurBB->getInstList().splice(CurBB->end(), Info.CleanupBlock->getInstList()); +    delete Info.CleanupBlock; +  } else  +    EmitBlock(Info.CleanupBlock);    if (Info.SwitchBlock)      EmitBlock(Info.SwitchBlock);  | 

