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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? s3c2410-uda1341.c

?? Linux驅(qū)動編程源碼
?? 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; 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品中文在线观看| 日韩欧美国产精品一区| 国产精品国产三级国产有无不卡 | 国产精品初高中害羞小美女文| 豆国产96在线|亚洲| 中文字幕在线不卡一区| 91片在线免费观看| 亚洲福利电影网| 日韩免费看的电影| 粉嫩av一区二区三区| 亚洲欧美国产毛片在线| 欧美日本在线一区| 午夜精品成人在线视频| 欧美日本视频在线| 激情欧美日韩一区二区| 欧美精彩视频一区二区三区| 91一区一区三区| 奇米亚洲午夜久久精品| 国产免费成人在线视频| 色综合中文字幕| 看电视剧不卡顿的网站| 中文字幕av一区二区三区免费看 | 6080亚洲精品一区二区| 国产精品中文欧美| 亚洲男女一区二区三区| 日韩欧美专区在线| av电影在线观看完整版一区二区| 午夜伦欧美伦电影理论片| 久久天堂av综合合色蜜桃网| av资源站一区| 蜜桃精品视频在线| 亚洲视频精选在线| 2021中文字幕一区亚洲| 国产午夜亚洲精品理论片色戒 | 亚洲欧美日韩国产另类专区| 日韩一区和二区| 99热99精品| 精品系列免费在线观看| 亚洲综合免费观看高清在线观看| 26uuu久久天堂性欧美| 欧美日韩久久一区二区| 成人一区在线看| 美女国产一区二区三区| 一区二区三区波多野结衣在线观看| 日韩午夜在线影院| 在线视频一区二区免费| 高清国产一区二区三区| 美女视频黄 久久| 夜夜亚洲天天久久| 国产精品乱人伦| 精品国产三级a在线观看| 欧美专区日韩专区| av电影在线观看一区| 国产精品综合久久| 蜜桃视频一区二区三区在线观看| 亚洲一区二区在线视频| 亚洲人午夜精品天堂一二香蕉| 久久噜噜亚洲综合| 欧美成人精品二区三区99精品| 91精彩视频在线观看| 97久久久精品综合88久久| 国产一区激情在线| 狠狠色狠狠色综合日日91app| 日韩福利电影在线| 亚洲电影第三页| 亚洲一区二区三区爽爽爽爽爽| 中文字幕一区二区三区av| 中文一区一区三区高中清不卡| 欧美精品一区二| 日韩精品一区二区三区四区视频 | 亚洲精品一二三| 国产精品看片你懂得| 国产精品欧美极品| 国产精品久久影院| 中文字幕欧美一| 中文字幕制服丝袜一区二区三区| 欧美极品aⅴ影院| 国产欧美一区二区精品性色超碰| 久久影院视频免费| 国产亚洲精品7777| 国产精品卡一卡二卡三| 国产精品视频麻豆| 最好看的中文字幕久久| 一区二区三区成人在线视频| 亚洲一区二区三区影院| 亚洲自拍另类综合| 日日夜夜免费精品| 蜜臀精品久久久久久蜜臀 | 国产精品国产三级国产有无不卡 | 日本不卡一二三区黄网| 麻豆精品视频在线观看| 韩国av一区二区三区| 国产寡妇亲子伦一区二区| 成人免费av网站| 色综合久久天天| 欧美日韩精品免费| 日韩欧美成人午夜| 国产蜜臀97一区二区三区| 亚洲三级小视频| 天堂av在线一区| 国产一区二区成人久久免费影院| 不卡av在线免费观看| 欧美中文字幕一区| 日韩精品在线网站| 国产精品美女一区二区| 亚洲一级片在线观看| 美女久久久精品| av在线一区二区| 在线播放欧美女士性生活| 久久综合久久鬼色中文字| 自拍偷拍国产精品| 日韩高清电影一区| a4yy欧美一区二区三区| 欧美二区在线观看| 国产精品三级电影| 日韩电影在线免费看| 国产99久久久国产精品潘金| 欧美少妇bbb| 欧美经典三级视频一区二区三区| 亚洲国产视频直播| 国产成人av电影在线观看| 欧美日韩免费电影| 中文字幕第一区二区| 男人操女人的视频在线观看欧美| 成人激情图片网| 精品少妇一区二区三区日产乱码 | 亚洲六月丁香色婷婷综合久久 | 欧美一区午夜精品| 亚洲人吸女人奶水| 国产一区在线观看麻豆| 欧美色倩网站大全免费| 欧美激情综合网| 美女脱光内衣内裤视频久久影院| 色综合久久久久久久久| 久久精品视频一区二区| 青青草视频一区| 欧美色成人综合| 亚洲女人的天堂| 国产黄色精品网站| 日韩精品在线一区二区| 亚洲午夜三级在线| 91在线看国产| 欧美国产日韩一二三区| 国内外成人在线视频| 在线电影院国产精品| 亚洲一区二区三区四区在线| 99精品一区二区三区| 久久久久国产精品人| 美女视频黄免费的久久| 欧美三片在线视频观看| 亚洲色图制服诱惑| 成人在线视频一区二区| 久久影院视频免费| 毛片一区二区三区| 欧美一区二区三区喷汁尤物| 亚洲高清在线精品| 欧美性欧美巨大黑白大战| 一区二区三区在线视频观看| 91麻豆免费看| 亚洲手机成人高清视频| 91丨国产丨九色丨pron| 国产精品成人免费精品自在线观看 | 在线不卡一区二区| 天堂精品中文字幕在线| 欧美一区二区三区视频在线观看 | 国产精品第五页| 成人av手机在线观看| 中文字幕一区二区三区不卡 | 国产久卡久卡久卡久卡视频精品| 日韩免费高清电影| 久草这里只有精品视频| 26uuu久久天堂性欧美| 国产九色精品成人porny| 中文字幕 久热精品 视频在线| 国产91精品一区二区麻豆网站| 国产精品欧美久久久久无广告| www.亚洲色图| 亚洲精品乱码久久久久久久久| 色天使色偷偷av一区二区| 亚洲一区二区三区国产| 91精品国产综合久久精品性色| 日本特黄久久久高潮| 精品国产一区a| 成人午夜视频在线| 亚洲综合激情网| 91精品国产免费| 国产乱人伦偷精品视频免下载| 亚洲国产成人自拍| 色综合久久久网| 日韩成人精品视频| 久久九九全国免费| 一本久久精品一区二区| 日本亚洲电影天堂| 国产视频一区二区在线观看| 99re在线视频这里只有精品| 丝袜亚洲另类丝袜在线| 国产亚洲精品超碰| 欧美日韩一区小说| 国产精品综合在线视频| 一区二区三区免费网站|