#include "ameteor/sound.hpp"
#include "globals.hpp"
#include "ameteor.hpp"
#include "debug.hpp"
namespace AMeteor
{
Sound::Sound () :
m_speaker(IO.GetRef16(Io::SOUND1CNT_L), IO.GetRef16(Io::SOUND1CNT_H),
IO.GetRef16(Io::SOUND1CNT_X),
IO.GetRef16(Io::SOUND2CNT_L), IO.GetRef16(Io::SOUND2CNT_H),
IO.GetRef16(Io::SOUND4CNT_L), IO.GetRef16(Io::SOUND4CNT_H),
IO.GetRef16(Io::SOUNDCNT_L), IO.GetRef16(Io::SOUNDCNT_H),
IO.GetRef16(Io::SOUNDCNT_X), IO.GetRef16(Io::SOUNDBIAS)),
m_fATimer(0),
m_fBTimer(0)
{
}
void Sound::Reset ()
{
m_fATimer = m_fBTimer = 0;
m_speaker.Reset();
}
void Sound::UpdateCntH1 (uint8_t val)
{
m_fATimer = (val & (0x1 << 10)) ? 1 : 0;
m_fBTimer = (val & (0x1 << 14)) ? 1 : 0;
if (val & (0x1 << 3))
m_speaker.ResetFifoA();
if (val & (0x1 << 7))
m_speaker.ResetFifoB();
}
void Sound::TimerOverflow (uint8_t timernum)
{
if (m_fATimer == timernum)
TimerOverflowA();
if (m_fBTimer == timernum)
TimerOverflowB();
}
inline void Sound::TimerOverflowA ()
{
if (m_speaker.GetSizeA() <= 16)
{
DMA.Check(1, Dma::Special);
if (m_speaker.GetSizeA() <= 16)
{
int8_t buf[16] = {0};
m_speaker.FillFifoA(buf);
}
}
m_speaker.NextSampleA ();
}
inline void Sound::TimerOverflowB ()
{
if (m_speaker.GetSizeB() <= 16)
{
DMA.Check(2, Dma::Special);
if (m_speaker.GetSizeB() <= 16)
{
int8_t buf[16] = {0};
m_speaker.FillFifoB(buf);
}
}
m_speaker.NextSampleB ();
}
bool Sound::SaveState (std::ostream& stream)
{
SS_WRITE_VAR(m_fATimer);
SS_WRITE_VAR(m_fBTimer);
if (!m_speaker.SaveState(stream))
return false;
return true;
}
bool Sound::LoadState (std::istream& stream)
{
SS_READ_VAR(m_fATimer);
SS_READ_VAR(m_fBTimer);
if (!m_speaker.LoadState(stream))
return false;
return true;
}
}