mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-18 10:31:57 +00:00
Fix an order-of-deallocation issue where the AttrListImpl could be deallocated before the global
LLVMContext, causing memory errors. Patch by Peter Collingbourne. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119721 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
27cb5e612a
commit
9fe010ecf8
@ -106,6 +106,11 @@ Attributes Attribute::typeIncompatible(const Type *Ty) {
|
|||||||
// AttributeListImpl Definition
|
// AttributeListImpl Definition
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
namespace llvm {
|
||||||
|
class AttributeListImpl;
|
||||||
|
}
|
||||||
|
|
||||||
|
static ManagedStatic<FoldingSet<AttributeListImpl> > AttributesLists;
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
static ManagedStatic<sys::SmartMutex<true> > ALMutex;
|
static ManagedStatic<sys::SmartMutex<true> > ALMutex;
|
||||||
@ -131,6 +136,8 @@ public:
|
|||||||
}
|
}
|
||||||
void DropRef() {
|
void DropRef() {
|
||||||
sys::SmartScopedLock<true> Lock(*ALMutex);
|
sys::SmartScopedLock<true> Lock(*ALMutex);
|
||||||
|
if (!AttributesLists.isConstructed())
|
||||||
|
return;
|
||||||
sys::cas_flag new_val = --RefCount;
|
sys::cas_flag new_val = --RefCount;
|
||||||
if (new_val == 0)
|
if (new_val == 0)
|
||||||
delete this;
|
delete this;
|
||||||
@ -147,8 +154,6 @@ public:
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
static ManagedStatic<FoldingSet<AttributeListImpl> > AttributesLists;
|
|
||||||
|
|
||||||
AttributeListImpl::~AttributeListImpl() {
|
AttributeListImpl::~AttributeListImpl() {
|
||||||
// NOTE: Lock must be acquired by caller.
|
// NOTE: Lock must be acquired by caller.
|
||||||
AttributesLists->RemoveNode(this);
|
AttributesLists->RemoveNode(this);
|
||||||
|
Loading…
Reference in New Issue
Block a user