]> granicus.if.org Git - clang/commitdiff
Ensure we evaluate VLA bounds if a variably-modified type is used as the
authorRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 14 Apr 2014 23:47:48 +0000 (23:47 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Mon, 14 Apr 2014 23:47:48 +0000 (23:47 +0000)
argument to __builtin_va_arg. Patch by Rahul Jain, some test massaging and
IR emission order changes by me.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@206223 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/CGExprScalar.cpp
test/CodeGen/varargs.c

index 5f932b08b55bee878bdd772be4c9697bc9f8ef04..08e410be0139324c7eb0b0335a378f47d2d37658 100644 (file)
@@ -3199,6 +3199,10 @@ Value *ScalarExprEmitter::VisitChooseExpr(ChooseExpr *E) {
 }
 
 Value *ScalarExprEmitter::VisitVAArgExpr(VAArgExpr *VE) {
+  QualType Ty = VE->getType();
+  if (Ty->isVariablyModifiedType())
+    CGF.EmitVariablyModifiedType(Ty);
+
   llvm::Value *ArgValue = CGF.EmitVAListRef(VE->getSubExpr());
   llvm::Value *ArgPtr = CGF.EmitVAArg(ArgValue, VE->getType());
 
index b6973d8337d85952ce05760a09e611066437a2cb..3e2cce0793819d7f962bb2da34da1c4748b379f9 100644 (file)
@@ -1,5 +1,4 @@
-// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s
-
+// RUN: %clang_cc1 -triple i386-unknown-unknown -emit-llvm -o - %s | FileCheck %s
 
 // PR6433 - Don't crash on va_arg(typedef).
 typedef double gdouble;
@@ -15,3 +14,10 @@ void function_as_vararg() {
   // CHECK-NOT: llvm.trap
   vararg(0, focus_changed_cb);
 }
+
+void vla(int n, ...)
+{
+  __builtin_va_list ap;
+  void *p;
+  p = __builtin_va_arg(ap, typeof (int (*)[++n])); // CHECK: add nsw i32 {{.*}}, 1
+}