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

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

?? uda1341.c

?? 這個是在s3c2410上的uda1341的驅動程序
?? C
?? 第 1 頁 / 共 3 頁
字號:
#include <linux/module.h> 
#include <linux/device.h> 
#include <linux/init.h> 
#include <linux/types.h> 
#include <linux/fs.h> 
#include <linux/mm.h> 
#include <linux/slab.h> 
#include <linux/delay.h> 
#include <linux/sched.h> 
#include <linux/poll.h> 
#include <linux/interrupt.h> 
#include <linux/errno.h> 
#include <linux/sound.h> 
#include <linux/soundcard.h> 

#include <linux/pm.h> 

#include <asm/uaccess.h> 
#include <asm/io.h> 
#include <asm/hardware.h> 
#include <asm/semaphore.h> 
#include <asm/dma.h> 
//#include <asm/arch/cpu_s3c2410.h> 
#include <asm/arch/dma.h> 
#include <asm/arch/regs-gpio.h> 
#include <asm/arch/regs-iis.h> 
#include <asm/hardware/clock.h> 
#include <asm/arch/regs-clock.h> 
#include <linux/dma-mapping.h> 
#include <asm/dma-mapping.h> 
#include <asm/arch/hardware.h> 
#include <asm/arch/map.h> 
#include <asm/arch/S3C2410.h> 
#define PFX "s3c2410-uda1341-superlp: " 

#define MAX_DMA_CHANNELS 0 

/* The S3C2410 has four internal DMA channels. */ 

#define MAX_S3C2410_DMA_CHANNELS S3C2410_DMA_CHANNELS 

#define DMA_CH0 0 
#define DMA_CH1 1 
#define DMA_CH2 2 
#define DMA_CH3 3 

#define DMA_BUF_WR 1 
#define DMA_BUF_RD 0 


#define dma_wrreg(chan, reg, val) writel((val), (chan)->regs + (reg)) 


static struct clk *iis_clock; 
static void __iomem *iis_base; 

static struct s3c2410_dma_client s3c2410iis_dma_out= { 
	.name = "I2SSDO", 
}; 

static struct s3c2410_dma_client s3c2410iis_dma_in = { 
	.name = "I2SSDI", 
}; 



#ifdef DEBUG 
#define DPRINTK printk 
#else 
#define DPRINTK( x... ) 
#endif 

static void init_s3c2410_iis_bus_rx(void); 
static void init_s3c2410_iis_bus_tx(void); 

#define DEF_VOLUME 65 

/* UDA1341 Register bits */ 
#define UDA1341_ADDR 0x14 

#define UDA1341_REG_DATA0 (UDA1341_ADDR + 0) 
#define UDA1341_REG_STATUS (UDA1341_ADDR + 2) 

/* status control */ 
#define STAT0 (0x00) 
#define STAT0_RST (1 << 6) 
#define STAT0_SC_MASK (3 << 4) 
#define STAT0_SC_512FS (0 << 4) 
#define STAT0_SC_384FS (1 << 4) 
#define STAT0_SC_256FS (2 << 4) 
#define STAT0_IF_MASK (7 << 1) 
#define STAT0_IF_I2S (0 << 1) 
#define STAT0_IF_LSB16 (1 << 1) 
#define STAT0_IF_LSB18 (2 << 1) 
#define STAT0_IF_LSB20 (3 << 1) 
#define STAT0_IF_MSB (4 << 1) 
#define STAT0_IF_LSB16MSB (5 << 1) 
#define STAT0_IF_LSB18MSB (6 << 1) 
#define STAT0_IF_LSB20MSB (7 << 1) 
#define STAT0_DC_FILTER (1 << 0) 
#define STAT0_DC_NO_FILTER (0 << 0) 

#define STAT1 (0x80) 
#define STAT1_DAC_GAIN (1 << 6) /* gain of DAC */ 
#define STAT1_ADC_GAIN (1 << 5) /* gain of ADC */ 
#define STAT1_ADC_POL (1 << 4) /* polarity of ADC */ 
#define STAT1_DAC_POL (1 << 3) /* polarity of DAC */ 
#define STAT1_DBL_SPD (1 << 2) /* double speed playback */ 
#define STAT1_ADC_ON (1 << 1) /* ADC powered */ 
#define STAT1_DAC_ON (1 << 0) /* DAC powered */ 

/* data0 direct control */ 
#define DATA0 (0x00) 
#define DATA0_VOLUME_MASK (0x3f) 
#define DATA0_VOLUME(x) (x) 

