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

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

?? mixer.c

?? LINUX 2.6.17.4的源碼
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
				ret = -EFAULT;			break;		case CMD_GETCTLGPR:			addr = emu10k1_find_control_gpr(&card->mgr, (char *) ctl->val, &((char *) ctl->val)[PATCH_NAME_SIZE]);			ctl->val[0] = sblive_readptr(card, addr, 0);			if (copy_to_user(argp, ctl, sizeof(struct mixer_private_ioctl)))				ret = -EFAULT;			break;		case CMD_SETPATCH:			if (ctl->val[0] == 0)				memcpy(&card->mgr.rpatch, &ctl->val[1], sizeof(struct dsp_rpatch));			else {				page = (ctl->val[0] - 1) / PATCHES_PER_PAGE;				if (page > MAX_PATCHES_PAGES) {					ret = -EINVAL;					break;				}				if (page >= card->mgr.current_pages) {					for (i = card->mgr.current_pages; i < page + 1; i++) {				                card->mgr.patch[i] = (void *)__get_free_page(GFP_KERNEL);						if(card->mgr.patch[i] == NULL) {							card->mgr.current_pages = i;							ret = -ENOMEM;							break;						}						memset(card->mgr.patch[i], 0, PAGE_SIZE);					}					card->mgr.current_pages = page + 1;				}				patch = PATCH(&card->mgr, ctl->val[0] - 1);				memcpy(patch, &ctl->val[1], sizeof(struct dsp_patch));				if (patch->code_size == 0) {					for(i = page + 1; i < card->mgr.current_pages; i++)                                                free_page((unsigned long) card->mgr.patch[i]);					card->mgr.current_pages = page + 1;				}			}			break;		case CMD_SETGPR:			if (ctl->val[0] > NUM_GPRS) {				ret = -EINVAL;				break;			}			memcpy(&card->mgr.gpr[ctl->val[0]], &ctl->val[1], sizeof(struct dsp_gpr));			break;		case CMD_SETCTLGPR:			addr = emu10k1_find_control_gpr(&card->mgr, (char *) ctl->val, (char *) ctl->val + PATCH_NAME_SIZE);			emu10k1_set_control_gpr(card, addr, *((s32 *)((char *) ctl->val + 2 * PATCH_NAME_SIZE)), 0);			break;		case CMD_SETGPOUT:			if ( ((ctl->val[0] > 2) && (!card->is_audigy))			     || (ctl->val[0] > 15) || ctl->val[1] > 1) {				ret= -EINVAL;				break;			}			if (card->is_audigy)				emu10k1_writefn0(card, (1 << 24) | ((ctl->val[0]) << 16) | A_IOCFG, ctl->val[1]);			else				emu10k1_writefn0(card, (1 << 24) | (((ctl->val[0]) + 10) << 16) | HCFG, ctl->val[1]);			break;		case CMD_GETGPR2OSS:			id = ctl->val[0];			ch = ctl->val[1];			if (id >= SOUND_MIXER_NRDEVICES || ch >= 2) {				ret = -EINVAL;				break;			}			ctl->val[2] = card->mgr.ctrl_gpr[id][ch];			if (copy_to_user(argp, ctl, sizeof(struct mixer_private_ioctl)))				ret = -EFAULT;			break;		case CMD_SETGPR2OSS:			id = ctl->val[0];			/* 0 == left, 1 == right */			ch = ctl->val[1];			addr = ctl->val[2];			if (id >= SOUND_MIXER_NRDEVICES || ch >= 2) {				ret = -EINVAL;				break;			}			card->mgr.ctrl_gpr[id][ch] = addr;			if (card->is_aps)				break;			if (addr >= 0) {				unsigned int state = card->ac97->mixer_state[id];				if (ch == 1) {					state >>= 8;					card->ac97->stereo_mixers |= (1 << id);				}				card->ac97->supported_mixers |= (1 << id);				if (id == SOUND_MIXER_TREBLE) {					set_treble(card, card->ac97->mixer_state[id] & 0xff, (card->ac97->mixer_state[id] >> 8) & 0xff);				} else if (id == SOUND_MIXER_BASS) {					set_bass(card, card->ac97->mixer_state[id] & 0xff, (card->ac97->mixer_state[id] >> 8) & 0xff);				} else					emu10k1_set_volume_gpr(card, addr, state & 0xff,							       volume_params[id]);			} else {				card->ac97->stereo_mixers &= ~(1 << id);				card->ac97->stereo_mixers |= card->ac97_stereo_mixers;				if (ch == 0) {					card->ac97->supported_mixers &= ~(1 << id);					card->ac97->supported_mixers |= card->ac97_supported_mixers;				}			}			break;		case CMD_SETPASSTHROUGH:			card->pt.selected = ctl->val[0] ? 1 : 0;			if (card->pt.state != PT_STATE_INACTIVE)				break;			card->pt.spcs_to_use = ctl->val[0] & 0x07;			break;		case CMD_PRIVATE3_VERSION:			ctl->val[0] = PRIVATE3_VERSION;	//private3 version			ctl->val[1] = MAJOR_VER;	//major driver version			ctl->val[2] = MINOR_VER;	//minor driver version			ctl->val[3] = card->is_audigy;	//1=card is audigy			if (card->is_audigy)				ctl->val[4]=emu10k1_readfn0(card, 0x18);			if (copy_to_user(argp, ctl, sizeof(struct mixer_private_ioctl)))				ret = -EFAULT;			break;		case CMD_AC97_BOOST:			if (ctl->val[0])				emu10k1_ac97_write(card->ac97, 0x18, 0x0);				else				emu10k1_ac97_write(card->ac97, 0x18, 0x0808);			break;		default:			ret = -EINVAL;			break;		}		kfree(ctl);		return ret;		break;	case SOUND_MIXER_PRIVATE4:		if (copy_from_user(&size, argp, sizeof(size)))			return -EFAULT;		DPD(2, "External tram size %#x\n", size);		if (size > 0x1fffff)			return -EINVAL;		size_reg = 0;		if (size != 0) {			size = (size - 1) >> 14;			while (size) {				size >>= 1;				size_reg++;			}			size = 0x4000 << size_reg;		}		DPD(2, "External tram size %#x %#x\n", size, size_reg);		if (size != card->tankmem.size) {			if (card->tankmem.size > 0) {				emu10k1_writefn0(card, HCFG_LOCKTANKCACHE, 1);				sblive_writeptr_tag(card, 0, TCB, 0, TCBS, 0, TAGLIST_END);				pci_free_consistent(card->pci_dev, card->tankmem.size, card->tankmem.addr, card->tankmem.dma_handle);				card->tankmem.size = 0;			}			if (size != 0) {				card->tankmem.addr = pci_alloc_consistent(card->pci_dev, size, &card->tankmem.dma_handle);				if (card->tankmem.addr == NULL)					return -ENOMEM;				card->tankmem.size = size;				sblive_writeptr_tag(card, 0, TCB, (u32) card->tankmem.dma_handle, TCBS,(u32) size_reg, TAGLIST_END);				emu10k1_writefn0(card, HCFG_LOCKTANKCACHE, 0);			}		}		return 0;		break;	default:		break;	}	return -EINVAL;}static int emu10k1_dsp_mixer(struct emu10k1_card *card, unsigned int oss_mixer, unsigned long arg){	unsigned int left, right;	int val;	int scale;	card->ac97->modcnt++;	if (get_user(val, (int __user *)arg))		return -EFAULT;	/* cleanse input a little */	right = ((val >> 8)  & 0xff);	left = (val  & 0xff);	if (right > 100) right = 100;	if (left > 100) left = 100;	card->ac97->mixer_state[oss_mixer] = (right << 8) | left;	if (oss_mixer == SOUND_MIXER_TREBLE) {		set_treble(card, left, right);		return 0;	} if (oss_mixer == SOUND_MIXER_BASS) {		set_bass(card, left, right);		return 0;	}	if (oss_mixer == SOUND_MIXER_VOLUME)		scale = 1 << card->ac97->bit_resolution;	else		scale = volume_params[oss_mixer];	emu10k1_set_volume_gpr(card, card->mgr.ctrl_gpr[oss_mixer][0], left, scale);	emu10k1_set_volume_gpr(card, card->mgr.ctrl_gpr[oss_mixer][1], right, scale);	if (card->ac97_supported_mixers & (1 << oss_mixer))		card->ac97->write_mixer(card->ac97, oss_mixer, left, right);	return 0;}static int emu10k1_mixer_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long arg){	int ret;	struct emu10k1_card *card = file->private_data;	unsigned int oss_mixer = _IOC_NR(cmd);		ret = -EINVAL;	if (!card->is_aps) {		if (cmd == SOUND_MIXER_INFO) {			mixer_info info;			strlcpy(info.id, card->ac97->name, sizeof(info.id));			if (card->is_audigy)				strlcpy(info.name, "Audigy - Emu10k1", sizeof(info.name));			else				strlcpy(info.name, "Creative SBLive - Emu10k1", sizeof(info.name));							info.modify_counter = card->ac97->modcnt;			if (copy_to_user((void __user *)arg, &info, sizeof(info)))				return -EFAULT;			return 0;		}		if ((_SIOC_DIR(cmd) == (_SIOC_WRITE|_SIOC_READ)) && oss_mixer <= SOUND_MIXER_NRDEVICES)			ret = emu10k1_dsp_mixer(card, oss_mixer, arg);		else			ret = card->ac97->mixer_ioctl(card->ac97, cmd, arg);	}		if (ret < 0)		ret = emu10k1_private_mixer(card, cmd, arg);	return ret;}static int emu10k1_mixer_open(struct inode *inode, struct file *file){	int minor = iminor(inode);	struct emu10k1_card *card = NULL;	struct list_head *entry;	DPF(4, "emu10k1_mixer_open()\n");	list_for_each(entry, &emu10k1_devs) {		card = list_entry(entry, struct emu10k1_card, list);		if (card->ac97->dev_mixer == minor)			goto match;	}	return -ENODEV;      match:	file->private_data = card;	return 0;}static int emu10k1_mixer_release(struct inode *inode, struct file *file){	DPF(4, "emu10k1_mixer_release()\n");	return 0;}struct file_operations emu10k1_mixer_fops = {	.owner		= THIS_MODULE,	.llseek		= no_llseek,	.ioctl		= emu10k1_mixer_ioctl,	.open		= emu10k1_mixer_open,	.release	= emu10k1_mixer_release,};

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区私人影院日本| 欧美日产在线观看| 日韩精品国产欧美| 国产欧美日韩一区二区三区在线观看| 成人国产精品免费观看动漫| 日韩二区三区四区| 亚洲精品久久嫩草网站秘色| 久久综合久久综合九色| 欧美视频在线一区二区三区| 国产成人一区二区精品非洲| 五月天精品一区二区三区| 国产精品欧美一区喷水| 久久综合国产精品| 日韩欧美高清一区| 91精品国产综合久久精品图片 | 精品区一区二区| 6080日韩午夜伦伦午夜伦| 色噜噜久久综合| 欧美在线一二三| 欧美亚洲国产一区二区三区va| 成人免费视频caoporn| 精品一区二区三区蜜桃| 日欧美一区二区| 伦理电影国产精品| 九九视频精品免费| 国产精品亚洲第一| 国产 日韩 欧美大片| 成人激情视频网站| 色先锋久久av资源部| 91精品欧美综合在线观看最新| 欧美精品日日鲁夜夜添| 6080国产精品一区二区| 91麻豆精品国产自产在线观看一区| 欧美福利一区二区| 久久蜜桃av一区精品变态类天堂 | 中文字幕欧美国产| 中文字幕人成不卡一区| 亚洲综合久久av| 精品夜夜嗨av一区二区三区| 成人午夜视频在线观看| 93久久精品日日躁夜夜躁欧美| 欧美这里有精品| 欧美精品一区二区三区高清aⅴ| 久久久99精品久久| 亚洲精品国产无天堂网2021| 美国毛片一区二区三区| 99国产精品久久久久久久久久久| 欧美久久一区二区| 中文字幕欧美一| 另类欧美日韩国产在线| 一本色道久久综合亚洲精品按摩| 日韩一区二区影院| 亚洲一区二区三区三| 国产精品亚洲人在线观看| 欧美日本国产一区| 亚洲色图欧美偷拍| 国产mv日韩mv欧美| 日韩亚洲欧美综合| 亚洲成年人影院| 色婷婷亚洲婷婷| 国产精品福利电影一区二区三区四区| 日韩国产在线观看| 在线观看视频一区二区| 成人欧美一区二区三区小说| 99re这里只有精品首页| 精品伦理精品一区| 日韩在线一区二区三区| 欧洲亚洲精品在线| 亚洲欧美日韩人成在线播放| 成人午夜电影久久影院| 国产三级欧美三级日产三级99| 日韩av不卡一区二区| 制服丝袜av成人在线看| 婷婷六月综合亚洲| 欧美一级夜夜爽| 毛片基地黄久久久久久天堂| 日韩精品最新网址| 韩国av一区二区三区| 国产亚洲精品bt天堂精选| 国产激情91久久精品导航| 国产精品福利一区| 欧美日韩一区高清| 九九精品一区二区| 国产精品理论片在线观看| 97精品国产露脸对白| 亚洲v日本v欧美v久久精品| 欧美一级在线视频| 国产精品一卡二卡在线观看| 日韩毛片一二三区| 欧美一区欧美二区| 高清在线不卡av| 香蕉影视欧美成人| 国产视频亚洲色图| 欧美久久一区二区| 成人国产精品免费网站| 午夜日韩在线电影| 国产精品视频免费| 51精品久久久久久久蜜臀| 国产a级毛片一区| 男女视频一区二区| 一区二区三区精品久久久| 日韩视频免费观看高清完整版在线观看 | 国产xxx精品视频大全| 亚洲午夜视频在线| 国产精品国产自产拍在线| 91精品国产91综合久久蜜臀| 欧美性受xxxx| 国产91丝袜在线播放0| 亚洲成人先锋电影| 一个色在线综合| 国产精品免费视频一区| 精品入口麻豆88视频| 欧美日韩高清影院| 在线观看日韩一区| 91丝袜美女网| a在线播放不卡| 国产一二三精品| 捆绑调教美女网站视频一区| 亚洲不卡在线观看| 亚洲成人免费av| 五月天网站亚洲| 免费观看久久久4p| 美女国产一区二区| 韩国女主播成人在线| 韩国欧美一区二区| 国产黄色成人av| 99这里都是精品| 一本久久综合亚洲鲁鲁五月天| aaa欧美大片| 欧洲一区在线电影| 51精品久久久久久久蜜臀| 91麻豆精品91久久久久久清纯| 欧美日韩国产片| 日韩欧美你懂的| 国产精品婷婷午夜在线观看| 亚洲日本电影在线| 午夜视频一区在线观看| 捆绑紧缚一区二区三区视频| 国产一区二区三区在线观看免费视频| 国产美女娇喘av呻吟久久| 国产在线乱码一区二区三区| 成人中文字幕在线| 色婷婷精品久久二区二区蜜臀av| 欧美日韩视频第一区| 精品成人一区二区| 又紧又大又爽精品一区二区| 蜜桃一区二区三区四区| 91片在线免费观看| 精品久久久久久最新网址| 日韩国产精品久久久久久亚洲| 日本少妇一区二区| 色综合天天综合| 精品女同一区二区| 亚洲一级片在线观看| 国内一区二区视频| 3atv一区二区三区| 夜夜嗨av一区二区三区| 国产高清成人在线| 欧美xfplay| 日韩—二三区免费观看av| 91麻豆视频网站| 国产色91在线| 激情久久五月天| 日韩亚洲欧美在线| 丝袜美腿一区二区三区| 色哟哟在线观看一区二区三区| 国产女同性恋一区二区| 九色综合狠狠综合久久| 欧美日本一道本在线视频| 亚洲午夜电影在线观看| 色呦呦国产精品| 亚洲免费av网站| 日本韩国一区二区| 亚洲一区二区三区中文字幕在线 | 欧美sm极限捆绑bd| 久久国产乱子精品免费女| 精品国产一区二区三区不卡| 免费在线视频一区| 日韩情涩欧美日韩视频| 久久91精品久久久久久秒播| 精品国产乱子伦一区| 国产精品69毛片高清亚洲| 国产欧美日韩在线视频| 成人亚洲精品久久久久软件| 中文字幕永久在线不卡| 日本福利一区二区| 视频在线在亚洲| 国产亚洲自拍一区| 色婷婷综合五月| 久久aⅴ国产欧美74aaa| 久久久久久久综合色一本| www.激情成人| 亚洲国产色一区| 国产欧美1区2区3区| 欧美怡红院视频| 国产二区国产一区在线观看| 亚洲女性喷水在线观看一区| 国产精品少妇自拍| 欧美色综合久久| 亚洲欧洲综合另类在线|