Fix a major regression with value-initialization of class types with

trivial default constructors. We're weren't zero-initializing them,
which manifested as <rdar://problem/8320532> (a regression in the GCC
test suite) and is likely to have caused significant other breakage.

llvm-svn: 111650
This commit is contained in:
Douglas Gregor
2010-08-20 16:57:37 +00:00
parent 2fb75f0455
commit e3b3464d4e
2 changed files with 34 additions and 1 deletions

View File

@@ -320,8 +320,14 @@ CodeGenFunction::EmitCXXConstructExpr(llvm::Value *Dest,
InitType = getContext().getBaseElementType(Array);
const CXXRecordDecl *RD =
cast<CXXRecordDecl>(InitType->getAs<RecordType>()->getDecl());
if (RD->hasTrivialConstructor())
if (RD->hasTrivialConstructor()) {
// The constructor is trivial, but we may still need to zero-initialize
// the class.
if (E->requiresZeroInitialization())
EmitNullInitialization(Dest, E->getType());
return;
}
}
// Code gen optimization to eliminate copy constructor and return
// its first argument instead, if in fact that argument is a temporary

View File

@@ -67,3 +67,30 @@ namespace test1 {
B();
}
}
namespace ptrmem {
struct S {
int mem1;
int S::*mem2;
};
// CHECK: define i32 @_ZN6ptrmem4testEPNS_1SE
int test(S *s) {
// CHECK: call void @llvm.memcpy.p0i8.p0i8.i64
// CHECK: getelementptr
// CHECK: ret
return s->*S().mem2;
}
}
namespace zeroinit {
struct S { int i; };
// CHECK: define i32 @_ZN8zeroinit4testEv()
int test() {
// CHECK: call void @llvm.memset.p0i8.i64
// CHECK: getelementptr
// CHECK: ret i32
return S().i;
}
}