[alsa-devel] [PATCH] hda: Add STAC_DELL_S14 quirk
Takashi Iwai
tiwai at suse.de
Fri Feb 13 08:46:30 CET 2009
At Thu, 12 Feb 2009 16:50:01 -0500,
Matthew Ranostay wrote:
>
> Add STAC_DELL_S14 quirk for new laptop series. Removed un-needed pins in pin_nids
> for stac92hd83xxx. Also reorganized connection selection code for the respective ports
> per quirk define.
Applied now. Thanks.
Takashi
>
> ---
> sound/pci/hda/patch_sigmatel.c | 52 +++++++++++++++++++++++++++-------------
> 1 files changed, 35 insertions(+), 17 deletions(-)
>
> diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
> index 12b3088..ed1c25c 100644
> --- a/sound/pci/hda/patch_sigmatel.c
> +++ b/sound/pci/hda/patch_sigmatel.c
> @@ -83,6 +83,7 @@ enum {
> enum {
> STAC_92HD83XXX_REF,
> STAC_92HD83XXX_PWR_REF,
> + STAC_DELL_S14,
> STAC_92HD83XXX_MODELS
> };
>
> @@ -480,10 +481,9 @@ static hda_nid_t stac92hd73xx_pin_nids[13] = {
> 0x14, 0x22, 0x23
> };
>
> -static hda_nid_t stac92hd83xxx_pin_nids[14] = {
> +static hda_nid_t stac92hd83xxx_pin_nids[10] = {
> 0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
> - 0x0f, 0x10, 0x11, 0x12, 0x13,
> - 0x1d, 0x1e, 0x1f, 0x20
> + 0x0f, 0x10, 0x11, 0x1f, 0x20,
> };
>
> #define STAC92HD71BXX_NUM_PINS 13
> @@ -857,9 +857,9 @@ static struct hda_verb stac92hd73xx_10ch_core_init[] = {
> };
>
> static struct hda_verb stac92hd83xxx_core_init[] = {
> - { 0xa, AC_VERB_SET_CONNECT_SEL, 0x0},
> - { 0xb, AC_VERB_SET_CONNECT_SEL, 0x0},
> - { 0xd, AC_VERB_SET_CONNECT_SEL, 0x1},
> + { 0xa, AC_VERB_SET_CONNECT_SEL, 0x1},
> + { 0xb, AC_VERB_SET_CONNECT_SEL, 0x1},
> + { 0xd, AC_VERB_SET_CONNECT_SEL, 0x0},
>
> /* power state controls amps */
> { 0x01, AC_VERB_SET_EAPD, 1 << 2},
> @@ -1730,21 +1730,28 @@ static struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = {
> {} /* terminator */
> };
>
> -static unsigned int ref92hd83xxx_pin_configs[14] = {
> +static unsigned int ref92hd83xxx_pin_configs[10] = {
> 0x02214030, 0x02211010, 0x02a19020, 0x02170130,
> 0x01014050, 0x01819040, 0x01014020, 0x90a3014e,
> - 0x40f000f0, 0x40f000f0, 0x40f000f0, 0x40f000f0,
> 0x01451160, 0x98560170,
> };
>
> +static unsigned int dell_s14_pin_configs[10] = {
> + 0x02214030, 0x02211010, 0x02a19020, 0x01014050,
> + 0x40f000f0, 0x01819040, 0x40f000f0, 0x90a60160,
> + 0x40f000f0, 0x40f000f0,
> +};
> +
> static unsigned int *stac92hd83xxx_brd_tbl[STAC_92HD83XXX_MODELS] = {
> [STAC_92HD83XXX_REF] = ref92hd83xxx_pin_configs,
> [STAC_92HD83XXX_PWR_REF] = ref92hd83xxx_pin_configs,
> + [STAC_DELL_S14] = dell_s14_pin_configs,
> };
>
> static const char *stac92hd83xxx_models[STAC_92HD83XXX_MODELS] = {
> [STAC_92HD83XXX_REF] = "ref",
> [STAC_92HD83XXX_PWR_REF] = "mic-ref",
> + [STAC_DELL_S14] = "dell-s14",
> };
>
> static struct snd_pci_quirk stac92hd83xxx_cfg_tbl[] = {
> @@ -1753,6 +1760,8 @@ static struct snd_pci_quirk stac92hd83xxx_cfg_tbl[] = {
> "DFI LanParty", STAC_92HD83XXX_REF),
> SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
> "DFI LanParty", STAC_92HD83XXX_REF),
> + SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ba,
> + "unknown Dell", STAC_DELL_S14),
> {} /* terminator */
> };
>
> @@ -4822,6 +4831,7 @@ static int patch_stac92hd83xxx(struct hda_codec *codec)
> hda_nid_t conn[STAC92HD83_DAC_COUNT + 1];
> int err;
> int num_dacs;
> + hda_nid_t nid;
>
> spec = kzalloc(sizeof(*spec), GFP_KERNEL);
> if (spec == NULL)
> @@ -4840,15 +4850,6 @@ static int patch_stac92hd83xxx(struct hda_codec *codec)
> spec->num_pwrs = ARRAY_SIZE(stac92hd83xxx_pwr_nids);
> spec->multiout.dac_nids = spec->dac_nids;
>
> -
> - /* set port 0xe to select the last DAC
> - */
> - num_dacs = snd_hda_get_connections(codec, 0x0e,
> - conn, STAC92HD83_DAC_COUNT + 1) - 1;
> -
> - snd_hda_codec_write_cache(codec, 0xe, 0,
> - AC_VERB_SET_CONNECT_SEL, num_dacs);
> -
> spec->init = stac92hd83xxx_core_init;
> spec->mixer = stac92hd83xxx_mixer;
> spec->num_pins = ARRAY_SIZE(stac92hd83xxx_pin_nids);
> @@ -4900,6 +4901,23 @@ again:
> return err;
> }
>
> + switch (spec->board_config) {
> + case STAC_DELL_S14:
> + nid = 0xf;
> + break;
> + default:
> + nid = 0xe;
> + break;
> + }
> +
> + num_dacs = snd_hda_get_connections(codec, nid,
> + conn, STAC92HD83_DAC_COUNT + 1) - 1;
> +
> + /* set port X to select the last DAC
> + */
> + snd_hda_codec_write_cache(codec, nid, 0,
> + AC_VERB_SET_CONNECT_SEL, num_dacs);
> +
> codec->patch_ops = stac92xx_patch_ops;
>
> codec->proc_widget_hook = stac92hd_proc_hook;
> --
> 1.5.6.3
>
>
More information about the Alsa-devel
mailing list