MTVU: fix linux crash after a shutdown

* Lock during the reset
* Purge the ring before memory unallocation

Close issue #474
This commit is contained in:
Gregory Hainaut 2015-03-17 09:31:25 +01:00
parent 3b5367c5b7
commit b20deb0752
2 changed files with 9 additions and 0 deletions

View File

@ -69,6 +69,8 @@ VU_Thread::~VU_Thread() throw()
void VU_Thread::Reset() void VU_Thread::Reset()
{ {
ScopedLock lock(mtxBusy);
read_pos = 0; read_pos = 0;
write_pos = 0; write_pos = 0;
write_offset = 0; write_offset = 0;

View File

@ -18,6 +18,7 @@
#include "IopCommon.h" #include "IopCommon.h"
#include "VUmicro.h" #include "VUmicro.h"
#include "newVif.h" #include "newVif.h"
#include "MTVU.h"
#include "SamplProf.h" #include "SamplProf.h"
@ -418,6 +419,12 @@ void SysMainMemory::DecommitAll()
Console.WriteLn( Color_Blue, "Decommitting host memory for virtual systems..." ); Console.WriteLn( Color_Blue, "Decommitting host memory for virtual systems..." );
ConsoleIndentScope indent(1); ConsoleIndentScope indent(1);
// On linux, the MTVU isn't empty and the thread still uses the m_ee/m_vu memory
vu1Thread.WaitVU();
// The EE thread must be stopped here command mustn't be send
// to the ring. Let's call it an extra safety valve :)
vu1Thread.Reset();
m_ee.Decommit(); m_ee.Decommit();
m_iop.Decommit(); m_iop.Decommit();
m_vu.Decommit(); m_vu.Decommit();