1114 lines
40 KiB
C++
1114 lines
40 KiB
C++
//***************************************************************************
|
|
//
|
|
// FileName:
|
|
// $Workfile: ZIVACHIP.CPP $
|
|
//
|
|
// Author:
|
|
// TOSHIBA [PCS](PSY) Seiichi Nakamura
|
|
// Copyright (c) 1997 TOSHIBA CORPORATION
|
|
//
|
|
// Description:
|
|
//
|
|
//***************************************************************************
|
|
// $Header: /DVD Drivers/ZiVA.WDM/ZIVACHIP.CPP 26 99/02/12 4:44p Yagi $
|
|
// $Modtime: 99/02/10 1:24p $
|
|
// $Nokeywords:$
|
|
//***************************************************************************
|
|
|
|
// for ziva debug
|
|
//#define DEBUG_ZIVA
|
|
|
|
// for ziva command print out
|
|
//#define DEBUG_ZIVA_COMMAND
|
|
|
|
//---------------------------------------------------------------------------
|
|
// INCLUDES
|
|
//---------------------------------------------------------------------------
|
|
|
|
#include "includes.h"
|
|
|
|
#include "ioif.h"
|
|
#include "timeout.h"
|
|
#include "zivachip.h"
|
|
|
|
#include "dvd1cmd.h" // from C-CUBE
|
|
#include "dramcfg.h" // from C-CUBE
|
|
|
|
// Ziva Command time out setting. 1000 is 1 sec
|
|
#define COMMAND_TIMEOUT (1000)
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// Constructor for CViZAMemory
|
|
//---------------------------------------------------------------------------
|
|
CZiVA::CZiVAMemory::CZiVAMemory(void):Address(0),m_ziva(NULL)
|
|
{
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::Init
|
|
//---------------------------------------------------------------------------
|
|
void CZiVA::CZiVAMemory::Init( CZiVA *pziva, DWORD addr )
|
|
{
|
|
Address = addr;
|
|
m_ziva = pziva;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::Get
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::CZiVAMemory::Get( DWORD *pData )
|
|
{
|
|
ASSERT( m_ziva != NULL );
|
|
#ifdef ZIVA_DEBUG
|
|
DBG_PRINTF( ("CZiVAMemory::Get Addr = 0x%x\n", Address ) );
|
|
#endif
|
|
return m_ziva->ZiVAReadMemory( Address, pData );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::Set
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::CZiVAMemory::Set( DWORD Data )
|
|
{
|
|
ASSERT( m_ziva != NULL );
|
|
#ifdef ZIVA_DEBUG
|
|
DBG_PRINTF( ("CZiVAMemory::Set Addr = 0x%x Data = 0x%x\n", Address, Data) );
|
|
#endif
|
|
return m_ziva->ZiVAWriteMemory( Address, Data );
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::GetAndSet
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::CZiVAMemory::GetAndSet( DWORD Mask, DWORD Data )
|
|
{
|
|
ASSERT( m_ziva != NULL );
|
|
DWORD GetData = 0;
|
|
m_ziva->ZiVAReadMemory( Address, &GetData );
|
|
GetData = GetData & Mask;
|
|
GetData = GetData | Data;
|
|
#ifdef ZIVA_DEBUG
|
|
// DBG_PRINTF( ("CZiVAMemory::GetAndSet Addr = 0x%x Mask = 0x%x Data = 0x%x WriteData = 0x%x \n", Address, Mask, Data,GetData ) );
|
|
#endif
|
|
return m_ziva->ZiVAWriteMemory( Address, GetData );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::operator&=
|
|
//---------------------------------------------------------------------------
|
|
CZiVA::CZiVAMemory& CZiVA::CZiVAMemory::operator&=(const DWORD &Data )
|
|
{
|
|
ASSERT( m_ziva != NULL );
|
|
DWORD GetData = 0;
|
|
m_ziva->ZiVAReadMemory( Address, &GetData );
|
|
GetData = GetData & Data;
|
|
#ifdef ZIVA_DEBUG
|
|
// DBG_PRINTF( ("CZiVAMemory::operator &= Addr = 0x%x Data = 0x%x WriteData = 0x%x \n", Address, Data,GetData ) );
|
|
#endif
|
|
m_ziva->ZiVAWriteMemory( Address, GetData );
|
|
return *this;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVAMemory::operator|=
|
|
//---------------------------------------------------------------------------
|
|
CZiVA::CZiVAMemory& CZiVA::CZiVAMemory::operator|=(const DWORD &Data )
|
|
{
|
|
ASSERT( m_ziva != NULL );
|
|
DWORD GetData = 0;
|
|
m_ziva->ZiVAReadMemory( Address, &GetData );
|
|
GetData = GetData | Data;
|
|
#ifdef ZIVA_DEBUG
|
|
// DBG_PRINTF( ("CZiVAMemory::operator |= Addr = 0x%x Data = 0x%x WriteData = 0x%x \n", Address, Data,GetData ) );
|
|
#endif
|
|
m_ziva->ZiVAWriteMemory( Address, GetData );
|
|
return *this;
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA constructor
|
|
//---------------------------------------------------------------------------
|
|
CZiVA::CZiVA( void ): m_pioif(NULL),m_pKernelObj( NULL )
|
|
{
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVAWriteMemory
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAWriteMemory( DWORD Addr, DWORD Data )
|
|
{
|
|
ASSERT( m_pKernelObj != NULL );
|
|
ASSERT( m_pioif != NULL );
|
|
|
|
m_pKernelObj->DisableHwInt();
|
|
|
|
#ifdef ZIVA_DEBUG
|
|
// DBG_PRINTF(( "ZiVAWriteMemory Addr = 0x%x Data = 0x%x\n", Addr,Data ));
|
|
#endif
|
|
|
|
// set auto increment off
|
|
m_pioif->zivaio.HIO[7] &= (BYTE)(~0x08);
|
|
|
|
m_pioif->zivaio.HIO[4] = (BYTE)( Addr & 0xff );
|
|
m_pioif->zivaio.HIO[5] = (BYTE)( ( Addr >> 8 ) & 0xff );
|
|
m_pioif->zivaio.HIO[6] = (BYTE)( ( Addr >> 16 ) & 0xff );
|
|
|
|
m_pioif->zivaio.HIO[3] = (BYTE)( (Data >> 24 ) & 0xff );
|
|
m_pioif->zivaio.HIO[2] = (BYTE)( (Data >> 16 ) & 0xff );
|
|
m_pioif->zivaio.HIO[1] = (BYTE)( (Data >> 8 ) & 0xff );
|
|
m_pioif->zivaio.HIO[0] = (BYTE)( Data & 0xff );
|
|
|
|
m_pKernelObj->EnableHwInt();
|
|
return 0;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVAReadMemory
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAReadMemory( DWORD Addr, DWORD *Data )
|
|
{
|
|
ASSERT( m_pioif != NULL );
|
|
ASSERT( m_pKernelObj != NULL );
|
|
|
|
m_pKernelObj->DisableHwInt();
|
|
|
|
DWORD rcData = 0;
|
|
|
|
// set auto increment off
|
|
m_pioif->zivaio.HIO[7] &= (BYTE)(~0x08);
|
|
|
|
m_pioif->zivaio.HIO[4] = (BYTE)( Addr & 0xff );
|
|
m_pioif->zivaio.HIO[5] = (BYTE)( ( Addr >> 8 ) & 0xff );
|
|
m_pioif->zivaio.HIO[6] = (BYTE)( ( Addr >> 16 ) & 0xff );
|
|
|
|
rcData = (BYTE)m_pioif->zivaio.HIO[3]; rcData = rcData << 8;
|
|
rcData += (BYTE)m_pioif->zivaio.HIO[2]; rcData = rcData << 8;
|
|
rcData += (BYTE)m_pioif->zivaio.HIO[1]; rcData = rcData << 8;
|
|
rcData += (BYTE)m_pioif->zivaio.HIO[0];
|
|
|
|
*Data = rcData;
|
|
|
|
#ifdef ZIVA_DEBUG
|
|
DBG_PRINTF(( "ZiVAReadMemory Addr = 0x%x Ret = 0x%x\n", Addr, *Data ));
|
|
#endif
|
|
|
|
m_pKernelObj->EnableHwInt();
|
|
return 0;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Init
|
|
//---------------------------------------------------------------------------
|
|
void CZiVA::Init( IKernelService *pKernelObj, CIOIF *pioif )
|
|
{
|
|
m_pioif = pioif;
|
|
m_pKernelObj = pKernelObj;
|
|
|
|
Host_Control.Init( this , 0x00 | 0x800000 );
|
|
|
|
ROM_INFO.Init( this, ADDR_ROM_INFO );
|
|
DRAM_INFO.Init( this, ADDR_DRAM_INFO );
|
|
UCODE_MEMORY.Init( this, ADDR_UCODE_MEMORY );
|
|
VIDEO_MODE.Init( this, ADDR_VIDEO_MODE );
|
|
DISPLAY_ASPECT_RATIO.Init( this, ADDR_DISPLAY_ASPECT_RATIO );
|
|
ASPECT_RATIO_MODE.Init( this, ADDR_ASPECT_RATIO_MODE );
|
|
PAN_SCAN_SOURCE.Init( this, ADDR_PAN_SCAN_SOURCE );
|
|
PAN_SCAN_HORIZONTAL_OFFSET.Init( this, ADDR_PAN_SCAN_HORIZONTAL_OFFSET );
|
|
TOP_BORDER.Init( this, ADDR_TOP_BORDER );
|
|
BORDER_COLOR.Init( this, ADDR_BORDER_COLOR );
|
|
BACKGROUND_COLOR.Init( this, ADDR_BACKGROUND_COLOR );
|
|
OSD_EVEN_FIELD.Init( this, ADDR_OSD_EVEN_FIELD );
|
|
OSD_ODD_FIELD.Init( this, ADDR_OSD_ODD_FIELD );
|
|
IC_TYPE.Init( this, ADDR_IC_TYPE );
|
|
ERR_CONCEALMENT_LEVEL.Init( this, ADDR_ERR_CONCEALMENT_LEVEL );
|
|
ERR_HORIZONTAL_SIZE.Init( this, ADDR_ERR_HORIZONTAL_SIZE );
|
|
ERR_VERTICAL_SIZE.Init( this, ADDR_ERR_VERTICAL_SIZE );
|
|
ERR_ASPECT_RATIO_INFORMATION.Init( this, ADDR_ERR_ASPECT_RATIO_INFORMATION );
|
|
ERR_FRAME_RATE_CODE.Init( this, ADDR_ERR_FRAME_RATE_CODE );
|
|
FORCE_CODED_ASPECT_RATIO.Init( this, ADDR_FORCE_CODED_ASPECT_RATIO );
|
|
AUDIO_CONFIG.Init( this, ADDR_AUDIO_CONFIG );
|
|
AUDIO_DAC_MODE.Init( this, ADDR_AUDIO_DAC_MODE );
|
|
AUDIO_CLOCK_SELECTION.Init( this, ADDR_AUDIO_CLOCK_SELECTION );
|
|
IEC_958_DELAY.Init( this, ADDR_IEC_958_DELAY );
|
|
AUDIO_ATTENUATION.Init( this, ADDR_AUDIO_ATTENUATION );
|
|
IEC_958_CHANNEL_STATUS_BITS.Init( this, ADDR_IEC_958_CHANNEL_STATUS_BITS );
|
|
AC3_OUTPUT_MODE.Init( this, ADDR_AC3_OUTPUT_MODE );
|
|
AC3_OPERATIONAL_MODE.Init( this, ADDR_AC3_OPERATIONAL_MODE );
|
|
AC3_LOW_BOOST.Init( this, ADDR_AC3_LOW_BOOST );
|
|
AC3_HIGH_CUT.Init( this, ADDR_AC3_HIGH_CUT );
|
|
AC3_PCM_SCALE_FACTOR.Init( this, ADDR_AC3_PCM_SCALE_FACTOR );
|
|
AC3_LFE_OUTPUT_ENABLE.Init( this, ADDR_AC3_LFE_OUTPUT_ENABLE );
|
|
AC3_VOICE_SELECT.Init( this, ADDR_AC3_VOICE_SELECT );
|
|
AC3_L_LEVEL.Init( this, ADDR_AC3_L_LEVEL );
|
|
AC3_C_LEVEL.Init( this, ADDR_AC3_C_LEVEL );
|
|
AC3_R_LEVEL.Init( this, ADDR_AC3_R_LEVEL );
|
|
AC3_SL_LEVEL.Init( this, ADDR_AC3_SL_LEVEL );
|
|
AC3_SR_LEVEL.Init( this, ADDR_AC3_SR_LEVEL );
|
|
AC3_CENTER_DELAY.Init( this, ADDR_AC3_CENTER_DELAY );
|
|
AC3_SURROUND_DELAY.Init( this, ADDR_AC3_SURROUND_DELAY );
|
|
BITSTREAM_TYPE.Init( this, ADDR_BITSTREAM_TYPE );
|
|
BITSTREAM_SOURCE.Init( this, ADDR_BITSTREAM_SOURCE );
|
|
SD_MODE.Init( this, ADDR_SD_MODE );
|
|
CD_MODE.Init( this, ADDR_CD_MODE );
|
|
AV_SYNC_MODE.Init( this, ADDR_AV_SYNC_MODE );
|
|
VIDEO_PTS_SKIP_INTERVAL.Init( this, ADDR_VIDEO_PTS_SKIP_INTERVAL );
|
|
VIDEO_PTS_REPEAT_INTERVAL.Init( this, ADDR_VIDEO_PTS_REPEAT_INTERVAL );
|
|
AUTOPAUSE_ENABLE.Init( this, ADDR_AUTOPAUSE_ENABLE );
|
|
VIDEO_ENV_CHANGE.Init( this, ADDR_VIDEO_ENV_CHANGE );
|
|
MEMCOPY_XFER_BLOCKSIZE.Init( this, ADDR_MEMCOPY_XFER_BLOCKSIZE );
|
|
INT_MASK.Init( this, ADDR_INT_MASK );
|
|
AUTO_FLUSH_INTERVAL.Init( this, ADDR_AUTO_FLUSH_INTERVAL );
|
|
RDY_S_THRESHOLD_LOW.Init( this, ADDR_RDY_S_THRESHOLD_LOW );
|
|
MEMORY_MAP.Init( this, ADDR_MEMORY_MAP );
|
|
PCI_BUFFER_START.Init( this, ADDR_PCI_BUFFER_START );
|
|
PCI_BUFFER_END.Init( this, ADDR_PCI_BUFFER_END );
|
|
DSI_BUFFER_START.Init( this, ADDR_DSI_BUFFER_START );
|
|
DSI_BUFFER_END.Init( this, ADDR_DSI_BUFFER_END );
|
|
OSD_BUFFER_START.Init( this, ADDR_OSD_BUFFER_START );
|
|
OSD_BUFFER_END.Init( this, ADDR_OSD_BUFFER_END );
|
|
OSD_BUFFER_IDLE_START.Init( this, ADDR_OSD_BUFFER_IDLE_START );
|
|
USER_DATA_BUFFER_START.Init( this, ADDR_USER_DATA_BUFFER_START );
|
|
USER_DATA_BUFFER_END.Init( this, ADDR_USER_DATA_BUFFER_END );
|
|
USER_DATA_READ.Init( this, ADDR_USER_DATA_READ );
|
|
USER_DATA_WRITE.Init( this, ADDR_USER_DATA_WRITE );
|
|
DUMP_DATA_BUFFER_START.Init( this, ADDR_DUMP_DATA_BUFFER_START );
|
|
DUMP_DATA_BUFFER_END.Init( this, ADDR_DUMP_DATA_BUFFER_END );
|
|
SUB_PICTURE_PALETTE_START.Init( this, ADDR_SUB_PICTURE_PALETTE_START );
|
|
SUB_PICTURE_PALETTE_END.Init( this, ADDR_SUB_PICTURE_PALETTE_END );
|
|
PROC_STATE.Init( this, ADDR_PROC_STATE );
|
|
MRC_ID.Init( this, ADDR_MRC_ID );
|
|
MRC_STATUS.Init( this, ADDR_MRC_STATUS );
|
|
INT_STATUS.Init( this, ADDR_INT_STATUS );
|
|
HLI_INT_SRC.Init( this, ADDR_HLI_INT_SRC );
|
|
BUFF_INT_SRC.Init( this, ADDR_BUFF_INT_SRC );
|
|
UND_INT_SRC.Init( this, ADDR_UND_INT_SRC );
|
|
PBT_INT_SRC.Init( this, ADDR_PBT_INT_SRC );
|
|
AOR_INT_SRC.Init( this, ADDR_AOR_INT_SRC );
|
|
AEE_INT_SRC.Init( this, ADDR_AEE_INT_SRC );
|
|
ERR_INT_SRC.Init( this, ADDR_ERR_INT_SRC );
|
|
VIDEO_EMPTINESS.Init( this, ADDR_VIDEO_EMPTINESS );
|
|
AUDIO_EMPTINESS.Init( this, ADDR_AUDIO_EMPTINESS );
|
|
CURR_PIC_DISPLAYED.Init( this, ADDR_CURR_PIC_DISPLAYED );
|
|
NEXT_PIC_DISPLAYED.Init( this, ADDR_NEXT_PIC_DISPLAYED );
|
|
VIDEO_FIELD.Init( this, ADDR_VIDEO_FIELD );
|
|
OSD_VALID.Init( this, ADDR_OSD_VALID );
|
|
NUM_DECODED.Init( this, ADDR_NUM_DECODED );
|
|
NUM_SKIPPED.Init( this, ADDR_NUM_SKIPPED );
|
|
NUM_REPEATED.Init( this, ADDR_NUM_REPEATED );
|
|
MRC_PIC_PTS.Init( this, ADDR_MRC_PIC_PTS );
|
|
MRC_PIC_STC.Init( this, ADDR_MRC_PIC_STC );
|
|
N_AUD_DECODED.Init( this, ADDR_N_AUD_DECODED );
|
|
NEXT_SECTOR_ADDR.Init( this, ADDR_NEXT_SECTOR_ADDR );
|
|
N_SYS_ERRORS.Init( this, ADDR_N_SYS_ERRORS );
|
|
N_VID_ERRORS.Init( this, ADDR_N_VID_ERRORS );
|
|
N_AUD_ERRORS.Init( this, ADDR_N_AUD_ERRORS );
|
|
DATE_TIME.Init( this, ADDR_DATE_TIME );
|
|
VERSION.Init( this, ADDR_VERSION );
|
|
EXTENDED_VERSION.Init( this, ADDR_EXTENDED_VERSION );
|
|
PIC1_BUFFER_START.Init( this, ADDR_PIC1_BUFFER_START );
|
|
PIC1_PTS.Init( this, ADDR_PIC1_PTS );
|
|
PIC1_PAN_SCAN.Init( this, ADDR_PIC1_PAN_SCAN );
|
|
PIC1_USER_DATA.Init( this, ADDR_PIC1_USER_DATA );
|
|
PIC1_TREF_PTYP_FLGS.Init( this, ADDR_PIC1_TREF_PTYP_FLGS );
|
|
PIC2_BUFFER_START.Init( this, ADDR_PIC2_BUFFER_START );
|
|
PIC2_PTS.Init( this, ADDR_PIC2_PTS );
|
|
PIC2_PAN_SCAN.Init( this, ADDR_PIC2_PAN_SCAN );
|
|
PIC2_USER_DATA.Init( this, ADDR_PIC2_USER_DATA );
|
|
PIC2_TREF_PTYP_FLGS.Init( this, ADDR_PIC2_TREF_PTYP_FLGS );
|
|
PIC3_BUFFER_START.Init( this, ADDR_PIC3_BUFFER_START );
|
|
PIC3_PTS.Init( this, ADDR_PIC3_PTS );
|
|
PIC3_PAN_SCAN.Init( this, ADDR_PIC3_PAN_SCAN );
|
|
PIC3_USER_DATA.Init( this, ADDR_PIC3_USER_DATA );
|
|
PIC3_TREF_PTYP_FLGS.Init( this, ADDR_PIC3_TREF_PTYP_FLGS );
|
|
STREAM_ID.Init( this, ADDR_STREAM_ID );
|
|
PACKET_LEN.Init( this, ADDR_PACKET_LEN );
|
|
PES_HEADER.Init( this, ADDR_PES_HEADER );
|
|
SUBPIC_EMPTINESS.Init( this, ADDR_SUBPIC_EMPTINESS );
|
|
H_SIZE.Init( this, ADDR_H_SIZE );
|
|
V_SIZE.Init( this, ADDR_V_SIZE );
|
|
APSECT_RATIO.Init( this, ADDR_APSECT_RATIO );
|
|
FRAME_RATE.Init( this, ADDR_FRAME_RATE );
|
|
BIT_RATE.Init( this, ADDR_BIT_RATE );
|
|
VBV_SIZE.Init( this, ADDR_VBV_SIZE );
|
|
SEQ_FLAGS.Init( this, ADDR_SEQ_FLAGS );
|
|
DISP_SIZE_H_V.Init( this, ADDR_DISP_SIZE_H_V );
|
|
TIME_CODE.Init( this, ADDR_TIME_CODE );
|
|
GOP_FLAGS.Init( this, ADDR_GOP_FLAGS );
|
|
TEMP_REF.Init( this, ADDR_TEMP_REF );
|
|
PIC_TYPE.Init( this, ADDR_PIC_TYPE );
|
|
VBV_DELAY.Init( this, ADDR_VBV_DELAY );
|
|
PIC_HEADER.Init( this, ADDR_PIC_HEADER );
|
|
AUDIO_TYPE.Init( this, ADDR_AUDIO_TYPE );
|
|
MPEG_AUDIO_HEADER1.Init( this, ADDR_MPEG_AUDIO_HEADER1 );
|
|
AC3_FRAME_NUMBER.Init( this, ADDR_AC3_FRAME_NUMBER );
|
|
LPCM_AUDIO_EMPHASIS_FLAG.Init( this, ADDR_LPCM_AUDIO_EMPHASIS_FLAG );
|
|
MPEG_AUDIO_HEADER2.Init( this, ADDR_MPEG_AUDIO_HEADER2 );
|
|
LPCM_AUDIO_MUTE_FLAG.Init( this, ADDR_LPCM_AUDIO_MUTE_FLAG );
|
|
AC3_BSI_IS_BEING_READ.Init( this, ADDR_AC3_BSI_IS_BEING_READ );
|
|
LPCM_AUDIO_FRAME_NUMBER.Init( this, ADDR_LPCM_AUDIO_FRAME_NUMBER );
|
|
AC3_BSI_VALID.Init( this, ADDR_AC3_BSI_VALID );
|
|
LPCM_AUDIO_QUANTIZATION_WORD_LENGTH.Init( this, ADDR_LPCM_AUDIO_QUANTIZATION_WORD_LENGTH );
|
|
AC3_BSI_FRAME.Init( this, ADDR_AC3_BSI_FRAME );
|
|
LPCM_AUDIO_SAMPLING_FREQUENCY.Init( this, ADDR_LPCM_AUDIO_SAMPLING_FREQUENCY );
|
|
AC3_FSCOD_FRMSIZECOD.Init( this, ADDR_AC3_FSCOD_FRMSIZECOD );
|
|
LPCM_AUDIO_NUMBER_OF_AUDIO_CHANNELS.Init( this, ADDR_LPCM_AUDIO_NUMBER_OF_AUDIO_CHANNELS );
|
|
AC3_BSID_BSMOD.Init( this, ADDR_AC3_BSID_BSMOD );
|
|
LPCM_AUDIO_DYNAMIC_RANGE_CONTROL.Init( this, ADDR_LPCM_AUDIO_DYNAMIC_RANGE_CONTROL );
|
|
AC3_ACMOD_CMIXLEV.Init( this, ADDR_AC3_ACMOD_CMIXLEV );
|
|
AC3_SURMIXLEV_DSURMOD.Init( this, ADDR_AC3_SURMIXLEV_DSURMOD );
|
|
AC3_LFEON_DIALNORM.Init( this, ADDR_AC3_LFEON_DIALNORM );
|
|
AC3_COMPR_LANGCOD.Init( this, ADDR_AC3_COMPR_LANGCOD );
|
|
AC3_MIXLEV_ROOMTYP.Init( this, ADDR_AC3_MIXLEV_ROOMTYP );
|
|
AC3_DIALNORM2_COMPR2.Init( this, ADDR_AC3_DIALNORM2_COMPR2 );
|
|
AC3_LANGCOD2_MIXLEV2.Init( this, ADDR_AC3_LANGCOD2_MIXLEV2 );
|
|
AC3_ROOMTYP2_COPYRIGHTB.Init( this, ADDR_AC3_ROOMTYP2_COPYRIGHTB );
|
|
AC3_ORIGBS_TIMECOD1.Init( this, ADDR_AC3_ORIGBS_TIMECOD1 );
|
|
// AC3_TIMECOD2.Init( this, ADDR_AC3_TIMECOD2 ); // 98.04.02 H.Yagi
|
|
AC3_TIMECOD2.Init( this, ADDR_AC3_TIMECOD2_EBITS ); // 98.04.02 H.Yagi
|
|
SE_STATUS.Init( this, ADDR_SE_STATUS );
|
|
NEW_AUDIO_MODE.Init( this, ADDR_NEW_AUDIO_MODE );
|
|
NEW_SUBPICTURE_PALETTE.Init( this, ADDR_NEW_SUBPICTURE_PALETTE );
|
|
NEW_AUDIO_CONFIG.Init( this, ADDR_NEW_AUDIO_CONFIG );
|
|
VSYNC_HEARTBEAT.Init( this, ADDR_VSYNC_HEARTBEAT );
|
|
ML_HEARTBEAT.Init( this, ADDR_ML_HEARTBEAT );
|
|
SUBPICTURE_ENABLE.Init( this, ADDR_SUBPICTURE_ENABLE );
|
|
HIGHLIGHT_ENABLE.Init( this, ADDR_HIGHLIGHT_ENABLE );
|
|
CURRENT_BUTTON.Init( this, ADDR_CURRENT_BUTTON );
|
|
|
|
ERR_MPEG_VERSION.Init( this, ADDR_ERR_MPEG_VERSION ); // 98.04.02 H.Yagi
|
|
VERTICAL_DISPLAYMODE.Init( this, ADDR_VERTICAL_DISPLAYMODE ); // 98.04.02 H.Yagi
|
|
AC3_ENGINE_VERSION.Init( this, ADDR_AC3_ENGINE_VERSION ); // 98.04.02 H.Yagi
|
|
ROM_END_POINTER.Init( this, ADDR_ROM_END_POINTER ); // 98.04.02 H.Yagi
|
|
CURRENT_VOB_CELL_ID.Init( this, ADDR_CURRENT_VOB_CELL_ID ); // 98.04.02 H.Yagi
|
|
PREV_VOBU_VIDEO_RLBN.Init( this, ADDR_PREV_VOBU_VIDEO_RLBN ); // 98.04.02 H.Yagi
|
|
|
|
|
|
// Authentication for only ZiVA1.1 or later // Yagi
|
|
KEY_ADDRESS.Init( this, 0x480 );
|
|
KEY_LENGTH.Init( this, 0x484 );
|
|
|
|
// toshiba special
|
|
AU_CLK_INOUT.Init( this, 0xf8 );
|
|
IDLE_DELAY.Init( this, ADDR_IDLE_DELAY );
|
|
|
|
// 98.05.29 H.Yagi
|
|
HOST_OPTIONS.Init( this, ADDR_HOST_OPTIONS );
|
|
};
|
|
|
|
|
|
|
|
void CZiVA::CppInit( DWORD gKeyAddress )
|
|
{
|
|
KEY_COMMAND.Init( this, gKeyAddress );
|
|
KEY_STATUS.Init( this, gKeyAddress+1*4 );
|
|
DRIVE_CHALLENGE_0.Init( this, gKeyAddress+2*4 );
|
|
DRIVE_CHALLENGE_1.Init( this, gKeyAddress+3*4 );
|
|
DRIVE_CHALLENGE_2.Init( this, gKeyAddress+4*4 );
|
|
DRIVE_CHALLENGE_3.Init( this, gKeyAddress+5*4 );
|
|
DRIVE_CHALLENGE_4.Init( this, gKeyAddress+6*4 );
|
|
DRIVE_CHALLENGE_5.Init( this, gKeyAddress+7*4 );
|
|
DRIVE_CHALLENGE_6.Init( this, gKeyAddress+8*4 );
|
|
DRIVE_CHALLENGE_7.Init( this, gKeyAddress+9*4 );
|
|
DRIVE_CHALLENGE_8.Init( this, gKeyAddress+10*4 );
|
|
DRIVE_CHALLENGE_9.Init( this, gKeyAddress+11*4 );
|
|
DECODER_CHALLENGE_0.Init( this, gKeyAddress+12*4 );
|
|
DECODER_CHALLENGE_1.Init( this, gKeyAddress+13*4 );
|
|
DECODER_CHALLENGE_2.Init( this, gKeyAddress+14*4 );
|
|
DECODER_CHALLENGE_3.Init( this, gKeyAddress+15*4 );
|
|
DECODER_CHALLENGE_4.Init( this, gKeyAddress+16*4 );
|
|
DECODER_CHALLENGE_5.Init( this, gKeyAddress+17*4 );
|
|
DECODER_CHALLENGE_6.Init( this, gKeyAddress+18*4 );
|
|
DECODER_CHALLENGE_7.Init( this, gKeyAddress+19*4 );
|
|
DECODER_CHALLENGE_8.Init( this, gKeyAddress+20*4 );
|
|
DECODER_CHALLENGE_9.Init( this, gKeyAddress+21*4 );
|
|
DRIVE_RESULT_0.Init( this, gKeyAddress+22*4 );
|
|
DRIVE_RESULT_1.Init( this, gKeyAddress+23*4 );
|
|
DRIVE_RESULT_2.Init( this, gKeyAddress+24*4 );
|
|
DRIVE_RESULT_3.Init( this, gKeyAddress+25*4 );
|
|
DRIVE_RESULT_4.Init( this, gKeyAddress+26*4 );
|
|
DECODER_RESULT_0.Init( this, gKeyAddress+27*4 );
|
|
DECODER_RESULT_1.Init( this, gKeyAddress+28*4 );
|
|
DECODER_RESULT_2.Init( this, gKeyAddress+29*4 );
|
|
DECODER_RESULT_3.Init( this, gKeyAddress+30*4 );
|
|
DECODER_RESULT_4.Init( this, gKeyAddress+31*4 );
|
|
TITLE_KEY_0.Init( this, gKeyAddress+32*4 );
|
|
TITLE_KEY_1.Init( this, gKeyAddress+33*4 );
|
|
TITLE_KEY_2.Init( this, gKeyAddress+34*4 );
|
|
TITLE_KEY_3.Init( this, gKeyAddress+35*4 );
|
|
TITLE_KEY_4.Init( this, gKeyAddress+36*4 );
|
|
};
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVACommand
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::ZiVACommand( DWORD CommandID, DWORD d1, DWORD d2, DWORD d3, DWORD d4, DWORD d5, DWORD d6 )
|
|
{
|
|
ASSERT( m_pioif != NULL );
|
|
|
|
DWORD StatusPointer = 0;
|
|
DWORD ZiVAStatus = 0;
|
|
|
|
CTimeOut TimeOut( COMMAND_TIMEOUT, 1 , m_pKernelObj );
|
|
|
|
// status pointer check?
|
|
while( TRUE )
|
|
{
|
|
ZiVAReadMemory(ADDR_STATUS_ADDRESS, &StatusPointer);
|
|
if( StatusPointer != 0 )
|
|
{
|
|
ZiVAReadMemory( StatusPointer, &ZiVAStatus );
|
|
// DBG_PRINTF( ("ZiVA Status = 0x%x\n", ZiVAStatus ));
|
|
break;
|
|
};
|
|
// Sleep
|
|
TimeOut.Sleep();
|
|
|
|
// check Time out....... 1 sec
|
|
if( TimeOut.CheckTimeOut() == TRUE )
|
|
return ZIVARESULT_TIMEOUT;
|
|
};
|
|
|
|
m_pKernelObj->DisableHwInt();
|
|
|
|
ZiVAWriteMemory( ADDR_COMMAND, CommandID );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_1, d1 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_2, d2 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_3, d3 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_4, d4 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_5, d5 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_6, d6 );
|
|
ZiVAWriteMemory( ADDR_STATUS_ADDRESS, 0x00 ); // zero the status pointer
|
|
|
|
// interrupt
|
|
// Host_Control |= 0x10C2;
|
|
|
|
m_pKernelObj->EnableHwInt();
|
|
|
|
CTimeOut TimeOut2( COMMAND_TIMEOUT, 1, m_pKernelObj );
|
|
|
|
// status pointer check?
|
|
while( TRUE )
|
|
{
|
|
ZiVAReadMemory(ADDR_STATUS_ADDRESS, &StatusPointer);
|
|
if( StatusPointer != 0 )
|
|
{
|
|
ZiVAReadMemory( StatusPointer, &ZiVAStatus );
|
|
DBG_PRINTF( ("ZiVA Status = 0x%x\n", ZiVAStatus ));
|
|
break;
|
|
};
|
|
// Sleep
|
|
TimeOut2.Sleep();
|
|
|
|
// check Time out....... 1 sec
|
|
if( TimeOut2.CheckTimeOut() == TRUE )
|
|
return ZIVARESULT_TIMEOUT;
|
|
};
|
|
|
|
|
|
return ZIVARESULT_NOERROR;
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVACommandNoWait
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::ZiVACommandNoWait( DWORD CommandID, DWORD d1, DWORD d2, DWORD d3, DWORD d4, DWORD d5, DWORD d6 )
|
|
{
|
|
ASSERT( m_pioif != NULL );
|
|
|
|
DWORD StatusPointer = 0;
|
|
// DWORD ZiVAStatus = 0;
|
|
|
|
// status pointer check?
|
|
|
|
ZiVAReadMemory(ADDR_STATUS_ADDRESS, &StatusPointer);
|
|
if( StatusPointer == 0 )
|
|
return ZIVARESULT_TIMEOUT;
|
|
|
|
m_pKernelObj->DisableHwInt();
|
|
|
|
ZiVAWriteMemory( ADDR_COMMAND, CommandID );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_1, d1 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_2, d2 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_3, d3 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_4, d4 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_5, d5 );
|
|
ZiVAWriteMemory( ADDR_PARAMETER_6, d6 );
|
|
ZiVAWriteMemory( ADDR_STATUS_ADDRESS, 0x00 ); // zero the status pointer
|
|
|
|
// interrupt
|
|
// Host_Control |= 0x10C2;
|
|
|
|
m_pKernelObj->EnableHwInt();
|
|
|
|
ZiVAReadMemory(ADDR_STATUS_ADDRESS, &StatusPointer);
|
|
if( StatusPointer == 0 )
|
|
return ZIVARESULT_TIMEOUT;
|
|
|
|
return ZIVARESULT_NOERROR;
|
|
};
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Abort
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Abort( DWORD Flush )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Abort 0x%x\n",Flush ));
|
|
#endif
|
|
return ZiVACommand( ABORT , Flush );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Digest
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Digest( DWORD x, DWORD y, DWORD decimation, DWORD threshold, DWORD start )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Digest 0x%x, 0x%x, 0x%x, 0x%x, 0x%x\n", x, y, decimation, threshold, start ));
|
|
#endif
|
|
return ZiVACommand( DIGEST , x, y, decimation, threshold, start );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::DumpDumpData_VCD
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::DumpData_VCD( DWORD start, DWORD length, DWORD address )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::DumpData_VCD 0x%x, 0x%x, 0x%x\n", start, length, address ));
|
|
#endif
|
|
return ZiVACommand( DUMPDATA_VCD , start, length, address );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::DumpData_DVD
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::DumpData_DVD( DWORD numberOfBytes )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( (" CZiVA::DumpData_DVD 0x%x\n", numberOfBytes ));
|
|
#endif
|
|
return ZiVACommand( DUMPDATA_DVD , numberOfBytes );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Fade
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Fade( DWORD level, DWORD fadetime )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Fade 0x%x, 0x%x\n", level, fadetime ));
|
|
#endif
|
|
return ZiVACommand( FADE , level, fadetime );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Freeze
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Freeze( DWORD displayMode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Freeze 0x%x\n", displayMode ));
|
|
#endif
|
|
return ZiVACommand( FREEZE , displayMode );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::HighLight
|
|
//---------------------------------------------------------------------------
|
|
// by oka
|
|
ZIVARESULT CZiVA::HighLight( DWORD button, DWORD action )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::HighLight 0x%x, 0x%x, 0x%x\n", button, group, action ));
|
|
#endif
|
|
// by oka
|
|
return ZiVACommand( HIGHLIGHT , button, action );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::HighLight2
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::HighLight2( DWORD Contrast, DWORD Color, DWORD YGeom, DWORD XGeom )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::HighLight2 0x%x, 0x%x, 0x%x, 0x%x\n", Contrast, Color, YGeom, XGeom ));
|
|
#endif
|
|
return ZiVACommand( HIGHLIGHT2,Contrast, Color, YGeom, XGeom );
|
|
};
|
|
|
|
/*
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::NewAudioMode
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::NewAudioMode( void )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::NewAudioMode\n" ));
|
|
#endif
|
|
return ZiVACommand( 0x0027 );
|
|
};
|
|
*/
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::NewPlayMode
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::NewPlayMode( void )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::NewPlayMode\n" ));
|
|
#endif
|
|
return ZiVACommand( NEWPLAYMODE );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Pause
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Pause( DWORD displaymode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Pause 0x%x\n" , displaymode ));
|
|
#endif
|
|
return ZiVACommand( PAUSE , displaymode );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Play
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Play( DWORD playmode, DWORD fadetime, DWORD start, DWORD stop )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Play 0x%x, 0x%x, 0x%x, 0x%x\n" , playmode, fadetime, start, stop ));
|
|
#endif
|
|
return ZiVACommand( PLAY , playmode, fadetime, start, stop );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::MemCopy(ROMtoDRAM)
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::MemCopy( DWORD romAddr, DWORD dramAddr, DWORD Length )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::MemCopy 0x%x, 0x%x, 0x%x\n", romAddr, dramAddr, Length ));
|
|
#endif
|
|
return ZiVACommand( MEMCOPY , romAddr, dramAddr, Length );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Reset
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Reset( void )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Reset\n" ));
|
|
#endif
|
|
return ZiVACommand( RESET );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
//
|
|
//---------------------------------------------------------------------------
|
|
//ZIVARESULT CZiVA::Resume( DWORD playmode )
|
|
//{
|
|
// return ZiVACommand( 0x012e , playmode );
|
|
//};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Resume
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Resume( void )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Resume\n" ));
|
|
#endif
|
|
return ZiVACommand( RESUME );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Scan
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Scan( DWORD skip, DWORD scanmode, DWORD displaymode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Scan 0x%x, 0x%x, 0x%x\n", skip, scanmode, displaymode ));
|
|
#endif
|
|
return ZiVACommand( SCAN , skip, scanmode, displaymode );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ScreenLoad
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::ScreenLoad( DWORD address, DWORD length, DWORD displaymode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::ScreenLoad 0x%x0, 0x%x, 0x%x\n", address, length, displaymode ));
|
|
#endif
|
|
return ZiVACommand( SCREENLOAD , address, length, displaymode );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SelectStream
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SelectStream( DWORD streamtype, DWORD streamnumber )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::SelectStream 0x%x, 0x%x\n", streamtype, streamnumber ));
|
|
#endif
|
|
return ZiVACommand( SELECTSTREAM , streamtype, streamnumber );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SetFill
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SetFill( DWORD x, DWORD y, DWORD length, DWORD height, DWORD color )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::SetFill 0x%x, 0x%x, 0x%x, 0x%x, 0x%x\n", x, y, length, height, color ));
|
|
#endif
|
|
return ZiVACommand( SETFILL , x, y, length, height, color );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SetStreams
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SetStreams( DWORD videoID, DWORD audioID )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::SetStreams 0x%x, 0x%x\n", videoID, audioID ));
|
|
#endif
|
|
return ZiVACommand( SETSTREAMS , videoID, audioID );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SingleStep
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SingleStep( DWORD displaymode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::SingleStep 0x%x\n", displaymode ));
|
|
#endif
|
|
return ZiVACommand( SINGLESTEP , displaymode );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SlowMotion
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SlowMotion( DWORD N, DWORD displaymode )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::SlowMotion 0x%x, 0x%x\n", N, displaymode ));
|
|
#endif
|
|
return ZiVACommand( SLOWMOTION , N, displaymode );
|
|
};
|
|
|
|
// by oka
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::Magnify
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::Magnify( DWORD x, DWORD y, DWORD factor )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( ("CZiVA::Magnify 0x%x, 0x%x\n", x,y,factor ));
|
|
#endif
|
|
return ZiVACommand( MAGNIFY , x, y, factor );
|
|
};
|
|
/*
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::SwitchOSDBuffer
|
|
//---------------------------------------------------------------------------
|
|
ZIVARESULT CZiVA::SwitchOSDBuffer( DWORD evenfield, DWORD oddfield )
|
|
{
|
|
return ZiVACommand( 0x8254 , evenfield, oddfield );
|
|
}
|
|
*/
|
|
|
|
ZIVARESULT CZiVA::TransferKey( DWORD KeyType, DWORD Authenticate )
|
|
{
|
|
#ifdef DEBUG_ZIVA_COMMAND
|
|
DBG_PRINTF( (" CZiVA::TransferKey 0x%x, 0x%x\n", KeyType, Authenticate ));
|
|
#endif
|
|
return ZiVACommand( 0x0137 , KeyType, Authenticate );
|
|
}
|
|
|
|
|
|
//===================================================
|
|
// ZiVA register ACCESS functions.
|
|
//===================================================
|
|
|
|
// CL6100 GBUS map
|
|
#define CF_read1 0x2d
|
|
#define CF_intrpt 0x1c // all the CFIFO registers changed
|
|
#define CF_command 0x1f
|
|
#define CPU_imdt 0x34 // IMEM data register
|
|
#define CPU_imadr 0x36 // IMEM read/write pointer
|
|
#define CPU_index 0x3a // index register for indirect regs
|
|
#define CPU_idxdt 0x3b // data port for indirect regs
|
|
#define HOST_control 0x00
|
|
#define DMA_adr 0x22 // DMA Indirect Index registe
|
|
#define DMA_MODE 0x0f // DMA Mode Setting register
|
|
#define DMA_data 0x23 // DMA Indirect Data register
|
|
#define DMA_CYCLE 0x11 // DMA Cycle register to define rom cycle/size
|
|
#define CPU_PC 0x9 // IMEM instruction pointer register
|
|
#define CPU_DIR 0xA // instruction register
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVAWriteReg
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAWriteReg(DWORD Addr, DWORD Data )
|
|
{
|
|
return ZiVAWriteMemory( Addr | 0x800000 , Data );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::ZiVAReadReg
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAReadReg(DWORD Addr, DWORD *Data )
|
|
{
|
|
return ZiVAReadMemory( Addr | 0x800000 , Data );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// ZiVA::ZiVAWriteIMEM
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAWriteIMEM(DWORD Addr, DWORD Data )
|
|
{
|
|
ZiVAWriteReg( CPU_imadr, Addr );
|
|
return ZiVAWriteReg( CPU_imdt, Data );
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// ZiVA::ZiVAReadIMEM
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::ZiVAReadIMEM(DWORD Addr, DWORD *Data )
|
|
{
|
|
ZiVAWriteReg( CPU_index, 0x0b );
|
|
ZiVAWriteReg( CPU_idxdt, Addr );
|
|
ZiVAWriteReg( CPU_index, 0x0e );
|
|
return ZiVAReadReg( CPU_idxdt , Data );
|
|
};
|
|
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::load_GetDWORD
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::load_GetDWORD()
|
|
{
|
|
DWORD dwResult = gpbRead[0] + (gpbRead[1] << 8) + (gpbRead[2] << 16) + (gpbRead[3] << 24);
|
|
gpbRead += 4;
|
|
return dwResult;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::load_GetDWORDSwap
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::load_GetDWORDSwap()
|
|
{
|
|
DWORD dwResult = gpbRead[3] + (gpbRead[2] << 8) + (gpbRead[1] << 16) + (gpbRead[0] << 24);
|
|
gpbRead += 4;
|
|
return dwResult;
|
|
};
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::load_GetDWORDSwapBackward
|
|
//---------------------------------------------------------------------------
|
|
DWORD CZiVA::load_GetDWORDSwapBackward()
|
|
{
|
|
DWORD dwResult = gpbRead[3] + (gpbRead[2] << 8) + (gpbRead[1] << 16) + (gpbRead[0] << 24);
|
|
gpbRead -= 4;
|
|
return dwResult;
|
|
};
|
|
|
|
|
|
#define IMEM_START_OFFSET 0x800 // byte offset
|
|
#define IMEM_LENGTH 0xFF // in 32-bit words
|
|
#define DRAM_IMAGE_LENGTH 0x7FF // in bytes
|
|
|
|
#define GBUS_TABLE_OFFSET 0xBFC // byte offset
|
|
#define STREAM_SOURCE 0x0 // SD Interface
|
|
|
|
#define SD_MODE 0xD // For SD Interface
|
|
|
|
|
|
|
|
//===================================================
|
|
// ZiVA Microcode Downloading
|
|
//===================================================
|
|
|
|
//---------------------------------------------------------------------------
|
|
// CZiVA::WriteMicrocode
|
|
//---------------------------------------------------------------------------
|
|
// Type 0:NTSC , 1:PAL
|
|
BOOL CZiVA::WriteMicrocode( DWORD Type )
|
|
{
|
|
|
|
DWORD dwSectionLength; // Section length in bytes
|
|
DWORD dwSectionAddress; // Start address in DRAM (WORD address)
|
|
DWORD dwSectionChecksum; // Section check sum value
|
|
DWORD dwCnt; // Counter of the bytes written to the DVD chip
|
|
DWORD dwAddress; // Current DRAM address (byte address)
|
|
BYTE * pbUCodeStart; // Sarting point of the UCode in the buffer (file)
|
|
BYTE * pbFinalGBUSStart; // Sarting point of the final GBUS writes.
|
|
DWORD dwTmp;
|
|
BYTE TmpTmp;
|
|
|
|
gpbRead = UXData; // Set pointer to the beginning of the buffer
|
|
|
|
// I-MODE SETING!!!
|
|
TmpTmp = m_pioif->zivaio.HIO[7];
|
|
|
|
|
|
// A. Skip the initial header of the file (12 bytes)
|
|
gpbRead += 12;
|
|
|
|
// B. Skip data_type, section flags and unused (4 bytes)
|
|
gpbRead += 4;
|
|
|
|
dwSectionLength = load_GetDWORD();
|
|
dwSectionAddress = load_GetDWORD();
|
|
dwSectionChecksum = load_GetDWORD();
|
|
|
|
// Remember the start of the UCode.
|
|
pbUCodeStart = gpbRead;
|
|
|
|
// C.1. Configuration-specific GBUS writes
|
|
|
|
|
|
// Issue "Host Run" command
|
|
Host_Control = 0x1000;
|
|
|
|
// C.1.1 Set up the DRAM.
|
|
ZiVAWriteReg( DMA_adr, DMA_MODE );
|
|
//ZiVAWriteReg( DMA_data, 0x4EC ); // 16 Mbits DRAM
|
|
ZiVAWriteReg( DMA_data, 0x14EC ); // 20 Mbits DRAM
|
|
|
|
// C.1.2 Set up the ROM and SRAM (if any).
|
|
ZiVAWriteReg( DMA_adr, DMA_CYCLE );
|
|
ZiVAWriteReg( DMA_data, 0 ); // No ROM or SRAM present
|
|
|
|
// C.2. Initial GBUS writes:
|
|
gpbRead = pbUCodeStart + GBUS_TABLE_OFFSET;
|
|
for ( dwCnt = load_GetDWORDSwapBackward(); dwCnt; dwCnt-- )
|
|
{
|
|
dwAddress = load_GetDWORDSwapBackward();
|
|
ZiVAWriteReg( dwAddress, load_GetDWORDSwapBackward() );
|
|
}
|
|
|
|
// Remember the start of the Final GBUS writes table.
|
|
pbFinalGBUSStart = gpbRead;
|
|
|
|
// C.3. Copy bootstrap code into IMEM
|
|
gpbRead = pbUCodeStart + IMEM_START_OFFSET;
|
|
|
|
for ( dwAddress=0; dwAddress < IMEM_LENGTH; dwAddress ++ )
|
|
{
|
|
DWORD dwValue = load_GetDWORDSwap();
|
|
ZiVAWriteIMEM( dwAddress, dwValue );
|
|
}
|
|
|
|
//return TRUE;
|
|
|
|
// C.4. Copy default DVD1 configuration data into DRAM
|
|
gpbRead = pbUCodeStart;
|
|
|
|
for ( dwAddress=0; dwAddress < dwSectionLength/*DRAM_IMAGE_LENGTH*/; )
|
|
{
|
|
ZiVAWriteMemory( dwAddress, load_GetDWORDSwap() );
|
|
dwAddress += 4; // Next 32-bit-WORD byte address in DRAM
|
|
}
|
|
|
|
// Check DRAM 12345
|
|
ZiVAReadMemory( 0x128, &dwTmp );
|
|
DBG_PRINTF( ("check DRAM 12345 ? Data = 0x%x\n", dwTmp ) );
|
|
|
|
/*
|
|
// C.5. Update configuration data in DRAM for the specific system.
|
|
DVD_WriteDRAM( DRAM_Stream_Source, STREAM_SOURCE );
|
|
DVD_WriteDRAM( DRAM_SD_Mode, SD_MODE );
|
|
DVD_WriteDRAM( DRAM_CFifo_Level, CFIFO_THRESHOLD );
|
|
DVD_WriteDRAM( DRAM_INFO, 1 ); // one 4Mbits DRAM increment
|
|
DVD_WriteDRAM( UCODE_MEMORY, 0 ); // Microcode is in DRAM
|
|
DVD_WriteDRAM( MEMORY_MAP, 3 ); // for 20 Mbits DRAM
|
|
DVD_WriteDRAM( AC3_OUTPUT_MODE, 7 ); // 6 channels audio
|
|
|
|
*/
|
|
DRAM_INFO = 0x01; // one 4Mbits DRAM increment
|
|
UCODE_MEMORY = 0x00; // microcode is in DRAM
|
|
VIDEO_MODE = 0x03; // VCLK slave, HSYNC and VSYNC master, CCIR-656 output
|
|
|
|
switch( Type )
|
|
{
|
|
case 0:
|
|
MEMORY_MAP = 0x03; // for 20 Mbits DRAM And NTSC
|
|
break;
|
|
case 1:
|
|
MEMORY_MAP = 0x06; // for 20 Mbits DRAM And PAL
|
|
break;
|
|
default:
|
|
DBG_BREAK();
|
|
return FALSE;
|
|
};
|
|
|
|
// C.6. Perform final GBUS writes.
|
|
gpbRead = pbFinalGBUSStart;
|
|
|
|
for ( dwCnt = load_GetDWORDSwapBackward(); dwCnt; dwCnt-- )
|
|
{
|
|
dwAddress = load_GetDWORDSwapBackward();
|
|
ZiVAWriteReg( dwAddress, load_GetDWORDSwapBackward() );
|
|
}
|
|
|
|
|
|
// Extend watchdog timer threashold. by H.Yagi 99.02.10
|
|
HOST_OPTIONS |= 0x0400;
|
|
|
|
//ZiVAWriteReg( CPU_cntl, 0x900000 ); // Run CPU.
|
|
|
|
// D. Wait for the DVD1 to enter the Idle state
|
|
|
|
|
|
|
|
// gets current time.
|
|
CTimeOut TimeOut( COMMAND_TIMEOUT, 1, m_pKernelObj );
|
|
// status pointer check?
|
|
DWORD State;
|
|
while( TRUE )
|
|
{
|
|
State = (DWORD)PROC_STATE;
|
|
DBG_PRINTF(( " Load UCode PROCSTATE = 0x%x\n" , State));
|
|
if( State == ZIVA_STATE_IDLE )
|
|
break;
|
|
// Sleep
|
|
TimeOut.Sleep();
|
|
|
|
// check Time out....... 1 sec
|
|
if( TimeOut.CheckTimeOut() == TRUE )
|
|
{
|
|
DBG_PRINTF(( " Load UCode failed: State = 0x%x\n" , (DWORD)PROC_STATE ));
|
|
DBG_BREAK();
|
|
return FALSE;
|
|
};
|
|
};
|
|
|
|
IDLE_DELAY = 0x10; // Power saving value
|
|
HOST_OPTIONS |= 0x20; // for NV interrupt correctly
|
|
|
|
DBG_PRINTF( (" LOAD UCODE completed. State = 0x%x\n", (DWORD)PROC_STATE ));
|
|
// _Debug_Printf_Service(" LOAD UCODE completed. State = 0x%x\n", (DWORD)PROC_STATE );
|
|
|
|
return TRUE;
|
|
};
|
|
|
|
|
|
//***************************************************************************
|
|
// End of
|
|
//***************************************************************************
|