From fac7c7b1fc33a35924312e38908b725d99bc7372 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Wed, 4 Sep 2019 01:41:41 -0400 Subject: [PATCH 1/2] gbalink: Amend code to compile with jbus changes --- gbalink/main.cpp | 43 +++++++++++++++++++++++++++---------------- 1 file changed, 27 insertions(+), 16 deletions(-) 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; From 5aafd3935be4d52c21f0fa308ba923e6efe9bc4b Mon Sep 17 00:00:00 2001 From: Lioncash Date: Wed, 4 Sep 2019 01:51:00 -0400 Subject: [PATCH 2/2] CGBASupport: Amend code to compile with jbus changes --- Runtime/MP1/CGBASupport.cpp | 40 +++++++++++++++++++++++++------------ 1 file changed, 27 insertions(+), 13 deletions(-) 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)