2015-05-06 00:54:15 -04:00
|
|
|
#include "INTC.h"
|
|
|
|
#include "../Log.h"
|
2019-02-06 13:34:51 -05:00
|
|
|
#include "../states/RegisterStateFile.h"
|
2015-05-06 00:54:15 -04:00
|
|
|
|
2018-05-25 12:38:51 -04:00
|
|
|
#define LOG_NAME ("ee_intc")
|
2015-05-06 00:54:15 -04:00
|
|
|
|
2018-04-30 21:01:23 +01:00
|
|
|
#define STATE_REGS_XML ("intc/regs.xml")
|
2015-05-06 00:54:15 -04:00
|
|
|
|
2021-12-03 13:44:24 -05:00
|
|
|
CINTC::CINTC()
|
2018-04-30 21:01:23 +01:00
|
|
|
: m_INTC_STAT(0)
|
|
|
|
, m_INTC_MASK(0)
|
2015-05-06 00:54:15 -04:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::Reset()
|
|
|
|
{
|
|
|
|
m_INTC_STAT = 0;
|
|
|
|
m_INTC_MASK = 0;
|
|
|
|
}
|
|
|
|
|
2016-09-06 22:48:59 -04:00
|
|
|
bool CINTC::IsInterruptPending() const
|
|
|
|
{
|
2021-12-03 13:44:24 -05:00
|
|
|
return (m_INTC_STAT & m_INTC_MASK) != 0;
|
2015-05-06 00:54:15 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
uint32 CINTC::GetRegister(uint32 nAddress)
|
|
|
|
{
|
|
|
|
switch(nAddress)
|
|
|
|
{
|
2016-09-06 21:53:46 -04:00
|
|
|
case INTC_STAT:
|
2021-12-03 13:44:24 -05:00
|
|
|
return m_INTC_STAT;
|
2015-05-06 00:54:15 -04:00
|
|
|
break;
|
2016-09-06 21:53:46 -04:00
|
|
|
case INTC_MASK:
|
2015-05-06 00:54:15 -04:00
|
|
|
return m_INTC_MASK;
|
|
|
|
break;
|
|
|
|
default:
|
2018-05-24 12:59:15 -04:00
|
|
|
CLog::GetInstance().Warn(LOG_NAME, "Read an unhandled register (0x%08X).\r\n", nAddress);
|
2015-05-06 00:54:15 -04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::SetRegister(uint32 nAddress, uint32 nValue)
|
|
|
|
{
|
|
|
|
switch(nAddress)
|
|
|
|
{
|
2016-09-06 21:53:46 -04:00
|
|
|
case INTC_STAT:
|
2015-05-06 00:54:15 -04:00
|
|
|
m_INTC_STAT &= ~nValue;
|
|
|
|
break;
|
2016-09-06 21:53:46 -04:00
|
|
|
case INTC_MASK:
|
2015-05-06 00:54:15 -04:00
|
|
|
m_INTC_MASK ^= nValue;
|
|
|
|
break;
|
|
|
|
default:
|
2018-05-24 12:59:15 -04:00
|
|
|
CLog::GetInstance().Warn(LOG_NAME, "Wrote to an unhandled register (0x%08X).\r\n", nAddress);
|
2015-05-06 00:54:15 -04:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::AssertLine(uint32 nLine)
|
|
|
|
{
|
|
|
|
m_INTC_STAT |= (1 << nLine);
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::LoadState(Framework::CZipArchiveReader& archive)
|
|
|
|
{
|
|
|
|
CRegisterStateFile registerFile(*archive.BeginReadFile(STATE_REGS_XML));
|
|
|
|
m_INTC_STAT = registerFile.GetRegister32("INTC_STAT");
|
|
|
|
m_INTC_MASK = registerFile.GetRegister32("INTC_MASK");
|
|
|
|
}
|
|
|
|
|
|
|
|
void CINTC::SaveState(Framework::CZipArchiveWriter& archive)
|
|
|
|
{
|
2023-07-23 17:22:18 -04:00
|
|
|
auto registerFile = std::make_unique<CRegisterStateFile>(STATE_REGS_XML);
|
2015-05-06 00:54:15 -04:00
|
|
|
registerFile->SetRegister32("INTC_STAT", m_INTC_STAT);
|
|
|
|
registerFile->SetRegister32("INTC_MASK", m_INTC_MASK);
|
2023-07-23 17:22:18 -04:00
|
|
|
archive.InsertFile(std::move(registerFile));
|
2015-05-06 00:54:15 -04:00
|
|
|
}
|