diff options
Diffstat (limited to 'sound')
| -rw-r--r-- | sound/pci/hda/patch_realtek.c | 84 | 
1 files changed, 40 insertions, 44 deletions
| diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 53538b0f999..17d4548cc35 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c @@ -7025,6 +7025,14 @@ static struct hda_input_mux alc889A_mb31_capture_source = {  	},  }; +static struct hda_input_mux alc889A_imac91_capture_source = { +	.num_items = 2, +	.items = { +		{ "Mic", 0x01 }, +		{ "Line", 0x2 }, /* Not sure! */ +	}, +}; +  /*   * 2ch mode   */ @@ -7486,15 +7494,8 @@ static struct snd_kcontrol_new alc885_macmini3_mixer[] = {  };  static struct snd_kcontrol_new alc885_imac91_mixer[] = { -	HDA_CODEC_VOLUME("Line-Out Playback Volume", 0x0c, 0x00, HDA_OUTPUT), -	HDA_BIND_MUTE   ("Line-Out Playback Switch", 0x0c, 0x02, HDA_INPUT), -	HDA_CODEC_MUTE  ("Speaker Playback Switch", 0x14, 0x00, HDA_OUTPUT), -	HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0d, 0x00, HDA_OUTPUT), -	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, 0x00, HDA_INPUT), -	HDA_CODEC_MUTE  ("Mic Playback Switch", 0x0b, 0x00, HDA_INPUT), -	HDA_CODEC_VOLUME("Mic Boost", 0x18, 0x00, HDA_INPUT), +	HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x00, HDA_OUTPUT), +	HDA_BIND_MUTE("Speaker Playback Switch", 0x0c, 0x02, HDA_INPUT),  	{ } /* end */  }; @@ -7995,61 +7996,56 @@ static struct hda_verb alc885_mbp3_init_verbs[] = {  /* iMac 9,1 */  static struct hda_verb alc885_imac91_init_verbs[] = { -	/* Line-Out mixer: unmute input/output amp left and right (volume = 0) */ -	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, -	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, -	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, -	/* Rear mixer */ -	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, -	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, -	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, -	/* HP Pin: output 0 (0x0c) */ +	/* Internal Speaker Pin (0x0c) */ +	{0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) }, +	{0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, +	{0x18, AC_VERB_SET_CONNECT_SEL, 0x00}, +	{0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, (PIN_OUT | AC_PINCTL_VREF_50) }, +	{0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, +	{0x1a, AC_VERB_SET_CONNECT_SEL, 0x00}, +	/* HP Pin: Rear */  	{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},  	{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},  	{0x14, AC_VERB_SET_CONNECT_SEL, 0x00}, -	{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC880_HP_EVENT | AC_USRSP_EN}, -	/* Internal Speakers: output 0 (0x0d) */ -	{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, +	{0x14, AC_VERB_SET_UNSOLICITED_ENABLE, (ALC880_HP_EVENT | AC_USRSP_EN)}, +	/* Line in Rear */ +	{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, AC_PINCTL_VREF_50},  	{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, -	{0x15, AC_VERB_SET_CONNECT_SEL, 0x00}, -	/* Mic (rear) pin: input vref at 80% */ -	{0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, -	{0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},  	/* Front Mic pin: input vref at 80% */  	{0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},  	{0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, -	/* Line In pin: use output 1 when in LineOut mode */ -	{0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, -	{0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, -	{0x1a, AC_VERB_SET_CONNECT_SEL, 0x01}, - -	/* FIXME: use matrix-type input source selection */ -	/* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */ -	/* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */ +	/* Rear mixer */ +	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, +	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, +	{0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, +	/* Line-Out mixer: unmute input/output amp left and right (volume = 0) */ +	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, +	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)}, +	{0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, +	/* 0x24 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */  	{0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},  	{0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},  	{0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},  	{0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, -	/* Input mixer2 */ +	/* 0x23 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */  	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},  	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},  	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},  	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, -	/* Input mixer3 */ +	/* 0x22 [Audio Mixer] wcaps 0x20010b: Stereo Amp-In */  	{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},  	{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},  	{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},  	{0x22, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)}, -	/* ADC1: mute amp left and right */ +	/* 0x07 [Audio Input] wcaps 0x10011b: Stereo Amp-In */  	{0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},  	{0x07, AC_VERB_SET_CONNECT_SEL, 0x00}, -	/* ADC2: mute amp left and right */ +	/* 0x08 [Audio Input] wcaps 0x10011b: Stereo Amp-In */  	{0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},  	{0x08, AC_VERB_SET_CONNECT_SEL, 0x00}, -	/* ADC3: mute amp left and right */ +	/* 0x09 [Audio Input] wcaps 0x10011b: Stereo Amp-In */  	{0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},  	{0x09, AC_VERB_SET_CONNECT_SEL, 0x00}, -  	{ }  }; @@ -8118,7 +8114,7 @@ static void alc885_imac91_setup(struct hda_codec *codec)  	struct alc_spec *spec = codec->spec;  	spec->autocfg.hp_pins[0] = 0x14; -	spec->autocfg.speaker_pins[0] = 0x15; +	spec->autocfg.speaker_pins[0] = 0x18;  	spec->autocfg.speaker_pins[1] = 0x1a;  } @@ -9627,14 +9623,14 @@ static struct alc_config_preset alc882_presets[] = {  		.init_hook = alc885_imac24_init_hook,  	},  	[ALC885_IMAC91] = { -		.mixers = { alc885_imac91_mixer, alc882_chmode_mixer }, +		.mixers = {alc885_imac91_mixer},  		.init_verbs = { alc885_imac91_init_verbs,  				alc880_gpio1_init_verbs },  		.num_dacs = ARRAY_SIZE(alc882_dac_nids),  		.dac_nids = alc882_dac_nids, -		.channel_mode = alc885_mbp_4ch_modes, -		.num_channel_mode = ARRAY_SIZE(alc885_mbp_4ch_modes), -		.input_mux = &alc882_capture_source, +		.channel_mode = alc885_mba21_ch_modes, +		.num_channel_mode = ARRAY_SIZE(alc885_mba21_ch_modes), +		.input_mux = &alc889A_imac91_capture_source,  		.dig_out_nid = ALC882_DIGOUT_NID,  		.dig_in_nid = ALC882_DIGIN_NID,  		.unsol_event = alc_automute_amp_unsol_event, | 
