From 3c90733886be1d15d2bfeeafbccbfc5bdba8fc0b Mon Sep 17 00:00:00 2001 From: Alexey Bataev Date: Mon, 10 Aug 2015 04:07:49 +0000 Subject: [PATCH] [MSVC] Crash fix: assigning of overloaded member function pointer caused assertion Original class was not marked with inheritance attribute and it causes a crash on codegen. Differential Revision: http://reviews.llvm.org/D11828 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@244428 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Sema/SemaCast.cpp | 2 ++ .../microsoft-abi-member-pointers.cpp | 17 +++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/lib/Sema/SemaCast.cpp b/lib/Sema/SemaCast.cpp index fe16fc2df3..dea9c22b74 100644 --- a/lib/Sema/SemaCast.cpp +++ b/lib/Sema/SemaCast.cpp @@ -1397,6 +1397,8 @@ TryStaticMemberPointerUpcast(Sema &Self, ExprResult &SrcExpr, QualType SrcType, msg = diag::err_bad_static_cast_member_pointer_nonmp; return TC_NotApplicable; } + if (Self.Context.getTargetInfo().getCXXABI().isMicrosoft()) + Self.RequireCompleteType(OpRange.getBegin(), SrcType, 0); // T == T, modulo cv if (!Self.Context.hasSameUnqualifiedType(SrcMemPtr->getPointeeType(), diff --git a/test/CodeGenCXX/microsoft-abi-member-pointers.cpp b/test/CodeGenCXX/microsoft-abi-member-pointers.cpp index a509d57194..27a2a5fc9c 100644 --- a/test/CodeGenCXX/microsoft-abi-member-pointers.cpp +++ b/test/CodeGenCXX/microsoft-abi-member-pointers.cpp @@ -729,3 +729,20 @@ typedef void (D::*DMemPtrTy)(); // CHECK: @"\01??_9C@pr23878@@$BA@AE" to i8*), i32 0, i32 4 DMemPtrTy get_memptr() { return &D::f; } } + +class C {}; + +typedef void (C::*f)(); + +class CA : public C { +public: + void OnHelp(void); + int OnHelp(int); +}; + +// CHECK-LABEL: foo_fun +void foo_fun() { + // CHECK: store i8* bitcast (void (%class.CA*)* @"\01?OnHelp@CA@@QAEXXZ" to i8*), i8** + f func = (f)&CA::OnHelp; +} + -- 2.40.0