#define DATA1 (0x40) 
#define DATA1_BASS(x) ((x) << 2) 
#define DATA1_BASS_MASK (15 << 2) 
#define DATA1_TREBLE(x) ((x)) 
#define DATA1_TREBLE_MASK (3) 

#define DATA2 (0x80) 
#define DATA2_PEAKAFTER (0x1 << 5) 
#define DATA2_DEEMP_NONE (0x0 << 3) 
#define DATA2_DEEMP_32KHz (0x1 << 3) 
#define DATA2_DEEMP_44KHz (0x2 << 3) 
#define DATA2_DEEMP_48KHz (0x3 << 3) 
#define DATA2_MUTE (0x1 << 2) 
#define DATA2_FILTER_FLAT (0x0 << 0) 
#define DATA2_FILTER_MIN (0x1 << 0) 
#define DATA2_FILTER_MAX (0x3 << 0) 
/* data0 extend control */ 
#define EXTADDR(n) (0xc0 | (n)) 
#define EXTDATA(d) (0xe0 | (d)) 

#define EXT0 0 
#define EXT0_CH1_GAIN(x) (x) 
#define EXT1 1 
#define EXT1_CH2_GAIN(x) (x) 
#define EXT2 2 
#define EXT2_MIC_GAIN_MASK (7 << 2) 
#define EXT2_MIC_GAIN(x) ((x) << 2) 
#define EXT2_MIXMODE_DOUBLEDIFF (0) 
#define EXT2_MIXMODE_CH1 (1) 
#define EXT2_MIXMODE_CH2 (2) 
#define EXT2_MIXMODE_MIX (3) 
#define EXT4 4 
#define EXT4_AGC_ENABLE (1 << 4) 
#define EXT4_INPUT_GAIN_MASK (3) 
#define EXT4_INPUT_GAIN(x) ((x) & 3) 
#define EXT5 5 
#define EXT5_INPUT_GAIN(x) ((x) >> 2) 
#define EXT6 6 
#define EXT6_AGC_CONSTANT_MASK (7 << 2) 
#define EXT6_AGC_CONSTANT(x) ((x) << 2) 
#define EXT6_AGC_LEVEL_MASK (3) 
#define EXT6_AGC_LEVEL(x) (x) 

#define AUDIO_NAME "UDA1341" 
#define AUDIO_NAME_VERBOSE "UDA1341 audio driver" 

#define AUDIO_FMT_MASK (AFMT_S16_LE) 
#define AUDIO_FMT_DEFAULT (AFMT_S16_LE) 

#define AUDIO_CHANNELS_DEFAULT 2 
#define AUDIO_RATE_DEFAULT 44100 

#define AUDIO_NBFRAGS_DEFAULT 8 
#define AUDIO_FRAGSIZE_DEFAULT 8192 

#define S_CLOCK_FREQ 384 
#define PCM_ABS(a) (a < 0 ? -a : a) 

typedef struct { 
	int size; /* buffer size */ 
	char *start; /* point to actual buffer */ 
	dma_addr_t dma_addr; /* physical buffer address */ 
	struct semaphore sem; /* down before touching the buffer */ 
	int master; /* owner for buffer allocation, contain size when true */ 
} audio_buf_t; 

typedef struct { 
	audio_buf_t *buffers; /* pointer to audio buffer structures */ 
	audio_buf_t *buf; /* current buffer used by read/write */ 
	u_int buf_idx; /* index for the pointer above */ 
	u_int fragsize; /* fragment i.e. buffer size */ 
	u_int nbfrags; /* nbr of fragments */ 
	dmach_t dma_ch; /* DMA channel (channel2 for audio) */ 
	u_int dma_ok; 
} audio_stream_t; 

static audio_stream_t output_stream; 
static audio_stream_t input_stream; /* input */ 

#define NEXT_BUF(_s_,_b_) { \ 
(_s_)->_b_##_idx++; \ 
(_s_)->_b_##_idx %= (_s_)->nbfrags; \ 
(_s_)->_b_ = (_s_)->buffers + (_s_)->_b_##_idx; } 


static u_int audio_rate; 
static int audio_channels; 
static int audio_fmt; 
static u_int audio_fragsize; 
static u_int audio_nbfrags; 


static int audio_rd_refcount; 
static int audio_wr_refcount; 
#define audio_active (audio_rd_refcount | audio_wr_refcount) 

static int audio_dev_dsp; 
static int audio_dev_mixer; 
static int audio_mix_modcnt; 

static int uda1341_volume; 
static u8 uda_sampling; 
static int uda1341_boost; 
static int mixer_igain=0x4; /* -6db*/ 

static void uda1341_l3_address(u8 data) 
{ 
	int i; 
	unsigned long flags; 

	local_irq_save(flags); 

// write_gpio_bit(GPIO_L3MODE, 0); 
	s3c2410_gpio_setpin(S3C2410_GPB2,0); 
// write_gpio_bit(GPIO_L3CLOCK, 1); 
	s3c2410_gpio_setpin(S3C2410_GPB4,1); 
	udelay(1); 

	for (i = 0; i < 8; i++) { 
		if (data & 0x1) { 
			s3c2410_gpio_setpin(S3C2410_GPB4,0); 
			s3c2410_gpio_setpin(S3C2410_GPB3,1); 
			udelay(1); 
			s3c2410_gpio_setpin(S3C2410_GPB4,1); 
		} else { 
			s3c2410_gpio_setpin(S3C2410_GPB4,0); 
			s3c2410_gpio_setpin(S3C2410_GPB3,0); 
			udelay(1); 
			s3c2410_gpio_setpin(S3C2410_GPB4,1); 
		} 
		data >>= 1; 
	} 

	s3c2410_gpio_setpin(S3C2410_GPB2,1); 
	s3c2410_gpio_setpin(S3C2410_GPB4,1); 
	local_irq_restore(flags); 
} 

static void uda1341_l3_data(u8 data) 
{ 
	int i; 
	unsigned long flags; 

	local_irq_save(flags); 
	udelay(1); 

	for (i = 0; i < 8; i++) { 
		if (data & 0x1) { 
			s3c2410_gpio_setpin(S3C2410_GPB4,0); 
			s3c2410_gpio_setpin(S3C2410_GPB3,1); 
			udelay(1); 
			s3c2410_gpio_setpin(S3C2410_GPB4,1); 
		} else { 
			s3c2410_gpio_setpin(S3C2410_GPB4,0); 
			s3c2410_gpio_setpin(S3C2410_GPB3,0); 
			udelay(1); 
			s3c2410_gpio_setpin(S3C2410_GPB4,1); 
		} 

		data >>= 1; 
	} 

	local_irq_restore(flags); 
} 

static void audio_clear_buf(audio_stream_t * s) 
{ 
	DPRINTK("audio_clear_buf\n"); 

	if(s->dma_ok) s3c2410_dma_ctrl(s->dma_ch, S3C2410_DMAOP_FLUSH); 

	if (s->buffers) { 
		int frag; 

		for (frag = 0; frag < s->nbfrags; frag++) { 
			if (!s->buffers[frag].master) 
				continue; 
			dma_free_coherent(NULL, 
			s->buffers[frag].master, 
			s->buffers[frag].start, 
			s->buffers[frag].dma_addr); 
		} 
		kfree(s->buffers); 
		s->buffers = NULL; 
	} 

	s->buf_idx = 0; 
	s->buf = NULL; 
} 

static int audio_setup_buf(audio_stream_t * s) 
{ 
	int frag; 
	int dmasize = 0; 
	char *dmabuf = 0; 
	dma_addr_t dmaphys = 0; 
	
	if (s->buffers) 
		return -EBUSY; 

	s->nbfrags = audio_nbfrags; 
	s->fragsize = audio_fragsize; 
	
	s->buffers = (audio_buf_t *) 
	kmalloc(sizeof(audio_buf_t) * s->nbfrags, GFP_KERNEL); 
	if (!s->buffers) 
		goto err; 
	memset(s->buffers, 0, sizeof(audio_buf_t) * s->nbfrags); 

	for (frag = 0; frag < s->nbfrags; frag++) { 
		audio_buf_t *b = &s->buffers[frag]; 

		if (!dmasize) { 
			dmasize = (s->nbfrags - frag) * s->fragsize; 
			do { 
				dmabuf = dma_alloc_coherent(NULL, dmasize, &dmaphys, GFP_KERNEL|GFP_DMA); 
				if (!dmabuf) 
				dmasize -= s->fragsize; 
			} while (!dmabuf && dmasize); 
				if (!dmabuf) 
					goto err; 
				b->master = dmasize; 
		} 

		b->start = dmabuf; 
		b->dma_addr = dmaphys; 
		sema_init(&b->sem, 1); 
		DPRINTK("buf %d: start %p dma %d\n", frag, b->start, b->dma_addr); 
		
		dmabuf += s->fragsize; 
		dmaphys += s->fragsize; 
		dmasize -= s->fragsize; 
	} 

	s->buf_idx = 0; 
	s->buf = &s->buffers[0]; 
	return 0; 
	
	err: 
	printk(AUDIO_NAME ": unable to allocate audio memory\n "); 
	audio_clear_buf(s); 
	return -ENOMEM; 
} 

