diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2009-04-20 03:54:15 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2009-04-20 03:54:15 +0000 |
| commit | bc633beda48001fed63de3fba459210d60017e5e (patch) | |
| tree | 5de0fd55b224f53c3c9c5c64792c13683e587d76 | |
| parent | 3253e189c6465fe35fb9059310c478b75f57ff32 (diff) | |
| download | bcm5719-llvm-bc633beda48001fed63de3fba459210d60017e5e.tar.gz bcm5719-llvm-bc633beda48001fed63de3fba459210d60017e5e.zip | |
PR3247: Handle a couple of cases where we weren't emitting VLA sizes (and
subsequently crashed).
llvm-svn: 69567
| -rw-r--r-- | clang/lib/CodeGen/CGDecl.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGExprScalar.cpp | 6 | ||||
| -rw-r--r-- | clang/test/CodeGen/variable-array.c | 14 |
3 files changed, 22 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp index 681d8f68afe..0a1d1d0bd1e 100644 --- a/clang/lib/CodeGen/CGDecl.cpp +++ b/clang/lib/CodeGen/CGDecl.cpp @@ -122,6 +122,10 @@ void CodeGenFunction::EmitStaticBlockVarDecl(const VarDecl &D) { // circular references. DMEntry = GV; + // Make sure to evaluate VLA bounds now so that we have them for later. + if (D.getType()->isVariablyModifiedType()) + EmitVLASize(D.getType()); + if (D.getInit()) { llvm::Constant *Init = CGM.EmitConstantExpr(D.getInit(), D.getType(), this); diff --git a/clang/lib/CodeGen/CGExprScalar.cpp b/clang/lib/CodeGen/CGExprScalar.cpp index 0c6e6c6854c..77771bd937a 100644 --- a/clang/lib/CodeGen/CGExprScalar.cpp +++ b/clang/lib/CodeGen/CGExprScalar.cpp @@ -213,7 +213,11 @@ public: return llvm::Constant::getNullValue(ConvertType(E->getType())); } Value *VisitImplicitCastExpr(const ImplicitCastExpr *E); - Value *VisitCastExpr(const CastExpr *E) { + Value *VisitCastExpr(const CastExpr *E) { + // Make sure to evaluate VLA bounds now so that we have them for later. + if (E->getType()->isVariablyModifiedType()) + CGF.EmitVLASize(E->getType()); + return EmitCastExpr(E->getSubExpr(), E->getType()); } Value *EmitCastExpr(const Expr *E, QualType T); diff --git a/clang/test/CodeGen/variable-array.c b/clang/test/CodeGen/variable-array.c index 280539fa897..f5621c289d7 100644 --- a/clang/test/CodeGen/variable-array.c +++ b/clang/test/CodeGen/variable-array.c @@ -1,7 +1,19 @@ -// RUN: clang-cc -emit-llvm < %s | grep puts +// RUN: clang-cc -emit-llvm < %s | grep puts | count 4 +// PR3248 int a(int x) { int (*y)[x]; return sizeof(*(puts("asdf"),y)); } + +// PR3247 +int b() { + return sizeof(*(char(*)[puts("asdf")])0); +} + +// PR3247 +int c() { + static int (*y)[puts("asdf")]; + return sizeof(*y); +} |

