2010-05-23 10:05:41 +00:00
|
|
|
#include "stdafx.h"
|
2008-09-18 03:15:49 +00:00
|
|
|
|
2010-05-22 04:47:15 +00:00
|
|
|
CAudio::CAudio (void)
|
2008-09-18 03:15:49 +00:00
|
|
|
{
|
2010-06-14 21:14:58 +00:00
|
|
|
Reset();
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
CAudio::~CAudio (void)
|
2008-09-18 03:15:49 +00:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
void CAudio::Reset ( void )
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
|
|
|
m_SecondBuff = 0;
|
2010-06-14 21:14:58 +00:00
|
|
|
m_Status = 0;
|
2010-06-30 21:35:44 +00:00
|
|
|
m_BytesPerSecond = 0;
|
2012-11-13 05:44:13 +00:00
|
|
|
m_CountsPerByte = AiCountPerBytes(); // should be calculated ... see below, instead allow from user settings
|
2010-06-29 02:11:22 +00:00
|
|
|
m_FramesPerSecond = 60;
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
DWORD CAudio::GetLength ( void )
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Start (m_SecondBuff = %d)",m_SecondBuff);
|
|
|
|
DWORD TimeLeft = _SystemTimer->GetTimer(CSystemTimer::AiTimer), Res = 0;
|
2010-06-14 21:14:58 +00:00
|
|
|
if (TimeLeft > 0)
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
Res = (TimeLeft / m_CountsPerByte) + m_SecondBuff;
|
2010-05-22 04:47:15 +00:00
|
|
|
}
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Done (res = %d, TimeLeft = %d)",Res, TimeLeft);
|
|
|
|
return Res;
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
DWORD CAudio::GetStatus ( void )
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": m_Status = %X",m_Status);
|
2010-05-22 04:47:15 +00:00
|
|
|
return m_Status;
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
void CAudio::LenChanged ( void )
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Start (_Reg->AI_LEN_REG = %d)",_Reg->AI_LEN_REG);
|
2010-07-05 11:29:46 +00:00
|
|
|
if (_Reg->AI_LEN_REG != 0)
|
2010-06-14 21:14:58 +00:00
|
|
|
{
|
2012-11-06 10:23:47 +00:00
|
|
|
if (_Reg->AI_LEN_REG >= 0x20000)
|
2012-11-02 23:27:19 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": *** Ignoring Write, To Large (%X)",_Reg->AI_LEN_REG);
|
2010-07-05 11:29:46 +00:00
|
|
|
} else {
|
2012-11-06 10:23:47 +00:00
|
|
|
m_Status |= 0x80000000;
|
2012-11-13 05:06:46 +00:00
|
|
|
if (_SystemTimer->GetTimer(CSystemTimer::AiTimer) == 0)
|
2012-11-06 08:09:56 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
if (m_SecondBuff)
|
|
|
|
{
|
|
|
|
_Notify->BreakPoint(__FILE__,__LINE__);
|
|
|
|
}
|
2012-11-06 08:09:56 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Set Timer AI_LEN_REG: %d m_CountsPerByte: %d",_Reg->AI_LEN_REG,m_CountsPerByte);
|
|
|
|
_SystemTimer->SetTimer(CSystemTimer::AiTimer,_Reg->AI_LEN_REG * m_CountsPerByte,false);
|
|
|
|
} else {
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Increasing Second Buffer (m_SecondBuff %d Increase: %d)",m_SecondBuff,_Reg->AI_LEN_REG);
|
2012-11-06 10:23:47 +00:00
|
|
|
m_SecondBuff += _Reg->AI_LEN_REG;
|
2012-11-06 08:09:56 +00:00
|
|
|
}
|
2012-11-02 23:27:19 +00:00
|
|
|
}
|
2008-09-18 03:15:49 +00:00
|
|
|
} else {
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": *** Reset Timer to 0");
|
2010-07-05 11:29:46 +00:00
|
|
|
_SystemTimer->StopTimer(CSystemTimer::AiTimer);
|
|
|
|
m_SecondBuff = 0;
|
|
|
|
m_Status = 0;
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
2010-07-05 11:29:46 +00:00
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
if (_Plugins->Audio()->LenChanged != NULL)
|
|
|
|
{
|
|
|
|
_Plugins->Audio()->LenChanged();
|
|
|
|
}
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Done");
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2010-06-14 21:14:58 +00:00
|
|
|
void CAudio::TimerDone ( void )
|
2010-05-22 04:47:15 +00:00
|
|
|
{
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Start (m_SecondBuff = %d)",m_SecondBuff);
|
2012-11-06 10:23:47 +00:00
|
|
|
if (m_SecondBuff != 0)
|
2012-11-02 23:27:19 +00:00
|
|
|
{
|
2012-11-06 10:23:47 +00:00
|
|
|
_SystemTimer->SetTimer(CSystemTimer::AiTimer,m_SecondBuff * m_CountsPerByte,false);
|
|
|
|
m_SecondBuff = 0;
|
|
|
|
} else {
|
|
|
|
_Reg->MI_INTR_REG |= MI_INTR_AI;
|
|
|
|
_Reg->CheckInterrupts();
|
|
|
|
m_Status &= 0x7FFFFFFF;
|
2010-06-14 21:14:58 +00:00
|
|
|
}
|
2012-11-13 05:06:46 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ ": Done",m_SecondBuff);
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
|
|
|
|
2012-10-06 04:09:17 +00:00
|
|
|
void CAudio::SetViIntr ( DWORD /*VI_INTR_TIME*/ )
|
2010-06-14 21:14:58 +00:00
|
|
|
{
|
2012-10-06 04:09:17 +00:00
|
|
|
/*
|
2010-06-29 02:11:22 +00:00
|
|
|
double CountsPerSecond = (DWORD)((double)VI_INTR_TIME * m_FramesPerSecond);
|
2010-06-30 21:35:44 +00:00
|
|
|
if (m_BytesPerSecond != 0)
|
|
|
|
{
|
|
|
|
//m_CountsPerByte = (double)CountsPerSecond / (double)m_BytesPerSecond;
|
|
|
|
}
|
2012-10-06 04:09:17 +00:00
|
|
|
*/
|
2008-09-18 03:15:49 +00:00
|
|
|
}
|
2010-06-14 21:14:58 +00:00
|
|
|
|
|
|
|
|
2010-06-29 02:11:22 +00:00
|
|
|
void CAudio::SetFrequency (DWORD Dacrate, DWORD System)
|
|
|
|
{
|
2011-01-04 09:10:28 +00:00
|
|
|
WriteTraceF(TraceAudio,__FUNCTION__ "(Dacrate: %X System: %d): AI_BITRATE_REG = %X",Dacrate,System,_Reg->AI_BITRATE_REG);
|
2010-06-29 02:11:22 +00:00
|
|
|
DWORD Frequency;
|
|
|
|
|
|
|
|
switch (System) {
|
|
|
|
case SYSTEM_PAL: Frequency = 49656530 / (Dacrate + 1); break;
|
|
|
|
case SYSTEM_MPAL: Frequency = 48628316 / (Dacrate + 1); break;
|
|
|
|
default: Frequency = 48681812 / (Dacrate + 1); break;
|
|
|
|
}
|
|
|
|
|
|
|
|
//nBlockAlign = 16 / 8 * 2;
|
|
|
|
m_BytesPerSecond = Frequency * 4;
|
2011-01-04 09:10:28 +00:00
|
|
|
m_BytesPerSecond = 194532;
|
|
|
|
m_BytesPerSecond = 128024;
|
2010-06-29 02:11:22 +00:00
|
|
|
|
|
|
|
if (System == SYSTEM_PAL) {
|
2010-10-29 03:20:25 +00:00
|
|
|
m_FramesPerSecond = 50;
|
2010-06-29 02:11:22 +00:00
|
|
|
} else {
|
2010-10-29 03:20:25 +00:00
|
|
|
m_FramesPerSecond = 60;
|
2010-06-29 02:11:22 +00:00
|
|
|
}
|
|
|
|
}
|
2010-06-14 21:14:58 +00:00
|
|
|
|