windows-nt/Source/XPSP1/NT/drivers/wdm/dvd/mini/toshiba/cadec.cpp
2020-09-26 16:20:57 +08:00

852 lines
18 KiB
C++

//***************************************************************************
// Audio decoder process
//
//***************************************************************************
#include "common.h"
#include "regs.h"
#include "cadec.h"
#include "zrnpch6.h"
#include "cdack.h"
void ADecoder::init( const PDEVICE_INIT_INFO pDevInit )
{
ioBase = pDevInit->ioBase;
// shoud be remove when release
// ASSERT( sizeof(ZRN_AC3_DEC) == 3891 );
// ASSERT( sizeof(ZRN_AC3_SPD) == 410 );
// ASSERT( sizeof(ZRN_PCM) == 6965 );
}
void ADecoder::SetParam( ULONG aMode, ULONG aFreq, ULONG aType, BOOL aCgms, Dack *pDak )
{
AudioMode = aMode;
AudioFreq = aFreq;
AudioType = aType;
AudioCgms = ( 0<=aCgms && aCgms<=3 ) ? aCgms : 3;
pDack = pDak;
}
// ***************************************************************************
// T C 6 8 0 0 A F
// ***************************************************************************
void ADecoder::AUDIO_TC6800_INIT_PCM()
{
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0xa0 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x80 );
}
void ADecoder::AUDIO_TC6800_INIT_AC3()
{
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x20 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
}
void ADecoder::AUDIO_TC6800_INIT_MPEG()
{
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x20 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
}
void ADecoder::AUDIO_TC6800_DATA_OFF()
{
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x66 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x60 );
}
// ***************************************************************************
// Z R 3 8 5 2 1
// ***************************************************************************
void ADecoder::AUDIO_ZR385_OUT( UCHAR val )
{
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x08 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, val );
// necessary?
pDack->PCIF_CHECK_SERIAL();
}
void ADecoder::AUDIO_ZR385_DOWNLOAD( PUCHAR pData, ULONG size )
{
ULONG i;
for( i = 0; i < size; i++ )
AUDIO_ZR385_OUT( *pData++ );
}
void ADecoder::AUDIO_ZR38521_BOOT_AC3()
{
AUDIO_ZR385_DOWNLOAD( ZRN_AC3_DEC, sizeof(ZRN_AC3_DEC) );
if( AudioType == AUDIO_OUT_DIGITAL )
AUDIO_ZR385_DOWNLOAD( ZRN_AC3_SPD, sizeof(ZRN_AC3_SPD) );
}
void ADecoder::AUDIO_ZR38521_BOOT_MPEG()
{
// not support!
}
void ADecoder::AUDIO_ZR38521_BOOT_PCM()
{
AUDIO_ZR385_DOWNLOAD( ZRN_PCM, sizeof(ZRN_PCM) );
}
NTSTATUS ADecoder::AUDIO_ZR38521_CFG()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x82 );
AUDIO_ZR385_OUT( 0x50 );
AUDIO_ZR385_OUT( 0x40 );
AUDIO_ZR385_OUT( 0x09 );
AUDIO_ZR385_OUT( 0x09 );
if( AudioType == AUDIO_OUT_DIGITAL )
AUDIO_ZR385_OUT( 0x70 );
else
AUDIO_ZR385_OUT( 0x50 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( 0x04 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_PCMX()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x88 );
AUDIO_ZR385_OUT( 0x81 );
AUDIO_ZR385_OUT( 0x82 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0xff );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_AC3()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x85 );
AUDIO_ZR385_OUT( 0x08 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0x11 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0xff );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_MPEG1()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x87 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0xff );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_PLAY()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x8a );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_MUTE_OFF()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x89 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_MUTE_ON()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x8b );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_STOP()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x8c );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_STOPF()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x8d );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_STCR()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x94 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf6 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_VDSCR_ON( ULONG stc )
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf4 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 25 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 17 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 9 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 1 ) & 0xff ) );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xc8 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_VDSCR_OFF( ULONG stc )
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf4 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 25 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 17 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 9 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 1 ) & 0xff ) );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xc8 );
AUDIO_ZR385_OUT( 0x80 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_AVSYNC_OFF( ULONG stc )
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf4 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 25 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 17 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 9 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 1 ) & 0xff ) );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xc8 );
AUDIO_ZR385_OUT( 0xc0 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_AVSYNC_ON( ULONG stc )
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf4 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x02 );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 25 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 17 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 9 ) & 0xff ) );
AUDIO_ZR385_OUT( (UCHAR)( ( stc >> 1 ) & 0xff ) );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xc8 );
AUDIO_ZR385_OUT( 0x40 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_STAT( PULONG pDiff )
{
UCHAR val;
if( pDiff == NULL )
return STATUS_UNSUCCESSFUL;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 ) {
*pDiff = 0x0908;
return STATUS_UNSUCCESSFUL;
}
*pDiff = 0;
AUDIO_ZR385_OUT( 0x8e );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
// Check DIFTH
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
*pDiff |= (ULONG)val << 8;
AUDIO_ZR385_OUT( 0x00 );
// Check DIFTL
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
*pDiff |= val & 0xff;
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
NTSTATUS ADecoder::AUDIO_ZR38521_KCOEF()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 )
return STATUS_UNSUCCESSFUL;
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0xf0 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x03 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x59 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x7f );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x59 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
void ADecoder::AUDIO_ZR38521_REPEAT_02()
{
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0xc3 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0x13 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xd0 );
AUDIO_ZR385_OUT( 0x44 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
}
void ADecoder::AUDIO_ZR38521_REPEAT_16()
{
AUDIO_ZR385_OUT( 0x93 );
AUDIO_ZR385_OUT( 0x0d );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0xc3 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x01 );
AUDIO_ZR385_OUT( 0x13 );
AUDIO_ZR385_OUT( 0xfb );
AUDIO_ZR385_OUT( 0xd3 );
AUDIO_ZR385_OUT( 0xc4 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
}
NTSTATUS ADecoder::AUDIO_ZR38521_BFST( PULONG pErrCode )
{
UCHAR val;
if( pErrCode == NULL )
return STATUS_UNSUCCESSFUL;
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
if( val != 0x80 ) {
*pErrCode = 0x0908;
return STATUS_UNSUCCESSFUL;
}
*pErrCode = 0;
AUDIO_ZR385_OUT( 0x8e );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
// Check IST
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
val &= 0x07;
*pErrCode |= (ULONG)val << 8;
AUDIO_ZR385_OUT( 0x00 );
// Check BFST
pDack->PCIF_CHECK_SERIAL();
val = READ_PORT_UCHAR( ioBase + PCIF_SR );
val &= 0x07;
*pErrCode |= val;
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
AUDIO_ZR385_OUT( 0x00 );
return STATUS_SUCCESS;
}
// ***************************************************************************
// T C 9 4 2 5 F
// ***************************************************************************
void ADecoder::AUDIO_TC9425_INIT_DIGITAL()
{
UCHAR val;
val = 0;
if( AudioType != AUDIO_OUT_ANALOG )
if( AudioMode == AUDIO_TYPE_AC3 )
val |= 0x40;
if( (AudioCgms & 0x02) == 0x00 ) {
val |= 0x20; // Copying is permitted without restriction
DebugPrint( ( DebugLevelTrace, "TOSDVD: AUDIO Copy OK\r\n" ) );
}
else {
val &= 0xDF; // Basically no copying is permitted (depend on L-Bit below)
DebugPrint( ( DebugLevelTrace, "TOSDVD: AUDIO Copy NG\r\n" ) );
}
// COPY, EMPH
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, val );
if( (AudioCgms & 0x01) == 0x00 ) {
val = 0x98; // L-Bit==0; One generation of copies may be made
DebugPrint( ( DebugLevelTrace, "TOSDVD: AUDIO 1 Time Copy OK\r\n" ) );
}
else {
val = 0x99; // L-Bit==1; No copying is permitted
DebugPrint( ( DebugLevelTrace, "TOSDVD: AUDIO 1 Time Copy NG\r\n" ) );
}
// Category Code, LBIT
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, val );
// Channel Num
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
if( AudioFreq == AUDIO_FS_32 )
val = 0xc0;
else if( AudioFreq == AUDIO_FS_44 )
val = 0x00;
else if( AudioFreq == AUDIO_FS_48 )
val = 0x40;
else
val = 0x40;
// FS1, FS2, CKA1, CKA2
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, val );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x72 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
}
void ADecoder::AUDIO_TC9425_INIT_ANALOG()
{
UCHAR val;
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
// MONO, CHS, EM, EMP
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x72 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0xc0 );
//
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
if( AudioType == AUDIO_OUT_DIGITAL )
val = 0x79;
else
val = 0x69;
if( AudioFreq == AUDIO_FS_96 )
val |= 0x04;
else if( AudioFreq == AUDIO_FS_48 )
val |= 0x04;
// BIT, DOIN, DOSEL, IFSEL, RLS
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, val );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x72 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0xc0 );
AUDIO_TC9425_SET_VOLUME( AudioVolume );
}
void ADecoder::AUDIO_TC9425_SET_VOLUME( ULONG vol )
{
UCHAR ucvol;
AudioVolume = vol;
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x00 );
ucvol = (UCHAR)vol;
ucvol = INVERSE_BYTE( ucvol );
ucvol = (UCHAR)( ucvol >> 1 );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x38 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, ucvol );
pDack->PCIF_CHECK_SERIAL();
WRITE_PORT_UCHAR( ioBase + PCIF_SCNT, 0x72 );
WRITE_PORT_UCHAR( ioBase + PCIF_SW, 0x40 );
}
UCHAR ADecoder::INVERSE_BYTE( UCHAR uc )
{
ULONG i;
UCHAR retch = 0;
for( i = 0; i < 8; i++ )
retch |= ( uc & 0x01 ) << ( 7 - i );
return retch;
}