⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 i2saudio.h

📁 EP9315开发板的Wince6.0的BSP包文件
💻 H
字号:
//**********************************************************************
//                                                                      
// Filename: i2saudio.h
//                                                                      
// Description: Interface for the I2S codec interface class.
//
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF
// ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A
// PARTICULAR PURPOSE.
//
// Use of this source code is subject to the terms of the Cirrus end-user
// license agreement (EULA) under which you licensed this SOFTWARE PRODUCT.
// If you did not accept the terms of the EULA, you are not authorized to 
// use this source code. For a copy of the EULA, please see the 
// EULA.RTF on your install media.
//
// Copyright(c) Cirrus Logic Corporation 2005, All Rights Reserved                       
//                                                                      
//**********************************************************************

#ifndef _H_I2SAUDIO
#define _H_I2SAUDIO

class I2SCodec : public CodecInterface
{
    public:
        I2SCodec(void);
        virtual MMRESULT Initialize();

        virtual MMRESULT    SetVolume
        (
            ULONG ulRightVolume, 
            ULONG ulLeftVolume, 
            ULONG ulChannel
        );

        virtual MMRESULT    SetRecordSampleRate(ULONG ulFrequency, ULONG ulChannel);
        virtual MMRESULT    SetPlaybackSampleRate(ULONG ulFrequency, ULONG ulChannel);
        virtual BOOL        HasSRC(void) { return FALSE; };
        virtual MMRESULT    StartRecord(ULONG ulChannel);
        virtual MMRESULT    StartPlayback(ULONG ulChannel);
        virtual MMRESULT    StopPlayback(ULONG ulChannel);
        virtual MMRESULT    StopRecord(ULONG ulChannel);
        virtual ULONG       GetDmaPort(void);
        virtual ULONG       DmaSampleSize(void) {return 32;}
        virtual             ~I2SCodec(void);
        void                ProducePIOTone(void);

		DWORD				MixerVolumeSettings( DWORD dwCode ,DWORD dwControl, DWORD dwSettings);

    private:
        MMRESULT            SetSampleRate(ULONG ulFrequency, ULONG ulChannel);
        MMRESULT            WriteCodecReg(UCHAR ucReg, UCHAR usValue);
        MMRESULT            ReadCodecReg(UCHAR ucReg,  PUCHAR pucValue);
        MMRESULT            WriteCodecRegNOSPI(UCHAR ucRegAddr, UCHAR ucRegValue);
        void                ReadAllCodecReg(void);
        BOOL                m_bUseI2SVolumeControl;
        CRITICAL_SECTION    m_CriticalSection;
        ULONG               m_ulM2SClock;
        ULONG               m_ulS2LRClock;
        LARGE_INTEGER       m_PerfFreq;    
        ULONG               m_ulActualFreq;
        ULONG               m_ulCurrentFreq;
        BOOL                m_bTwoWire;
        ULONG               m_ulCodec;


		volatile ULONG *	m_pdwResetGPIO_DR;
		volatile ULONG *	m_pdwResetGPIO_DDR;
		BYTE				m_cResetBit;

		volatile ULONG *	m_pdwAudioSelect_DR;
		volatile ULONG *	m_pdwAudioSelect_DDR;

		BYTE				m_cAudioSelectBit;
		BOOL				m_bWithMuteHW;

};
//
// CS4228 Register set
//
#define CS4228_DEV_ADDRESS          0x22

#define CS4228_CLOCK_MODE           1
#define CS4228_CHIP_CNTL            2
#define CS4228_ADC_CNTL             3
#define CS4228_DAC_MUTE1            4
#define CS4228_DAC_MUTE2            5
#define CS4228_DAC_DEEMPHASIS       6
#define CS4228_DAC1_VOL             7
#define CS4228_DAC2_VOL             8
#define CS4228_DAC3_VOL             9
#define CS4228_DAC4_VOL             10
#define CS4228_DAC5_VOL             11
#define CS4228_DAC6_VOL             12
#define CS4228_SERIAL_MODE          13
#define CS4228_STATUS               14


#define CS4271_DEV_ADDRESS          0x22

#define CS4271_MODE_CNTL            1
#define CS4271_DAC_CNTL             2
#define CS4271_DAC_VOL              3
#define CS4271_DACA_VOL             4
#define CS4271_DACB_VOL             5
#define CS4271_ADC_CNTL             6
#define CS4271_MODE_CNTL2           7
#define CS4271_CHIP_ID              8

//
// CS4271 Register fields
//
#define DACX_VOL_MUTE               0x80
#define DACX_VOL_MASK               0x7F

#define CLOCK_MODE_BASERATE_128     0x00
#define CLOCK_MODE_BASERATE_256     0x04
#define CLOCK_MODE_BASERATE_384     0x08
#define CLOCK_MODE_BASERATE_512     0x0C
#define CLOCK_MODE_HIGHRATE_64      0x80
#define CLOCK_MODE_HIGHRATE_128     0x84
#define CLOCK_MODE_HIGHRATE_192     0x88
#define CLOCK_MODE_HIGHRATE_256     0x8C

#define CHIP_CNTL_NDIGPN            0x80
#define CHIP_CNTL_ADCPDN            0x10
#define CHIP_CNTL_DACPDN12          0x08
#define CHIP_CNTL_DACPDN34          0x04
#define CHIP_CNTL_DACPDN56          0x02

#define MUTE2_MUTEZ                 0x40
#define MUTE2_MUTEC                 0x80

#define SERIAL_MODE_DCK_MASK        0xC0
#define SERIAL_MODE_DCK_H32         0x80
#define SERIAL_MODE_DCK_H64         0xC0
#define SERIAL_MODE_DCK_B32         0x00
#define SERIAL_MODE_DCK_B48         0x40
#define SERIAL_MODE_DCK_B64         0x80
#define SERIAL_MODE_DCK_B128        0xC0
#define SERIAL_MODE_DMS_MASK        0x30
#define SERIAL_MODE_DMS_SLAVE       0x00
#define SERIAL_MODE_DMS_MASTER      0x30
#define SERIAL_MODE_DDF_RIGHT_24BIT 0x00
#define SERIAL_MODE_DDF_RIGHT_20BIT 0x01
#define SERIAL_MODE_DDF_RIGHT_16BIT 0x02
#define SERIAL_MODE_DDF_LEFT_24BIT  0x03
#define SERIAL_MODE_DDF_I2S_24BIT   0x04
#define SERIAL_MODE_DDF_MASK        0x07



#endif // _H_I2SAUDIO

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -