diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index f86e970c25af..dd66f6cc7a10 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -309,12 +309,13 @@ createReferenceTemporary(CodeGenFunction &CGF, (M->getType()->isArrayType() || M->getType()->isRecordType()) && CGF.CGM.isTypeConstant(M->getType(), true)) if (llvm::Constant *Init = - CGF.CGM.EmitConstantExpr(Inner, M->getType(), &CGF)) { + CGF.CGM.EmitConstantExpr(Inner, Inner->getType(), &CGF)) { auto *GV = new llvm::GlobalVariable( CGF.CGM.getModule(), Init->getType(), /*isConstant=*/true, llvm::GlobalValue::PrivateLinkage, Init, ".ref.tmp"); - GV->setAlignment( - CGF.getContext().getTypeAlignInChars(M->getType()).getQuantity()); + GV->setAlignment(CGF.getContext() + .getTypeAlignInChars(Inner->getType()) + .getQuantity()); // FIXME: Should we put the new global into a COMDAT? return GV; } diff --git a/clang/test/CodeGenCXX/cxx0x-initializer-references.cpp b/clang/test/CodeGenCXX/cxx0x-initializer-references.cpp index d4a8f20f3573..bdc97b5bd501 100644 --- a/clang/test/CodeGenCXX/cxx0x-initializer-references.cpp +++ b/clang/test/CodeGenCXX/cxx0x-initializer-references.cpp @@ -1,5 +1,7 @@ // RUN: %clang_cc1 -std=c++11 -S -triple armv7-none-eabi -emit-llvm -o - %s | FileCheck %s +// CHECK: private constant { i8** } { i8** getelementptr inbounds ([3 x i8*], [3 x i8*]* @_ZTVN7PR2316510ChildClassE, i64 0, i64 2) }, align 4 + namespace reference { struct A { int i1, i2; @@ -79,3 +81,22 @@ namespace reference { } } + +namespace PR23165 { +struct AbstractClass { + virtual void foo() const = 0; +}; + +struct ChildClass : public AbstractClass { + virtual void foo() const {} +}; + +void helper(const AbstractClass ¶m) { + param.foo(); +} + +void foo() { +// CHECK: call void @_ZN7PR231656helperERKNS_13AbstractClassE(%{{.*}} bitcast ({ i8** }* @{{.*}} to %{{.*}}*)) + helper(ChildClass()); +} +}