diff options
Diffstat (limited to 'lib/CodeGen/CodeGenFunction.cpp')
-rw-r--r-- | lib/CodeGen/CodeGenFunction.cpp | 30 |
1 files changed, 15 insertions, 15 deletions
diff --git a/lib/CodeGen/CodeGenFunction.cpp b/lib/CodeGen/CodeGenFunction.cpp index 73b71b2f62..2ef4bcf981 100644 --- a/lib/CodeGen/CodeGenFunction.cpp +++ b/lib/CodeGen/CodeGenFunction.cpp @@ -428,25 +428,25 @@ llvm::Value *CodeGenFunction::EmitVLASize(QualType Ty) if (const VariableArrayType *VAT = getContext().getAsVariableArrayType(Ty)) { llvm::Value *&SizeEntry = VLASizeMap[VAT]; - assert(!SizeEntry && "Must not emit the same VLA size more than once!"); + if (!SizeEntry) { + // Get the element size; + llvm::Value *ElemSize; - // Get the element size; - llvm::Value *ElemSize; + QualType ElemTy = VAT->getElementType(); - QualType ElemTy = VAT->getElementType(); - - if (ElemTy->isVariableArrayType()) - ElemSize = EmitVLASize(ElemTy); - else { - // FIXME: We use Int32Ty here because the alloca instruction takes a - // 32-bit integer. What should we do about overflow? - ElemSize = llvm::ConstantInt::get(llvm::Type::Int32Ty, - getContext().getTypeSize(ElemTy) / 8); - } + if (ElemTy->isVariableArrayType()) + ElemSize = EmitVLASize(ElemTy); + else { + // FIXME: We use Int32Ty here because the alloca instruction takes a + // 32-bit integer. What should we do about overflow? + ElemSize = llvm::ConstantInt::get(llvm::Type::Int32Ty, + getContext().getTypeSize(ElemTy) / 8); + } - llvm::Value *NumElements = EmitScalarExpr(VAT->getSizeExpr()); + llvm::Value *NumElements = EmitScalarExpr(VAT->getSizeExpr()); - SizeEntry = Builder.CreateMul(ElemSize, NumElements); + SizeEntry = Builder.CreateMul(ElemSize, NumElements); + } return SizeEntry; } else if (const PointerType *PT = Ty->getAsPointerType()) |