static void audio_dmaout_done_callback(s3c2410_dma_chan_t *ch, void *buf, int size, 
s3c2410_dma_buffresult_t result) 
{ 
	audio_buf_t *b = (audio_buf_t *) buf; 
	up(&b->sem); 
	wake_up(&b->sem.wait); 
} 

static void audio_dmain_done_callback(s3c2410_dma_chan_t *ch, void *buf, int size, 
s3c2410_dma_buffresult_t result) 
{ 
	audio_buf_t *b = (audio_buf_t *) buf; 
	b->size = size; 
	up(&b->sem); 
	wake_up(&b->sem.wait); 
} 
/* using when write */ 
static int audio_sync(struct file *file) 
{ 
	audio_stream_t *s = &output_stream; 
	audio_buf_t *b = s->buf; 
	
	DPRINTK("audio_sync\n"); 
	
	if (!s->buffers) 
	return 0; 

	if (b->size != 0) { 
		down(&b->sem); 
		s3c2410_dma_enqueue(s->dma_ch, (void *) b, b->dma_addr, b->size); 
		b->size = 0; 
		NEXT_BUF(s, buf); 
	} 

	b = s->buffers + ((s->nbfrags + s->buf_idx - 1) % s->nbfrags); 
	if (down_interruptible(&b->sem)) 
	return -EINTR; 
	up(&b->sem); 
	
	return 0; 
} 

static inline int copy_from_user_mono_stereo(char *to, const char *from, int count) 
{ 
	u_int *dst = (u_int *)to; 
	const char *end = from + count; 

	if (verify_area(VERIFY_READ, from, count)) 
		return -EFAULT; 

	if ((int)from & 0x2) { 
		u_int v; 
		__get_user(v, (const u_short *)from); from += 2; 
		*dst++ = v | (v << 16); 
	} 

	while (from < end-2) { 
		u_int v, x, y; 
		__get_user(v, (const u_int *)from); from += 4; 
		x = v << 16; 
		x |= x >> 16; 
		y = v >> 16; 
		y |= y << 16; 
		*dst++ = x; 
		*dst++ = y; 
	} 

	if (from < end) { 
		u_int v; 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产福利一区在线观看| 亚洲欧洲国产日本综合| 久久狠狠亚洲综合| 日韩精品影音先锋| 激情国产一区二区| 中文字幕免费不卡在线| 不卡的av中国片| 亚洲图片欧美激情| 欧美美女bb生活片| 日韩成人一级片| 26uuu亚洲| 高清国产一区二区| 亚洲嫩草精品久久| 欧美顶级少妇做爰| 国内精品伊人久久久久av影院| 国产亚洲精品中文字幕| 99久久精品99国产精品| 亚洲chinese男男1069| 日韩欧美一卡二卡| 成人久久视频在线观看| 亚洲免费在线视频一区 二区| 欧美性色aⅴ视频一区日韩精品| 免费在线观看一区| 国产蜜臀97一区二区三区| 色狠狠桃花综合| 蜜桃精品在线观看| 中文字幕五月欧美| 欧美一区2区视频在线观看| 国产电影精品久久禁18| 一区二区三区色| 精品国产网站在线观看| 99久久国产综合精品女不卡| 日韩 欧美一区二区三区| 国产精品久久久久久户外露出 | 97精品视频在线观看自产线路二| 亚洲欧美日韩国产综合在线| 日韩欧美在线影院| 风间由美中文字幕在线看视频国产欧美 | av网站免费线看精品| 五月婷婷综合在线| 中文无字幕一区二区三区| 欧美电影一区二区三区| 成人午夜激情影院| 免费在线看成人av| 一区二区三区电影在线播| 国产午夜精品久久| 97久久精品人人澡人人爽| 久久99精品视频| 一区二区三区四区蜜桃 | 91福利精品第一导航| 国产一区二区精品久久91| 亚洲国产成人av网| 国产精品天干天干在线综合| 日韩精品一区在线| 欧美日韩卡一卡二| 97久久超碰国产精品电影| 国产精品亚洲一区二区三区妖精 | 欧美精品三级日韩久久| 不卡电影一区二区三区| 国产精品99久久久久久久vr| 日韩福利电影在线| 亚洲一区二区三区国产| 亚洲三级电影网站| 国产精品理论在线观看| 久久久久久久综合日本| 日韩午夜在线观看| 欧美一级搡bbbb搡bbbb| 欧美日韩1234| 精品视频色一区| 欧美日韩一区二区电影| 91久久一区二区| 日本韩国欧美在线| 91色.com| 日本二三区不卡| 色欧美片视频在线观看| 一本色道久久综合亚洲精品按摩| 不卡的av网站| av中文字幕不卡| 99国产精品久| 91在线视频网址| 91亚洲精品久久久蜜桃网站| 成人久久视频在线观看| 97久久久精品综合88久久| 9i看片成人免费高清| 97se亚洲国产综合自在线| 99久久伊人精品| 色婷婷久久久久swag精品| 在线观看欧美黄色| 欧美日韩一区二区欧美激情 | 日韩欧美成人激情| 欧美xingq一区二区| 日韩一级精品视频在线观看| 精品久久人人做人人爰| 国产日韩欧美精品一区| 中文字幕一区av| 亚洲制服丝袜av| 免费久久99精品国产| 精品一区二区三区在线视频| 国产一二精品视频| 99re热这里只有精品视频| 在线观看一区日韩| 7777精品伊人久久久大香线蕉 | 欧美在线视频你懂得| 欧美人xxxx| 日韩精品最新网址| 欧美国产一区二区在线观看| 亚洲天堂2014| 日韩影院精彩在线| 国产精品一级片| 色综合天天天天做夜夜夜夜做| 欧美性猛交xxxxxx富婆| 日韩欧美国产精品| 中文字幕精品一区| 性做久久久久久| 国产精品12区| 在线免费亚洲电影| 欧美mv和日韩mv国产网站| 欧美国产综合色视频| 亚洲国产欧美一区二区三区丁香婷 | 欧美日韩卡一卡二| 国产亚洲一区二区三区在线观看| 亚洲色图视频免费播放| 久久精品国产精品亚洲红杏| 99久久777色| 日韩一级视频免费观看在线| 亚洲视频免费看| 久久99精品久久久久久国产越南 | 亚洲美女在线国产| 美女网站在线免费欧美精品| 国产99一区视频免费| 欧美另类高清zo欧美| 国产精品久线观看视频| 免费在线观看日韩欧美| 在线视频亚洲一区| 欧美激情一区二区三区| 裸体歌舞表演一区二区| 在线一区二区三区做爰视频网站| 久久丝袜美腿综合| 视频一区欧美精品| 91国在线观看| 久久久久高清精品| 蜜臀av在线播放一区二区三区| 色狠狠综合天天综合综合| 中文字幕av不卡| 国产麻豆日韩欧美久久| 91精品国产综合久久久久久久久久 | 欧美精品一区二区三区蜜臀| 亚洲高清免费在线| 一本大道综合伊人精品热热| 日本一区二区在线不卡| 国产综合一区二区| 欧美一区二区三区日韩视频| 亚洲一区二区三区四区在线| 不卡高清视频专区| 欧美极品xxx| 国产伦精品一区二区三区在线观看| 亚洲精品国产精华液| 成人高清视频在线| 久久久精品综合| 青青草国产成人99久久| 亚洲国产精品久久人人爱蜜臀| 色婷婷精品大在线视频| 亚洲一区二区免费视频| 欧美一级黄色片| 成年人国产精品| 悠悠色在线精品| 777色狠狠一区二区三区| 免费成人你懂的| 国产精品家庭影院| 欧美日韩国产小视频在线观看| 亚洲影院久久精品| 免费在线观看一区| 91色在线porny| 亚洲免费大片在线观看| 91视频精品在这里| 亚洲精品乱码久久久久| 在线免费观看日韩欧美| 一区二区三区精品在线观看| 在线观看日产精品| 婷婷久久综合九色国产成人 | 色av成人天堂桃色av| 亚洲三级免费观看| 欧美专区日韩专区| 天堂一区二区在线| 精品少妇一区二区三区日产乱码 | 亚洲视频一区在线| 91黄色免费看| 日韩成人一区二区| 欧美v日韩v国产v| 国产精品一区二区无线| 国产精品视频一二三区| 一本久久综合亚洲鲁鲁五月天| 亚洲综合一二三区| 欧美一区二区大片| 国产精品一区免费视频| 日韩理论片网站| 欧美精品777| 国产乱人伦偷精品视频不卡| 中文字幕一区二区日韩精品绯色 | 日韩一级大片在线|