From 556d18f865a387ff11a3f052d9afc804d20cdf3e Mon Sep 17 00:00:00 2001 From: Vincent Pelletier Date: Mon, 26 Sep 2022 13:43:08 +0000 Subject: [PATCH 1/3] DSPSpy: Unhide stack registers The screen real-estate is already reserved, the values are dumped and restored by the on-DSP code, why not make something out of these values ? Allows following: - where exactly send_back was called from ($st1) - the boundaries and progress of the innermost BLOOP{,I} ($st0, 2 and 3) up to send_back's call --- Source/DSPSpy/main_spy.cpp | 18 +++++++----------- 1 file changed, 7 insertions(+), 11 deletions(-) diff --git a/Source/DSPSpy/main_spy.cpp b/Source/DSPSpy/main_spy.cpp index 89cf2d3ed795..bfff921e1024 100644 --- a/Source/DSPSpy/main_spy.cpp +++ b/Source/DSPSpy/main_spy.cpp @@ -149,21 +149,17 @@ void print_reg_block(int x, int y, int sel, const u16* regs, const u16* compare_ { for (int i = 0; i < 8; i++) { - // Do not even display the loop stack registers. const int reg = j * 8 + i; + u8 color1 = regs[reg] == compare_regs[reg] ? CON_BRIGHT_WHITE : CON_BRIGHT_RED; CON_SetColor(sel == reg ? CON_BRIGHT_YELLOW : CON_GREEN); CON_Printf(x + j * 9, i + y, "%s ", reg_names[reg]); - if (j != 1 || i < 4) + for (int k = 0; k < 4; k++) { - u8 color1 = regs[reg] == compare_regs[reg] ? CON_BRIGHT_WHITE : CON_BRIGHT_RED; - for (int k = 0; k < 4; k++) - { - if (sel == reg && k == small_cursor_x && ui_mode == UIM_EDIT_REG) - CON_SetColor(CON_BRIGHT_CYAN); - else - CON_SetColor(color1); - CON_Printf(x + 4 + j * 9 + k, i + y, "%01x", (regs[reg] >> ((3 - k) * 4)) & 0xf); - } + if (sel == reg && k == small_cursor_x && ui_mode == UIM_EDIT_REG) + CON_SetColor(CON_BRIGHT_CYAN); + else + CON_SetColor(color1); + CON_Printf(x + 4 + j * 9 + k, i + y, "%01x", (regs[reg] >> ((3 - k) * 4)) & 0xf); } } } From 12142c4fa865561c8288c0b163b8852a061b7994 Mon Sep 17 00:00:00 2001 From: Vincent Pelletier Date: Fri, 30 Sep 2022 11:06:38 +0000 Subject: [PATCH 2/3] DSPSpy: Add st3 BLOOP{,I} tests. --- Source/DSPSpy/tests/st3_test.ds | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) create mode 100644 Source/DSPSpy/tests/st3_test.ds diff --git a/Source/DSPSpy/tests/st3_test.ds b/Source/DSPSpy/tests/st3_test.ds new file mode 100644 index 000000000000..a10724af3781 --- /dev/null +++ b/Source/DSPSpy/tests/st3_test.ds @@ -0,0 +1,25 @@ +; This test checks when $st3 gets decremented during BLOOP{,I} iterations. +; Expected $st3 values are: 2, 1, 0x0b88, 2, 1, 0x0b88. + +incdir "tests" +include "dsp_base.inc" + +test_main: + LRI $ac0.l, #2 + BLOOP $ac0.l, last_of_bloop + CALL send_back + NOP + NOP +last_of_bloop: + NOP + CALL send_back + + BLOOPI #2, last_of_bloopi + CALL send_back + NOP + NOP +last_of_bloopi: + NOP + CALL send_back + + JMP end_of_test From 099e6c9ab60987879e889944c0ae52b23772f9a1 Mon Sep 17 00:00:00 2001 From: Vincent Pelletier Date: Mon, 26 Sep 2022 13:33:20 +0000 Subject: [PATCH 3/3] docs/DSP: Trivial adjustment to BLOOP{,I} sub-operation order Noticed while tracing in a BLOOP using DSPSpy with $st{0..3} unmasked. BLOOPI assumed to follow the pattern. --- .../GameCube_DSP_Users_Manual.tex | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/docs/DSP/GameCube_DSP_Users_Manual/GameCube_DSP_Users_Manual.tex b/docs/DSP/GameCube_DSP_Users_Manual/GameCube_DSP_Users_Manual.tex index fc352182f503..be426f579078 100644 --- a/docs/DSP/GameCube_DSP_Users_Manual/GameCube_DSP_Users_Manual.tex +++ b/docs/DSP/GameCube_DSP_Users_Manual/GameCube_DSP_Users_Manual.tex @@ -46,7 +46,7 @@ % Document front page material \title{\textbf{\Huge GameCube DSP User's Manual}} \author{Reverse-engineered and documented by Duddie \\ \href{mailto:duddie@walla.com}{duddie@walla.com}} -\date{\today\\v0.1.4} +\date{\today\\v0.1.5} % Title formatting commands \newcommand{\OpcodeTitle}[1]{\subsection{#1}\label{instruction:#1}} @@ -262,6 +262,7 @@ 0.1.2 & 2022.05.21 & Pokechu22 & Fixed ``ILLR'' typo in Instruction Memory section \\ \hline 0.1.3 & 2022.05.27 & Pokechu22 & Renamed \texttt{CMPAR} instruction to \texttt{CMPAXH} \\ \hline 0.1.4 & 2022.06.02 & Pokechu22 & Fixed typos; added sections on 16-bit and 40-bit modes and on main and extended opcode writing to the same register. \\ \hline +0.1.5 & 2022.09.29 & vpelletier & Fixed \texttt{BLOOP} and \texttt{BLOOPI} suboperation order \\ \hline \end{tabular} \end{table} @@ -1664,10 +1665,11 @@ \section{Alphabetical list of opcodes} // On real hardware, the below does not happen, // this opcode only sets stack registers - WHILE ($st3--) + WHILE ($st3) DO EXECUTE_OPCODE($pc) WHILE($pc != $st2) + $st3-- $pc = $st0 END $pc = addrA + 1 @@ -1702,10 +1704,11 @@ \section{Alphabetical list of opcodes} // On real hardware, the below does not happen, // this opcode only sets stack registers - WHILE ($st3--) + WHILE ($st3) DO EXECUTE_OPCODE($pc) WHILE($pc != $st2) + $st3-- $pc = $st0 END $pc = addrA + 1