亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ac97.h

?? Xcale270Bsp包,wince平臺
?? H
字號:
/*++

$Workfile: AC97.H $

$Date: 4/03/03 8:24p $

Abstract:  
	Header file for AC 97 specific functions

Functions:

Notes: 

$Log: /Projects/Windows_CE/XSC_Software/BVDMAIN_SP_2003/drivers/Wavedev2/AC97.H $
//
//1     4/03/03 8:24p Spaden
//
//1     11/14/02 9:51p Spaden
//initial checkin
//
//3     11/12/02 9:17p Spaden
//
//11    1/17/02 10:56p Spaden
//support sample rates based on CHIP ID
//
//10    1/17/02 10:01p Spaden
//check for UCB1400 version, added coded (which is commented out) to
//enable the head phones for UCB1400
//
//9     11/06/01 12:58a Spaden
//fix typo where logical and (&&) was in place of a bitwise and (&)
//
//8     11/02/01 12:25a Spaden
//optimize for power consumption
//
//7     10/29/01 8:04p Spaden
//add vendor id register defines
//
//6     3/20/01 5:05p Spaden
//
//5     2/28/01 9:28p Spaden
//place all code that offends WindowsCE under one ifndef UNDER_CE
//
//4     2/28/01 8:42p Spaden
//place all code that offends WindowsCE under one ifndef UNDER_CE
//
//3     2/28/01 8:28p Spaden
//place all code that offends WindowsCE under one ifndef UNDER_CE
//
//2     2/28/01 3:19p Spaden
//place all code that offends WindowsCE under one ifndef UNDER_CE
//
//1     2/23/01 9:47p Spaden
//remove globals defined in .h file
//
//1     1/31/01 5:17p Spaden

--*/


/* 
** INTEL CONFIDENTIAL
** Copyright 2000-2003 Intel Corporation All Rights Reserved.
**
** The source code contained or described herein and all documents
** related to the source code (Material) are owned by Intel Corporation
** or its suppliers or licensors.  Title to the Material remains with
** Intel Corporation or its suppliers and licensors. The Material contains
** trade secrets and proprietary and confidential information of Intel
** or its suppliers and licensors. The Material is protected by worldwide
** copyright and trade secret laws and treaty provisions. No part of the
** Material may be used, copied, reproduced, modified, published, uploaded,
** posted, transmitted, distributed, or disclosed in any way without Intel抯
** prior express written permission.

** No license under any patent, copyright, trade secret or other intellectual
** property right is granted to or conferred upon you by disclosure or
** delivery of the Materials, either expressly, by implication, inducement,
** estoppel or otherwise. Any license under such intellectual property rights
** must be express and approved by Intel in writing.
*/



#ifndef __XSC_AC97_H__
#define __XSC_AC97_H__

// Index of Codec Registers on AC-link.
// Note:  Only items having a "Usage" comment are actively used by the driver.		  

//		Register Name			Index			// Usage
//-----------------------------------------------------------------------
#define RESET					0X00			// RESET CODEC TO DEFAULT					
#define MASTER_VOLUME			0X02			// LINE OUT VOLUME
#define HEADPHONE_VOLUME		0X04
#define MASTER_VOLUME_MONO		0X06
#define MASTER_TONE_R_L			0X08
#define PC_BEEP_VOLUME			0X0A
#define PHONE_VOLUME			0X0C
#define MIC_VOLUME				0X0E			// MICROPHONE VOLUME/ AGC
#define LINE_IN_VOLUME			0X10			// LINE IN VOLUME
#define CD_VOLUME				0X12
#define VIDEO_VOLUME			0X14
#define AUX_VOLUME				0X16
#define PCM_OUT_VOL				0X18
#define RECORD_SELECT			0X1A			// SELECT LINE IN OR MICROPHONE
#define RECORD_GAIN				0X1C
#define RECORD_GAIN_MIC			0X1E			//undefined for UCB1400
#define GENERAL_PURPOSE			0X20
#define CONTROL_3D				0X22
#define RESERVED				0X24
#define POWERDOWN_CTRL_STAT		0X26			// POWER MANAGEMENT
#define EXTENDED_AUDIO_ID		0X28
#define EXTENDED_AUDIO_CTRL		0X2A			// BIT 0 must be set to 1 for variable rate audio
#define AUDIO_DAC_RATE			0X2C			// 16 bit unsigned is sample rate in hertz
#define AUDIO_ADC_RATE			0X32			// 16 bit unsigned is sample rate in hertz
#define FEATURE_CSR1			0x6A			// UCB1400 specific bass, treble and other items
#define FEATURE_CSR2			0x6C			// UCB1400 specific bass, treble and other items
#define VENDOR_ID1	  		    0x7c			// UCB1400 id first 16 bits
#define VENDOR_ID2	  		    0x7e			// UCB1400 id second 16 bits

