Fixes issue 5330.
This commit is contained in:
parent
995a84e06a
commit
404a6b9ba8
|
@ -58,12 +58,14 @@
|
||||||
#include "CommonPaths.h"
|
#include "CommonPaths.h"
|
||||||
#include "IPC_HLE/WII_IPC_HLE_Device_usb.h"
|
#include "IPC_HLE/WII_IPC_HLE_Device_usb.h"
|
||||||
|
|
||||||
|
|
||||||
|
std::string CWII_IPC_HLE_Device_es::m_ContentFile;
|
||||||
|
|
||||||
CWII_IPC_HLE_Device_es::CWII_IPC_HLE_Device_es(u32 _DeviceID, const std::string& _rDeviceName)
|
CWII_IPC_HLE_Device_es::CWII_IPC_HLE_Device_es(u32 _DeviceID, const std::string& _rDeviceName)
|
||||||
: IWII_IPC_HLE_Device(_DeviceID, _rDeviceName)
|
: IWII_IPC_HLE_Device(_DeviceID, _rDeviceName)
|
||||||
, m_pContentLoader(NULL)
|
, m_pContentLoader(NULL)
|
||||||
, m_TitleID(-1)
|
, m_TitleID(-1)
|
||||||
, AccessIdentID(0x6000000)
|
, AccessIdentID(0x6000000)
|
||||||
, m_ContentFile()
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
CWII_IPC_HLE_Device_es::~CWII_IPC_HLE_Device_es()
|
CWII_IPC_HLE_Device_es::~CWII_IPC_HLE_Device_es()
|
||||||
|
@ -763,21 +765,7 @@ bool CWII_IPC_HLE_Device_es::IOCtlV(u32 _CommandAddress)
|
||||||
PC = DolLoader.GetEntryPoint() | 0x80000000;
|
PC = DolLoader.GetEntryPoint() | 0x80000000;
|
||||||
IOSv = ContentLoader.GetIosVersion();
|
IOSv = ContentLoader.GetIosVersion();
|
||||||
bSuccess = true;
|
bSuccess = true;
|
||||||
// Reset the connection of all connected wiimotes
|
|
||||||
// ugly haxx
|
|
||||||
static CWII_IPC_HLE_Device_usb_oh1_57e_305* s_Usb = GetUsbPointer();
|
|
||||||
for (unsigned int i = 0; i < 4; i++)
|
|
||||||
{
|
|
||||||
if (s_Usb->m_WiiMotes[i].IsConnected())
|
|
||||||
{
|
|
||||||
s_Usb->m_WiiMotes[i].Activate(false);
|
|
||||||
s_Usb->m_WiiMotes[i].Activate(true);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
s_Usb->m_WiiMotes[i].Activate(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -790,8 +778,30 @@ bool CWII_IPC_HLE_Device_es::IOCtlV(u32 _CommandAddress)
|
||||||
IOSv = TitleID & 0xffff;
|
IOSv = TitleID & 0xffff;
|
||||||
}
|
}
|
||||||
if (!bSuccess)
|
if (!bSuccess)
|
||||||
|
{
|
||||||
PanicAlertT("IOCTL_ES_LAUNCH: Game tried to reload ios or a title that is not available in your nand dump\n"
|
PanicAlertT("IOCTL_ES_LAUNCH: Game tried to reload ios or a title that is not available in your nand dump\n"
|
||||||
"TitleID %016llx.\n Dolphin will likely hang now", TitleID);
|
"TitleID %016llx.\n Dolphin will likely hang now", TitleID);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
WII_IPC_HLE_Interface::Reset(true);
|
||||||
|
WII_IPC_HLE_Interface::Init();
|
||||||
|
|
||||||
|
static CWII_IPC_HLE_Device_usb_oh1_57e_305* s_Usb = GetUsbPointer();
|
||||||
|
for (unsigned int i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
if (s_Usb->m_WiiMotes[i] && s_Usb->m_WiiMotes[i].IsConnected())
|
||||||
|
{
|
||||||
|
s_Usb->m_WiiMotes[i].Activate(false);
|
||||||
|
s_Usb->m_WiiMotes[i].Activate(true);
|
||||||
|
}
|
||||||
|
else if (s_Usb->m_WiiMotes[i])
|
||||||
|
{
|
||||||
|
s_Usb->m_WiiMotes[i].Activate(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
// Pass the "#002 check"
|
// Pass the "#002 check"
|
||||||
// Apploader should write the IOS version and revision to 0x3140, and compare it
|
// Apploader should write the IOS version and revision to 0x3140, and compare it
|
||||||
// to 0x3188 to pass the check, but we don't do it, and i don't know where to read the IOS rev...
|
// to 0x3188 to pass the check, but we don't do it, and i don't know where to read the IOS rev...
|
||||||
|
|
|
@ -135,7 +135,7 @@ private:
|
||||||
u64 m_TitleID;
|
u64 m_TitleID;
|
||||||
u32 AccessIdentID;
|
u32 AccessIdentID;
|
||||||
// This should only be cleared on power reset
|
// This should only be cleared on power reset
|
||||||
std::string m_ContentFile;
|
static std::string m_ContentFile;
|
||||||
|
|
||||||
u64 GetCurrentTitleID() const;
|
u64 GetCurrentTitleID() const;
|
||||||
|
|
||||||
|
|
|
@ -462,7 +462,7 @@ void cUIDsys::AddTitle(u64 _TitleID)
|
||||||
File::CreateFullPath(uidSys);
|
File::CreateFullPath(uidSys);
|
||||||
File::IOFile pFile(uidSys, "ab");
|
File::IOFile pFile(uidSys, "ab");
|
||||||
|
|
||||||
if (pFile.WriteArray(&Element, 1))
|
if (!pFile.WriteArray(&Element, 1))
|
||||||
ERROR_LOG(DISCIO, "fwrite failed");
|
ERROR_LOG(DISCIO, "fwrite failed");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue