2009-07-26 11:51:40 +00:00
|
|
|
// Copyright (C) 2003-2009 Dolphin Project.
|
2008-12-08 04:46:09 +00:00
|
|
|
|
|
|
|
// This program is free software: you can redistribute it and/or modify
|
|
|
|
// it under the terms of the GNU General Public License as published by
|
|
|
|
// the Free Software Foundation, version 2.0.
|
|
|
|
|
|
|
|
// This program is distributed in the hope that it will be useful,
|
|
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
// GNU General Public License 2.0 for more details.
|
|
|
|
|
|
|
|
// A copy of the GPL 2.0 should have been included with the program.
|
|
|
|
// If not, see http://www.gnu.org/licenses/
|
|
|
|
|
|
|
|
// Official SVN repository and contact information can be found at
|
|
|
|
// http://code.google.com/p/dolphin-emu/
|
|
|
|
|
|
|
|
#ifndef _DSPHANDLER_H
|
|
|
|
#define _DSPHANDLER_H
|
|
|
|
|
|
|
|
#include "Common.h"
|
|
|
|
#include "MailHandler.h"
|
|
|
|
#include "UCodes/UCodes.h"
|
|
|
|
|
|
|
|
class CDSPHandler
|
|
|
|
{
|
|
|
|
public:
|
2009-04-08 18:36:53 +00:00
|
|
|
void Update(int cycles);
|
2008-12-08 04:46:09 +00:00
|
|
|
unsigned short WriteControlRegister(unsigned short _Value);
|
|
|
|
unsigned short ReadControlRegister();
|
|
|
|
void SendMailToDSP(u32 _uMail);
|
|
|
|
IUCode* GetUCode();
|
|
|
|
void SetUCode(u32 _crc);
|
|
|
|
|
|
|
|
CMailHandler& AccessMailHandler() { return m_MailHandler; }
|
|
|
|
|
|
|
|
static CDSPHandler& GetInstance()
|
|
|
|
{
|
|
|
|
return *m_pInstance;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void Destroy()
|
|
|
|
{
|
|
|
|
delete m_pInstance;
|
|
|
|
m_pInstance = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static CDSPHandler& CreateInstance()
|
|
|
|
{
|
|
|
|
if (!m_pInstance)
|
|
|
|
m_pInstance = new CDSPHandler();
|
|
|
|
|
|
|
|
return *m_pInstance;
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
CDSPHandler();
|
|
|
|
~CDSPHandler();
|
|
|
|
|
|
|
|
// UDSPControl
|
|
|
|
union UDSPControl
|
|
|
|
{
|
|
|
|
u16 Hex;
|
|
|
|
struct
|
|
|
|
{
|
|
|
|
unsigned DSPReset : 1; // Write 1 to reset and waits for 0
|
|
|
|
unsigned DSPAssertInt : 1;
|
|
|
|
unsigned DSPHalt : 1;
|
|
|
|
|
|
|
|
unsigned AI : 1;
|
|
|
|
unsigned AI_mask : 1;
|
|
|
|
unsigned ARAM : 1;
|
|
|
|
unsigned ARAM_mask : 1;
|
|
|
|
unsigned DSP : 1;
|
|
|
|
unsigned DSP_mask : 1;
|
|
|
|
|
|
|
|
unsigned ARAM_DMAState : 1; // DSPGetDMAStatus() uses this flag
|
|
|
|
unsigned DSPInitCode : 1;
|
|
|
|
unsigned DSPInit : 1; // DSPInit() writes to this flag
|
|
|
|
unsigned pad : 4;
|
|
|
|
};
|
|
|
|
|
|
|
|
UDSPControl(u16 _Hex = 0)
|
|
|
|
: Hex(_Hex)
|
|
|
|
{}
|
|
|
|
};
|
|
|
|
|
|
|
|
// singleton instance
|
|
|
|
static CDSPHandler* m_pInstance;
|
|
|
|
|
|
|
|
IUCode* m_pUCode;
|
|
|
|
UDSPControl m_DSPControl;
|
|
|
|
CMailHandler m_MailHandler;
|
|
|
|
|
|
|
|
bool m_bHalt;
|
|
|
|
bool m_bAssertInt;
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif
|