Browse Source

Merge branch 'ticket/51'

tickets/52/52/1
rarified 2 years ago
parent
commit
f9723462d7
  1. 4
      Sources/Plasma/PubUtilLib/plResMgr/plRegistryKeyList.cpp
  2. 1
      Sources/Plasma/PubUtilLib/plResMgr/plRegistryNode.cpp
  3. 14
      Sources/Plasma/PubUtilLib/plResMgr/plResManager.cpp

4
Sources/Plasma/PubUtilLib/plResMgr/plRegistryKeyList.cpp

@ -59,10 +59,12 @@ plRegistryKeyList::~plRegistryKeyList()
for (int i = 0; i < fStaticKeys.size(); i++) for (int i = 0; i < fStaticKeys.size(); i++)
{ {
plKeyImp* keyImp = fStaticKeys[i]; plKeyImp* keyImp = fStaticKeys[i];
if (!keyImp->ObjectIsLoaded()) if (keyImp && !keyImp->ObjectIsLoaded()) {
fStaticKeys[i] = nullptr;
delete keyImp; delete keyImp;
} }
} }
}
// Special dummy key that lets us set the return value of the GetName call. // Special dummy key that lets us set the return value of the GetName call.
// Makes it easier to do STL searches. // Makes it easier to do STL searches.

1
Sources/Plasma/PubUtilLib/plResMgr/plRegistryNode.cpp

@ -203,6 +203,7 @@ void plRegistryPageNode::UnloadKeys()
for (; it != fKeyLists.end(); it++) for (; it != fKeyLists.end(); it++)
{ {
plRegistryKeyList* keyList = it->second; plRegistryKeyList* keyList = it->second;
it->second = nullptr;
delete keyList; delete keyList;
} }
fKeyLists.clear(); fKeyLists.clear();

14
Sources/Plasma/PubUtilLib/plResMgr/plResManager.cpp

@ -219,14 +219,20 @@ void plResManager::IShutdown()
// Shut down the registry (finally!) // Shut down the registry (finally!)
ILockPages(); ILockPages();
PageSet::const_iterator it; // Unload all keys before actually deleting the pages.
for (it = fAllPages.begin(); it != fAllPages.end(); it++) // When a key's refcount drops to zero, IKeyUnreffed looks up the key's page.
// If the page is already deleted at that point, this causes a use after free and potential crash.
for (PageSet::const_iterator it = fAllPages.begin(); it != fAllPages.end(); it++) {
(*it)->UnloadKeys();
}
fLoadedPages.clear();
fLastFoundPage = nil;
for (PageSet::const_iterator it = fAllPages.begin(); it != fAllPages.end(); it++) {
delete *it; delete *it;
}
fAllPages.clear(); fAllPages.clear();
fLoadedPages.clear();
IUnlockPages(); IUnlockPages();
fLastFoundPage = nil;
// Now, kill off the Dispatcher // Now, kill off the Dispatcher
hsRefCnt_SafeUnRef(fDispatch); hsRefCnt_SafeUnRef(fDispatch);

Loading…
Cancel
Save