mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-19 11:35:51 -04:00

r369697 changed the behavior of stripPointerCasts to no longer include aliases. However, the code in CGDeclCXX.cpp's createAtExitStub counted on the looking through aliases to properly set the calling convention of a call. The result of the change was that the calling convention mismatch of the call would be replaced with a llvm.trap, causing a runtime crash. Differential Revision: https://reviews.llvm.org/D68584 llvm-svn: 373929
22 lines
821 B
C++
22 lines
821 B
C++
// RUN: %clang_cc1 -triple i686-windows-pc -emit-llvm -o - -mconstructor-aliases -O1 -disable-llvm-passes %s | FileCheck %s
|
|
|
|
struct Base { virtual ~Base(); };
|
|
struct Derived : Base {
|
|
virtual ~Derived();
|
|
static Derived inst;
|
|
};
|
|
|
|
Base::~Base(){}
|
|
Derived::~Derived(){}
|
|
Derived Derived::inst;
|
|
|
|
// CHECK: @"??1Derived@@UAE@XZ" = dso_local unnamed_addr alias void (%struct.Derived*), bitcast (void (%struct.Base*)* @"??1Base@@UAE@XZ" to void (%struct.Derived*)*)
|
|
|
|
// CHECK: define dso_local x86_thiscallcc void @"??1Base@@UAE@XZ"
|
|
// CHECK: define internal void @"??__E?inst@Derived@@2U1@A@@YAXXZ"
|
|
// CHECK: call i32 @atexit(void ()* @"??__F?inst@Derived@@2U1@A@@YAXXZ"
|
|
//
|
|
// CHECK: define internal void @"??__F?inst@Derived@@2U1@A@@YAXXZ"
|
|
// CHECK-NEXT: entry:
|
|
// CHECK-NEXT: call x86_thiscallcc void @"??1Derived@@UAE@XZ"
|