#define VRA_ENABLED_MASK		0x1				// VRA bit set to 1 enables sample rate conversion

#define EQ_MASK					0xFE00			//1111111000000000
#define BASS_MASK				0XE000			//1110000000000000
#define TREB_MASK				0x1800			//0001100000000000
#define MODE_MASK				0x0600			//0000011000000000
#define MID_BASS_MAX_TREB		0x9E00			//1001111000000000

#define BASS_BIT_POSTN			(0x1u<<11)
#define TREB_BIT_POSTN			(0x1u<<00)
#define MODE_BIT_POSTN			(0x1u<<07)

//power management bits
#define PWR_ADC					(0x1)
#define PWR_DAC					(0x1<<1)
#define PWR_ANL					(0x1<<2)
#define PWR_REF					(0x1<<3)
#define PWR_PR0					(0x1<<8) //write this bit to power down the adc
#define PWR_PR1					(0x1<<9) //write this bit to power down the dac
#define PWR_PR0_ADC				(0x1<<8) //write this bit to power down the adc
#define PWR_PR1_DAC				(0x1<<9) //write this bit to power down the dac
#define PWR_PR2					(0x1<<10)
#define PWR_PR3					(0x1<<11)
#define PWR_PR4					(0x1<<12)
#define PWR_PR5					(0x1<<13)
#define PWR_PR6					(0x1<<14)
#define PWR_EAPD				(0x1<<15)

//smart power bits
#define PWR_SLP0				(0x1<<4)
#define PWR_SLP1				(0x1<<5)
//#define PWR_SMART_NONE          
#define PWR_SMART_CODEC         PWR_SLP0
#define PWR_SMART_PLL			PWR_SLP1
#define PWR_SMART_BOTH			(PWR_SLP0 & PWR_SLP1)

// Volume Specific Bits
#define	MUTE_VOL				0X8000

#define RECORD_GAIN_MAX			0X0f0f
#define RECORD_GAIN_MIN			0X0
#define MUTE_MASK        		0x8000

#define AUDIO_LINE_INPUT_STEREO 0X4040
#define AUDIO_MIC_INPUT_MONO	 0X0

// Codec Register Masks.

#define MASTER_VOLUME_R_MASK	0x0000003F		// 5 bits required. 6 optional.
#define	MASTER_VOLUME_SHIFT		8				// Left volume bit2 13:8

// AC-link Specifics.

#define	READ_CODEC				( 1<<7 )		// AC-link. Command Address Port "read" bit.
#define	WRITE_CODEC				( 0x00 )		// AC-link. Command Address Port "write" bit.
												//   Bit 7 is zero for writes.
// Useful Constants
#define	DWORD_ZEROS		((DWORD)0x00000000)

//UCB1400 STUFF
#define REV_2A 0x2a0
#define REV_1B 0x2a
#define HPEN_BIT_POS		      (6U)	//bit 6 is headphone enable
#define HPEN_MASK				  (0xf << HPEN_BIT_POS)  // bit 6

//CODEC TYPES
#define GENERIC_AC97 0
#define UCB14001B 1
#define UCB14002A 2


// Serial Audio Control Register (SACR0) bit masks.
#define	SACR0_ENB_MASK		(1<<0)		// Pins function as SAC
#define	SACR0_BCKD_MASK		(1<<2)		// BIT_CLK diretion; 1 ==> Output.
#define	SACR0_RST_MASK		(1<<3)		// Reset is active to other SAC registers.
#define	SACR0_SAC_ENB		1			// Enable pins as SAC controller.
#define	SACR0_BCKD_INPUT	0			// BIT_CLK pin set to input.
#define	SACR0_RESET_ACTIVE	1			// Reset other SAC registers(not SACR0) & FIFO
#define	SACR0_RESET_CLEAR	0			// Deassert Reset.
// Serial Audio Control Register (SACR2) bit masks.
#define	SACR2_WKUP_MASK		(1<<2)		// Wake up codec by activating SYNC. 
#define	SACR2_DRPL_MASK		(1<<4)		// AC-link Replay; 1==> Disabled.
#define	SACR2_RESET_MASK	(1<<6)		// Cold Codec Reset. 
#define	SACR2_DRPL_DISABLE	1			// 1==> AC-link replay is diabled.
#define	SACR2_WKUP_ENABLE	1			// 1==> Activate SYNC signal.
#define	SACR2_RESET_ACTIVE		0		// Cold Reset; 0 ==> Active.
#define	SACR2_RESET_NOTACTIVE	1		// Cold Reset; 0 ==> Active.
// Serial Audio Status Register (SASR1) bit masks.
#define	SASR1_TUR_MASK		(1<<5)			// AC-link Command Address and Data Transmit
#define	SASR1_ROR_MASK		(1<<6)			// AC-link Command Address and Data Transmit
#define	SASR1_CADT_MASK		(1<<16)			// AC-link Command Address and Data Transmit
										// 1 ==> Done
#define	SASR1_SADR_MASK		(1<<17)			// AC-link Command Address and Data are Received.
										// 1 ==> Done
#define	SASR1_RSTO_MASK		(1<<18)			// Read Status Timeout. 
										// 1 ==> Timeout detected 4 Frames after Read Command. 		
#define	SASR1_CRDY_MASK		(1<<20)			// Codec Ready. 1 ==> Ready for normal operation.
// Serial Audio Status Clear Register (SASCR)
#define	SASCR_DTS_CLEAR		1			// Clear the status sent bit in SASR1.
#define	SASCR_TUR_CLEAR		1			// Clear the status sent bit in SASR1.
#define	SASCR_ROR_CLEAR		1			// Clear the status sent bit in SASR1.
// Serial Audio DMA Receive/Transmit Control Registers ( SADRCS, SADTCS)
#define	SADRTCS_DEN_MASK		(1<<0)		// Enable DMA
//#define	SADRTCS_DEN_MASK_tst	(1<<0)		// $$ Enable DMA
#define	SADRTCS_DIE_MASK		(1<<1)		// Enable DMA Interrupts for Done A or B.
#define	SADRTCS_DONE_A_MASK		(1<<3)		// The "A" transfer is done.
#define	SADRTCS_DONE_B_MASK		(1<<5)		// The "B" transfer is done.
#define	SADRTCS_START_A_MASK	(1<<4)		// Start "A" transfer
#define	SADRTCS_START_B_MASK	(1<<6)		// Start "B" transfer
#define	SADRTCS_BIU_MASK		(1<<7)		// A or B actively transferring data.

// System Bus Control Register (SKCR) bit masks.
#define	SKCR_SeLAC_MASK		(1<<8)			// AC-link Command Address and Data Transmit
#define	SKCR_SeLAC_ACLINK	1			// Enable AC-link.
// System Power Control Register (SKPCR) bit masks.
#define	SKPCR_ACCLNKEN_MASK	(1<<1)			// Audio Controller AC Link Clock Enable.
#define	SKPCR_ACCLKEN		1			// 1==> AC-link clock enable.
// SA-1111 CPLD. (Section 4.4, Sa-1111 Microprocessor Developent Module, User's Guide Dec 99)
// AUD_CTL, Audio Control Register.
#define	AUD_CTL_SELECT_AC97			0		//  0==> AC97
#define	SA1111_PLD_SEL1341_MASK	(1<<0)

  // Bits Values
#define		AC_Link_Active	1
#define		I2S_Active		0

// SA1111 Interrupt Controller ( 0 - 31)
//#define	INT_AUD_DTS_MASK	(1<<)

// SA1111 Interrupt Controller ( 0 - 31)
#define	INT_AUD_DTS_MASK	(1 << 40-32)	// Data Sent to codec register.
#define	INT_AUD_RDD_MASK	(1 << 41-32)	// Data received from codec 



//
//  Virtual Base Addresses
//

#define	NOCOMPILE_RSTREG_PHYSICAL	 0x90030000
#define	NOCOMPILE_RSTREG_VIRTUAL	 0xA9030000


//
// This appears in bvd1.h, but is not compiled.
//

// Input for the function
//	void SA_StartAC97DMA(void * p, void * ba, int len, int ie)

/*
typedef enum {
     PLAY_XMIT,
     RECORD_RCV
} AC97_TRANSFER;
*/
// Buffer sizes in units of 16-bit Stereo samples.
//		Assume AUDIO_DMA_PAGE_SIZE is multiple of 4 bytes.
#define	OUT_SAMPLE_SIZE_AC97			4		// Bytes in Stereo 16-Bits
#define	AUDIO_DMA_16BIT_BUF_SIZE		(AUDIO_DMA_PAGE_SIZE/2)
#define	AUDIO_MORE_THAN_MAX				(1<<30)


//#ifdef NOCOMPILE
/***
struct rsrrBits {
	unsigned swr			:1;
	unsigned rsvd0			:31;
};

struct rcsrBits {
	unsigned hwr			:1;
	unsigned swr			:1;
	unsigned wdr			:1;
	unsigned smr			:1;
	unsigned rsvd0			:28;
};

struct rstreg{
	struct rsrrBits			rsrr;
	struct rcsrBits			rcsr;
	unsigned				tucr;
};
***/

//#endif


#endif // __XSC_AC97_H__

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一二三四区| 91精品国产综合久久精品麻豆 | 国产一区不卡精品| 日韩精品亚洲专区| 午夜精品久久久久久久久久| 亚洲国产成人高清精品| 亚洲va欧美va国产va天堂影院| 夜色激情一区二区| 亚洲一区二区三区国产| 亚洲国产aⅴ天堂久久| 五月天丁香久久| 日韩高清在线不卡| 韩国三级在线一区| 国产ts人妖一区二区| 欧美情侣在线播放| 日韩免费一区二区| 2020国产成人综合网| 国产精品嫩草久久久久| 亚洲欧美日韩国产成人精品影院| 亚洲精品一卡二卡| 美女久久久精品| 国产成人午夜视频| 欧美在线观看禁18| 日韩欧美的一区| 国产亲近乱来精品视频| 一区二区三区小说| 免费在线一区观看| 成人av免费网站| 欧美日韩国产经典色站一区二区三区| 日韩欧美一级精品久久| 亚洲国产精品av| 亚洲成人精品一区二区| 国产精品18久久久久| 在线日韩一区二区| 久久综合狠狠综合久久综合88| 中文字幕日本不卡| 美国欧美日韩国产在线播放| 成人app网站| 精品欧美乱码久久久久久1区2区| 中文字幕亚洲视频| 久久精品国产精品亚洲红杏 | 91美女在线观看| 日韩久久精品一区| 亚洲伦理在线精品| 激情另类小说区图片区视频区| 色噜噜狠狠色综合欧洲selulu| 日韩三级中文字幕| 亚洲电影在线播放| 成人激情视频网站| 精品播放一区二区| 三级一区在线视频先锋| 色呦呦一区二区三区| 久久久久99精品一区| 偷窥国产亚洲免费视频| 91在线视频网址| 久久精品夜色噜噜亚洲aⅴ| 午夜激情一区二区| 欧美私人免费视频| 亚洲欧洲性图库| 国产999精品久久| 2022国产精品视频| 伦理电影国产精品| 欧美高清激情brazzers| 亚洲韩国精品一区| 色婷婷香蕉在线一区二区| 国产精品欧美一区喷水| 国产美女精品人人做人人爽| 欧美一级爆毛片| 丝袜美腿亚洲色图| 91.com视频| 丝袜美腿成人在线| 欧美精品xxxxbbbb| 日本在线播放一区二区三区| 欧美日韩高清影院| 午夜精品久久久久久久99水蜜桃| 在线观看亚洲专区| 亚洲一区二区三区四区五区中文| 色就色 综合激情| 亚洲国产综合91精品麻豆| 在线观看免费亚洲| 亚洲一区二区黄色| 777午夜精品免费视频| 热久久久久久久| 精品欧美乱码久久久久久1区2区| 狠狠色丁香婷婷综合| 久久久久久久久久久久久女国产乱| 精品在线免费观看| 中文字幕乱码亚洲精品一区| 成人黄色大片在线观看| 亚洲免费高清视频在线| 欧美三级日韩三级国产三级| 日产国产欧美视频一区精品| xf在线a精品一区二区视频网站| 国产河南妇女毛片精品久久久| 亚洲国产成人午夜在线一区| 色视频成人在线观看免| 亚洲图片一区二区| 精品国产3级a| 色中色一区二区| 激情小说欧美图片| 亚洲欧洲精品一区二区三区| 欧美三级视频在线播放| 奇米影视7777精品一区二区| 国产精品77777| 亚洲久草在线视频| 欧美mv日韩mv国产网站app| 成人午夜av电影| 亚洲国产wwwccc36天堂| 久久色成人在线| 色老头久久综合| 国产成人丝袜美腿| 偷窥国产亚洲免费视频| 国产精品初高中害羞小美女文| 欧美日韩高清一区| 成人毛片视频在线观看| 午夜伦理一区二区| 亚洲天堂福利av| 久久久青草青青国产亚洲免观| 欧美性生活一区| 日韩欧美一区二区在线视频| eeuss鲁片一区二区三区| 日本aⅴ免费视频一区二区三区| 国产精品久久久久久久久免费相片| 在线不卡免费av| 91视频在线观看免费| 国产盗摄一区二区| 秋霞电影一区二区| 亚洲成人在线网站| 中文字幕一区二区三区色视频 | 久久午夜羞羞影院免费观看| 色综合久久六月婷婷中文字幕| 国产精品自在欧美一区| 蜜桃一区二区三区四区| 亚洲国产精品影院| 中文字幕精品—区二区四季| 精品国产免费视频| 欧美一区二区性放荡片| 日本道免费精品一区二区三区| 成人免费视频免费观看| 国产精品一区不卡| 毛片不卡一区二区| 日韩成人精品在线| 午夜精品福利一区二区三区蜜桃| 亚洲欧美色图小说| 综合电影一区二区三区 | 国产成人a级片| 韩国av一区二区三区| 蜜臀a∨国产成人精品| 日本欧美一区二区三区| 香蕉久久一区二区不卡无毒影院| 亚洲精品亚洲人成人网| 夜夜嗨av一区二区三区四季av| 亚洲婷婷综合久久一本伊一区| 国产精品视频看| 一区在线播放视频| 亚洲婷婷国产精品电影人久久| 亚洲柠檬福利资源导航| 一区二区三区在线观看视频| 樱桃视频在线观看一区| 亚洲一区二区在线视频| 亚洲成av人片| 久久99九九99精品| 国产91丝袜在线18| 91视频免费观看| 欧美少妇性性性| 精品国产乱码久久久久久影片| 久久久不卡影院| 亚洲品质自拍视频网站| 亚洲a一区二区| 久草中文综合在线| 成人永久aaa| 欧美日韩一区小说| 精品久久久久久亚洲综合网| 亚洲国产精华液网站w| 亚洲免费色视频| 日本欧美一区二区在线观看| 国产成人精品1024| 欧美色图天堂网| 久久在线免费观看| 亚洲品质自拍视频| 精品一区二区精品| 一本大道久久a久久综合婷婷| 6080国产精品一区二区| 亚洲国产精品激情在线观看| 亚洲国产精品麻豆| 精品亚洲国产成人av制服丝袜| www.亚洲免费av| 91精品国产综合久久久久久久| 国产精品黄色在线观看| 日韩中文字幕麻豆| 波多野结衣在线一区| 制服丝袜在线91| 国产精品毛片高清在线完整版| 婷婷夜色潮精品综合在线| 国产福利视频一区二区三区| 欧美日韩精品一区二区三区蜜桃 | 午夜精品久久久久久久蜜桃app| 国产黄色精品网站| 欧美日高清视频| 亚洲欧洲成人精品av97|