Disable part of the adapter features for netplay
In order to avoid desyncs
This commit is contained in:
parent
8d23ebaa6b
commit
8f0cbefbe5
|
@ -8,6 +8,7 @@
|
||||||
#include "Common/MsgHandler.h"
|
#include "Common/MsgHandler.h"
|
||||||
#include "Common/Logging/Log.h"
|
#include "Common/Logging/Log.h"
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
|
#include "Core/NetPlayProto.h"
|
||||||
#include "Core/HW/GCPad.h"
|
#include "Core/HW/GCPad.h"
|
||||||
#include "Core/HW/SI_DeviceGCAdapter.h"
|
#include "Core/HW/SI_DeviceGCAdapter.h"
|
||||||
#include "InputCommon/GCAdapter.h"
|
#include "InputCommon/GCAdapter.h"
|
||||||
|
@ -33,84 +34,25 @@ GCPadStatus CSIDevice_GCAdapter::GetPadStatus()
|
||||||
return PadStatus;
|
return PadStatus;
|
||||||
}
|
}
|
||||||
|
|
||||||
int CSIDevice_GCAdapter::RunBuffer(u8* _pBuffer, int _iLength)
|
int CSIDevice_GCAdapter::RunBuffer(u8* buffer, int length)
|
||||||
{
|
{
|
||||||
// For debug logging only
|
if (!NetPlay::IsNetPlayRunning())
|
||||||
ISIDevice::RunBuffer(_pBuffer, _iLength);
|
{
|
||||||
|
// The previous check is a hack to prevent a netplay desync due to
|
||||||
|
// SI devices being different and returning different values on
|
||||||
|
// RunBuffer(); the corresponding code in GCAdapter.cpp has the same
|
||||||
|
// check.
|
||||||
|
|
||||||
// Read the command
|
// This returns an error value if there is no controller plugged
|
||||||
EBufferCommands command = static_cast<EBufferCommands>(_pBuffer[3]);
|
// into this port on the hardware gc adapter, exposing it to the game.
|
||||||
|
if (!GCAdapter::DeviceConnected(ISIDevice::m_iDeviceNumber))
|
||||||
const u8 numPAD = NetPlay_InGamePadToLocalPad(ISIDevice::m_iDeviceNumber);
|
|
||||||
if (numPAD < 4)
|
|
||||||
{
|
{
|
||||||
if (!GCAdapter::DeviceConnected(numPAD))
|
TSIDevices device = SI_NONE;
|
||||||
{
|
memcpy(buffer, &device, sizeof(device));
|
||||||
reinterpret_cast<u32*>(_pBuffer)[0] = SI_NONE;
|
|
||||||
return 4;
|
return 4;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return CSIDevice_GCController::RunBuffer(buffer, length);
|
||||||
// Handle it
|
|
||||||
switch (command)
|
|
||||||
{
|
|
||||||
case CMD_RESET:
|
|
||||||
case CMD_ID:
|
|
||||||
*(u32*)&_pBuffer[0] = SI_GC_CONTROLLER;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CMD_DIRECT:
|
|
||||||
{
|
|
||||||
INFO_LOG(SERIALINTERFACE, "PAD - Direct (Length: %d)", _iLength);
|
|
||||||
u32 high, low;
|
|
||||||
GetData(high, low);
|
|
||||||
for (int i = 0; i < (_iLength - 1) / 2; i++)
|
|
||||||
{
|
|
||||||
_pBuffer[i + 0] = (high >> (i * 8)) & 0xff;
|
|
||||||
_pBuffer[i + 4] = (low >> (i * 8)) & 0xff;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CMD_ORIGIN:
|
|
||||||
{
|
|
||||||
INFO_LOG(SERIALINTERFACE, "PAD - Get Origin");
|
|
||||||
|
|
||||||
Calibrate();
|
|
||||||
|
|
||||||
u8* pCalibration = reinterpret_cast<u8*>(&m_Origin);
|
|
||||||
for (int i = 0; i < (int)sizeof(SOrigin); i++)
|
|
||||||
{
|
|
||||||
_pBuffer[i ^ 3] = *pCalibration++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// Recalibrate (FiRES: i am not 100 percent sure about this)
|
|
||||||
case CMD_RECALIBRATE:
|
|
||||||
{
|
|
||||||
INFO_LOG(SERIALINTERFACE, "PAD - Recalibrate");
|
|
||||||
|
|
||||||
Calibrate();
|
|
||||||
|
|
||||||
u8* pCalibration = reinterpret_cast<u8*>(&m_Origin);
|
|
||||||
for (int i = 0; i < (int)sizeof(SOrigin); i++)
|
|
||||||
{
|
|
||||||
_pBuffer[i ^ 3] = *pCalibration++;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
// DEFAULT
|
|
||||||
default:
|
|
||||||
{
|
|
||||||
ERROR_LOG(SERIALINTERFACE, "Unknown SI command (0x%x)", command);
|
|
||||||
PanicAlert("SI: Unknown command (0x%x)", command);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
return _iLength;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void CSIDevice_GCController::Rumble(u8 numPad, ControlState strength)
|
void CSIDevice_GCController::Rumble(u8 numPad, ControlState strength)
|
||||||
|
|
|
@ -14,5 +14,5 @@ public:
|
||||||
CSIDevice_GCAdapter(SIDevices device, int _iDeviceNumber);
|
CSIDevice_GCAdapter(SIDevices device, int _iDeviceNumber);
|
||||||
|
|
||||||
GCPadStatus GetPadStatus() override;
|
GCPadStatus GetPadStatus() override;
|
||||||
int RunBuffer(u8* _pBuffer, int _iLength) override;
|
int RunBuffer(u8* buffer, int length) override;
|
||||||
};
|
};
|
||||||
|
|
|
@ -12,6 +12,7 @@
|
||||||
#include "Core/ConfigManager.h"
|
#include "Core/ConfigManager.h"
|
||||||
#include "Core/Core.h"
|
#include "Core/Core.h"
|
||||||
#include "Core/CoreTiming.h"
|
#include "Core/CoreTiming.h"
|
||||||
|
#include "Core/NetPlayProto.h"
|
||||||
#include "Core/HW/SI.h"
|
#include "Core/HW/SI.h"
|
||||||
#include "Core/HW/SystemTimers.h"
|
#include "Core/HW/SystemTimers.h"
|
||||||
|
|
||||||
|
@ -417,8 +418,11 @@ void Input(int chan, GCPadStatus* pad)
|
||||||
pad->triggerLeft = controller_payload_copy[1 + (9 * chan) + 7];
|
pad->triggerLeft = controller_payload_copy[1 + (9 * chan) + 7];
|
||||||
pad->triggerRight = controller_payload_copy[1 + (9 * chan) + 8];
|
pad->triggerRight = controller_payload_copy[1 + (9 * chan) + 8];
|
||||||
}
|
}
|
||||||
else
|
else if (!NetPlay::IsNetPlayRunning())
|
||||||
{
|
{
|
||||||
|
// This is a hack to prevent a netplay desync due to SI devices
|
||||||
|
// being different and returning different values.
|
||||||
|
// The corresponding code in DeviceGCAdapter has the same check
|
||||||
pad->button = PAD_ERR_STATUS;
|
pad->button = PAD_ERR_STATUS;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue