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

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

?? patch_realtek.c

?? LINUX2.6.15的源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* * Universal Interface for Intel High Definition Audio Codec * * HD audio interface patch for ALC 260/880/882 codecs * * Copyright (c) 2004 PeiSen Hou <pshou@realtek.com.tw> *                    Takashi Iwai <tiwai@suse.de> * *  This driver 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 driver 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., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA */#include <sound/driver.h>#include <linux/init.h>#include <linux/delay.h>#include <linux/slab.h>#include <linux/pci.h>#include <sound/core.h>#include "hda_codec.h"#include "hda_local.h"/* ALC880 board config type */enum {	ALC880_3ST,	ALC880_3ST_DIG,	ALC880_5ST,	ALC880_5ST_DIG,	ALC880_W810,	ALC880_Z71V,	ALC880_AUTO,	ALC880_6ST,	ALC880_6ST_DIG,	ALC880_F1734,	ALC880_ASUS,	ALC880_ASUS_DIG,	ALC880_ASUS_W1V,	ALC880_UNIWILL_DIG,#ifdef CONFIG_SND_DEBUG	ALC880_TEST,#endif	ALC880_MODEL_LAST /* last tag */};/* ALC260 models */enum {	ALC260_BASIC,	ALC260_HP,	ALC260_FUJITSU_S702x,	ALC260_MODEL_LAST /* last tag */};/* amp values */#define AMP_IN_MUTE(idx)	(0x7080 | ((idx)<<8))#define AMP_IN_UNMUTE(idx)	(0x7000 | ((idx)<<8))#define AMP_OUT_MUTE	0xb080#define AMP_OUT_UNMUTE	0xb000#define AMP_OUT_ZERO	0xb000/* pinctl values */#define PIN_IN		0x20#define PIN_VREF80	0x24#define PIN_VREF50	0x21#define PIN_OUT		0x40#define PIN_HP		0xc0#define PIN_HP_AMP	0x80struct alc_spec {	/* codec parameterization */	snd_kcontrol_new_t *mixers[3];	/* mixer arrays */	unsigned int num_mixers;	const struct hda_verb *init_verbs[3];	/* initialization verbs						 * don't forget NULL termination!						 */	unsigned int num_init_verbs;	char *stream_name_analog;	/* analog PCM stream */	struct hda_pcm_stream *stream_analog_playback;	struct hda_pcm_stream *stream_analog_capture;	char *stream_name_digital;	/* digital PCM stream */ 	struct hda_pcm_stream *stream_digital_playback;	struct hda_pcm_stream *stream_digital_capture;	/* playback */	struct hda_multi_out multiout;	/* playback set-up					 * max_channels, dacs must be set					 * dig_out_nid and hp_nid are optional					 */	/* capture */	unsigned int num_adc_nids;	hda_nid_t *adc_nids;	hda_nid_t dig_in_nid;		/* digital-in NID; optional */	/* capture source */	const struct hda_input_mux *input_mux;	unsigned int cur_mux[3];	/* channel model */	const struct alc_channel_mode *channel_mode;	int num_channel_mode;	/* PCM information */	struct hda_pcm pcm_rec[2];	/* used in alc_build_pcms() */	/* dynamic controls, init_verbs and input_mux */	struct auto_pin_cfg autocfg;	unsigned int num_kctl_alloc, num_kctl_used;	snd_kcontrol_new_t *kctl_alloc;	struct hda_input_mux private_imux;	hda_nid_t private_dac_nids[4];};/* * input MUX handling */static int alc_mux_enum_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	return snd_hda_input_mux_info(spec->input_mux, uinfo);}static int alc_mux_enum_get(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);	ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];	return 0;}static int alc_mux_enum_put(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);	return snd_hda_input_mux_put(codec, spec->input_mux, ucontrol,				     spec->adc_nids[adc_idx], &spec->cur_mux[adc_idx]);}/* * channel mode setting */struct alc_channel_mode {	int channels;	const struct hda_verb *sequence;};static int alc880_ch_mode_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	int items = kcontrol->private_value ? (int)kcontrol->private_value : 2;	snd_assert(spec->channel_mode, return -ENXIO);	uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;	uinfo->count = 1;	uinfo->value.enumerated.items = items;	if (uinfo->value.enumerated.item >= items)		uinfo->value.enumerated.item = items - 1;	sprintf(uinfo->value.enumerated.name, "%dch",		spec->channel_mode[uinfo->value.enumerated.item].channels);	return 0;}static int alc880_ch_mode_get(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	int items = kcontrol->private_value ? (int)kcontrol->private_value : 2;	int i;	snd_assert(spec->channel_mode, return -ENXIO);	for (i = 0; i < items; i++) {		if (spec->multiout.max_channels == spec->channel_mode[i].channels) {			ucontrol->value.enumerated.item[0] = i;			break;		}	}	return 0;}static int alc880_ch_mode_put(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct alc_spec *spec = codec->spec;	int mode;	snd_assert(spec->channel_mode, return -ENXIO);	mode = ucontrol->value.enumerated.item[0] ? 1 : 0;	if (spec->multiout.max_channels == spec->channel_mode[mode].channels &&	    ! codec->in_resume)		return 0;	/* change the current channel setting */	spec->multiout.max_channels = spec->channel_mode[mode].channels;	if (spec->channel_mode[mode].sequence)		snd_hda_sequence_write(codec, spec->channel_mode[mode].sequence);	return 1;}/* * Control of pin widget settings via the mixer.  Only boolean settings are * supported, so VrefEn can't be controlled using these functions as they * stand. */static int alc_pinctl_switch_info(snd_kcontrol_t *kcontrol, snd_ctl_elem_info_t *uinfo){	uinfo->type = SNDRV_CTL_ELEM_TYPE_BOOLEAN;	uinfo->count = 1;	uinfo->value.integer.min = 0;	uinfo->value.integer.max = 1;	return 0;}static int alc_pinctl_switch_get(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	hda_nid_t nid = kcontrol->private_value & 0xffff;	long mask = (kcontrol->private_value >> 16) & 0xff;	long *valp = ucontrol->value.integer.value;	*valp = 0;	if (snd_hda_codec_read(codec,nid,0,AC_VERB_GET_PIN_WIDGET_CONTROL,0x00) & mask)		*valp = 1;	return 0;}static int alc_pinctl_switch_put(snd_kcontrol_t *kcontrol, snd_ctl_elem_value_t *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	hda_nid_t nid = kcontrol->private_value & 0xffff;	long mask = (kcontrol->private_value >> 16) & 0xff;	long *valp = ucontrol->value.integer.value;	unsigned int pinctl = snd_hda_codec_read(codec,nid,0,AC_VERB_GET_PIN_WIDGET_CONTROL,0x00);	int change = ((pinctl & mask)!=0) != *valp;	if (change)		snd_hda_codec_write(codec,nid,0,AC_VERB_SET_PIN_WIDGET_CONTROL,			*valp?(pinctl|mask):(pinctl&~mask));	return change;}#define ALC_PINCTL_SWITCH(xname, nid, mask) \	{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, .name = xname, .index = 0,  \	  .info = alc_pinctl_switch_info, \	  .get = alc_pinctl_switch_get, \	  .put = alc_pinctl_switch_put, \	  .private_value = (nid) | (mask<<16) }/* * ALC880 3-stack model * * DAC: Front = 0x02 (0x0c), Surr = 0x05 (0x0f), CLFE = 0x04 (0x0e) * Pin assignment: Front = 0x14, Line-In/Surr = 0x1a, Mic/CLFE = 0x18, F-Mic = 0x1b *                 HP = 0x19 */static hda_nid_t alc880_dac_nids[4] = {	/* front, rear, clfe, rear_surr */	0x02, 0x05, 0x04, 0x03};static hda_nid_t alc880_adc_nids[3] = {	/* ADC0-2 */	0x07, 0x08, 0x09,};/* The datasheet says the node 0x07 is connected from inputs, * but it shows zero connection in the real implementation on some devices. */static hda_nid_t alc880_adc_nids_alt[2] = {	/* ADC1-2 */	0x08, 0x09,};#define ALC880_DIGOUT_NID	0x06#define ALC880_DIGIN_NID	0x0astatic struct hda_input_mux alc880_capture_source = {	.num_items = 4,	.items = {		{ "Mic", 0x0 },		{ "Front Mic", 0x3 },		{ "Line", 0x2 },		{ "CD", 0x4 },	},};/* channel source setting (2/6 channel selection for 3-stack) *//* 2ch mode */static struct hda_verb alc880_threestack_ch2_init[] = {	/* set line-in to input, mute it */	{ 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN },	{ 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },	/* set mic-in to input vref 80%, mute it */	{ 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 },	{ 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },	{ } /* end */};/* 6ch mode */static struct hda_verb alc880_threestack_ch6_init[] = {	/* set line-in to output, unmute it */	{ 0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },	{ 0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },	/* set mic-in to output, unmute it */	{ 0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT },	{ 0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },	{ } /* end */};static struct alc_channel_mode alc880_threestack_modes[2] = {	{ 2, alc880_threestack_ch2_init },	{ 6, alc880_threestack_ch6_init },};static snd_kcontrol_new_t alc880_three_stack_mixer[] = {	HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),	HDA_BIND_MUTE("Front Playback Switch", 0x0c, 2, HDA_INPUT),	HDA_CODEC_VOLUME("Surround Playback Volume", 0x0f, 0x0, HDA_OUTPUT),	HDA_BIND_MUTE("Surround Playback Switch", 0x0f, 2, HDA_INPUT),	HDA_CODEC_VOLUME_MONO("Center Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_MONO("LFE Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),	HDA_BIND_MUTE_MONO("Center Playback Switch", 0x0e, 1, 2, HDA_INPUT),	HDA_BIND_MUTE_MONO("LFE Playback Switch", 0x0e, 2, 2, HDA_INPUT),	HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),	HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),	HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),	HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),	HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),	HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),	HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x3, HDA_INPUT),	HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x3, HDA_INPUT),	HDA_CODEC_VOLUME("PC Speaker Playback Volume", 0x0b, 0x05, HDA_INPUT),	HDA_CODEC_MUTE("PC Speaker Playback Switch", 0x0b, 0x05, HDA_INPUT),	HDA_CODEC_MUTE("Headphone Playback Switch", 0x19, 0x0, HDA_OUTPUT),	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = "Channel Mode",		.info = alc880_ch_mode_info,		.get = alc880_ch_mode_get,		.put = alc880_ch_mode_put,	},	{ } /* end */};/* capture mixer elements */static snd_kcontrol_new_t alc880_capture_mixer[] = {	HDA_CODEC_VOLUME("Capture Volume", 0x07, 0x0, HDA_INPUT),	HDA_CODEC_MUTE("Capture Switch", 0x07, 0x0, HDA_INPUT),	HDA_CODEC_VOLUME_IDX("Capture Volume", 1, 0x08, 0x0, HDA_INPUT),	HDA_CODEC_MUTE_IDX("Capture Switch", 1, 0x08, 0x0, HDA_INPUT),	HDA_CODEC_VOLUME_IDX("Capture Volume", 2, 0x09, 0x0, HDA_INPUT),	HDA_CODEC_MUTE_IDX("Capture Switch", 2, 0x09, 0x0, HDA_INPUT),	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		/* The multiple "Capture Source" controls confuse alsamixer		 * So call somewhat different..		 * FIXME: the controls appear in the "playback" view!		 */		/* .name = "Capture Source", */		.name = "Input Source",		.count = 3,		.info = alc_mux_enum_info,		.get = alc_mux_enum_get,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品福利影院| 视频一区二区三区入口| 亚洲电影激情视频网站| 精品系列免费在线观看| 色吧成人激情小说| 国产日韩欧美麻豆| 久久精品国产亚洲5555| 欧美中文字幕一区| 自拍偷拍国产亚洲| 国产精品夜夜嗨| 欧美不卡视频一区| 日韩中文字幕91| 在线免费不卡视频| 亚洲精品一二三| 成年人国产精品| 国产偷国产偷亚洲高清人白洁| 午夜精品一区二区三区电影天堂| 99久久久国产精品免费蜜臀| 久久精品亚洲麻豆av一区二区| 男女性色大片免费观看一区二区| 欧美又粗又大又爽| 亚洲精品大片www| 一本大道av一区二区在线播放| 中国色在线观看另类| 国产一区二区三区电影在线观看 | 亚洲一区二区在线免费观看视频| 国产成a人亚洲精品| 中文字幕五月欧美| 激情综合色播五月| 精品88久久久久88久久久| 美女久久久精品| 日韩欧美国产一区二区在线播放| 人人爽香蕉精品| 日韩女优电影在线观看| 麻豆传媒一区二区三区| 久久综合色鬼综合色| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 久久亚洲精精品中文字幕早川悠里 | 菠萝蜜视频在线观看一区| 欧美国产日韩精品免费观看| 国产精品亚洲午夜一区二区三区| 国产色一区二区| 99精品视频在线免费观看| 亚洲欧美偷拍卡通变态| 91激情在线视频| 亚洲18色成人| 欧美变态口味重另类| 国产精品123| 亚洲色图欧美在线| 欧美日韩精品免费观看视频| 日韩精品亚洲一区| 精品久久久三级丝袜| 国产精品香蕉一区二区三区| 国产精品传媒入口麻豆| 色狠狠色噜噜噜综合网| 奇米精品一区二区三区在线观看| 2021久久国产精品不只是精品| 成人国产亚洲欧美成人综合网| 一区二区三区久久| 日韩欧美国产电影| 99国产麻豆精品| 午夜精品一区二区三区电影天堂| 2017欧美狠狠色| 91成人免费在线视频| 捆绑调教美女网站视频一区| 国产精品网站在线播放| 欧美丰满少妇xxxxx高潮对白| 国产精品一区二区你懂的| 亚洲综合小说图片| 精品国产a毛片| 91美女福利视频| 国模无码大尺度一区二区三区| 国产精品免费aⅴ片在线观看| 欧美日韩成人一区| 成人高清在线视频| 日本欧美一区二区三区乱码| 1024成人网色www| 精品国产一区二区在线观看| 色狠狠桃花综合| 国产精品羞羞答答xxdd| 日本欧美大码aⅴ在线播放| 黑人精品欧美一区二区蜜桃| 亚洲欧美一区二区久久| 久久久av毛片精品| 欧美日韩国产123区| 99久久99久久免费精品蜜臀| 国产在线视频精品一区| 天天色天天操综合| 亚洲欧美日韩国产一区二区三区 | 国产精品久久久久久久久免费相片| 欧美日韩国产大片| 91女神在线视频| 国产成人综合亚洲网站| 日本不卡一区二区三区| 一区av在线播放| 亚洲欧洲在线观看av| 欧美激情艳妇裸体舞| 欧美大片日本大片免费观看| 欧美卡1卡2卡| 欧美三区免费完整视频在线观看| 99久久国产综合精品色伊| 国产a精品视频| 懂色中文一区二区在线播放| 韩国一区二区在线观看| 久久99精品视频| 免费在线观看成人| 美女尤物国产一区| 日本va欧美va精品发布| 三级不卡在线观看| 五月激情丁香一区二区三区| 亚洲综合小说图片| 亚洲国产你懂的| 欧美日本乱大交xxxxx| 欧美96一区二区免费视频| 国产婷婷一区二区| 国产亚洲自拍一区| eeuss鲁片一区二区三区在线观看| 亚洲欧美另类在线| 久久久影视传媒| 欧美一区二区三区的| 99精品国产视频| 久色婷婷小香蕉久久| 亚洲成人av电影| 中文字幕av一区二区三区| 欧美一区二区播放| 婷婷中文字幕综合| 国产清纯白嫩初高生在线观看91| 欧美va亚洲va在线观看蝴蝶网| 精品少妇一区二区| 国产日韩一级二级三级| 中文字幕亚洲一区二区va在线| 中文字幕在线不卡一区| 一区二区三区久久久| 日韩不卡在线观看日韩不卡视频| 另类小说图片综合网| 国产麻豆日韩欧美久久| 岛国一区二区三区| 欧美自拍偷拍一区| 国产日韩欧美a| 中文字幕制服丝袜一区二区三区| 国产精品久久久久一区二区三区共| 18成人在线视频| 天天色天天爱天天射综合| 国产精品性做久久久久久| 91蝌蚪porny| 日韩一区二区三区观看| 国产精品色在线| 污片在线观看一区二区| 狠狠色丁香久久婷婷综| 91亚洲精品一区二区乱码| 5566中文字幕一区二区电影 | 不卡一区中文字幕| 欧美日韩成人综合天天影院| 亚洲精品一区二区三区精华液| 国产精品视频麻豆| 日韩中文字幕91| av一区二区不卡| 日韩一级大片在线观看| 亚洲欧洲一区二区在线播放| 人人爽香蕉精品| 色婷婷精品久久二区二区蜜臀av | 欧美精三区欧美精三区| 国产精品视频九色porn| 美国毛片一区二区三区| 91丨九色丨蝌蚪丨老版| 2021久久国产精品不只是精品| 亚洲一区二区三区激情| 丁香激情综合国产| 在线综合+亚洲+欧美中文字幕| 亚洲四区在线观看| 国产精品一区二区91| 日韩片之四级片| 亚洲444eee在线观看| 色综合天天综合狠狠| 国产偷v国产偷v亚洲高清| 久久精品国产第一区二区三区| 欧美体内she精视频| 欧美经典三级视频一区二区三区| 免费观看成人av| 欧美日韩久久久久久| 一区二区理论电影在线观看| 成人毛片在线观看| 久久精品在线观看| 韩国成人在线视频| 精品国产制服丝袜高跟| 蜜桃传媒麻豆第一区在线观看| 国产精品色婷婷| 精品一区二区成人精品| 欧美一级黄色片| 日本网站在线观看一区二区三区| 欧美在线影院一区二区| 亚洲乱码中文字幕综合| 成人91在线观看| **网站欧美大片在线观看| 不卡视频一二三| 国产精品乱人伦| 91视视频在线直接观看在线看网页在线看| 久久五月婷婷丁香社区| 国产成人激情av| 中文字幕 久热精品 视频在线 |