Re: [PATCH - Full support for Toshiba NB200 1/1] Support for Toshiba NB200

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



At Sun, 15 Nov 2009 22:10:38 +0100,
cjg@xxxxxxxxxxx wrote:
> 
> From: Giuseppe Coviello <cjg@xxxxxxxxxxx>
> 
> 
> Signed-off-by: Giuseppe Coviello <cjg@xxxxxxxxxxx>

Thanks for the patch.
But, what is the exact reason for this change?
Doesn't the very latest alsa-driver give you the full features?
Since it's not documented in the changelog, I can't take it as is.

Basically it's more preferable to fix / enhance the auto-parser
than adding the new big quirk code.  Please give alsa-info.sh with the
very latest alsa-driver for analysis.


thanks,

Takashi

> ---
>  sound/pci/hda/patch_realtek.c |   86 ++++++++++++++++++++++++++++++++++++++++-
>  1 files changed, 85 insertions(+), 1 deletions(-)
> 
> diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c
> index c0a98e7..69484b8 100644
> --- a/sound/pci/hda/patch_realtek.c
> +++ b/sound/pci/hda/patch_realtek.c
> @@ -191,6 +191,7 @@ enum {
>  	ALC272_DELL,
>  	ALC272_DELL_ZM1,
>  	ALC272_SAMSUNG_NC10,
> +	ALC272_TOSHIBA_NB200,
>  	ALC662_AUTO,
>  	ALC662_MODEL_LAST,
>  };
> @@ -16355,6 +16356,40 @@ static struct hda_verb alc272_dell_init_verbs[] = {
>  	{}
>  };
>  
> +static struct snd_kcontrol_new alc272_toshiba_mixer[] = {
> +	HDA_CODEC_VOLUME("Front Mic Boost", 0x19, 0, HDA_INPUT),
> +
> +	HDA_CODEC_VOLUME("i-Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
> +	HDA_CODEC_MUTE("i-Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
> +	HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
> +	HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
> +	{ } /* end */
> +};
> +
> +static struct hda_verb alc272_toshiba_init_verbs[] = {
> +	/* Front Pin: output 0 (0x0c) */
> +	{0x17, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, /* 0x14 */
> +	{0x17, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* 0x14 */
> +	/* Front Mic pin: input vref at 80% */
> +	{0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, /* 0x19 */
> +	{0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},    /* 0x19 */
> +	{0x17, AC_VERB_SET_EAPD_BTLENABLE, 2}, /* 0x14 */
> +	{0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* originally 0x12 */
> +	{0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
> +	{0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
> +	{0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
> +	{0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
> +	{0x21, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
> +	{0x21, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
> +	{0x21, AC_VERB_SET_CONNECT_SEL, 0x01},  /* Headphone */
> +	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
> +	{0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(9)},
> +	{0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_MIC_EVENT},
> +	{0x21, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC880_HP_EVENT},
> +	{}
> +};
> +
> +
>  static struct snd_kcontrol_new alc662_auto_capture_mixer[] = {
>  	HDA_CODEC_VOLUME("Capture Volume", 0x09, 0x0, HDA_INPUT),
>  	HDA_CODEC_MUTE("Capture Switch", 0x09, 0x0, HDA_INPUT),
> @@ -16579,6 +16614,40 @@ static void alc663_m51va_inithook(struct hda_codec *codec)
>  	alc_mic_automute(codec);
>  }
>  
> +static void alc272_toshiba_speaker_automute(struct hda_codec *codec)
> +{
> +	unsigned int present;
> +	unsigned char bits;
> +
> +	present = snd_hda_codec_read(codec, 0x21, 0,
> +			AC_VERB_GET_PIN_SENSE, 0)
> +			& AC_PINSENSE_PRESENCE;
> +	bits = present ? HDA_AMP_MUTE : 0;
> +	snd_hda_codec_amp_stereo(codec, 0x17, HDA_OUTPUT, 0,
> +			AMP_OUT_MUTE, bits);
> +	snd_hda_codec_amp_stereo(codec, 0x17, HDA_OUTPUT, 1,
> +			AMP_OUT_MUTE, bits);
> +}
> +
> +static void alc272_toshiba_unsol_event(struct hda_codec *codec,
> +		unsigned int res)
> +{
> +	switch (res >> 26) {
> +	case ALC880_HP_EVENT:
> +		alc272_toshiba_speaker_automute(codec);
> +		break;
> +	case ALC880_MIC_EVENT:
> +		alc_mic_automute(codec);
> +		break;
> +	}
> +}
> +
> +static void alc272_toshiba_inithook(struct hda_codec *codec)
> +{
> +	alc272_toshiba_speaker_automute(codec);
> +	alc_mic_automute(codec);
> +}
> +
>  /* ***************** Mode1 ******************************/
>  #define alc663_mode1_unsol_event	alc663_m51va_unsol_event
>  #define alc663_mode1_setup		alc663_m51va_setup
> @@ -16830,6 +16899,7 @@ static const char *alc662_models[ALC662_MODEL_LAST] = {
>  	[ALC663_ASUS_MODE6] = "asus-mode6",
>  	[ALC272_DELL]		= "dell",
>  	[ALC272_DELL_ZM1]	= "dell-zm1",
> +	[ALC272_TOSHIBA_NB200]  = "toshiba-nb200",
>  	[ALC272_SAMSUNG_NC10]	= "samsung-nc10",
>  	[ALC662_AUTO]		= "auto",
>  };
> @@ -16838,6 +16908,7 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = {
>  	SND_PCI_QUIRK(0x1019, 0x9087, "ECS", ALC662_ECS),
>  	SND_PCI_QUIRK(0x1028, 0x02d6, "DELL", ALC272_DELL),
>  	SND_PCI_QUIRK(0x1028, 0x02f4, "DELL ZM1", ALC272_DELL_ZM1),
> +	SND_PCI_QUIRK(0x1179, 0xff6e, "Toshiba NB200", ALC272_TOSHIBA_NB200),
>  	SND_PCI_QUIRK(0x1043, 0x1000, "ASUS N50Vm", ALC663_ASUS_MODE1),
>  	SND_PCI_QUIRK(0x1043, 0x1092, "ASUS NB", ALC663_ASUS_MODE3),
>  	SND_PCI_QUIRK(0x1043, 0x11c3, "ASUS M70V", ALC663_ASUS_MODE3),
> @@ -16888,7 +16959,6 @@ static struct snd_pci_quirk alc662_cfg_tbl[] = {
>  	SND_PCI_QUIRK(0x105b, 0x0cd6, "Foxconn", ALC662_ECS),
>  	SND_PCI_QUIRK(0x105b, 0x0d47, "Foxconn 45CMX/45GMX/45CMX-K",
>  		      ALC662_3ST_6ch_DIG),
> -	SND_PCI_QUIRK(0x1179, 0xff6e, "Toshiba NB200", ALC663_ASUS_MODE4),
>  	SND_PCI_QUIRK(0x144d, 0xca00, "Samsung NC10", ALC272_SAMSUNG_NC10),
>  	SND_PCI_QUIRK(0x1458, 0xa002, "Gigabyte 945GCM-S2L",
>  		      ALC662_3ST_6ch_DIG),
> @@ -17175,6 +17245,20 @@ static struct alc_config_preset alc662_presets[] = {
>  		.setup = alc663_mode4_setup,
>  		.init_hook = alc663_mode4_inithook,
>  	},
> +	[ALC272_TOSHIBA_NB200] = {
> +		.mixers = { alc663_m51va_mixer, alc272_toshiba_mixer },
> +		.init_verbs = { alc662_init_verbs, alc272_toshiba_init_verbs },
> +		.num_dacs = ARRAY_SIZE(alc662_dac_nids),
> +		.dac_nids = alc662_dac_nids,
> +		.num_channel_mode = ARRAY_SIZE(alc662_3ST_2ch_modes),
> +		.adc_nids = alc662_adc_nids,
> +		.num_adc_nids = ARRAY_SIZE(alc662_adc_nids),
> +		.capsrc_nids = alc662_capsrc_nids,
> +		.channel_mode = alc662_3ST_2ch_modes,
> +		.input_mux = &alc663_capture_source,
> +		.unsol_event = alc272_toshiba_unsol_event,
> +		.init_hook = alc272_toshiba_inithook,
> +	},
>  };
>  
>  
> -- 
> 1.6.4.2
> 
_______________________________________________
Alsa-devel mailing list
Alsa-devel@xxxxxxxxxxxxxxxx
http://mailman.alsa-project.org/mailman/listinfo/alsa-devel

[Index of Archives]     [ALSA User]     [Linux Audio Users]     [Kernel Archive]     [Asterisk PBX]     [Photo Sharing]     [Linux Sound]     [Video 4 Linux]     [Gimp]     [Yosemite News]

  Powered by Linux