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

📄 ecard.h

📁 鼎力推荐!本程序是基于嵌入式LUNUX系统开发的源程序代码
💻 H
字号:
/*      ********************************************************************** *     ecard.h *     Copyright 1999, 2000 Creative Labs, Inc.  *  **********************************************************************  *  *     This program is free software; you can redistribute it and/or  *     modify it under the terms of the GNU General Public License as  *     published by the Free Software Foundation; either version 2 of  *     the License, or (at your option) any later version.  *  *     This program is distributed in the hope that it will be useful,  *     but WITHOUT ANY WARRANTY; without even the implied warranty of  *     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the  *     GNU General Public License for more details.  *  *     You should have received a copy of the GNU General Public  *     License along with this program; if not, write to the Free  *     Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139,  *     USA.  *  **********************************************************************  */ #ifndef _ECARD_H#define _ECARD_H#include "8010.h"#include "hwaccess.h"#include <linux/init.h>/* In A1 Silicon, these bits are in the HC register */#define HOOKN_BIT   (1L << 12)#define HANDN_BIT   (1L << 11)#define PULSEN_BIT  (1L << 10)#define EC_GDI1 (1 << 13)#define EC_GDI0 (1 << 14)#define EC_NUM_CONTROL_BITS 20#define EC_AC3_DATA_SELN  0x0001L#define EC_EE_DATA_SEL    0x0002L#define EC_EE_CNTRL_SELN  0x0004L#define EC_EECLK          0x0008L#define EC_EECS           0x0010L#define EC_EESDO          0x0020L#define EC_TRIM_CSN	  0x0040L#define EC_TRIM_SCLK	  0x0080L#define EC_TRIM_SDATA	  0x0100L#define EC_TRIM_MUTEN	  0x0200L#define EC_ADCCAL	  0x0400L#define EC_ADCRSTN	  0x0800L#define EC_DACCAL	  0x1000L#define EC_DACMUTEN	  0x2000L#define EC_LEDN		  0x4000L#define EC_SPDIF0_SEL_SHIFT	15#define EC_SPDIF1_SEL_SHIFT	17	#define EC_SPDIF0_SEL_MASK	(0x3L << EC_SPDIF0_SEL_SHIFT)#define EC_SPDIF1_SEL_MASK	(0x7L << EC_SPDIF1_SEL_SHIFT)#define EC_SPDIF0_SELECT(_x) (((_x) << EC_SPDIF0_SEL_SHIFT) & EC_SPDIF0_SEL_MASK)#define EC_SPDIF1_SELECT(_x) (((_x) << EC_SPDIF1_SEL_SHIFT) & EC_SPDIF1_SEL_MASK)#define EC_CURRENT_PROM_VERSION 0x01 /* Self-explanatory.  This should                                      * be incremented any time the EEPROM's                                      * format is changed.  */#define EC_EEPROM_SIZE	        0x40 /* ECARD EEPROM has 64 16-bit words *//* Addresses for special values stored in to EEPROM */#define EC_PROM_VERSION_ADDR	0x20	/* Address of the current prom version */#define EC_BOARDREV0_ADDR	0x21	/* LSW of board rev */#define EC_BOARDREV1_ADDR 	0x22	/* MSW of board rev */ #define EC_LAST_PROMFILE_ADDR	0x2f#define EC_SERIALNUM_ADD	0x30	/* First word of serial number.  The number                                         * can be up to 30 characters in length                                         * and is stored as a NULL-terminated                                         * ASCII string.  Any unused bytes must be                                         * filled with zeros */#define EC_CHECKSUM_ADDR	0x3f    /* Location at which checksum is stored *//* Most of this stuff is pretty self-evident.  According to the hardware  * dudes, we need to leave the ADCCAL bit low in order to avoid a DC  * offset problem.  Weird. */#define EC_RAW_RUN_MODE	(EC_DACMUTEN | EC_ADCRSTN | EC_TRIM_MUTEN | EC_TRIM_CSN)#define EC_DEFAULT_ADC_GAIN   0xC4C4#define EC_DEFAULT_SPDIF0_SEL 0x0#define EC_DEFAULT_SPDIF1_SEL 0x4#define HC_EA 0x01L/* ECARD state structure.  This structure maintains the state * for various portions of the ECARD's onboard hardware. */struct ecard_state {	u32 control_bits;	u16 adc_gain;	u16 mux0_setting;	u16 mux1_setting;	u16 mux2_setting;};void emu10k1_ecard_init(struct emu10k1_card *) __devinit;#endif /* _ECARD_H */

⌨️ 快捷键说明

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