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

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

?? patch_sigmatel.c

?? linux 內核源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
/* * Universal Interface for Intel High Definition Audio Codec * * HD audio interface patch for SigmaTel STAC92xx * * Copyright (c) 2005 Embedded Alley Solutions, Inc. * Matt Porter <mporter@embeddedalley.com> * * Based on patch_cmedia.c and patch_realtek.c * Copyright (c) 2004 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 <sound/asoundef.h>#include "hda_codec.h"#include "hda_local.h"#define NUM_CONTROL_ALLOC	32#define STAC_HP_EVENT		0x37enum {	STAC_REF,	STAC_9200_DELL_D21,	STAC_9200_DELL_D22,	STAC_9200_DELL_D23,	STAC_9200_DELL_M21,	STAC_9200_DELL_M22,	STAC_9200_DELL_M23,	STAC_9200_DELL_M24,	STAC_9200_DELL_M25,	STAC_9200_DELL_M26,	STAC_9200_DELL_M27,	STAC_9200_GATEWAY,	STAC_9200_MODELS};enum {	STAC_9205_REF,	STAC_9205_DELL_M42,	STAC_9205_DELL_M43,	STAC_9205_DELL_M44,	STAC_9205_MODELS};enum {	STAC_925x_REF,	STAC_M2_2,	STAC_MA6,	STAC_PA6,	STAC_925x_MODELS};enum {	STAC_D945_REF,	STAC_D945GTP3,	STAC_D945GTP5,	STAC_INTEL_MAC_V1,	STAC_INTEL_MAC_V2,	STAC_INTEL_MAC_V3,	STAC_INTEL_MAC_V4,	STAC_INTEL_MAC_V5,	/* for backward compatibility */	STAC_MACMINI,	STAC_MACBOOK,	STAC_MACBOOK_PRO_V1,	STAC_MACBOOK_PRO_V2,	STAC_IMAC_INTEL,	STAC_IMAC_INTEL_20,	STAC_922X_DELL_D81,	STAC_922X_DELL_D82,	STAC_922X_DELL_M81,	STAC_922X_DELL_M82,	STAC_922X_MODELS};enum {	STAC_D965_REF,	STAC_D965_3ST,	STAC_D965_5ST,	STAC_DELL_3ST,	STAC_927X_MODELS};struct sigmatel_spec {	struct snd_kcontrol_new *mixers[4];	unsigned int num_mixers;	int board_config;	unsigned int surr_switch: 1;	unsigned int line_switch: 1;	unsigned int mic_switch: 1;	unsigned int alt_switch: 1;	unsigned int hp_detect: 1;	unsigned int gpio_mute: 1;	unsigned int gpio_mask, gpio_data;	/* playback */	struct hda_multi_out multiout;	hda_nid_t dac_nids[5];	/* capture */	hda_nid_t *adc_nids;	unsigned int num_adcs;	hda_nid_t *mux_nids;	unsigned int num_muxes;	hda_nid_t *dmic_nids;	unsigned int num_dmics;	hda_nid_t dmux_nid;	hda_nid_t dig_in_nid;	/* pin widgets */	hda_nid_t *pin_nids;	unsigned int num_pins;	unsigned int *pin_configs;	unsigned int *bios_pin_configs;	/* codec specific stuff */	struct hda_verb *init;	struct snd_kcontrol_new *mixer;	/* capture source */	struct hda_input_mux *dinput_mux;	unsigned int cur_dmux;	struct hda_input_mux *input_mux;	unsigned int cur_mux[3];	/* i/o switches */	unsigned int io_switch[2];	unsigned int clfe_swap;	unsigned int aloopback;	struct hda_pcm pcm_rec[2];	/* PCM information */	/* dynamic controls and input_mux */	struct auto_pin_cfg autocfg;	unsigned int num_kctl_alloc, num_kctl_used;	struct snd_kcontrol_new *kctl_alloc;	struct hda_input_mux private_dimux;	struct hda_input_mux private_imux;};static hda_nid_t stac9200_adc_nids[1] = {        0x03,};static hda_nid_t stac9200_mux_nids[1] = {        0x0c,};static hda_nid_t stac9200_dac_nids[1] = {        0x02,};static hda_nid_t stac925x_adc_nids[1] = {        0x03,};static hda_nid_t stac925x_mux_nids[1] = {        0x0f,};static hda_nid_t stac925x_dac_nids[1] = {        0x02,};#define STAC925X_NUM_DMICS	1static hda_nid_t stac925x_dmic_nids[STAC925X_NUM_DMICS + 1] = {	0x15, 0};static hda_nid_t stac922x_adc_nids[2] = {        0x06, 0x07,};static hda_nid_t stac922x_mux_nids[2] = {        0x12, 0x13,};static hda_nid_t stac927x_adc_nids[3] = {        0x07, 0x08, 0x09};static hda_nid_t stac927x_mux_nids[3] = {        0x15, 0x16, 0x17};static hda_nid_t stac9205_adc_nids[2] = {        0x12, 0x13};static hda_nid_t stac9205_mux_nids[2] = {        0x19, 0x1a};#define STAC9205_NUM_DMICS	2static hda_nid_t stac9205_dmic_nids[STAC9205_NUM_DMICS + 1] = {        0x17, 0x18, 0};static hda_nid_t stac9200_pin_nids[8] = {	0x08, 0x09, 0x0d, 0x0e, 	0x0f, 0x10, 0x11, 0x12,};static hda_nid_t stac925x_pin_nids[8] = {	0x07, 0x08, 0x0a, 0x0b, 	0x0c, 0x0d, 0x10, 0x11,};static hda_nid_t stac922x_pin_nids[10] = {	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,	0x0f, 0x10, 0x11, 0x15, 0x1b,};static hda_nid_t stac927x_pin_nids[14] = {	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,	0x0f, 0x10, 0x11, 0x12, 0x13,	0x14, 0x21, 0x22, 0x23,};static hda_nid_t stac9205_pin_nids[12] = {	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,	0x0f, 0x14, 0x16, 0x17, 0x18,	0x21, 0x22,};static int stac92xx_dmux_enum_info(struct snd_kcontrol *kcontrol,				   struct snd_ctl_elem_info *uinfo){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	return snd_hda_input_mux_info(spec->dinput_mux, uinfo);}static int stac92xx_dmux_enum_get(struct snd_kcontrol *kcontrol,				  struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	ucontrol->value.enumerated.item[0] = spec->cur_dmux;	return 0;}static int stac92xx_dmux_enum_put(struct snd_kcontrol *kcontrol,				  struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	return snd_hda_input_mux_put(codec, spec->dinput_mux, ucontrol,				     spec->dmux_nid, &spec->cur_dmux);}static int stac92xx_mux_enum_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	return snd_hda_input_mux_info(spec->input_mux, uinfo);}static int stac92xx_mux_enum_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_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 stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_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->mux_nids[adc_idx], &spec->cur_mux[adc_idx]);}#define stac92xx_aloopback_info snd_ctl_boolean_mono_infostatic int stac92xx_aloopback_get(struct snd_kcontrol *kcontrol,	struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	ucontrol->value.integer.value[0] = spec->aloopback;	return 0;}static int stac92xx_aloopback_put(struct snd_kcontrol *kcontrol,		struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct sigmatel_spec *spec = codec->spec;	unsigned int dac_mode;	if (spec->aloopback == ucontrol->value.integer.value[0])		return 0;	spec->aloopback = ucontrol->value.integer.value[0];	dac_mode = snd_hda_codec_read(codec, codec->afg, 0,		kcontrol->private_value & 0xFFFF, 0x0);	if (spec->aloopback) {		snd_hda_power_up(codec);		dac_mode |= 0x40;	} else {		snd_hda_power_down(codec);		dac_mode &= ~0x40;	}	snd_hda_codec_write_cache(codec, codec->afg, 0,		kcontrol->private_value >> 16, dac_mode);	return 1;}static struct hda_verb stac9200_core_init[] = {	/* set dac0mux for dac converter */	{ 0x07, AC_VERB_SET_CONNECT_SEL, 0x00},	{}};static struct hda_verb stac9200_eapd_init[] = {	/* set dac0mux for dac converter */	{0x07, AC_VERB_SET_CONNECT_SEL, 0x00},	{0x08, AC_VERB_SET_EAPD_BTLENABLE, 0x02},	{}};static struct hda_verb stac925x_core_init[] = {	/* set dac0mux for dac converter */	{ 0x06, AC_VERB_SET_CONNECT_SEL, 0x00},	{}};static struct hda_verb stac922x_core_init[] = {	/* set master volume and direct control */		{ 0x16, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},	{}};static struct hda_verb d965_core_init[] = {	/* set master volume and direct control */		{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},	/* unmute node 0x1b */	{ 0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},	/* select node 0x03 as DAC */		{ 0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},	{}};static struct hda_verb stac927x_core_init[] = {	/* set master volume and direct control */		{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},	{}};static struct hda_verb stac9205_core_init[] = {	/* set master volume and direct control */		{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},	{}};#define STAC_INPUT_SOURCE(cnt) \	{ \		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \		.name = "Input Source", \		.count = cnt, \		.info = stac92xx_mux_enum_info, \		.get = stac92xx_mux_enum_get, \		.put = stac92xx_mux_enum_put, \	}#define STAC_ANALOG_LOOPBACK(verb_read,verb_write) \	{ \		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \		.name  = "Analog Loopback", \		.count = 1, \		.info  = stac92xx_aloopback_info, \		.get   = stac92xx_aloopback_get, \		.put   = stac92xx_aloopback_put, \		.private_value = verb_read | (verb_write << 16), \	}static struct snd_kcontrol_new stac9200_mixer[] = {	HDA_CODEC_VOLUME("Master Playback Volume", 0xb, 0, HDA_OUTPUT),	HDA_CODEC_MUTE("Master Playback Switch", 0xb, 0, HDA_OUTPUT),	STAC_INPUT_SOURCE(1),	HDA_CODEC_VOLUME("Capture Volume", 0x0a, 0, HDA_OUTPUT),	HDA_CODEC_MUTE("Capture Switch", 0x0a, 0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Capture Mux Volume", 0x0c, 0, HDA_OUTPUT),	{ } /* end */};static struct snd_kcontrol_new stac925x_mixer[] = {	STAC_INPUT_SOURCE(1),	HDA_CODEC_VOLUME("Capture Volume", 0x09, 0, HDA_OUTPUT),	HDA_CODEC_MUTE("Capture Switch", 0x09, 0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Capture Mux Volume", 0x0f, 0, HDA_OUTPUT),	{ } /* end */};static struct snd_kcontrol_new stac9205_mixer[] = {	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = "Digital Input Source",		.count = 1,		.info = stac92xx_dmux_enum_info,		.get = stac92xx_dmux_enum_get,		.put = stac92xx_dmux_enum_put,	},	STAC_INPUT_SOURCE(2),	STAC_ANALOG_LOOPBACK(0xFE0, 0x7E0),	HDA_CODEC_VOLUME_IDX("Capture Volume", 0x0, 0x1b, 0x0, HDA_INPUT),	HDA_CODEC_MUTE_IDX("Capture Switch", 0x0, 0x1d, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_IDX("Mux Capture Volume", 0x0, 0x19, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_IDX("Capture Volume", 0x1, 0x1c, 0x0, HDA_INPUT),	HDA_CODEC_MUTE_IDX("Capture Switch", 0x1, 0x1e, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_IDX("Mux Capture Volume", 0x1, 0x1A, 0x0, HDA_OUTPUT),	{ } /* end */};

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美不卡在线观看视频| 美女久久久精品| 亚洲第一综合色| 国产成人精品亚洲777人妖| 91福利国产精品| 久久久一区二区三区捆绑**| 亚洲一区二区三区四区在线免费观看| 久久9热精品视频| 欧洲一区二区av| 国产精品久久午夜夜伦鲁鲁| 久久国产精品第一页| 欧美三级资源在线| 亚洲三级免费电影| 成人免费高清视频| 久久久久久久网| 日韩av在线免费观看不卡| 欧美伊人精品成人久久综合97| 国产精品美女一区二区三区 | 欧美视频在线一区| 久久久久久久久久久久久久久99| 视频一区二区欧美| 欧美怡红院视频| 亚洲最大成人网4388xx| zzijzzij亚洲日本少妇熟睡| 久久久久久久网| 国产高清无密码一区二区三区| 日韩欧美国产综合| 免费精品视频在线| 日韩女优视频免费观看| 日本最新不卡在线| 日韩一区二区三区免费观看| 蜜桃av一区二区| 日韩免费在线观看| 精品亚洲欧美一区| 久久老女人爱爱| 成人一区二区三区视频在线观看 | 欧美丰满嫩嫩电影| 日欧美一区二区| 欧美一区二区黄| 久久国产乱子精品免费女| 欧美videossexotv100| 精品在线视频一区| 久久亚洲捆绑美女| 99精品视频一区| 一区二区三区在线免费播放| 欧美体内she精高潮| 三级不卡在线观看| 夜夜精品视频一区二区| 色狠狠一区二区| 日本亚洲一区二区| 欧美精品一区视频| aaa欧美色吧激情视频| 一二三四社区欧美黄| 91精品国产一区二区三区| 九九九精品视频| 亚洲欧美在线视频观看| 在线观看国产精品网站| 蜜臀av一区二区三区| 久久久久国产精品麻豆ai换脸| 91在线观看污| 亚洲一区二区视频| 久久综合久久鬼色中文字| 99精品国产91久久久久久| 五月天一区二区| 久久久www成人免费毛片麻豆 | 精品一区二区三区在线播放 | 欧美成人vr18sexvr| 成人毛片老司机大片| 亚洲专区一二三| 久久久精品tv| 欧美中文字幕一区| 国产精品自拍三区| 亚洲第一激情av| 国产色产综合色产在线视频| 欧美日韩视频在线观看一区二区三区| 美女www一区二区| 国产精品不卡一区| 91精品国产欧美一区二区18| 国产白丝网站精品污在线入口| 亚洲成人福利片| 中文一区一区三区高中清不卡| 欧美精品777| 91麻豆视频网站| 国产一区91精品张津瑜| 亚洲第一电影网| 亚洲日本中文字幕区| 欧美成人精品福利| 欧美性大战久久久久久久蜜臀| 粉嫩一区二区三区性色av| 手机精品视频在线观看| 亚洲卡通动漫在线| 中文字幕欧美国产| 久久午夜国产精品| 日韩欧美国产午夜精品| 欧美亚男人的天堂| 91无套直看片红桃| 国产成人精品一区二区三区四区 | 日本高清不卡在线观看| 国产成人亚洲综合色影视| 日韩激情在线观看| 亚洲午夜精品一区二区三区他趣| 国产精品毛片无遮挡高清| 国产亚洲精品精华液| 欧美成人a∨高清免费观看| 欧美三级午夜理伦三级中视频| www.日韩av| www.亚洲在线| www.66久久| 成人免费看黄yyy456| 欧美日韩二区三区| 99v久久综合狠狠综合久久| 国产福利电影一区二区三区| 国产麻豆精品在线观看| 久久99精品久久久| 国模冰冰炮一区二区| 极品瑜伽女神91| 国产精品影视网| 国产·精品毛片| 99久久国产综合精品色伊| 成人黄色av网站在线| www.亚洲精品| 91精彩视频在线观看| 欧美色综合久久| 欧美日韩国产一级二级| 欧美色图在线观看| 911精品产国品一二三产区| 欧美精品色一区二区三区| 日韩手机在线导航| 久久久久久久精| 中文欧美字幕免费| 亚洲免费av网站| 婷婷开心久久网| 精品中文av资源站在线观看| 国产福利91精品| 色综合久久综合| 欧美日韩精品一区二区三区蜜桃| 4438x亚洲最大成人网| 2021国产精品久久精品| 国产精品久久久久婷婷| 一区二区三区在线视频播放| 日本成人在线网站| 国产精品一区二区视频| 91在线观看视频| 欧美一区二区精品久久911| 中文字幕免费观看一区| 一区二区三区精品在线| 日韩不卡在线观看日韩不卡视频| 国产成人精品亚洲日本在线桃色| 91免费看`日韩一区二区| 欧美挠脚心视频网站| 久久这里只有精品6| 亚洲黄一区二区三区| 色婷婷av一区二区三区软件| 欧美日韩性生活| 欧美经典三级视频一区二区三区| 亚洲第一成人在线| 国产福利精品一区二区| 欧美日韩大陆在线| 欧美高清在线视频| 伦理电影国产精品| 日本福利一区二区| 国产情人综合久久777777| 亚洲一区二区中文在线| 国产91精品在线观看| 欧美精品第一页| 亚洲三级在线看| 高清国产午夜精品久久久久久| 欧美日韩一本到| 亚洲视频在线一区观看| 国内精品免费在线观看| 欧美丝袜丝交足nylons| 亚洲国产精品二十页| 黄色日韩三级电影| 欧美精品v国产精品v日韩精品| 亚洲三级理论片| 成人性生交大片免费看中文| 日韩免费看网站| 日精品一区二区三区| 日本精品一区二区三区高清| 日本一区二区三区四区在线视频 | 成人黄色777网| 久久久99久久| 老司机精品视频线观看86| 欧美日韩一二三区| 一个色综合av| 欧洲av在线精品| 伊人色综合久久天天人手人婷| 高清不卡在线观看| 久久众筹精品私拍模特| 久久 天天综合| 精品国产91乱码一区二区三区| 婷婷久久综合九色综合伊人色| 久久久久亚洲综合| 日韩和欧美的一区| 91 com成人网| 午夜伦理一区二区| 51久久夜色精品国产麻豆| 偷拍一区二区三区| 欧美一级二级三级蜜桃| 另类欧美日韩国产在线|