added an AX disasm with (few) comments. Moved some code around to prepare to share some breakpoint code between the ppc and dsp

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@3566 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
hrydgard 2009-06-28 11:47:39 +00:00
parent f49e479d09
commit 7c92dada85
23 changed files with 2625 additions and 56 deletions

View File

@ -2003,10 +2003,6 @@
RelativePath=".\Src\Debugger\Debugger_SymbolMap.h" RelativePath=".\Src\Debugger\Debugger_SymbolMap.h"
> >
</File> </File>
<File
RelativePath=".\Src\Debugger\DebugInterface.h"
>
</File>
<File <File
RelativePath=".\Src\Debugger\Dump.cpp" RelativePath=".\Src\Debugger\Dump.cpp"
> >

View File

@ -22,16 +22,13 @@
#include "../PowerPC/PPCSymbolDB.h" #include "../PowerPC/PPCSymbolDB.h"
#include "Debugger_BreakPoints.h" #include "Debugger_BreakPoints.h"
BreakPoints g_breakpoints;
MemChecks g_memchecks;
void TMemCheck::Action(u32 iValue, u32 addr, bool write, int size, u32 pc) void TMemCheck::Action(u32 iValue, u32 addr, bool write, int size, u32 pc)
{ {
if ((write && OnWrite) || (!write && OnRead)) if ((write && OnWrite) || (!write && OnRead))
{ {
if (Log) if (Log)
{ {
DEBUG_LOG(MEMMAP,"CHK %08x %s%i at %08x (%s)", DEBUG_LOG(MEMMAP, "CHK %08x %s%i at %08x (%s)",
iValue, write ? "Write" : "Read", // read or write iValue, write ? "Write" : "Read", // read or write
size*8, addr, // address size*8, addr, // address
g_symbolDB.GetDescription(addr) // symbol map description g_symbolDB.GetDescription(addr) // symbol map description

View File

@ -77,8 +77,6 @@ private:
u32 m_iBreakOnCount; u32 m_iBreakOnCount;
}; };
extern BreakPoints g_breakpoints;
// Memory breakpoints // Memory breakpoints
class MemChecks class MemChecks
@ -96,7 +94,5 @@ public:
void Clear(); void Clear();
}; };
extern MemChecks g_memchecks;
#endif #endif

View File

@ -41,7 +41,7 @@ void AddAutoBreakpoints()
{ {
Symbol *symbol = g_symbolDB.GetSymbolFromName(bps[i]); Symbol *symbol = g_symbolDB.GetSymbolFromName(bps[i]);
if (symbol) if (symbol)
g_breakpoints.Add(symbol->address, false); PowerPC::breakpoints.Add(symbol->address, false);
} }
#endif #endif
#endif #endif

View File

@ -104,18 +104,18 @@ bool PPCDebugInterface::isAlive()
bool PPCDebugInterface::isBreakpoint(unsigned int address) bool PPCDebugInterface::isBreakpoint(unsigned int address)
{ {
return g_breakpoints.IsAddressBreakPoint(address); return PowerPC::breakpoints.IsAddressBreakPoint(address);
} }
void PPCDebugInterface::setBreakpoint(unsigned int address) void PPCDebugInterface::setBreakpoint(unsigned int address)
{ {
if (g_breakpoints.Add(address)) if (PowerPC::breakpoints.Add(address))
jit.NotifyBreakpoint(address, true); jit.NotifyBreakpoint(address, true);
} }
void PPCDebugInterface::clearBreakpoint(unsigned int address) void PPCDebugInterface::clearBreakpoint(unsigned int address)
{ {
if (g_breakpoints.Remove(address)) if (PowerPC::breakpoints.Remove(address))
jit.NotifyBreakpoint(address, false); jit.NotifyBreakpoint(address, false);
} }
@ -123,10 +123,10 @@ void PPCDebugInterface::clearAllBreakpoints() {}
void PPCDebugInterface::toggleBreakpoint(unsigned int address) void PPCDebugInterface::toggleBreakpoint(unsigned int address)
{ {
if (g_breakpoints.IsAddressBreakPoint(address)) if (PowerPC::breakpoints.IsAddressBreakPoint(address))
g_breakpoints.Remove(address); PowerPC::breakpoints.Remove(address);
else else
g_breakpoints.Add(address); PowerPC::breakpoints.Add(address);
} }
void PPCDebugInterface::insertBLR(unsigned int address, unsigned int value) void PPCDebugInterface::insertBLR(unsigned int address, unsigned int value)

View File

@ -4,7 +4,7 @@
#include <string> #include <string>
#include "DebugInterface.h" #include "DebugInterface.h"
#include "Debugger_Breakpoints.h"
//wrapper between disasm control and Dolphin debugger //wrapper between disasm control and Dolphin debugger
class PPCDebugInterface : public DebugInterface class PPCDebugInterface : public DebugInterface

View File

@ -132,7 +132,7 @@ void PatchFunctions()
Symbol *symbol = g_symbolDB.GetSymbolFromName(OSPatches[i].m_szPatchName); Symbol *symbol = g_symbolDB.GetSymbolFromName(OSPatches[i].m_szPatchName);
if (symbol > 0) if (symbol > 0)
{ {
g_breakpoints.Add(symbol->address, false); PowerPC::breakpoints.Add(symbol->address, false);
INFO_LOG(HLE,"Adding BP to %s %08x", OSBreakPoints[i].m_szPatchName, symbol->address); INFO_LOG(HLE,"Adding BP to %s %08x", OSBreakPoints[i].m_szPatchName, symbol->address);
} }
} }

View File

@ -21,7 +21,6 @@
#include "WII_IOB.h" #include "WII_IOB.h"
#include "../Core.h" #include "../Core.h"
#include "../PowerPC/PowerPC.h" #include "../PowerPC/PowerPC.h"
#include "../Debugger/Debugger_BreakPoints.h"
namespace Memory namespace Memory
{ {
@ -254,7 +253,7 @@ u8 Read_U8(const u32 _Address)
u8 _var = 0; u8 _var = 0;
ReadFromHardware<u8>(_var, _Address, _Address, FLAG_READ); ReadFromHardware<u8>(_var, _Address, _Address, FLAG_READ);
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -269,7 +268,7 @@ u16 Read_U16(const u32 _Address)
u16 _var = 0; u16 _var = 0;
ReadFromHardware<u16>(_var, _Address, _Address, FLAG_READ); ReadFromHardware<u16>(_var, _Address, _Address, FLAG_READ);
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -291,7 +290,7 @@ u32 Read_U32(const u32 _Address)
u32 _var = 0; u32 _var = 0;
ReadFromHardware<u32>(_var, _Address, _Address, FLAG_READ); ReadFromHardware<u32>(_var, _Address, _Address, FLAG_READ);
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -307,7 +306,7 @@ u64 Read_U64(const u32 _Address)
u64 _var = 0; u64 _var = 0;
ReadFromHardware<u64>(_var, _Address, _Address, FLAG_READ); ReadFromHardware<u64>(_var, _Address, _Address, FLAG_READ);
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -321,7 +320,7 @@ u64 Read_U64(const u32 _Address)
void Write_U8(const u8 _Data, const u32 _Address) void Write_U8(const u8 _Data, const u32 _Address)
{ {
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -335,7 +334,7 @@ void Write_U8(const u8 _Data, const u32 _Address)
void Write_U16(const u16 _Data, const u32 _Address) void Write_U16(const u16 _Data, const u32 _Address)
{ {
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -350,7 +349,7 @@ void Write_U16(const u16 _Data, const u32 _Address)
void Write_U32(const u32 _Data, const u32 _Address) void Write_U32(const u32 _Data, const u32 _Address)
{ {
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;
@ -364,7 +363,7 @@ void Write_U32(const u32 _Data, const u32 _Address)
void Write_U64(const u64 _Data, const u32 _Address) void Write_U64(const u64 _Data, const u32 _Address)
{ {
#ifndef NOCHECK #ifndef NOCHECK
TMemCheck *mc = g_memchecks.GetMemCheck(_Address); TMemCheck *mc = PowerPC::memchecks.GetMemCheck(_Address);
if (mc) if (mc)
{ {
mc->numHits++; mc->numHits++;

View File

@ -21,7 +21,6 @@
#include "../PPCTables.h" #include "../PPCTables.h"
#include "Interpreter.h" #include "Interpreter.h"
#include "../../Debugger/Debugger_SymbolMap.h" #include "../../Debugger/Debugger_SymbolMap.h"
#include "../../Debugger/Debugger_BreakPoints.h"
#include "../../CoreTiming.h" #include "../../CoreTiming.h"
#include "../../Core.h" #include "../../Core.h"
#include "PowerPCDisasm.h" #include "PowerPCDisasm.h"
@ -166,7 +165,7 @@ void Run()
#endif #endif
//2: check for breakpoint //2: check for breakpoint
if (g_breakpoints.IsAddressBreakPoint(PC)) if (PowerPC::breakpoints.IsAddressBreakPoint(PC))
{ {
#ifdef SHOW_HISTORY #ifdef SHOW_HISTORY
NOTICE_LOG(POWERPC, "----------------------------"); NOTICE_LOG(POWERPC, "----------------------------");
@ -187,8 +186,8 @@ void Run()
#endif #endif
INFO_LOG(POWERPC, "Hit Breakpoint - %08x", PC); INFO_LOG(POWERPC, "Hit Breakpoint - %08x", PC);
CCPU::Break(); CCPU::Break();
if (g_breakpoints.IsTempBreakPoint(PC)) if (PowerPC::breakpoints.IsTempBreakPoint(PC))
g_breakpoints.Remove(PC); PowerPC::breakpoints.Remove(PC);
Host_UpdateDisasmDialog(); Host_UpdateDisasmDialog();
return; return;

View File

@ -25,7 +25,6 @@
#include "../../Core.h" #include "../../Core.h"
#include "../../PatchEngine.h" #include "../../PatchEngine.h"
#include "../../CoreTiming.h" #include "../../CoreTiming.h"
#include "../../Debugger/Debugger_BreakPoints.h"
#include "../../ConfigManager.h" #include "../../ConfigManager.h"
#include "../PowerPC.h" #include "../PowerPC.h"
#include "../Profiler.h" #include "../Profiler.h"
@ -550,7 +549,7 @@ const u8* Jit64::DoJit(u32 em_address, PPCAnalyst::CodeBuffer *code_buffer, JitB
} }
// If starting from the breakpointed instruction, we don't break. // If starting from the breakpointed instruction, we don't break.
if (em_address != ops[i].address && g_breakpoints.IsAddressBreakPoint(ops[i].address)) if (em_address != ops[i].address && PowerPC::breakpoints.IsAddressBreakPoint(ops[i].address))
{ {
} }

View File

@ -42,6 +42,9 @@ volatile CPUState state = CPU_STEPPING;
static CoreMode mode; static CoreMode mode;
BreakPoints breakpoints;
MemChecks memchecks;
void CompactCR() void CompactCR()
{ {
u32 new_cr = ppcState.cr_fast[0] << 28; u32 new_cr = ppcState.cr_fast[0] << 28;

View File

@ -20,6 +20,7 @@
#include "Common.h" #include "Common.h"
#include "Gekko.h" #include "Gekko.h"
#include "../Debugger/Debugger_BreakPoints.h"
class PointerWrap; class PointerWrap;
@ -73,6 +74,9 @@ enum CPUState
extern PowerPCState ppcState; extern PowerPCState ppcState;
extern BreakPoints breakpoints;
extern MemChecks memchecks;
void Init(); void Init();
void Shutdown(); void Shutdown();
void DoState(PointerWrap &p); void DoState(PointerWrap &p);

View File

@ -31,7 +31,7 @@
#include "DSPCore.h" #include "DSPCore.h"
#include "DSPAnalyzer.h" #include "DSPAnalyzer.h"
#include "gdsp_interface.h" #include "DSPHWInterface.h"
#include "DSPIntUtil.h" #include "DSPIntUtil.h"
namespace DSPInterpreter { namespace DSPInterpreter {

View File

@ -26,7 +26,6 @@
#include "Common.h" #include "Common.h"
#include "DSPCore.h" #include "DSPCore.h"
// #include "DSPInterpreter.h"
#include "DSPStacks.h" #include "DSPStacks.h"
// Stacks. The stacks are outside the DSP RAM, in dedicated hardware. // Stacks. The stacks are outside the DSP RAM, in dedicated hardware.

View File

@ -20,7 +20,7 @@
#include "Host.h" #include "Host.h"
#include "Debugger.h" #include "Debugger.h"
#include "StringUtil.h" #include "StringUtil.h"
#include "Debugger/Debugger_BreakPoints.h" #include "PowerPC/PowerPC.h"
BEGIN_EVENT_TABLE(BreakPointDlg,wxDialog) BEGIN_EVENT_TABLE(BreakPointDlg,wxDialog)
@ -72,7 +72,7 @@ void BreakPointDlg::OnOK(wxCommandEvent& /*event*/)
u32 Address = 0; u32 Address = 0;
if (AsciiToHex(AddressString.mb_str(), Address)) if (AsciiToHex(AddressString.mb_str(), Address))
{ {
g_breakpoints.Add(Address); PowerPC::breakpoints.Add(Address);
Host_UpdateBreakPointView(); Host_UpdateBreakPointView();
Close(); Close();
} }

View File

@ -19,9 +19,9 @@
#include "Common.h" #include "Common.h"
#include "BreakpointView.h" #include "BreakpointView.h"
#include "Debugger/Debugger_BreakPoints.h"
#include "Debugger/Debugger_SymbolMap.h" #include "Debugger/Debugger_SymbolMap.h"
#include "PowerPC/PPCSymbolDB.h" #include "PowerPC/PPCSymbolDB.h"
#include "PowerPC/PowerPC.h"
BEGIN_EVENT_TABLE(CBreakPointView, wxListCtrl) BEGIN_EVENT_TABLE(CBreakPointView, wxListCtrl)
@ -47,7 +47,7 @@ void CBreakPointView::Update()
InsertColumn(4, wxT("Flags"), wxLIST_FORMAT_CENTER, 100); InsertColumn(4, wxT("Flags"), wxLIST_FORMAT_CENTER, 100);
char szBuffer[64]; char szBuffer[64];
const BreakPoints::TBreakPoints& rBreakPoints = g_breakpoints.GetBreakPoints(); const BreakPoints::TBreakPoints& rBreakPoints = PowerPC::breakpoints.GetBreakPoints();
for (size_t i = 0; i < rBreakPoints.size(); i++) for (size_t i = 0; i < rBreakPoints.size(); i++)
{ {
const TBreakPoint& rBP = rBreakPoints[i]; const TBreakPoint& rBP = rBreakPoints[i];
@ -74,7 +74,7 @@ void CBreakPointView::Update()
} }
} }
const MemChecks::TMemChecks& rMemChecks = g_memchecks.GetMemChecks(); const MemChecks::TMemChecks& rMemChecks = PowerPC::memchecks.GetMemChecks();
for (size_t i = 0; i < rMemChecks.size(); i++) for (size_t i = 0; i < rMemChecks.size(); i++)
{ {
const TMemCheck& rMemCheck = rMemChecks[i]; const TMemCheck& rMemCheck = rMemChecks[i];
@ -115,8 +115,8 @@ void CBreakPointView::DeleteCurrentSelection()
if (Item >= 0) if (Item >= 0)
{ {
u32 Address = (u32)GetItemData(Item); u32 Address = (u32)GetItemData(Item);
g_breakpoints.DeleteByAddress(Address); PowerPC::breakpoints.DeleteByAddress(Address);
g_memchecks.DeleteByAddress(Address); PowerPC::memchecks.DeleteByAddress(Address);
Update(); Update();
} }
} }

View File

@ -23,7 +23,7 @@
#include "BreakPointDlg.h" #include "BreakPointDlg.h"
#include "MemoryCheckDlg.h" #include "MemoryCheckDlg.h"
#include "Host.h" #include "Host.h"
#include "Debugger/Debugger_BreakPoints.h" // for TMemCheck #include "PowerPC/PowerPC.h"
#include <wx/mstream.h> #include <wx/mstream.h>
@ -205,7 +205,7 @@ CBreakPointWindow::OnDelete(wxCommandEvent& event)
void void
CBreakPointWindow::OnClear(wxCommandEvent& event) CBreakPointWindow::OnClear(wxCommandEvent& event)
{ {
g_breakpoints.Clear(); PowerPC::breakpoints.Clear();
} }
// ============ // ============
@ -244,7 +244,7 @@ CBreakPointWindow::OnAddBreakPointMany(wxCommandEvent& event)
u32 Address = 0; u32 Address = 0;
if (AsciiToHex(line.c_str(), Address)) if (AsciiToHex(line.c_str(), Address))
{ {
g_breakpoints.Add(Address); PowerPC::breakpoints.Add(Address);
} }
} }
// only update after we are done with the loop // only update after we are done with the loop
@ -346,7 +346,7 @@ CBreakPointWindow::OnAddMemoryCheckMany(wxCommandEvent& event)
MemCheck.Log = true; MemCheck.Log = true;
//MemCheck.Break = false; // this is also what sets Active "on" in the breakpoint window //MemCheck.Break = false; // this is also what sets Active "on" in the breakpoint window
// so don't think it's off because we are only writing this to the log // so don't think it's off because we are only writing this to the log
g_memchecks.Add(MemCheck); PowerPC::memchecks.Add(MemCheck);
} }
} }
// update after we are done with the loop // update after we are done with the loop

View File

@ -20,7 +20,7 @@
#include "Debugger.h" #include "Debugger.h"
#include "StringUtil.h" #include "StringUtil.h"
#include "Host.h" #include "Host.h"
#include "Debugger/Debugger_BreakPoints.h" #include "PowerPC/PowerPC.h"
BEGIN_EVENT_TABLE(MemoryCheckDlg,wxDialog) BEGIN_EVENT_TABLE(MemoryCheckDlg,wxDialog)
EVT_CLOSE(MemoryCheckDlg::OnClose) EVT_CLOSE(MemoryCheckDlg::OnClose)
@ -91,7 +91,7 @@ void MemoryCheckDlg::OnOK(wxCommandEvent& /*event*/)
MemCheck.Log = true; MemCheck.Log = true;
MemCheck.Break = true; MemCheck.Break = true;
g_memchecks.Add(MemCheck); PowerPC::memchecks.Add(MemCheck);
Host_UpdateBreakPointView(); Host_UpdateBreakPointView();
Close(); Close();
} }

View File

@ -40,9 +40,9 @@ IUCode* UCodeFactory(u32 _CRC, CMailHandler& _rMailHandler)
case 0x65d6cc6f: // CARD case 0x65d6cc6f: // CARD
return new CUCode_CARD(_rMailHandler); return new CUCode_CARD(_rMailHandler);
case 0x3ad3b7ac: // Naruto3 case 0x3ad3b7ac: // Naruto3, Paper Mario - The Thousand Year Door
case 0x3daf59b9: // Alien Hominid case 0x3daf59b9: // Alien Hominid
case 0x4e8a8b21: // spdemo, ctaxi, 18 wheeler, disney, monkeyball2,cubivore,puzzlecollection,wario, case 0x4e8a8b21: // spdemo, ctaxi, 18 wheeler, disney, monkeyball 1/2,cubivore,puzzlecollection,wario,
// capcom vs snk, naruto2, lost kingdoms, star fox, mario party 4, mortal kombat, // capcom vs snk, naruto2, lost kingdoms, star fox, mario party 4, mortal kombat,
// smugglers run warzone, smash brothers, sonic mega collection, ZooCube // smugglers run warzone, smash brothers, sonic mega collection, ZooCube
// nddemo, starfox // nddemo, starfox

View File

@ -88,6 +88,7 @@ u32 DSPHost_CodeLoaded(const u8 *ptr, int size)
switch (ector_crc) { switch (ector_crc) {
case 0x86840740: success = DSPSymbols::ReadAnnotatedAssembly("../../Docs/DSP/DSP_UC_Zelda.txt"); break; case 0x86840740: success = DSPSymbols::ReadAnnotatedAssembly("../../Docs/DSP/DSP_UC_Zelda.txt"); break;
case 0x42f64ac4: success = DSPSymbols::ReadAnnotatedAssembly("../../Docs/DSP/DSP_UC_Luigi.txt"); break; case 0x42f64ac4: success = DSPSymbols::ReadAnnotatedAssembly("../../Docs/DSP/DSP_UC_Luigi.txt"); break;
case 0x4e8a8b21: success = DSPSymbols::ReadAnnotatedAssembly("../../Docs/DSP/DSP_UC_AX1.txt"); break;
default: success = false; break; default: success = false; break;
} }

View File

@ -147,7 +147,7 @@ void ReadData()
{ {
//INFO_LOG(CONSOLE, "Writing data to the Wiimote\n"); //INFO_LOG(CONSOLE, "Writing data to the Wiimote\n");
SEvent& rEvent = m_EventWriteQueue.front(); SEvent& rEvent = m_EventWriteQueue.front();
wiiuse_io_write(m_pWiiMote, (byte*)rEvent.m_PayLoad, m_EventWriteQueue.size()); wiiuse_io_write(m_pWiiMote, (byte*)rEvent.m_PayLoad, (int)m_EventWriteQueue.size());
m_EventWriteQueue.pop(); m_EventWriteQueue.pop();
#ifdef _WIN32 #ifdef _WIN32

2565
docs/DSP/DSP_UC_AX1.txt Normal file

File diff suppressed because it is too large Load Diff

View File

@ -6,7 +6,8 @@
// ector-CRC: 42f64ac4 // ector-CRC: 42f64ac4
// Notable differences: // Notable differences:
// Luigi init: //
// Luigi init (not using mail exception):
// sbset #0x02 // sbset #0x02
// sbset #0x03 // sbset #0x03
// sbclr #0x04 // sbclr #0x04
@ -16,7 +17,7 @@
// clr15 // clr15
// m0 // m0
// Zelda init: // Zelda init (using mail exception):
// sbclr #0x02 ! // sbclr #0x02 !
// sbclr #0x03 ! // sbclr #0x03 !
// sbclr #0x04 // sbclr #0x04
@ -26,6 +27,16 @@
// clr15 // clr15
// m0 // m0
// AX1 init (not using mail exception, same as Luigi init):
// sbset #0x02
// sbset #0x03
// sbclr #0x04
// sbset #0x05
// sbset #0x06
// set16
// clr15
// m0
// exception vectors // exception vectors