From 024e983c3a92a07a7101845b1413c1c7290ef148 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Dec 2020 12:18:42 -0500 Subject: [PATCH 1/3] DSP: Make Mailbox enum strongly typed Avoids implicit conversions and also prevents dumping identifiers into the current namespace. --- Source/Core/Core/DSP/DSPCore.h | 9 ++++-- Source/Core/Core/DSP/DSPHWInterface.cpp | 42 ++++++++++++------------- Source/Core/Core/HW/DSPLLE/DSPLLE.cpp | 10 +++--- 3 files changed, 32 insertions(+), 29 deletions(-) diff --git a/Source/Core/Core/DSP/DSPCore.h b/Source/Core/Core/DSP/DSPCore.h index fb8af13e38..bbb4c0041c 100644 --- a/Source/Core/Core/DSP/DSPCore.h +++ b/Source/Core/Core/DSP/DSPCore.h @@ -228,10 +228,10 @@ enum class ExceptionType ExternalInterrupt = 7 // 0x000e external int (message from CPU) }; -enum Mailbox : int +enum class Mailbox { - MAILBOX_CPU, - MAILBOX_DSP + CPU, + DSP }; struct DSP_Regs @@ -445,6 +445,9 @@ struct SDSP u16* coef = nullptr; private: + auto& GetMailbox(Mailbox mailbox) { return mbox[static_cast(mailbox)]; } + const auto& GetMailbox(Mailbox mailbox) const { return mbox[static_cast(mailbox)]; } + void FreeMemoryPages(); void DoDMA(); diff --git a/Source/Core/Core/DSP/DSPHWInterface.cpp b/Source/Core/Core/DSP/DSPHWInterface.cpp index 0733cc4e22..1b9cb2fe99 100644 --- a/Source/Core/Core/DSP/DSPHWInterface.cpp +++ b/Source/Core/Core/DSP/DSPHWInterface.cpp @@ -25,21 +25,21 @@ void SDSP::InitializeIFX() { ifx_regs.fill(0); - mbox[MAILBOX_CPU].store(0); - mbox[MAILBOX_DSP].store(0); + GetMailbox(Mailbox::CPU).store(0); + GetMailbox(Mailbox::DSP).store(0); } u32 SDSP::PeekMailbox(Mailbox mailbox) const { - return mbox[mailbox].load(); + return GetMailbox(mailbox).load(); } u16 SDSP::ReadMailboxLow(Mailbox mailbox) { - const u32 value = mbox[mailbox].load(std::memory_order_acquire); - mbox[mailbox].store(value & ~0x80000000, std::memory_order_release); + const u32 value = GetMailbox(mailbox).load(std::memory_order_acquire); + GetMailbox(mailbox).store(value & ~0x80000000, std::memory_order_release); - if (m_dsp_core.GetInitHax() && mailbox == MAILBOX_DSP) + if (m_dsp_core.GetInitHax() && mailbox == Mailbox::DSP) { m_dsp_core.SetInitHax(false); m_dsp_core.Reset(); @@ -47,7 +47,7 @@ u16 SDSP::ReadMailboxLow(Mailbox mailbox) } #if defined(_DEBUG) || defined(DEBUGFAST) - const char* const type = mailbox == MAILBOX_DSP ? "DSP" : "CPU"; + const char* const type = mailbox == Mailbox::DSP ? "DSP" : "CPU"; DEBUG_LOG_FMT(DSP_MAIL, "{}(RM) B:{} M:0x{:#010x} (pc={:#06x})", type, mailbox, PeekMailbox(mailbox), pc); #endif @@ -57,7 +57,7 @@ u16 SDSP::ReadMailboxLow(Mailbox mailbox) u16 SDSP::ReadMailboxHigh(Mailbox mailbox) { - if (m_dsp_core.GetInitHax() && mailbox == MAILBOX_DSP) + if (m_dsp_core.GetInitHax() && mailbox == Mailbox::DSP) { return 0x8054; } @@ -68,13 +68,13 @@ u16 SDSP::ReadMailboxHigh(Mailbox mailbox) void SDSP::WriteMailboxLow(Mailbox mailbox, u16 value) { - const u32 old_value = mbox[mailbox].load(std::memory_order_acquire); + const u32 old_value = GetMailbox(mailbox).load(std::memory_order_acquire); const u32 new_value = (old_value & ~0xffff) | value; - mbox[mailbox].store(new_value | 0x80000000, std::memory_order_release); + GetMailbox(mailbox).store(new_value | 0x80000000, std::memory_order_release); #if defined(_DEBUG) || defined(DEBUGFAST) - const char* const type = mailbox == MAILBOX_DSP ? "DSP" : "CPU"; + const char* const type = mailbox == Mailbox::DSP ? "DSP" : "CPU"; DEBUG_LOG_FMT(DSP_MAIL, "{}(WM) B:{} M:{:#010x} (pc={:#06x})", type, mailbox, PeekMailbox(mailbox), pc); #endif @@ -82,10 +82,10 @@ void SDSP::WriteMailboxLow(Mailbox mailbox, u16 value) void SDSP::WriteMailboxHigh(Mailbox mailbox, u16 value) { - const u32 old_value = mbox[mailbox].load(std::memory_order_acquire); + const u32 old_value = GetMailbox(mailbox).load(std::memory_order_acquire); const u32 new_value = (old_value & 0xffff) | (value << 16); - mbox[mailbox].store(new_value & ~0x80000000, std::memory_order_release); + GetMailbox(mailbox).store(new_value & ~0x80000000, std::memory_order_release); } void SDSP::WriteIFX(u32 address, u16 value) @@ -102,19 +102,19 @@ void SDSP::WriteIFX(u32 address, u16 value) break; case DSP_DMBH: - WriteMailboxHigh(MAILBOX_DSP, value); + WriteMailboxHigh(Mailbox::DSP, value); break; case DSP_DMBL: - WriteMailboxLow(MAILBOX_DSP, value); + WriteMailboxLow(Mailbox::DSP, value); break; case DSP_CMBH: - WriteMailboxHigh(MAILBOX_CPU, value); + WriteMailboxHigh(Mailbox::CPU, value); break; case DSP_CMBL: - WriteMailboxLow(MAILBOX_CPU, value); + WriteMailboxLow(Mailbox::CPU, value); break; case DSP_DSBL: @@ -207,16 +207,16 @@ u16 SDSP::ReadIFXImpl(u16 address) switch (address & 0xff) { case DSP_DMBH: - return ReadMailboxHigh(MAILBOX_DSP); + return ReadMailboxHigh(Mailbox::DSP); case DSP_DMBL: - return ReadMailboxLow(MAILBOX_DSP); + return ReadMailboxLow(Mailbox::DSP); case DSP_CMBH: - return ReadMailboxHigh(MAILBOX_CPU); + return ReadMailboxHigh(Mailbox::CPU); case DSP_CMBL: - return ReadMailboxLow(MAILBOX_CPU); + return ReadMailboxLow(Mailbox::CPU); case DSP_DSCR: return ifx_regs[address & 0xFF]; diff --git a/Source/Core/Core/HW/DSPLLE/DSPLLE.cpp b/Source/Core/Core/HW/DSPLLE/DSPLLE.cpp index 03a9cefc43..2dc420864d 100644 --- a/Source/Core/Core/HW/DSPLLE/DSPLLE.cpp +++ b/Source/Core/Core/HW/DSPLLE/DSPLLE.cpp @@ -213,25 +213,25 @@ u16 DSPLLE::DSP_ReadControlRegister() u16 DSPLLE::DSP_ReadMailBoxHigh(bool cpu_mailbox) { - return m_dsp_core.ReadMailboxHigh(cpu_mailbox ? MAILBOX_CPU : MAILBOX_DSP); + return m_dsp_core.ReadMailboxHigh(cpu_mailbox ? Mailbox::CPU : Mailbox::DSP); } u16 DSPLLE::DSP_ReadMailBoxLow(bool cpu_mailbox) { - return m_dsp_core.ReadMailboxLow(cpu_mailbox ? MAILBOX_CPU : MAILBOX_DSP); + return m_dsp_core.ReadMailboxLow(cpu_mailbox ? Mailbox::CPU : Mailbox::DSP); } void DSPLLE::DSP_WriteMailBoxHigh(bool cpu_mailbox, u16 value) { if (cpu_mailbox) { - if ((m_dsp_core.PeekMailbox(MAILBOX_CPU) & 0x80000000) != 0) + if ((m_dsp_core.PeekMailbox(Mailbox::CPU) & 0x80000000) != 0) { // the DSP didn't read the previous value WARN_LOG_FMT(DSPLLE, "Mailbox isn't empty ... strange"); } - m_dsp_core.WriteMailboxHigh(MAILBOX_CPU, value); + m_dsp_core.WriteMailboxHigh(Mailbox::CPU, value); } else { @@ -243,7 +243,7 @@ void DSPLLE::DSP_WriteMailBoxLow(bool cpu_mailbox, u16 value) { if (cpu_mailbox) { - m_dsp_core.WriteMailboxLow(MAILBOX_CPU, value); + m_dsp_core.WriteMailboxLow(Mailbox::CPU, value); } else { From f9d8d06037d172b7d42aed68aedcfc18ce51d2b4 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Dec 2020 12:25:15 -0500 Subject: [PATCH 2/3] DSP: Make mailboxes private These aren't used externally anywhere and can be made private. --- Source/Core/Core/DSP/DSPCore.cpp | 4 ++-- Source/Core/Core/DSP/DSPCore.h | 8 +++----- 2 files changed, 5 insertions(+), 7 deletions(-) diff --git a/Source/Core/Core/DSP/DSPCore.cpp b/Source/Core/Core/DSP/DSPCore.cpp index d06c324118..45e7cdfe8a 100644 --- a/Source/Core/Core/DSP/DSPCore.cpp +++ b/Source/Core/Core/DSP/DSPCore.cpp @@ -387,8 +387,8 @@ void SDSP::DoState(PointerWrap& p) p.Do(step_counter); p.DoArray(ifx_regs); accelerator->DoState(p); - p.Do(mbox[0]); - p.Do(mbox[1]); + p.Do(m_mailbox[0]); + p.Do(m_mailbox[1]); Common::UnWriteProtectMemory(iram, DSP_IRAM_BYTE_SIZE, false); p.DoArray(iram, DSP_IRAM_SIZE); Common::WriteProtectMemory(iram, DSP_IRAM_BYTE_SIZE, false); diff --git a/Source/Core/Core/DSP/DSPCore.h b/Source/Core/Core/DSP/DSPCore.h index bbb4c0041c..c57a35f4c1 100644 --- a/Source/Core/Core/DSP/DSPCore.h +++ b/Source/Core/Core/DSP/DSPCore.h @@ -429,9 +429,6 @@ struct SDSP u32 iram_crc = 0; u64 step_counter = 0; - // Mailbox. - std::atomic mbox[2]; - // Accelerator / DMA / other hardware registers. Not GPRs. std::array ifx_regs{}; @@ -445,8 +442,8 @@ struct SDSP u16* coef = nullptr; private: - auto& GetMailbox(Mailbox mailbox) { return mbox[static_cast(mailbox)]; } - const auto& GetMailbox(Mailbox mailbox) const { return mbox[static_cast(mailbox)]; } + auto& GetMailbox(Mailbox mailbox) { return m_mailbox[static_cast(mailbox)]; } + const auto& GetMailbox(Mailbox mailbox) const { return m_mailbox[static_cast(mailbox)]; } void FreeMemoryPages(); @@ -458,6 +455,7 @@ private: u16 ReadIFXImpl(u16 address); + std::atomic m_mailbox[2]; DSPCore& m_dsp_core; Analyzer m_analyzer; }; From e1f41bab1cbd5358836ec69020bd488ce5999b9d Mon Sep 17 00:00:00 2001 From: Lioncash Date: Tue, 29 Dec 2020 12:27:54 -0500 Subject: [PATCH 3/3] DSP: Make mailboxes use std::array Makes the array strongly typed and prevents pointer decay. This also allows for tuning bounds checks with various implementations. --- Source/Core/Core/DSP/DSPCore.h | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Source/Core/Core/DSP/DSPCore.h b/Source/Core/Core/DSP/DSPCore.h index c57a35f4c1..60b317eecf 100644 --- a/Source/Core/Core/DSP/DSPCore.h +++ b/Source/Core/Core/DSP/DSPCore.h @@ -455,7 +455,7 @@ private: u16 ReadIFXImpl(u16 address); - std::atomic m_mailbox[2]; + std::array, 2> m_mailbox; DSPCore& m_dsp_core; Analyzer m_analyzer; };