forked from OSchip/llvm-project
Destroy the dynamic loader plugin in Process::Finalize. If you wait till the auto_ptr gets deleted in the normal course of things the real process class will have been destroyed already, and it's hard to shut down the dynamic loader without accessing some process pure virtual method.
llvm-svn: 125668
This commit is contained in:
parent
81c4306005
commit
d0a3e12b05
|
@ -279,6 +279,11 @@ Process::Finalize()
|
|||
{
|
||||
// Do any cleanup needed prior to being destructed... Subclasses
|
||||
// that override this method should call this superclass method as well.
|
||||
|
||||
// We need to destroy the loader before the derived Process class gets destroyed
|
||||
// since it is very likely that undoing the loader will require access to the real process.
|
||||
if (m_dyld_ap.get() != NULL)
|
||||
m_dyld_ap.reset();
|
||||
}
|
||||
|
||||
void
|
||||
|
|
|
@ -98,8 +98,8 @@ Target::DeleteCurrentProcess ()
|
|||
m_section_load_list.Clear();
|
||||
if (m_process_sp->IsAlive())
|
||||
m_process_sp->Destroy();
|
||||
else
|
||||
m_process_sp->Finalize();
|
||||
|
||||
m_process_sp->Finalize();
|
||||
|
||||
// Do any cleanup of the target we need to do between process instances.
|
||||
// NB It is better to do this before destroying the process in case the
|
||||
|
|
Loading…
Reference in New Issue