From: Devang Patel Date: Sat, 5 Sep 2009 00:34:14 +0000 (+0000) Subject: Detect VLAs. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=bd1d6a8ce1197de640df52e1da2e63e8ce8d8705;p=oota-llvm.git Detect VLAs. Do not use DenseMap operator[] because it inserts new entry if lookup fails. Use find() to check an entry in a DenseMap first. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81058 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp index 555ef9e1b0a..cd05f7124d2 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp @@ -3981,7 +3981,11 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) { // Don't handle byval struct arguments or VLAs, for example. if (!AI) return 0; - int FI = FuncInfo.StaticAllocaMap[AI]; + DenseMap::iterator SI = + FuncInfo.StaticAllocaMap.find(AI); + if (SI == FuncInfo.StaticAllocaMap.end()) + return 0; // VLAs. + int FI = SI->second; DW->RecordVariable(cast(Variable), FI); return 0; }