X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=pico%2Fdebug.c;h=5bbf8c4b431988ad16ec19c7783908a530016d82;hb=266c6afa84bde8d77a54d61ced8f227480247e24;hp=d6b91bdda30332c857ae2c3ed7beb05f0a1a4bbd;hpb=87b0845f3733166b491ae236feb8bc2eb0fca2ec;p=picodrive.git diff --git a/pico/debug.c b/pico/debug.c index d6b91bd..5bbf8c4 100644 --- a/pico/debug.c +++ b/pico/debug.c @@ -35,7 +35,7 @@ char *PDebugMain(void) sprintf(dstrp, "mode set 4: %02x\n", (r=reg[0xC])); MVP; sprintf(dstrp, "interlace: %i%i, cells: %i, shadow: %i\n", bit(r,2), bit(r,1), (r&0x80) ? 40 : 32, bit(r,3)); MVP; sprintf(dstrp, "scroll size: w: %i, h: %i SRAM: %i; eeprom: %i (%i)\n", reg[0x10]&3, (reg[0x10]&0x30)>>4, - bit(Pico.m.sram_reg, 4), bit(Pico.m.sram_reg, 2), SRam.eeprom_type); MVP; + !!(SRam.flags & SRF_ENABLED), !!(SRam.flags & SRF_EEPROM), SRam.eeprom_type); MVP; sprintf(dstrp, "sram range: %06x-%06x, reg: %02x\n", SRam.start, SRam.end, Pico.m.sram_reg); MVP; sprintf(dstrp, "pend int: v:%i, h:%i, vdp status: %04x\n", bit(pv->pending_ints,5), bit(pv->pending_ints,4), pv->status); MVP; sprintf(dstrp, "pal: %i, hw: %02x, frame#: %i\n", Pico.m.pal, Pico.m.hardware, Pico.m.frame_count); MVP; @@ -59,6 +59,35 @@ char *PDebugMain(void) return dstr; } +char *PDebug32x(void) +{ + char *dstrp = dstr; + unsigned short *r; + int i; + + r = Pico32x.regs; + sprintf(dstrp, "regs:\n"); MVP; + for (i = 0; i < 0x40/2; i += 8) { + sprintf(dstrp, "%02x: %04x %04x %04x %04x %04x %04x %04x %04x\n", + i*2, r[i+0], r[i+1], r[i+2], r[i+3], r[i+4], r[i+5], r[i+6], r[i+7]); MVP; + } + + i = 0; + r = Pico32x.vdp_regs; + sprintf(dstrp, "VDP regs:\n"); MVP; + sprintf(dstrp, "%02x: %04x %04x %04x %04x %04x %04x %04x %04x\n", + i*2, r[i+0], r[i+1], r[i+2], r[i+3], r[i+4], r[i+5], r[i+6], r[i+7]); MVP; + + sprintf(dstrp, " mSH2 sSH2\n"); MVP; + sprintf(dstrp, "PC: %08x %08x\n", msh2_pc(), ssh2_pc()); MVP; + for (i = 0; i < 16/2; i++) { + sprintf(dstrp, "R%d,%2d %08x,%08x %08x,%08x\n", i, i + 8, + msh2_reg(i), msh2_reg(i+8), ssh2_reg(i), ssh2_reg(i+8)); MVP; + } + + return dstr; +} + char *PDebugSpriteList(void) { struct PicoVideo *pvid=&Pico.video; @@ -298,6 +327,14 @@ void PDebugDumpMem(void) dump_ram_noswab(Pico_mcd->pcm_ram,"dumps/pcm_ram.bin"); dump_ram_noswab(Pico_mcd->bram, "dumps/bram.bin"); } + + if (PicoAHW & PAHW_32X) + { + dump_ram(Pico32xMem->sdram, "dumps/sdram.bin"); + dump_ram(Pico32xMem->dram[0], "dumps/dram0.bin"); + dump_ram(Pico32xMem->dram[1], "dumps/dram1.bin"); + dump_ram(Pico32xMem->pal, "dumps/pal32x.bin"); + } } void PDebugZ80Frame(void) @@ -346,7 +383,7 @@ void PDebugZ80Frame(void) void PDebugCPUStep(void) { if (PicoAHW & PAHW_SMS) - z80_run(1); + z80_run_nr(1); else SekStepM68k(); }