(just some obsessive code cleanup)

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@3142 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
hrydgard 2009-05-03 11:57:53 +00:00
parent 0772db6af6
commit 59ed31f291
4 changed files with 66 additions and 114 deletions

View File

@ -200,7 +200,7 @@ void mulcmvz(const UDSPInstruction& opc)
// update prod // update prod
u8 sreg = (opc.hex >> 12) & 0x1; u8 sreg = (opc.hex >> 12) & 0x1;
u8 treg = (opc.hex >> 11) & 0x1; u8 treg = (opc.hex >> 11) & 0x1;
dsp_multiply(dsp_get_acc_m(sreg), (s64)dsp_get_ax_h(treg)); dsp_multiply(dsp_get_acc_m(sreg), dsp_get_ax_h(treg));
// update acc // update acc
u8 rreg = (opc.hex >> 8) & 0x1; u8 rreg = (opc.hex >> 8) & 0x1;
@ -223,7 +223,7 @@ void mulcmv(const UDSPInstruction& opc)
// update prod // update prod
u8 sreg = (opc.hex >> 12) & 0x1; u8 sreg = (opc.hex >> 12) & 0x1;
u8 treg = (opc.hex >> 11) & 0x1; u8 treg = (opc.hex >> 11) & 0x1;
dsp_multiply(dsp_get_acc_m(sreg), (s64)dsp_get_ax_h(treg)); dsp_multiply(dsp_get_acc_m(sreg), dsp_get_ax_h(treg));
// update acc // update acc
u8 rreg = (opc.hex >> 8) & 0x1; u8 rreg = (opc.hex >> 8) & 0x1;
@ -244,7 +244,7 @@ void mulcac(const UDSPInstruction& opc)
// update prod // update prod
u8 sreg = (opc.hex >> 12) & 0x1; u8 sreg = (opc.hex >> 12) & 0x1;
u8 treg = (opc.hex >> 11) & 0x1; u8 treg = (opc.hex >> 11) & 0x1;
dsp_multiply(dsp_get_acc_m(sreg), (s64)dsp_get_ax_h(treg)); dsp_multiply(dsp_get_acc_m(sreg), dsp_get_ax_h(treg));
// update acc // update acc
u8 rreg = (opc.hex >> 8) & 0x1; u8 rreg = (opc.hex >> 8) & 0x1;

View File

@ -217,8 +217,8 @@ void dsp_op_ext_r_epi(const UDSPInstruction& opc)
case 0x02: // IR case 0x02: // IR
dsp_increment_addr_reg(reg); dsp_increment_addr_reg(reg);
break; break;
case 0x03: // NR case 0x03: // NR
g_dsp.r[reg] += g_dsp.r[reg + 4]; g_dsp.r[reg] += g_dsp.r[reg + 4];
break; break;
} }
@ -376,43 +376,43 @@ void dsp_op_ext_ops_pro(const UDSPInstruction& opc)
switch ((opc.hex >> 4) & 0xf) switch ((opc.hex >> 4) & 0xf)
{ {
case 0x00: case 0x00:
dsp_op_ext_r_epi(opc.hex); dsp_op_ext_r_epi(opc.hex);
break; break;
case 0x01: case 0x01:
dsp_op_ext_mv(opc.hex); dsp_op_ext_mv(opc.hex);
break; break;
case 0x02: case 0x02:
case 0x03: case 0x03:
dsp_op_ext_s(opc.hex); dsp_op_ext_s(opc.hex);
break; break;
case 0x04: case 0x04:
case 0x05: case 0x05:
case 0x06: case 0x06:
case 0x07: case 0x07:
dsp_op_ext_l(opc.hex); dsp_op_ext_l(opc.hex);
break; break;
case 0x08: case 0x08:
case 0x09: case 0x09:
case 0x0a: case 0x0a:
case 0x0b: case 0x0b:
if (opc.hex & 0x2) if (opc.hex & 0x2)
dsp_op_ext_sl_pro(opc.hex); dsp_op_ext_sl_pro(opc.hex);
else else
dsp_op_ext_ls_pro(opc.hex); dsp_op_ext_ls_pro(opc.hex);
break; break;
case 0x0c: case 0x0c:
case 0x0d: case 0x0d:
case 0x0e: case 0x0e:
case 0x0f: case 0x0f:
dsp_op_ext_ld(opc.hex); dsp_op_ext_ld(opc.hex);
break; break;
} }
} }

