From 22ab8d86ec613ace6602b6de11fa9ccc08580f6b Mon Sep 17 00:00:00 2001 From: Anders Carlsson Date: Tue, 10 Feb 2009 22:50:24 +0000 Subject: [PATCH] Handle the case where EmitBlock might be called multiple times for the same block. Fixes PR3536. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@64252 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/CGStmt.cpp | 10 ++++++++-- test/CodeGen/vla.c | 11 +++++++++++ 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/lib/CodeGen/CGStmt.cpp b/lib/CodeGen/CGStmt.cpp index 85ea8c5e31..d23547fb36 100644 --- a/lib/CodeGen/CGStmt.cpp +++ b/lib/CodeGen/CGStmt.cpp @@ -182,8 +182,14 @@ void CodeGenFunction::EmitBlock(llvm::BasicBlock *BB, bool IsFinished) { // If necessary, associate the block with the cleanup stack size. if (!CleanupEntries.empty()) { - BlockScopes[BB] = CleanupEntries.size() - 1; - CleanupEntries.back().Blocks.push_back(BB); + // Check if the basic block has already been inserted. + BlockScopeMap::iterator I = BlockScopes.find(BB); + if (I != BlockScopes.end()) { + assert(I->second == CleanupEntries.size() - 1); + } else { + BlockScopes[BB] = CleanupEntries.size() - 1; + CleanupEntries.back().Blocks.push_back(BB); + } } CurFn->getBasicBlockList().push_back(BB); diff --git a/test/CodeGen/vla.c b/test/CodeGen/vla.c index 2197ee10cf..beb928b066 100644 --- a/test/CodeGen/vla.c +++ b/test/CodeGen/vla.c @@ -18,3 +18,14 @@ int f0(int x) { int vla[x]; return vla[x-1]; } + +void +f(int count) +{ + int a[count]; + + do { } while (0); + + if (a[0] != 3) { + } +} -- 2.40.0