mirror of
https://github.com/intel/llvm.git
synced 2026-02-02 02:00:03 +08:00
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:
@@ -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
|
||||
|
||||
@@ -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;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user