mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2026-03-21 17:49:58 -05:00
AMMediaboard: Add NetworkCMDBufferCheck calls for reading of timeout in Select commands.
This commit is contained in:
parent
95442a2b6a
commit
a5eca09967
|
|
@ -996,7 +996,7 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
fd_set* exceptfds = nullptr;
|
||||
|
||||
timeval timeout = {};
|
||||
u8* timeout_src = nullptr;
|
||||
std::optional<u32> timeout_offset;
|
||||
|
||||
fd_set fds;
|
||||
FD_ZERO(&fds);
|
||||
|
|
@ -1018,24 +1018,27 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
if (s_media_buffer_32[3] != 0)
|
||||
{
|
||||
readfds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[3] - NetworkCommandAddress2;
|
||||
timeout_offset = s_media_buffer_32[3] - NetworkCommandAddress2;
|
||||
}
|
||||
else if (s_media_buffer_32[4] != 0)
|
||||
{
|
||||
writefds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[4] - NetworkCommandAddress2;
|
||||
timeout_offset = s_media_buffer_32[4] - NetworkCommandAddress2;
|
||||
}
|
||||
else if (s_media_buffer_32[5] != 0)
|
||||
{
|
||||
exceptfds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[5] - NetworkCommandAddress2;
|
||||
timeout_offset = s_media_buffer_32[5] - NetworkCommandAddress2;
|
||||
}
|
||||
}
|
||||
|
||||
// Copy timeout if set
|
||||
if (timeout_src != nullptr)
|
||||
if (timeout_offset.has_value())
|
||||
{
|
||||
std::memcpy(&timeout, timeout_src, sizeof(timeval));
|
||||
if (!NetworkCMDBufferCheck(*timeout_offset, sizeof(timeval)))
|
||||
break;
|
||||
|
||||
std::memcpy(&timeout, s_network_command_buffer + *timeout_offset, sizeof(timeval));
|
||||
}
|
||||
|
||||
// BUG: The game sets timeout to two seconds
|
||||
|
|
@ -1237,6 +1240,7 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
if ((offset >= 0x00400000) && (offset <= 0x600000))
|
||||
{
|
||||
const u32 fw_offset = offset - 0x00400000;
|
||||
// TODO: Bounds checking for s_firmware
|
||||
memory.CopyFromEmu(s_firmware + fw_offset, address, length);
|
||||
return 0;
|
||||
}
|
||||
|
|
@ -1578,7 +1582,7 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
fd_set* exceptfds = nullptr;
|
||||
|
||||
timeval timeout = {};
|
||||
u8* timeout_src = nullptr;
|
||||
std::optional<u32> timeout_offset;
|
||||
|
||||
fd_set fds;
|
||||
FD_ZERO(&fds);
|
||||
|
|
@ -1600,24 +1604,27 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
if (s_media_buffer_32[11] != 0)
|
||||
{
|
||||
readfds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[11] - NetworkCommandAddress1;
|
||||
timeout_offset = s_media_buffer_32[11] - NetworkCommandAddress1;
|
||||
}
|
||||
else if (s_media_buffer_32[12] != 0)
|
||||
{
|
||||
writefds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[12] - NetworkCommandAddress1;
|
||||
timeout_offset = s_media_buffer_32[12] - NetworkCommandAddress1;
|
||||
}
|
||||
else if (s_media_buffer_32[13] != 0)
|
||||
{
|
||||
exceptfds = &fds;
|
||||
timeout_src = s_network_command_buffer + s_media_buffer_32[13] - NetworkCommandAddress1;
|
||||
timeout_offset = s_media_buffer_32[13] - NetworkCommandAddress1;
|
||||
}
|
||||
}
|
||||
|
||||
// Copy timeout if set
|
||||
if (timeout_src != nullptr)
|
||||
if (timeout_offset.has_value())
|
||||
{
|
||||
std::memcpy(&timeout, timeout_src, sizeof(timeval));
|
||||
if (!NetworkCMDBufferCheck(*timeout_offset, sizeof(timeval)))
|
||||
break;
|
||||
|
||||
std::memcpy(&timeout, s_network_command_buffer + *timeout_offset, sizeof(timeval));
|
||||
}
|
||||
|
||||
// BUG?: F-Zero AX Monster calls select with a two second timeout
|
||||
|
|
@ -1629,7 +1636,7 @@ u32 ExecuteCommand(std::array<u32, 3>& dicmd_buf, u32* diimm_buf, u32 address, u
|
|||
}
|
||||
|
||||
const int ret =
|
||||
select(fd + 1, readfds, writefds, exceptfds, timeout_src ? &timeout : nullptr);
|
||||
select(fd + 1, readfds, writefds, exceptfds, timeout_offset ? &timeout : nullptr);
|
||||
const int err = WSAGetLastError();
|
||||
|
||||
NOTICE_LOG_FMT(AMMEDIABOARD_NET,
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user