diff --git a/Runtime/MP1/CGBASupport.cpp b/Runtime/MP1/CGBASupport.cpp index 781a82ab6..113241436 100644 --- a/Runtime/MP1/CGBASupport.cpp +++ b/Runtime/MP1/CGBASupport.cpp @@ -1,8 +1,12 @@ #include "CGBASupport.hpp" -#include "CDvdRequest.hpp" + +#include + #include "CBasics.hpp" -#include "jbus/Listener.hpp" -#include "jbus/Endpoint.hpp" +#include "CDvdRequest.hpp" + +#include +#include namespace urde::MP1 { @@ -65,19 +69,27 @@ bool CGBASupport::PollResponse() { if (status != (jbus::GBA_JSTAT_PSF1 | jbus::GBA_JSTAT_SEND)) return false; - u8 bytes[4]; - if (g_JbusEndpoint->GBARead(bytes, &status) == jbus::GBA_NOT_READY) - return false; - if (reinterpret_cast(bytes) != SBIG('AMTE')) + jbus::ReadWriteBuffer bytes; + if (g_JbusEndpoint->GBARead(bytes, &status) == jbus::GBA_NOT_READY) { return false; + } - if (g_JbusEndpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) - return false; - if (status != jbus::GBA_JSTAT_PSF1) + u32 bytesU32; + std::memcpy(&bytesU32, bytes.data(), sizeof(bytes)); + if (bytesU32 != SBIG('AMTE')) { return false; + } - if (g_JbusEndpoint->GBAWrite((unsigned char*)"AMTE", &status) == jbus::GBA_NOT_READY) + if (g_JbusEndpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) { return false; + } + if (status != jbus::GBA_JSTAT_PSF1) { + return false; + } + + if (g_JbusEndpoint->GBAWrite({'A', 'M', 'T', 'E'}, &status) == jbus::GBA_NOT_READY) { + return false; + } if (g_JbusEndpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) return false; @@ -103,11 +115,13 @@ bool CGBASupport::PollResponse() { break; } - if (g_JbusEndpoint->GBARead(bytes, &status) != jbus::GBA_READY) + if (g_JbusEndpoint->GBARead(bytes, &status) != jbus::GBA_READY) { return false; + } - if (bytes[3] != CalculateFusionJBusChecksum(bytes, 3)) + if (bytes[3] != CalculateFusionJBusChecksum(bytes.data(), 3)) { return false; + } x44_fusionLinked = (bytes[2] & 0x2) == 0; if (x44_fusionLinked && (bytes[2] & 0x1) != 0) diff --git a/gbalink/main.cpp b/gbalink/main.cpp index 08ab14c9b..3b33f804b 100644 --- a/gbalink/main.cpp +++ b/gbalink/main.cpp @@ -1,11 +1,12 @@ #include -#include "GCNTypes.hpp" +#include #include -#include -#include #include -#include "jbus/Endpoint.hpp" -#include "jbus/Listener.hpp" + +#include "GCNTypes.hpp" + +#include +#include #undef min #undef max @@ -97,24 +98,34 @@ bool CGBASupport::PollResponse() { if (status != (jbus::GBA_JSTAT_PSF1 | jbus::GBA_JSTAT_SEND)) return false; - u8 bytes[4]; - if (m_endpoint->GBARead(bytes, &status) == jbus::GBA_NOT_READY) - return false; - if (reinterpret_cast(bytes) != SBIG('AMTE')) + jbus::ReadWriteBuffer bytes; + if (m_endpoint->GBARead(bytes, &status) == jbus::GBA_NOT_READY) { return false; + } - if (m_endpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) - return false; - if (status != jbus::GBA_JSTAT_PSF1) + u32 bytesU32; + std::memcpy(&bytesU32, bytes.data(), sizeof(bytes)); + if (bytesU32 != SBIG('AMTE')) { return false; + } - if (m_endpoint->GBAWrite((unsigned char*)"AMTE", &status) == jbus::GBA_NOT_READY) + if (m_endpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) { return false; + } + if (status != jbus::GBA_JSTAT_PSF1) { + return false; + } - if (m_endpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) + if (m_endpoint->GBAWrite({'A', 'M', 'T', 'E'}, &status) == jbus::GBA_NOT_READY) { return false; - if ((status & jbus::GBA_JSTAT_FLAGS_MASK) != jbus::GBA_JSTAT_FLAGS_MASK) + } + + if (m_endpoint->GBAGetStatus(&status) == jbus::GBA_NOT_READY) { return false; + } + if ((status & jbus::GBA_JSTAT_FLAGS_MASK) != jbus::GBA_JSTAT_FLAGS_MASK) { + return false; + } u64 profStart = jbus::GetGCTicks(); const u64 timeToSpin = jbus::GetGCTicksPerSec() / 8000; @@ -138,7 +149,7 @@ bool CGBASupport::PollResponse() { if (m_endpoint->GBARead(bytes, &status) != jbus::GBA_READY) return false; - if (bytes[3] != CalculateFusionJBusChecksum(bytes, 3)) + if (bytes[3] != CalculateFusionJBusChecksum(bytes.data(), 3)) return false; x44_fusionLinked = (bytes[2] & 0x2) == 0;