Play-/Source/ee/INTC.cpp
Jean-Philip Desjardins 30568a057d
Some checks failed
Build macOS / build_macos (push) Has been cancelled
Build Android / build_android (apk) (push) Has been cancelled
Build Android / build_android (libretro) (push) Has been cancelled
Build Linux ARM32 / build_linux_arm32 (push) Has been cancelled
Build Linux ARM64 / build_linux_arm64 (push) Has been cancelled
Build Windows Psf / build_windows_psf (off, x86_64, Visual Studio 16 2019, installer64.nsi, x64) (push) Has been cancelled
Build Windows Psf / build_windows_psf (on, x86_64, Visual Studio 16 2019, installer64.nsi, x64) (push) Has been cancelled
Build Windows / build_windows (x86_32, Visual Studio 16 2019, installer32.nsi, win32_msvc2019, Win32) (push) Has been cancelled
Build Windows / build_windows (x86_64, Visual Studio 16 2019, installer64.nsi, win64_msvc2019_64, x64) (push) Has been cancelled
Check Format / run_clangformat (push) Has been cancelled
Build iOS / build_ios (push) Has been cancelled
Build JavaScript / build_js (push) Has been cancelled
Build Linux / build_linux (push) Has been cancelled
Use app_config module.
2025-03-11 16:18:58 -04:00

78 lines
1.5 KiB
C++

#include "INTC.h"
#include "Log.h"
#include "../states/RegisterStateFile.h"
#define LOG_NAME ("ee_intc")
#define STATE_REGS_XML ("intc/regs.xml")
CINTC::CINTC()
: m_INTC_STAT(0)
, m_INTC_MASK(0)
{
}
void CINTC::Reset()
{
m_INTC_STAT = 0;
m_INTC_MASK = 0;
}
bool CINTC::IsInterruptPending() const
{
return (m_INTC_STAT & m_INTC_MASK) != 0;
}
uint32 CINTC::GetRegister(uint32 nAddress)
{
switch(nAddress)
{
case INTC_STAT:
return m_INTC_STAT;
break;
case INTC_MASK:
return m_INTC_MASK;
break;
default:
CLog::GetInstance().Warn(LOG_NAME, "Read an unhandled register (0x%08X).\r\n", nAddress);
break;
}
return 0;
}
void CINTC::SetRegister(uint32 nAddress, uint32 nValue)
{
switch(nAddress)
{
case INTC_STAT:
m_INTC_STAT &= ~nValue;
break;
case INTC_MASK:
m_INTC_MASK ^= nValue;
break;
default:
CLog::GetInstance().Warn(LOG_NAME, "Wrote to an unhandled register (0x%08X).\r\n", nAddress);
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)
{
auto registerFile = std::make_unique<CRegisterStateFile>(STATE_REGS_XML);
registerFile->SetRegister32("INTC_STAT", m_INTC_STAT);
registerFile->SetRegister32("INTC_MASK", m_INTC_MASK);
archive.InsertFile(std::move(registerFile));
}