...and aggregate POD types.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@72676 91177308-0d34-0410-b5e6-96231b3b80d8
diff --git a/lib/CodeGen/CGCXX.cpp b/lib/CodeGen/CGCXX.cpp
index 9e20530..febfbac 100644
--- a/lib/CodeGen/CGCXX.cpp
+++ b/lib/CodeGen/CGCXX.cpp
@@ -299,10 +299,8 @@
         Builder.CreateStore(EmitScalarExpr(Init), NewPtr);
       else if (AllocType->isAnyComplexType())
         EmitComplexExprIntoAddr(Init, NewPtr, AllocType.isVolatileQualified());
-      else {
-        ErrorUnsupported(E, "new expression");
-        return llvm::UndefValue::get(ConvertType(E->getType()));
-      }
+      else
+        EmitAggExpr(Init, NewPtr, AllocType.isVolatileQualified());
     }
     
     return NewPtr;
diff --git a/test/CodeGenCXX/new.cpp b/test/CodeGenCXX/new.cpp
index dde7bfe..bf959c9 100644
--- a/test/CodeGenCXX/new.cpp
+++ b/test/CodeGenCXX/new.cpp
@@ -11,8 +11,15 @@
   int* b = new (a) int;
 }
 
+struct S {
+  int a;
+};
+
 void t3() {
   int *a = new int(10);
   _Complex int* b = new _Complex int(10i);
   
+  S s;
+  s.a = 10;
+  S *sp = new S(s);
 }