зеркало из https://github.com/microsoft/clang-1.git
Fix PR7097, a bad interaction between -fno-use-cxa-atexit and
-mconstructor-aliases by using a WeakVH instead of a raw pointer. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@106384 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Родитель
b9d5c22529
Коммит
810112e28d
|
@ -193,11 +193,6 @@ CodeGenModule::EmitCXXGlobalInitFunc() {
|
|||
AddGlobalCtor(Fn);
|
||||
}
|
||||
|
||||
void CodeGenModule::AddCXXDtorEntry(llvm::Constant *DtorFn,
|
||||
llvm::Constant *Object) {
|
||||
CXXGlobalDtors.push_back(std::make_pair(DtorFn, Object));
|
||||
}
|
||||
|
||||
void CodeGenModule::EmitCXXGlobalDtorFunc() {
|
||||
if (CXXGlobalDtors.empty())
|
||||
return;
|
||||
|
@ -238,14 +233,14 @@ void CodeGenFunction::GenerateCXXGlobalInitFunc(llvm::Function *Fn,
|
|||
}
|
||||
|
||||
void CodeGenFunction::GenerateCXXGlobalDtorFunc(llvm::Function *Fn,
|
||||
const std::vector<std::pair<llvm::Constant*, llvm::Constant*> >
|
||||
const std::vector<std::pair<llvm::WeakVH, llvm::Constant*> >
|
||||
&DtorsAndObjects) {
|
||||
StartFunction(GlobalDecl(), getContext().VoidTy, Fn, FunctionArgList(),
|
||||
SourceLocation());
|
||||
|
||||
// Emit the dtors, in reverse order from construction.
|
||||
for (unsigned i = 0, e = DtorsAndObjects.size(); i != e; ++i) {
|
||||
llvm::Constant *Callee = DtorsAndObjects[e - i - 1].first;
|
||||
llvm::Value *Callee = DtorsAndObjects[e - i - 1].first;
|
||||
llvm::CallInst *CI = Builder.CreateCall(Callee,
|
||||
DtorsAndObjects[e - i - 1].second);
|
||||
// Make sure the call and the callee agree on calling convention.
|
||||
|
|
|
@ -1268,7 +1268,7 @@ public:
|
|||
/// GenerateCXXGlobalDtorFunc - Generates code for destroying global
|
||||
/// variables.
|
||||
void GenerateCXXGlobalDtorFunc(llvm::Function *Fn,
|
||||
const std::vector<std::pair<llvm::Constant*,
|
||||
const std::vector<std::pair<llvm::WeakVH,
|
||||
llvm::Constant*> > &DtorsAndObjects);
|
||||
|
||||
void GenerateCXXGlobalVarDeclInitFunc(llvm::Function *Fn, const VarDecl *D);
|
||||
|
|
|
@ -142,7 +142,7 @@ class CodeGenModule : public BlockModule {
|
|||
|
||||
/// CXXGlobalDtors - Global destructor functions and arguments that need to
|
||||
/// run on termination.
|
||||
std::vector<std::pair<llvm::Constant*,llvm::Constant*> > CXXGlobalDtors;
|
||||
std::vector<std::pair<llvm::WeakVH,llvm::Constant*> > CXXGlobalDtors;
|
||||
|
||||
/// CFConstantStringClassRef - Cached reference to the class for constant
|
||||
/// strings. This value has type int * but is actually an Obj-C class pointer.
|
||||
|
@ -350,7 +350,9 @@ public:
|
|||
|
||||
/// AddCXXDtorEntry - Add a destructor and object to add to the C++ global
|
||||
/// destructor function.
|
||||
void AddCXXDtorEntry(llvm::Constant *DtorFn, llvm::Constant *Object);
|
||||
void AddCXXDtorEntry(llvm::Constant *DtorFn, llvm::Constant *Object) {
|
||||
CXXGlobalDtors.push_back(std::make_pair(DtorFn, Object));
|
||||
}
|
||||
|
||||
/// CreateRuntimeFunction - Create a new runtime function with the specified
|
||||
/// type and name.
|
||||
|
|
|
@ -1,5 +1,8 @@
|
|||
// RUN: %clang_cc1 -triple x86_64 %s -fno-use-cxa-atexit -emit-llvm -o - | FileCheck %s
|
||||
|
||||
// PR7097
|
||||
// RUN: %clang_cc1 -triple x86_64 %s -fno-use-cxa-atexit -mconstructor-aliases -emit-llvm -o - | FileCheck %s
|
||||
|
||||
// CHECK: define internal void @_GLOBAL__D_a()
|
||||
// CHECK: call void @_ZN1AD1Ev(%class.A* @b)
|
||||
// CHECK: call void @_ZN1AD1Ev(%class.A* @a)
|
||||
|
|
Загрузка…
Ссылка в новой задаче