12
Source/DSPSpy/display.h Normal file
View File

@ -0,0 +1,12 @@
#ifndef _DISPLAY_H
#define _DISPLAY_H
void ds_text_out(int xpos, int ypos, const char *str);
void ds_set_colour(int f, int b);
void ds_init(void *framebuffer, int xstart, int ystart, int xres, int yres, int stride);
void ds_underline(int xpos, int ypos, int len, int col);
void ds_printf(int x, int y, const char *fmt, ...);
void ds_clear(void);
#endif

View File

@ -23,12 +23,14 @@
#include "processor.h" #include "processor.h"
#include "irq.h" #include "irq.h"
#include "dsp.h" #include "dsp.h"
#include "display.h"
// Pull in some constants etc from DSPCore. // Pull in some constants etc from DSPCore.
#include "../Core/DSPCore/Src/gdsp_registers.h" #include "../Core/DSPCore/Src/gdsp_registers.h"
// This is where the DSP binary is. // This is where the DSP binary is.
#include "dsp_code.h" #include "dsp_code.h"
#include "mem_dump.h"
// DSPCR bits // DSPCR bits
#define DSPCR_DSPRESET 0x0800 // Reset DSP #define DSPCR_DSPRESET 0x0800 // Reset DSP
@ -46,9 +48,6 @@
// Used for communications with the DSP, such as dumping registers etc. // Used for communications with the DSP, such as dumping registers etc.
u16 dspbuffer[16 * 1024] __attribute__ ((aligned (0x4000))); u16 dspbuffer[16 * 1024] __attribute__ ((aligned (0x4000)));
// #define ENABLE_OUT
#undef ENABLE_OUT
static void *xfb = NULL; static void *xfb = NULL;
void (*reload)() = (void(*)())0x80001800; void (*reload)() = (void(*)())0x80001800;
GXRModeObj *rmode; GXRModeObj *rmode;
@ -86,14 +85,7 @@ u16 dspreg_in[32] = {
0x0000, 0x0000, 0x0000, 0xde6d, 0x0000, 0x0000, 0x0000, 0x004e, 0x0000, 0x0000, 0x0000, 0xde6d, 0x0000, 0x0000, 0x0000, 0x004e,
};*/ };*/
#include "mem_dump.h"
void ds_text_out(int xpos, int ypos, const char *str);
void ds_set_colour(int f, int b);
void ds_init(void *framebuffer, int xstart, int ystart, int xres, int yres, int stride);
void ds_underline(int xpos, int ypos, int len, int col);
void ds_printf(int x, int y, const char *fmt, ...);
void ds_clear(void);
u16 dspreg_out[1000][32]; u16 dspreg_out[1000][32];
@ -117,10 +109,10 @@ volatile int regs_refreshed = false;
// Handler for DSP interrupt. // Handler for DSP interrupt.
static void my__dsp_handler(u32 nIrq,void *pCtx) static void my__dsp_handler(u32 nIrq, void *pCtx)
{ {
// Acknowledge interrupt? // Acknowledge interrupt?
_dspReg[5] = (_dspReg[5]&~(DSPCR_AIINT|DSPCR_ARINT)) | DSPCR_DSPINT; _dspReg[5] = (_dspReg[5] & ~(DSPCR_AIINT|DSPCR_ARINT)) | DSPCR_DSPINT;
} }
@ -202,21 +194,13 @@ void print_regs(int _step, int _dsp_steps)
void ui_pad_sel(void) void ui_pad_sel(void)
{ {
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_RIGHT) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_RIGHT)
{ cursor_reg += 8;
cursor_reg+=8;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_LEFT) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_LEFT)
{ cursor_reg -= 8;
cursor_reg-=8;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_UP) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_UP)
{
cursor_reg--; cursor_reg--;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_DOWN) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_DOWN)
{
cursor_reg++; cursor_reg++;
}
cursor_reg &= 0x1f; cursor_reg &= 0x1f;
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_A) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_A)
{ {
@ -225,59 +209,20 @@ void ui_pad_sel(void)
} }
} }
/*
void ui_pad_edit_bin(void)
{
u8 pos;
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_RIGHT)
{
small_cursor_x++;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_LEFT)
{
small_cursor_x--;
}
small_cursor_x &= 0xf;
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_UP)
{
pos = 0xf - small_cursor_x;
*reg_value |= 1 << pos;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_DOWN)
{
pos = 0xf - small_cursor_x;
*reg_value &= ~(1 << pos);
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_A)
{
ui_mode = UIM_SEL;
}
}*/
void ui_pad_edit_reg(void) void ui_pad_edit_reg(void)
{ {
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_RIGHT) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_RIGHT)
{
small_cursor_x++; small_cursor_x++;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_LEFT) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_LEFT)
{
small_cursor_x--; small_cursor_x--;
}
small_cursor_x &= 0x3; small_cursor_x &= 0x3;
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_UP) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_UP)
{
*reg_value += 0x1 << (4 * (3 - small_cursor_x)); *reg_value += 0x1 << (4 * (3 - small_cursor_x));
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_DOWN) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_DOWN)
{
*reg_value -= 0x1 << (4 * (3 - small_cursor_x)); *reg_value -= 0x1 << (4 * (3 - small_cursor_x));
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_A) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_A)
{
ui_mode = UIM_SEL; ui_mode = UIM_SEL;
}
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_1) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_1)
*reg_value = 0; *reg_value = 0;
if (WPAD_ButtonsDown(0) & WPAD_BUTTON_2) if (WPAD_ButtonsDown(0) & WPAD_BUTTON_2)
@ -349,21 +294,17 @@ int main()
dspbufU = (u32 *)(MEM_K0_TO_K1(dspbuffer)); dspbufU = (u32 *)(MEM_K0_TO_K1(dspbuffer));
DCInvalidateRange(dspbuffer, 0x2000); DCInvalidateRange(dspbuffer, 0x2000);
for (int j = 0 ; j < 0x800; j++) for (int j = 0; j < 0x800; j++)
dspbufU[j] = 0xffffffff; dspbufU[j] = 0xffffffff;
_dspReg[5] = (_dspReg[5]&~(DSPCR_AIINT|DSPCR_ARINT|DSPCR_DSPINT))|DSPCR_DSPRESET; _dspReg[5] = (_dspReg[5] & ~(DSPCR_AIINT|DSPCR_ARINT|DSPCR_DSPINT)) | DSPCR_DSPRESET;
_dspReg[5] = (_dspReg[5]&~(DSPCR_HALT|DSPCR_AIINT|DSPCR_ARINT|DSPCR_DSPINT)); _dspReg[5] = (_dspReg[5] & ~(DSPCR_HALT|DSPCR_AIINT|DSPCR_ARINT|DSPCR_DSPINT));
// This code looks odd - shouldn't we initialize level?
u32 level; u32 level;
_CPU_ISR_Disable(level); _CPU_ISR_Disable(level);
IRQ_Request(IRQ_DSP_DSP, my__dsp_handler,NULL); IRQ_Request(IRQ_DSP_DSP, my__dsp_handler, NULL);
_CPU_ISR_Restore(level); _CPU_ISR_Restore(level);
#if ENABLE_OUT
if_config("192.168.0.5", "192.168.0.1", "255.255.255.0", false);
//printf("Network Intitalized\n");
#endif
// Both GC and Wii controls. // Both GC and Wii controls.
PAD_Init(); PAD_Init();
@ -371,7 +312,6 @@ int main()
int dsp_steps = 0; int dsp_steps = 0;
int show_step = 0; int show_step = 0;
while (true) while (true)
{ {
// Should put a loop around this too. // Should put a loop around this too.