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

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

?? trident.c

?? linux和2410結合開發 用他可以生成2410所需的zImage文件
?? C
?? 第 1 頁 / 共 5 頁
字號:
				if(!ret)					ret = -ENXIO;				goto out;			}			continue;		}		if (copy_to_user(buffer, dmabuf->rawbuf + swptr, cnt)) {			if (!ret) ret = -EFAULT;			goto out;		}		swptr = (swptr + cnt) % dmabuf->dmasize;		spin_lock_irqsave(&state->card->lock, flags);		dmabuf->swptr = swptr;		dmabuf->count -= cnt;		spin_unlock_irqrestore(&state->card->lock, flags);		count -= cnt;		buffer += cnt;		ret += cnt;		start_adc(state);	}out:	up(&state->sem);	return ret;}/* in this loop, dmabuf.count signifies the amount of data that is waiting to be dma to   the soundcard.  it is drained by the dma machine and filled by this loop. */static ssize_t trident_write(struct file *file, const char *buffer, size_t count, loff_t *ppos){	struct trident_state *state = (struct trident_state *)file->private_data;	struct dmabuf *dmabuf = &state->dmabuf;	ssize_t ret;	unsigned long flags;	unsigned swptr;	int cnt;	unsigned int state_cnt;	unsigned int copy_count;#ifdef DEBUG	printk("trident: trident_write called, count = %d\n", count);#endif	VALIDATE_STATE(state);	if (ppos != &file->f_pos)		return -ESPIPE;		/*	 *	Guard against an mmap or ioctl while writing	 */		 	down(&state->sem);		if (dmabuf->mapped)	{		ret = -ENXIO;		goto out;	}	if (!dmabuf->ready && (ret = prog_dmabuf(state, 0)))		goto out;	if (!access_ok(VERIFY_READ, buffer, count))	{		ret= -EFAULT;		goto out;	}		ret = 0;	while (count > 0) {		spin_lock_irqsave(&state->card->lock, flags);		if (dmabuf->count < 0) {			/* buffer underrun, we are recovering from sleep_on_timeout,			   resync hwptr and swptr */			dmabuf->count = 0;			dmabuf->swptr = dmabuf->hwptr;		}		swptr = dmabuf->swptr;		cnt = dmabuf->dmasize - swptr;		if (dmabuf->count + cnt > dmabuf->dmasize)			cnt = dmabuf->dmasize - dmabuf->count;		spin_unlock_irqrestore(&state->card->lock, flags);		if (cnt > count)			cnt = count;		if (cnt <= 0) {			unsigned long tmo;			/* buffer is full, start the dma machine and wait for data to be			   played */			start_dac(state);			if (file->f_flags & O_NONBLOCK) {				if (!ret) ret = -EAGAIN;				goto out;			}			/* No matter how much data left in the buffer, we have to wait until			   CSO == ESO/2 or CSO == ESO when address engine interrupts */			lock_set_fmt(state);			tmo = (dmabuf->dmasize * HZ) / (dmabuf->rate * 2);			tmo >>= sample_shift[dmabuf->fmt];			unlock_set_fmt(state);			up(&state->sem);						/* There are two situations when sleep_on_timeout returns, one is when			   the interrupt is serviced correctly and the process is waked up by			   ISR ON TIME. Another is when timeout is expired, which means that			   either interrupt is NOT serviced correctly (pending interrupt) or it			   is TOO LATE for the process to be scheduled to run (scheduler latency)			   which results in a (potential) buffer underrun. And worse, there is			   NOTHING we can do to prevent it. */			if (!interruptible_sleep_on_timeout(&dmabuf->wait, tmo)) {#ifdef DEBUG				printk(KERN_ERR "trident: playback schedule timeout, "				       "dmasz %u fragsz %u count %i hwptr %u swptr %u\n",				       dmabuf->dmasize, dmabuf->fragsize, dmabuf->count,				       dmabuf->hwptr, dmabuf->swptr);#endif				/* a buffer underrun, we delay the recovery until next time the				   while loop begin and we REALLY have data to play */			}			if (signal_pending(current)) {				if (!ret) ret = -ERESTARTSYS;				goto out;			}			down(&state->sem);			if(dmabuf->mapped)			{				if(!ret)					ret = -ENXIO;				goto out;			}			continue;		}		lock_set_fmt(state);		if (state->chans_num == 6) {			copy_count = 0;			state_cnt = 0;			if (ali_write_5_1(state, buffer, cnt, &copy_count, &state_cnt) == -EFAULT) {				if (state_cnt){					swptr = (swptr + state_cnt) % dmabuf->dmasize;					spin_lock_irqsave(&state->card->lock, flags);					dmabuf->swptr = swptr;					dmabuf->count += state_cnt;					dmabuf->endcleared = 0;					spin_unlock_irqrestore(&state->card->lock, flags);				}				ret += copy_count;				if (!ret) ret = -EFAULT;				unlock_set_fmt(state);				goto out;			}		}		else {			if (copy_from_user(dmabuf->rawbuf + swptr, buffer, cnt)) {				if (!ret) ret = -EFAULT;				unlock_set_fmt(state);				goto out;			}			state_cnt = cnt;		}		unlock_set_fmt(state);				swptr = (swptr + state_cnt) % dmabuf->dmasize;						spin_lock_irqsave(&state->card->lock, flags);		dmabuf->swptr = swptr;		dmabuf->count += state_cnt;		dmabuf->endcleared = 0;		spin_unlock_irqrestore(&state->card->lock, flags);		count -= cnt;		buffer += cnt;			ret += cnt;		start_dac(state);	}out:	up(&state->sem);	return ret;}/* No kernel lock - we have our own spinlock */static unsigned int trident_poll(struct file *file, struct poll_table_struct *wait){	struct trident_state *state = (struct trident_state *)file->private_data;	struct dmabuf *dmabuf = &state->dmabuf;	unsigned long flags;	unsigned int mask = 0;	VALIDATE_STATE(state);	/*	 *	Guard against a parallel poll and write causing multiple	 *	prog_dmabuf events	 */	 	down(&state->sem);	if (file->f_mode & FMODE_WRITE) {		if (!dmabuf->ready && prog_dmabuf(state, 0))		{			up(&state->sem);			return 0;		}		poll_wait(file, &dmabuf->wait, wait);	}	if (file->f_mode & FMODE_READ) {		if (!dmabuf->ready && prog_dmabuf(state, 1))		{			up(&state->sem);			return 0;		}		poll_wait(file, &dmabuf->wait, wait);	}	up(&state->sem);		spin_lock_irqsave(&state->card->lock, flags);	trident_update_ptr(state);	if (file->f_mode & FMODE_READ) {		if (dmabuf->count >= (signed)dmabuf->fragsize)			mask |= POLLIN | POLLRDNORM;	}	if (file->f_mode & FMODE_WRITE) {		if (dmabuf->mapped) {			if (dmabuf->count >= (signed)dmabuf->fragsize)				mask |= POLLOUT | POLLWRNORM;		} else {			if ((signed)dmabuf->dmasize >= dmabuf->count + (signed)dmabuf->fragsize)				mask |= POLLOUT | POLLWRNORM;		}	}	spin_unlock_irqrestore(&state->card->lock, flags);	return mask;}static int trident_mmap(struct file *file, struct vm_area_struct *vma){	struct trident_state *state = (struct trident_state *)file->private_data;	struct dmabuf *dmabuf = &state->dmabuf;	int ret = -EINVAL;	unsigned long size;	VALIDATE_STATE(state);	lock_kernel();		/*	 *	Lock against poll read write or mmap creating buffers. Also lock	 *	a read or write against an mmap.	 */	 	down(&state->sem);		if (vma->vm_flags & VM_WRITE) {		if ((ret = prog_dmabuf(state, 0)) != 0)			goto out;	} else if (vma->vm_flags & VM_READ) {		if ((ret = prog_dmabuf(state, 1)) != 0)			goto out;	} else		goto out;	ret = -EINVAL;	if (vma->vm_pgoff != 0)		goto out;	size = vma->vm_end - vma->vm_start;	if (size > (PAGE_SIZE << dmabuf->buforder))		goto out;	ret = -EAGAIN;	if (remap_page_range(vma->vm_start, virt_to_phys(dmabuf->rawbuf),			     size, vma->vm_page_prot))		goto out;	dmabuf->mapped = 1;	ret = 0;out:	up(&state->sem);	unlock_kernel();	return ret;}static int trident_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg){	struct trident_state *state = (struct trident_state *)file->private_data;	struct dmabuf *dmabuf = &state->dmabuf;	unsigned long flags;	audio_buf_info abinfo;	count_info cinfo;	int val, mapped, ret = 0;	struct trident_card *card = state->card;	VALIDATE_STATE(state);	mapped = ((file->f_mode & FMODE_WRITE) && dmabuf->mapped) ||		((file->f_mode & FMODE_READ) && dmabuf->mapped);#ifdef DEBUG	printk("trident: trident_ioctl, command = %2d, arg = 0x%08x\n",	       _IOC_NR(cmd), arg ? *(int *)arg : 0);#endif	switch (cmd) 	{	case OSS_GETVERSION:		ret = put_user(SOUND_VERSION, (int *)arg);		break;			case SNDCTL_DSP_RESET:		/* FIXME: spin_lock ? */		if (file->f_mode & FMODE_WRITE) {			stop_dac(state);			synchronize_irq();			dmabuf->ready = 0;			dmabuf->swptr = dmabuf->hwptr = 0;			dmabuf->count = dmabuf->total_bytes = 0;		}		if (file->f_mode & FMODE_READ) {			stop_adc(state);			synchronize_irq();			dmabuf->ready = 0;			dmabuf->swptr = dmabuf->hwptr = 0;			dmabuf->count = dmabuf->total_bytes = 0;		}		break;	case SNDCTL_DSP_SYNC:		if (file->f_mode & FMODE_WRITE)			ret = drain_dac(state, file->f_flags & O_NONBLOCK);		break;	case SNDCTL_DSP_SPEED: /* set smaple rate */		if (get_user(val, (int *)arg))		{			ret = -EFAULT;			break;		}		if (val >= 0) {			if (file->f_mode & FMODE_WRITE) {				stop_dac(state);				dmabuf->ready = 0;				spin_lock_irqsave(&state->card->lock, flags);				trident_set_dac_rate(state, val);				spin_unlock_irqrestore(&state->card->lock, flags);			}			if (file->f_mode & FMODE_READ) {				stop_adc(state);				dmabuf->ready = 0;				spin_lock_irqsave(&state->card->lock, flags);				trident_set_adc_rate(state, val);				spin_unlock_irqrestore(&state->card->lock, flags);			}		}		ret = put_user(dmabuf->rate, (int *)arg);		break;	case SNDCTL_DSP_STEREO: /* set stereo or mono channel */		if (get_user(val, (int *)arg))		{			ret = -EFAULT;			break;		}		lock_set_fmt(state);		if (file->f_mode & FMODE_WRITE) {			stop_dac(state);			dmabuf->ready = 0;			if (val)				dmabuf->fmt |= TRIDENT_FMT_STEREO;			else				dmabuf->fmt &= ~TRIDENT_FMT_STEREO;		}		if (file->f_mode & FMODE_READ) {			stop_adc(state);			dmabuf->ready = 0;			if (val)				dmabuf->fmt |= TRIDENT_FMT_STEREO;			else				dmabuf->fmt &= ~TRIDENT_FMT_STEREO;		}		unlock_set_fmt(state);		break;	case SNDCTL_DSP_GETBLKSIZE:		if (file->f_mode & FMODE_WRITE) {			if ((val = prog_dmabuf(state, 0)))				ret = val;			else				ret = put_user(dmabuf->fragsize, (int *)arg);			break;		}		if (file->f_mode & FMODE_READ) {			if ((val = prog_dmabuf(state, 1)))				ret = val;			else				ret = put_user(dmabuf->fragsize, (int *)arg);			break;		}	case SNDCTL_DSP_GETFMTS: /* Returns a mask of supported sample format*/		ret = put_user(AFMT_S16_LE|AFMT_U16_LE|AFMT_S8|AFMT_U8, (int *)arg);		break;	case SNDCTL_DSP_SETFMT: /* Select sample format */		if (get_user(val, (int *)arg))		{			ret = -EFAULT;			break;		}		lock_set_fmt(state);		if (val != AFMT_QUERY) {			if (file->f_mode & FMODE_WRITE) {				stop_dac(state);				dmabuf->ready = 0;				if (val == AFMT_S16_LE)					dmabuf->fmt |= TRIDENT_FMT_16BIT;				else					dmabuf->fmt &= ~TRIDENT_FMT_16BIT;			}			if (file->f_mode & FMODE_READ) {				stop_adc(state);				dmabuf->ready = 0;				if (val == AFMT_S16_LE)					dmabuf->fmt |= TRIDENT_FMT_16BIT;				else					dmabuf->fmt &= ~TRIDENT_FMT_16BIT;			}		}		unlock_set_fmt(state);		ret = put_user((dmabuf->fmt & TRIDENT_FMT_16BIT) ?				AFMT_S16_LE : AFMT_U8, (int *)arg);		break;	case SNDCTL_DSP_CHANNELS:		if (get_user(val, (int *)arg))		{			ret = -EFAULT;			break;		}		if (val != 0) {			lock_set_fmt(state);			if (file->f_mode & FMODE_WRITE) {				stop_dac(state);				dmabuf->ready = 0;												//prevent from memory leak				if ((state->chans_num > 2) && (state->chans_num != val)) {					ali_free_other_states_resources(state);					state->chans_num =

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费一级片91| 欧美成人性战久久| 日韩av成人高清| 国产精品美女久久福利网站| 色狠狠色狠狠综合| 国产精品538一区二区在线| 国产精品丝袜在线| 日韩精品在线一区二区| 在线区一区二视频| 国产精品1区二区.| 亚洲福利一区二区三区| 精品粉嫩超白一线天av| 欧美三级三级三级| 国产成人亚洲综合色影视| 一区二区三区欧美日韩| 国产午夜精品美女毛片视频| 在线观看日产精品| 国产69精品久久久久777| 亚洲一区二区三区在线| 国产精品乱子久久久久| 欧美经典一区二区| 在线中文字幕一区二区| 大胆亚洲人体视频| 国产福利精品导航| 国产·精品毛片| 国模冰冰炮一区二区| 国产成人在线免费| 国产成人精品一区二| 国产精品一区在线| 国产一区 二区 三区一级| 日韩av一区二区在线影视| 亚洲综合一二区| 婷婷丁香激情综合| 天天综合色天天综合| 一区二区三区久久久| 亚洲一级电影视频| 丝袜诱惑亚洲看片| 黄色日韩三级电影| 成人激情动漫在线观看| 色婷婷综合久色| 7799精品视频| 精品噜噜噜噜久久久久久久久试看| 8v天堂国产在线一区二区| 精品久久久久久亚洲综合网| 久久久精品欧美丰满| 亚洲欧洲韩国日本视频| 日韩中文字幕不卡| 国产成人免费在线视频| 91成人免费在线视频| 久久精品亚洲精品国产欧美kt∨ | 一级日本不卡的影视| 国产成人夜色高潮福利影视| 久久精品在这里| 成人性色生活片| 久久久精品综合| 捆绑变态av一区二区三区| 欧美在线观看18| 一区二区三区毛片| 色爱区综合激月婷婷| 亚洲日本在线a| 波多野结衣视频一区| 中文字幕欧美一| av电影一区二区| 自拍偷在线精品自拍偷无码专区 | 久久精品国产一区二区三| 不卡在线视频中文字幕| 国产精品污www在线观看| 激情图区综合网| 日韩欧美国产电影| 国产精品影视在线| 国产精品久久久久久久午夜片| 国产成人在线影院| 中文字幕不卡三区| 欧美亚洲一区三区| 日韩成人午夜精品| 欧美精品一区二区三区蜜桃视频| 欧美日韩一区二区三区在线| 亚洲欧美日韩一区| 91精品国产欧美日韩| 欧美中文字幕一区| 亚洲欧洲成人精品av97| av一区二区三区在线| 蜜臀精品一区二区三区在线观看 | 久久久五月婷婷| 欧美猛男男办公室激情| 色婷婷av一区二区| 国产91精品免费| 国产精品中文字幕欧美| 免费在线看成人av| 婷婷久久综合九色综合伊人色| 国产精品美女一区二区三区| 久久国产精品无码网站| 亚洲精品日韩综合观看成人91| 国产乱码字幕精品高清av | 国产精品视频一二三区| 欧美中文字幕一区二区三区| 精品一区二区三区视频在线观看| 亚洲欧美偷拍另类a∨色屁股| 91麻豆精品久久久久蜜臀| 日韩电影免费在线观看网站| 欧美理论在线播放| 午夜精品一区二区三区免费视频| 91精品国产美女浴室洗澡无遮挡| 五月天精品一区二区三区| 欧美电视剧免费观看| 国产成人免费在线观看不卡| 亚洲免费观看高清完整版在线观看| 在线观看网站黄不卡| 麻豆精品视频在线观看| 日本一区二区视频在线| 欧美三级日韩三级国产三级| 精品无人码麻豆乱码1区2区| 国产精品人成在线观看免费| 欧美日韩在线免费视频| 国产一区二区福利| 五月天一区二区| 国产精品午夜久久| 777久久久精品| 91丨porny丨国产| 国产精品18久久久久久vr| 亚洲第一福利视频在线| 国产亚洲1区2区3区| 精品国产免费久久 | 91精彩视频在线| 欧美日产国产精品| 国产白丝网站精品污在线入口| 亚洲国产日日夜夜| 久久精品欧美日韩| 欧美色国产精品| 国产成人精品免费在线| 日韩中文字幕av电影| 亚洲卡通欧美制服中文| 日韩和欧美的一区| 日韩欧美区一区二| 99久久免费精品高清特色大片| 免费人成网站在线观看欧美高清| 精品无人码麻豆乱码1区2区| 国产黄色成人av| 色综合网站在线| 欧美一激情一区二区三区| 精品播放一区二区| 亚洲精品国产视频| 久久99国产精品久久99果冻传媒| 国产一区二区不卡在线| 色综合天天综合| 日韩精品一区在线| 国产精品久久久久久久岛一牛影视| 亚洲日本电影在线| 免费看欧美美女黄的网站| 波多野结衣在线一区| 欧美丰满美乳xxx高潮www| 久久精品欧美日韩精品| 亚洲成在人线免费| 国产成人在线视频免费播放| 欧美日韩视频在线第一区 | 亚洲日本va在线观看| 日韩成人午夜电影| 99国产欧美另类久久久精品| 欧美一区二区三区电影| 国产精品高清亚洲| 黄一区二区三区| 欧美日韩国产高清一区二区| 欧美国产丝袜视频| 天堂av在线一区| 91丨porny丨蝌蚪视频| 精品福利一区二区三区| 亚洲午夜日本在线观看| 成人免费毛片app| 久久综合色鬼综合色| 日韩综合在线视频| 91成人网在线| 日韩一区在线播放| 国产精品一区二区在线观看不卡| 69久久夜色精品国产69蝌蚪网| 亚洲同性同志一二三专区| 国产精品1024| 久久香蕉国产线看观看99| 日韩高清不卡一区| 欧美天堂亚洲电影院在线播放| 中文字幕免费观看一区| 国产精品一级黄| 欧美xfplay| 久久99国产精品尤物| 91精品综合久久久久久| 午夜精品久久久久久| 91九色02白丝porn| 亚洲精品国产一区二区三区四区在线 | 亚洲日穴在线视频| 成人三级在线视频| 亚洲国产成人自拍| 国产69精品久久久久毛片| 久久精品视频网| 成人免费高清视频| 中文字幕视频一区二区三区久| 成人美女在线观看| 亚洲女同一区二区| 色综合色狠狠天天综合色| 亚洲精品日韩一| 精品污污网站免费看| 天使萌一区二区三区免费观看|