⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 patch_analog.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 5 页
字号:
	[AD1986A_LAPTOP_EAPD]	= "laptop-eapd",	[AD1986A_LAPTOP_AUTOMUTE] = "laptop-automute",	[AD1986A_ULTRA]		= "ultra",};static struct snd_pci_quirk ad1986a_cfg_tbl[] = {	SND_PCI_QUIRK(0x103c, 0x30af, "HP B2800", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x10de, 0xcb84, "ASUS A8N-VM", AD1986A_3STACK),	SND_PCI_QUIRK(0x1043, 0x1153, "ASUS M9", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x1213, "ASUS A6J", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x11f7, "ASUS U5A", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x1263, "ASUS U5F", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x1297, "ASUS Z62F", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x12b3, "ASUS V1j", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x1302, "ASUS W3j", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x1043, 0x1447, "ASUS A8J", AD1986A_3STACK),	SND_PCI_QUIRK(0x1043, 0x817f, "ASUS P5", AD1986A_3STACK),	SND_PCI_QUIRK(0x1043, 0x818f, "ASUS P5", AD1986A_LAPTOP),	SND_PCI_QUIRK(0x1043, 0x81b3, "ASUS P5", AD1986A_3STACK),	SND_PCI_QUIRK(0x1043, 0x81cb, "ASUS M2N", AD1986A_3STACK),	SND_PCI_QUIRK(0x1043, 0x8234, "ASUS M2N", AD1986A_3STACK),	SND_PCI_QUIRK(0x144d, 0xb03c, "Samsung R55", AD1986A_3STACK),	SND_PCI_QUIRK(0x144d, 0xc01e, "FSC V2060", AD1986A_LAPTOP),	SND_PCI_QUIRK(0x144d, 0xc023, "Samsung X60", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x144d, 0xc024, "Samsung R65", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x144d, 0xc026, "Samsung X11", AD1986A_LAPTOP_EAPD),	SND_PCI_QUIRK(0x144d, 0xc504, "Samsung Q35", AD1986A_3STACK),	SND_PCI_QUIRK(0x144d, 0xc027, "Samsung Q1", AD1986A_ULTRA),	SND_PCI_QUIRK(0x17aa, 0x1011, "Lenovo M55", AD1986A_LAPTOP),	SND_PCI_QUIRK(0x17aa, 0x1017, "Lenovo A60", AD1986A_3STACK),	SND_PCI_QUIRK(0x17aa, 0x2066, "Lenovo N100", AD1986A_LAPTOP_AUTOMUTE),	SND_PCI_QUIRK(0x17c0, 0x2017, "Samsung M50", AD1986A_LAPTOP),	{}};#ifdef CONFIG_SND_HDA_POWER_SAVEstatic struct hda_amp_list ad1986a_loopbacks[] = {	{ 0x13, HDA_OUTPUT, 0 }, /* Mic */	{ 0x14, HDA_OUTPUT, 0 }, /* Phone */	{ 0x15, HDA_OUTPUT, 0 }, /* CD */	{ 0x16, HDA_OUTPUT, 0 }, /* Aux */	{ 0x17, HDA_OUTPUT, 0 }, /* Line */	{ } /* end */};#endifstatic int patch_ad1986a(struct hda_codec *codec){	struct ad198x_spec *spec;	int board_config;	spec = kzalloc(sizeof(*spec), GFP_KERNEL);	if (spec == NULL)		return -ENOMEM;	codec->spec = spec;	spec->multiout.max_channels = 6;	spec->multiout.num_dacs = ARRAY_SIZE(ad1986a_dac_nids);	spec->multiout.dac_nids = ad1986a_dac_nids;	spec->multiout.dig_out_nid = AD1986A_SPDIF_OUT;	spec->num_adc_nids = 1;	spec->adc_nids = ad1986a_adc_nids;	spec->capsrc_nids = ad1986a_capsrc_nids;	spec->input_mux = &ad1986a_capture_source;	spec->num_mixers = 1;	spec->mixers[0] = ad1986a_mixers;	spec->num_init_verbs = 1;	spec->init_verbs[0] = ad1986a_init_verbs;#ifdef CONFIG_SND_HDA_POWER_SAVE	spec->loopback.amplist = ad1986a_loopbacks;#endif	codec->patch_ops = ad198x_patch_ops;	/* override some parameters */	board_config = snd_hda_check_board_config(codec, AD1986A_MODELS,						  ad1986a_models,						  ad1986a_cfg_tbl);	switch (board_config) {	case AD1986A_3STACK:		spec->num_mixers = 2;		spec->mixers[1] = ad1986a_3st_mixers;		spec->num_init_verbs = 2;		spec->init_verbs[1] = ad1986a_ch2_init;		spec->channel_mode = ad1986a_modes;		spec->num_channel_mode = ARRAY_SIZE(ad1986a_modes);		spec->need_dac_fix = 1;		spec->multiout.max_channels = 2;		spec->multiout.num_dacs = 1;		break;	case AD1986A_LAPTOP:		spec->mixers[0] = ad1986a_laptop_mixers;		spec->multiout.max_channels = 2;		spec->multiout.num_dacs = 1;		spec->multiout.dac_nids = ad1986a_laptop_dac_nids;		break;	case AD1986A_LAPTOP_EAPD:		spec->mixers[0] = ad1986a_laptop_eapd_mixers;		spec->num_init_verbs = 2;		spec->init_verbs[1] = ad1986a_eapd_init_verbs;		spec->multiout.max_channels = 2;		spec->multiout.num_dacs = 1;		spec->multiout.dac_nids = ad1986a_laptop_dac_nids;		spec->multiout.dig_out_nid = 0;		spec->input_mux = &ad1986a_laptop_eapd_capture_source;		break;	case AD1986A_LAPTOP_AUTOMUTE:		spec->mixers[0] = ad1986a_laptop_automute_mixers;		spec->num_init_verbs = 3;		spec->init_verbs[1] = ad1986a_eapd_init_verbs;		spec->init_verbs[2] = ad1986a_hp_init_verbs;		spec->multiout.max_channels = 2;		spec->multiout.num_dacs = 1;		spec->multiout.dac_nids = ad1986a_laptop_dac_nids;		spec->multiout.dig_out_nid = 0;		spec->input_mux = &ad1986a_laptop_eapd_capture_source;		codec->patch_ops.unsol_event = ad1986a_hp_unsol_event;		codec->patch_ops.init = ad1986a_hp_init;		break;	case AD1986A_ULTRA:		spec->mixers[0] = ad1986a_laptop_eapd_mixers;		spec->num_init_verbs = 2;		spec->init_verbs[1] = ad1986a_ultra_init;		spec->multiout.max_channels = 2;		spec->multiout.num_dacs = 1;		spec->multiout.dac_nids = ad1986a_laptop_dac_nids;		spec->multiout.dig_out_nid = 0;		break;	}	/* AD1986A has a hardware problem that it can't share a stream	 * with multiple output pins.  The copy of front to surrounds	 * causes noisy or silent outputs at a certain timing, e.g.	 * changing the volume.	 * So, let's disable the shared stream.	 */	spec->multiout.no_share_stream = 1;	return 0;}/* * AD1983 specific */#define AD1983_SPDIF_OUT	0x02#define AD1983_DAC		0x03#define AD1983_ADC		0x04static hda_nid_t ad1983_dac_nids[1] = { AD1983_DAC };static hda_nid_t ad1983_adc_nids[1] = { AD1983_ADC };static hda_nid_t ad1983_capsrc_nids[1] = { 0x15 };static struct hda_input_mux ad1983_capture_source = {	.num_items = 4,	.items = {		{ "Mic", 0x0 },		{ "Line", 0x1 },		{ "Mix", 0x2 },		{ "Mix Mono", 0x3 },	},};/* * SPDIF playback route */static int ad1983_spdif_route_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo){	static char *texts[] = { "PCM", "ADC" };	uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;	uinfo->count = 1;	uinfo->value.enumerated.items = 2;	if (uinfo->value.enumerated.item > 1)		uinfo->value.enumerated.item = 1;	strcpy(uinfo->value.enumerated.name, texts[uinfo->value.enumerated.item]);	return 0;}static int ad1983_spdif_route_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct ad198x_spec *spec = codec->spec;	ucontrol->value.enumerated.item[0] = spec->spdif_route;	return 0;}static int ad1983_spdif_route_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol){	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);	struct ad198x_spec *spec = codec->spec;	if (spec->spdif_route != ucontrol->value.enumerated.item[0]) {		spec->spdif_route = ucontrol->value.enumerated.item[0];		snd_hda_codec_write_cache(codec, spec->multiout.dig_out_nid, 0,					  AC_VERB_SET_CONNECT_SEL,					  spec->spdif_route);		return 1;	}	return 0;}static struct snd_kcontrol_new ad1983_mixers[] = {	HDA_CODEC_VOLUME("Front Playback Volume", 0x05, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Front Playback Switch", 0x05, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Headphone Playback Volume", 0x06, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Headphone Playback Switch", 0x06, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x07, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x07, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("PCM Playback Volume", 0x11, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("PCM Playback Switch", 0x11, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Mic Playback Volume", 0x12, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Mic Playback Switch", 0x12, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Line Playback Volume", 0x13, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Line Playback Switch", 0x13, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_MONO("PC Speaker Playback Volume", 0x10, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE_MONO("PC Speaker Playback Switch", 0x10, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Mic Boost", 0x0c, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Capture Volume", 0x15, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Capture Switch", 0x15, 0x0, HDA_OUTPUT),	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = "Capture Source",		.info = ad198x_mux_enum_info,		.get = ad198x_mux_enum_get,		.put = ad198x_mux_enum_put,	},	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,NONE) "Source",		.info = ad1983_spdif_route_info,		.get = ad1983_spdif_route_get,		.put = ad1983_spdif_route_put,	},	{ } /* end */};static struct hda_verb ad1983_init_verbs[] = {	/* Front, HP, Mono; mute as default */	{0x05, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x06, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x07, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* Beep, PCM, Mic, Line-In: mute */	{0x10, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x11, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x12, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x13, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* Front, HP selectors; from Mix */	{0x05, AC_VERB_SET_CONNECT_SEL, 0x01},	{0x06, AC_VERB_SET_CONNECT_SEL, 0x01},	/* Mono selector; from Mix */	{0x0b, AC_VERB_SET_CONNECT_SEL, 0x03},	/* Mic selector; Mic */	{0x0c, AC_VERB_SET_CONNECT_SEL, 0x0},	/* Line-in selector: Line-in */	{0x0d, AC_VERB_SET_CONNECT_SEL, 0x0},	/* Mic boost: 0dB */	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},	/* Record selector: mic */	{0x15, AC_VERB_SET_CONNECT_SEL, 0x0},	{0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* SPDIF route: PCM */	{0x02, AC_VERB_SET_CONNECT_SEL, 0x0},	/* Front Pin */	{0x05, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },	/* HP Pin */	{0x06, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0 },	/* Mono Pin */	{0x07, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40 },	/* Mic Pin */	{0x08, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24 },	/* Line Pin */	{0x09, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20 },	{ } /* end */};#ifdef CONFIG_SND_HDA_POWER_SAVEstatic struct hda_amp_list ad1983_loopbacks[] = {	{ 0x12, HDA_OUTPUT, 0 }, /* Mic */	{ 0x13, HDA_OUTPUT, 0 }, /* Line */	{ } /* end */};#endifstatic int patch_ad1983(struct hda_codec *codec){	struct ad198x_spec *spec;	spec = kzalloc(sizeof(*spec), GFP_KERNEL);	if (spec == NULL)		return -ENOMEM;	codec->spec = spec;	spec->multiout.max_channels = 2;	spec->multiout.num_dacs = ARRAY_SIZE(ad1983_dac_nids);	spec->multiout.dac_nids = ad1983_dac_nids;	spec->multiout.dig_out_nid = AD1983_SPDIF_OUT;	spec->num_adc_nids = 1;	spec->adc_nids = ad1983_adc_nids;	spec->capsrc_nids = ad1983_capsrc_nids;	spec->input_mux = &ad1983_capture_source;	spec->num_mixers = 1;	spec->mixers[0] = ad1983_mixers;	spec->num_init_verbs = 1;	spec->init_verbs[0] = ad1983_init_verbs;	spec->spdif_route = 0;#ifdef CONFIG_SND_HDA_POWER_SAVE	spec->loopback.amplist = ad1983_loopbacks;#endif	codec->patch_ops = ad198x_patch_ops;	return 0;}/* * AD1981 HD specific */#define AD1981_SPDIF_OUT	0x02#define AD1981_DAC		0x03#define AD1981_ADC		0x04static hda_nid_t ad1981_dac_nids[1] = { AD1981_DAC };static hda_nid_t ad1981_adc_nids[1] = { AD1981_ADC };static hda_nid_t ad1981_capsrc_nids[1] = { 0x15 };/* 0x0c, 0x09, 0x0e, 0x0f, 0x19, 0x05, 0x18, 0x17 */static struct hda_input_mux ad1981_capture_source = {	.num_items = 7,	.items = {		{ "Front Mic", 0x0 },		{ "Line", 0x1 },		{ "Mix", 0x2 },		{ "Mix Mono", 0x3 },		{ "CD", 0x4 },		{ "Mic", 0x6 },		{ "Aux", 0x7 },	},};static struct snd_kcontrol_new ad1981_mixers[] = {	HDA_CODEC_VOLUME("Front Playback Volume", 0x05, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Front Playback Switch", 0x05, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Headphone Playback Volume", 0x06, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Headphone Playback Switch", 0x06, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x07, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x07, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("PCM Playback Volume", 0x11, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("PCM Playback Switch", 0x11, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x12, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Front Mic Playback Switch", 0x12, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Line Playback Volume", 0x13, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Line Playback Switch", 0x13, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Aux Playback Volume", 0x1b, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Aux Playback Switch", 0x1b, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Mic Playback Volume", 0x1c, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Mic Playback Switch", 0x1c, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("CD Playback Volume", 0x1d, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("CD Playback Switch", 0x1d, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME_MONO("PC Speaker Playback Volume", 0x0d, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE_MONO("PC Speaker Playback Switch", 0x0d, 1, 0x0, HDA_OUTPUT),	HDA_CODEC_VOLUME("Front Mic Boost", 0x08, 0x0, HDA_INPUT),	HDA_CODEC_VOLUME("Mic Boost", 0x18, 0x0, HDA_INPUT),	HDA_CODEC_VOLUME("Capture Volume", 0x15, 0x0, HDA_OUTPUT),	HDA_CODEC_MUTE("Capture Switch", 0x15, 0x0, HDA_OUTPUT),	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = "Capture Source",		.info = ad198x_mux_enum_info,		.get = ad198x_mux_enum_get,		.put = ad198x_mux_enum_put,	},	/* identical with AD1983 */	{		.iface = SNDRV_CTL_ELEM_IFACE_MIXER,		.name = SNDRV_CTL_NAME_IEC958("",PLAYBACK,NONE) "Source",		.info = ad1983_spdif_route_info,		.get = ad1983_spdif_route_get,		.put = ad1983_spdif_route_put,	},	{ } /* end */};static struct hda_verb ad1981_init_verbs[] = {	/* Front, HP, Mono; mute as default */	{0x05, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x06, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x07, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* Beep, PCM, Front Mic, Line, Rear Mic, Aux, CD-In: mute */	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x11, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x12, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x13, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x1c, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	{0x1d, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* Front, HP selectors; from Mix */	{0x05, AC_VERB_SET_CONNECT_SEL, 0x01},	{0x06, AC_VERB_SET_CONNECT_SEL, 0x01},	/* Mono selector; from Mix */	{0x0b, AC_VERB_SET_CONNECT_SEL, 0x03},	/* Mic Mixer; select Front Mic */	{0x1e, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},	{0x1f, AC_VERB_SET_AMP_GAIN_MUTE, 0xb080},	/* Mic boost: 0dB */	{0x08, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},	{0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},	/* Record selector: Front mic */	{0x15, AC_VERB_SET_CONNECT_SEL, 0x0},

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -