2006-06-15 04:19:30 +00:00
|
|
|
#include "INTC.h"
|
2008-01-12 01:27:04 +00:00
|
|
|
#include "Log.h"
|
2006-06-15 04:19:30 +00:00
|
|
|
|
2008-01-12 01:27:04 +00:00
|
|
|
#define LOG_NAME "intc"
|
2006-06-15 04:19:30 +00:00
|
|
|
|
|
|
|
using namespace Framework;
|
|
|
|
|
2008-01-12 01:27:04 +00:00
|
|
|
CINTC::CINTC(CDMAC& dmac) :
|
|
|
|
m_INTC_STAT(0),
|
|
|
|
m_INTC_MASK(0),
|
|
|
|
m_dmac(dmac)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
CINTC::~CINTC()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2006-06-15 04:19:30 +00:00
|
|
|
void CINTC::Reset()
|
|
|
|
{
|
|
|
|
m_INTC_STAT = 0;
|
|
|
|
m_INTC_MASK = 0;
|
|
|
|
}
|
|
|
|
|
2008-01-12 01:27:04 +00:00
|
|
|
bool CINTC::IsInterruptPending()
|
2006-06-15 04:19:30 +00:00
|
|
|
{
|
2008-01-12 01:27:04 +00:00
|
|
|
if(m_dmac.IsInterruptPending())
|
2006-06-15 04:19:30 +00:00
|
|
|
{
|
|
|
|
m_INTC_STAT |= 0x02;
|
|
|
|
}
|
|
|
|
|
2008-01-12 01:27:04 +00:00
|
|
|
return (m_INTC_STAT & m_INTC_MASK) != 0;
|
2006-06-15 04:19:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32 CINTC::GetRegister(uint32 nAddress)
|
|
|
|
{
|
|
|
|
switch(nAddress)
|
|
|
|
{
|
|
|
|
case 0x1000F000:
|
|
|
|
return m_INTC_STAT;
|
|
|
|
break;
|
|
|
|
case 0x1000F010:
|
|
|
|
return m_INTC_MASK;
|
|
|
|
break;
|
|
|
|
default:
|
2008-01-12 01:27:04 +00:00
|
|
|
CLog::GetInstance().Print(LOG_NAME, "Read an unhandled register (0x%0.8X).\r\n", nAddress);
|
2006-06-15 04:19:30 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::SetRegister(uint32 nAddress, uint32 nValue)
|
|
|
|
{
|
|
|
|
switch(nAddress)
|
|
|
|
{
|
|
|
|
case 0x1000F000:
|
|
|
|
m_INTC_STAT &= ~nValue;
|
|
|
|
break;
|
|
|
|
case 0x1000F010:
|
|
|
|
m_INTC_MASK ^= nValue;
|
|
|
|
break;
|
|
|
|
default:
|
2008-01-12 01:27:04 +00:00
|
|
|
CLog::GetInstance().Print(LOG_NAME, "Wrote to an unhandled register (0x%0.8X).\r\n", nAddress);
|
2006-06-15 04:19:30 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::AssertLine(uint32 nLine)
|
|
|
|
{
|
|
|
|
m_INTC_STAT |= (1 << nLine);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::LoadState(CStream* pStream)
|
|
|
|
{
|
|
|
|
pStream->Read(&m_INTC_STAT, 4);
|
|
|
|
pStream->Read(&m_INTC_MASK, 4);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::SaveState(CStream* pStream)
|
|
|
|
{
|
|
|
|
pStream->Write(&m_INTC_STAT, 4);
|
|
|
|
pStream->Write(&m_INTC_MASK, 4);
|
|
|
|
}
|