Linux Audio

Check our new training course

Yocto / OpenEmbedded training

Feb 10-13, 2025
Register
Loading...
v6.8
   1// SPDX-License-Identifier: GPL-2.0-or-later
   2/*
   3 * Universal Interface for Intel High Definition Audio Codec
   4 *
   5 * HD audio interface patch for SigmaTel STAC92xx
   6 *
   7 * Copyright (c) 2005 Embedded Alley Solutions, Inc.
   8 * Matt Porter <mporter@embeddedalley.com>
   9 *
  10 * Based on patch_cmedia.c and patch_realtek.c
  11 * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
  12 */
  13
  14#include <linux/init.h>
  15#include <linux/delay.h>
  16#include <linux/slab.h>
  17#include <linux/pci.h>
  18#include <linux/dmi.h>
  19#include <linux/module.h>
  20#include <sound/core.h>
 
  21#include <sound/jack.h>
  22#include <sound/hda_codec.h>
 
  23#include "hda_local.h"
  24#include "hda_auto_parser.h"
  25#include "hda_beep.h"
  26#include "hda_jack.h"
  27#include "hda_generic.h"
  28
  29enum {
 
 
 
 
 
 
 
 
 
 
  30	STAC_REF,
  31	STAC_9200_OQO,
  32	STAC_9200_DELL_D21,
  33	STAC_9200_DELL_D22,
  34	STAC_9200_DELL_D23,
  35	STAC_9200_DELL_M21,
  36	STAC_9200_DELL_M22,
  37	STAC_9200_DELL_M23,
  38	STAC_9200_DELL_M24,
  39	STAC_9200_DELL_M25,
  40	STAC_9200_DELL_M26,
  41	STAC_9200_DELL_M27,
  42	STAC_9200_M4,
  43	STAC_9200_M4_2,
  44	STAC_9200_PANASONIC,
  45	STAC_9200_EAPD_INIT,
  46	STAC_9200_MODELS
  47};
  48
  49enum {
 
  50	STAC_9205_REF,
  51	STAC_9205_DELL_M42,
  52	STAC_9205_DELL_M43,
  53	STAC_9205_DELL_M44,
  54	STAC_9205_EAPD,
  55	STAC_9205_MODELS
  56};
  57
  58enum {
 
  59	STAC_92HD73XX_NO_JD, /* no jack-detection */
  60	STAC_92HD73XX_REF,
  61	STAC_92HD73XX_INTEL,
  62	STAC_DELL_M6_AMIC,
  63	STAC_DELL_M6_DMIC,
  64	STAC_DELL_M6_BOTH,
  65	STAC_DELL_EQ,
  66	STAC_ALIENWARE_M17X,
  67	STAC_ELO_VUPOINT_15MX,
  68	STAC_92HD89XX_HP_FRONT_JACK,
  69	STAC_92HD89XX_HP_Z1_G2_RIGHT_MIC_JACK,
  70	STAC_92HD73XX_ASUS_MOBO,
  71	STAC_92HD73XX_MODELS
  72};
  73
  74enum {
 
  75	STAC_92HD83XXX_REF,
  76	STAC_92HD83XXX_PWR_REF,
  77	STAC_DELL_S14,
  78	STAC_DELL_VOSTRO_3500,
  79	STAC_92HD83XXX_HP_cNB11_INTQUAD,
  80	STAC_HP_DV7_4000,
  81	STAC_HP_ZEPHYR,
  82	STAC_92HD83XXX_HP_LED,
  83	STAC_92HD83XXX_HP_INV_LED,
  84	STAC_92HD83XXX_HP_MIC_LED,
  85	STAC_HP_LED_GPIO10,
  86	STAC_92HD83XXX_HEADSET_JACK,
  87	STAC_92HD83XXX_HP,
  88	STAC_HP_ENVY_BASS,
  89	STAC_HP_BNB13_EQ,
  90	STAC_HP_ENVY_TS_BASS,
  91	STAC_HP_ENVY_TS_DAC_BIND,
  92	STAC_92HD83XXX_GPIO10_EAPD,
  93	STAC_92HD83XXX_MODELS
  94};
  95
  96enum {
 
  97	STAC_92HD71BXX_REF,
  98	STAC_DELL_M4_1,
  99	STAC_DELL_M4_2,
 100	STAC_DELL_M4_3,
 101	STAC_HP_M4,
 102	STAC_HP_DV4,
 103	STAC_HP_DV5,
 104	STAC_HP_HDX,
 105	STAC_92HD71BXX_HP,
 106	STAC_92HD71BXX_NO_DMIC,
 107	STAC_92HD71BXX_NO_SMUX,
 108	STAC_92HD71BXX_MODELS
 109};
 110
 111enum {
 112	STAC_92HD95_HP_LED,
 113	STAC_92HD95_HP_BASS,
 114	STAC_92HD95_MODELS
 115};
 116
 117enum {
 118	STAC_925x_REF,
 119	STAC_M1,
 120	STAC_M1_2,
 121	STAC_M2,
 122	STAC_M2_2,
 123	STAC_M3,
 124	STAC_M5,
 125	STAC_M6,
 126	STAC_925x_MODELS
 127};
 128
 129enum {
 
 130	STAC_D945_REF,
 131	STAC_D945GTP3,
 132	STAC_D945GTP5,
 133	STAC_INTEL_MAC_V1,
 134	STAC_INTEL_MAC_V2,
 135	STAC_INTEL_MAC_V3,
 136	STAC_INTEL_MAC_V4,
 137	STAC_INTEL_MAC_V5,
 138	STAC_INTEL_MAC_AUTO,
 
 
 
 
 
 
 
 
 
 139	STAC_ECS_202,
 140	STAC_922X_DELL_D81,
 141	STAC_922X_DELL_D82,
 142	STAC_922X_DELL_M81,
 143	STAC_922X_DELL_M82,
 144	STAC_922X_INTEL_MAC_GPIO,
 145	STAC_922X_MODELS
 146};
 147
 148enum {
 
 149	STAC_D965_REF_NO_JD, /* no jack-detection */
 150	STAC_D965_REF,
 151	STAC_D965_3ST,
 152	STAC_D965_5ST,
 153	STAC_D965_5ST_NO_FP,
 154	STAC_D965_VERBS,
 155	STAC_DELL_3ST,
 156	STAC_DELL_BIOS,
 157	STAC_NEMO_DEFAULT,
 158	STAC_DELL_BIOS_AMIC,
 159	STAC_DELL_BIOS_SPDIF,
 160	STAC_927X_DELL_DMIC,
 161	STAC_927X_VOLKNOB,
 162	STAC_927X_MODELS
 163};
 164
 165enum {
 
 166	STAC_9872_VAIO,
 167	STAC_9872_MODELS
 168};
 169
 
 
 
 
 
 
 
 
 
 
 170struct sigmatel_spec {
 171	struct hda_gen_spec gen;
 
 172
 
 173	unsigned int eapd_switch: 1;
 
 
 
 
 
 
 174	unsigned int linear_tone_beep:1;
 175	unsigned int headset_jack:1; /* 4-pin headset jack (hp + mono mic) */
 176	unsigned int volknob_init:1; /* special volume-knob initialization */
 177	unsigned int powerdown_adcs:1;
 178	unsigned int have_spdif_mux:1;
 179
 180	/* gpio lines */
 181	unsigned int eapd_mask;
 182	unsigned int gpio_mask;
 183	unsigned int gpio_dir;
 184	unsigned int gpio_data;
 185	unsigned int gpio_mute;
 186	unsigned int gpio_led;
 187	unsigned int gpio_led_polarity;
 188	unsigned int vref_mute_led_nid; /* pin NID for mute-LED vref control */
 189	unsigned int vref_led;
 190	int default_polarity;
 191
 192	unsigned int mic_mute_led_gpio; /* capture mute LED GPIO */
 193	unsigned int mic_enabled; /* current mic mute state (bitmask) */
 194
 195	/* stream */
 196	unsigned int stream_delay;
 197
 198	/* analog loopback */
 199	const struct snd_kcontrol_new *aloopback_ctl;
 200	unsigned int aloopback;
 201	unsigned char aloopback_mask;
 202	unsigned char aloopback_shift;
 203
 204	/* power management */
 205	unsigned int power_map_bits;
 206	unsigned int num_pwrs;
 207	const hda_nid_t *pwr_nids;
 208	unsigned int active_adcs;
 209
 210	/* beep widgets */
 211	hda_nid_t anabeep_nid;
 212	bool beep_power_on;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 213
 214	/* SPDIF-out mux */
 215	const char * const *spdif_labels;
 216	struct hda_input_mux spdif_mux;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 217	unsigned int cur_smux[2];
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 218};
 219
 220#define AC_VERB_IDT_SET_POWER_MAP	0x7ec
 221#define AC_VERB_IDT_GET_POWER_MAP	0xfec
 222
 
 
 
 
 
 
 
 
 
 
 
 
 223static const hda_nid_t stac92hd73xx_pwr_nids[8] = {
 224	0x0a, 0x0b, 0x0c, 0xd, 0x0e,
 225	0x0f, 0x10, 0x11
 226};
 227
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 228static const hda_nid_t stac92hd83xxx_pwr_nids[7] = {
 229	0x0a, 0x0b, 0x0c, 0xd, 0x0e,
 230	0x0f, 0x10
 231};
 232
 
 
 
 
 
 
 
 
 233static const hda_nid_t stac92hd71bxx_pwr_nids[3] = {
 234	0x0a, 0x0d, 0x0f
 235};
 236
 
 
 
 237
 238/*
 239 * PCM hooks
 240 */
 241static void stac_playback_pcm_hook(struct hda_pcm_stream *hinfo,
 242				   struct hda_codec *codec,
 243				   struct snd_pcm_substream *substream,
 244				   int action)
 245{
 246	struct sigmatel_spec *spec = codec->spec;
 247	if (action == HDA_GEN_PCM_ACT_OPEN && spec->stream_delay)
 248		msleep(spec->stream_delay);
 249}
 250
 251static void stac_capture_pcm_hook(struct hda_pcm_stream *hinfo,
 252				  struct hda_codec *codec,
 253				  struct snd_pcm_substream *substream,
 254				  int action)
 255{
 256	struct sigmatel_spec *spec = codec->spec;
 257	int i, idx = 0;
 258
 259	if (!spec->powerdown_adcs)
 260		return;
 
 261
 262	for (i = 0; i < spec->gen.num_all_adcs; i++) {
 263		if (spec->gen.all_adcs[i] == hinfo->nid) {
 264			idx = i;
 265			break;
 266		}
 267	}
 268
 269	switch (action) {
 270	case HDA_GEN_PCM_ACT_OPEN:
 271		msleep(40);
 272		snd_hda_codec_write(codec, hinfo->nid, 0,
 273				    AC_VERB_SET_POWER_STATE, AC_PWRST_D0);
 274		spec->active_adcs |= (1 << idx);
 275		break;
 276	case HDA_GEN_PCM_ACT_CLOSE:
 277		snd_hda_codec_write(codec, hinfo->nid, 0,
 278				    AC_VERB_SET_POWER_STATE, AC_PWRST_D3);
 279		spec->active_adcs &= ~(1 << idx);
 280		break;
 281	}
 282}
 283
 284/*
 285 * Early 2006 Intel Macintoshes with STAC9220X5 codecs seem to have a
 286 * funky external mute control using GPIO pins.
 287 */
 288
 289static void stac_gpio_set(struct hda_codec *codec, unsigned int mask,
 290			  unsigned int dir_mask, unsigned int data)
 291{
 292	unsigned int gpiostate, gpiomask, gpiodir;
 293	hda_nid_t fg = codec->core.afg;
 
 294
 295	codec_dbg(codec, "%s msk %x dir %x gpio %x\n", __func__, mask, dir_mask, data);
 
 
 296
 297	gpiostate = snd_hda_codec_read(codec, fg, 0,
 298				       AC_VERB_GET_GPIO_DATA, 0);
 299	gpiostate = (gpiostate & ~dir_mask) | (data & dir_mask);
 300
 301	gpiomask = snd_hda_codec_read(codec, fg, 0,
 302				      AC_VERB_GET_GPIO_MASK, 0);
 303	gpiomask |= mask;
 304
 305	gpiodir = snd_hda_codec_read(codec, fg, 0,
 306				     AC_VERB_GET_GPIO_DIRECTION, 0);
 307	gpiodir |= dir_mask;
 
 308
 309	/* Configure GPIOx as CMOS */
 310	snd_hda_codec_write(codec, fg, 0, 0x7e7, 0);
 
 311
 312	snd_hda_codec_write(codec, fg, 0,
 313			    AC_VERB_SET_GPIO_MASK, gpiomask);
 314	snd_hda_codec_read(codec, fg, 0,
 315			   AC_VERB_SET_GPIO_DIRECTION, gpiodir); /* sync */
 
 
 316
 317	msleep(1);
 
 
 318
 319	snd_hda_codec_read(codec, fg, 0,
 320			   AC_VERB_SET_GPIO_DATA, gpiostate); /* sync */
 321}
 322
 323/* hook for controlling mic-mute LED GPIO */
 324static int stac_capture_led_update(struct led_classdev *led_cdev,
 325				   enum led_brightness brightness)
 326{
 327	struct hda_codec *codec = dev_to_hda_codec(led_cdev->dev->parent);
 328	struct sigmatel_spec *spec = codec->spec;
 329
 330	if (brightness)
 331		spec->gpio_data |= spec->mic_mute_led_gpio;
 332	else
 333		spec->gpio_data &= ~spec->mic_mute_led_gpio;
 334	stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data);
 335	return 0;
 336}
 337
 338static int stac_vrefout_set(struct hda_codec *codec,
 339					hda_nid_t nid, unsigned int new_vref)
 340{
 341	int error, pinctl;
 342
 343	codec_dbg(codec, "%s, nid %x ctl %x\n", __func__, nid, new_vref);
 344	pinctl = snd_hda_codec_read(codec, nid, 0,
 345				AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
 346
 347	if (pinctl < 0)
 348		return pinctl;
 
 349
 350	pinctl &= 0xff;
 351	pinctl &= ~AC_PINCTL_VREFEN;
 352	pinctl |= (new_vref & AC_PINCTL_VREFEN);
 353
 354	error = snd_hda_set_pin_ctl_cache(codec, nid, pinctl);
 355	if (error < 0)
 356		return error;
 357
 358	return 1;
 359}
 
 
 360
 361/* prevent codec AFG to D3 state when vref-out pin is used for mute LED */
 362/* this hook is set in stac_setup_gpio() */
 363static unsigned int stac_vref_led_power_filter(struct hda_codec *codec,
 364					       hda_nid_t nid,
 365					       unsigned int power_state)
 366{
 367	if (nid == codec->core.afg && power_state == AC_PWRST_D3)
 368		return AC_PWRST_D1;
 369	return snd_hda_gen_path_power_filter(codec, nid, power_state);
 370}
 
 371
 372/* update mute-LED accoring to the master switch */
 373static void stac_update_led_status(struct hda_codec *codec, bool muted)
 374{
 375	struct sigmatel_spec *spec = codec->spec;
 376
 377	if (!spec->gpio_led)
 378		return;
 
 379
 380	/* LED state is inverted on these systems */
 381	if (spec->gpio_led_polarity)
 382		muted = !muted;
 383
 384	if (!spec->vref_mute_led_nid) {
 385		if (muted)
 386			spec->gpio_data |= spec->gpio_led;
 387		else
 388			spec->gpio_data &= ~spec->gpio_led;
 389		stac_gpio_set(codec, spec->gpio_mask,
 390				spec->gpio_dir, spec->gpio_data);
 391	} else {
 392		spec->vref_led = muted ? AC_PINCTL_VREF_50 : AC_PINCTL_VREF_GRD;
 393		stac_vrefout_set(codec,	spec->vref_mute_led_nid,
 394				 spec->vref_led);
 395	}
 396}
 397
 398/* vmaster hook to update mute LED */
 399static int stac_vmaster_hook(struct led_classdev *led_cdev,
 400			     enum led_brightness brightness)
 401{
 402	struct hda_codec *codec = dev_to_hda_codec(led_cdev->dev->parent);
 403
 404	stac_update_led_status(codec, brightness);
 405	return 0;
 406}
 
 407
 408/* automute hook to handle GPIO mute and EAPD updates */
 409static void stac_update_outputs(struct hda_codec *codec)
 410{
 411	struct sigmatel_spec *spec = codec->spec;
 
 
 
 
 
 412
 413	if (spec->gpio_mute)
 414		spec->gen.master_mute =
 415			!(snd_hda_codec_read(codec, codec->core.afg, 0,
 416				AC_VERB_GET_GPIO_DATA, 0) & spec->gpio_mute);
 417
 418	snd_hda_gen_update_outputs(codec);
 419
 420	if (spec->eapd_mask && spec->eapd_switch) {
 421		unsigned int val = spec->gpio_data;
 422		if (spec->gen.speaker_muted)
 423			val &= ~spec->eapd_mask;
 424		else
 425			val |= spec->eapd_mask;
 426		if (spec->gpio_data != val) {
 427			spec->gpio_data = val;
 428			stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir,
 429				      val);
 430		}
 431	}
 432}
 433
 434static void stac_toggle_power_map(struct hda_codec *codec, hda_nid_t nid,
 435				  bool enable, bool do_write)
 436{
 437	struct sigmatel_spec *spec = codec->spec;
 438	unsigned int idx, val;
 439
 440	for (idx = 0; idx < spec->num_pwrs; idx++) {
 441		if (spec->pwr_nids[idx] == nid)
 442			break;
 443	}
 444	if (idx >= spec->num_pwrs)
 445		return;
 446
 447	idx = 1 << idx;
 
 
 
 
 448
 449	val = spec->power_map_bits;
 450	if (enable)
 451		val &= ~idx;
 452	else
 453		val |= idx;
 
 
 
 
 
 
 454
 455	/* power down unused output ports */
 456	if (val != spec->power_map_bits) {
 457		spec->power_map_bits = val;
 458		if (do_write)
 459			snd_hda_codec_write(codec, codec->core.afg, 0,
 460					    AC_VERB_IDT_SET_POWER_MAP, val);
 461	}
 462}
 
 
 
 463
 464/* update power bit per jack plug/unplug */
 465static void jack_update_power(struct hda_codec *codec,
 466			      struct hda_jack_callback *jack)
 467{
 
 468	struct sigmatel_spec *spec = codec->spec;
 469	int i;
 470
 471	if (!spec->num_pwrs)
 472		return;
 473
 474	if (jack && jack->nid) {
 475		stac_toggle_power_map(codec, jack->nid,
 476				      snd_hda_jack_detect(codec, jack->nid),
 477				      true);
 478		return;
 479	}
 480
 481	/* update all jacks */
 482	for (i = 0; i < spec->num_pwrs; i++) {
 483		hda_nid_t nid = spec->pwr_nids[i];
 484		if (!snd_hda_jack_tbl_get(codec, nid))
 485			continue;
 486		stac_toggle_power_map(codec, nid,
 487				      snd_hda_jack_detect(codec, nid),
 488				      false);
 489	}
 490
 491	snd_hda_codec_write(codec, codec->core.afg, 0,
 492			    AC_VERB_IDT_SET_POWER_MAP,
 493			    spec->power_map_bits);
 494}
 495
 496static void stac_vref_event(struct hda_codec *codec,
 497			    struct hda_jack_callback *event)
 498{
 499	unsigned int data;
 
 
 500
 501	data = snd_hda_codec_read(codec, codec->core.afg, 0,
 502				  AC_VERB_GET_GPIO_DATA, 0);
 503	/* toggle VREF state based on GPIOx status */
 504	snd_hda_codec_write(codec, codec->core.afg, 0, 0x7e0,
 505			    !!(data & (1 << event->private_data)));
 506}
 507
 508/* initialize the power map and enable the power event to jacks that
 509 * haven't been assigned to automute
 510 */
 511static void stac_init_power_map(struct hda_codec *codec)
 512{
 
 513	struct sigmatel_spec *spec = codec->spec;
 514	int i;
 515
 516	for (i = 0; i < spec->num_pwrs; i++)  {
 517		hda_nid_t nid = spec->pwr_nids[i];
 518		unsigned int def_conf = snd_hda_codec_get_pincfg(codec, nid);
 519		def_conf = get_defcfg_connect(def_conf);
 520		if (def_conf == AC_JACK_PORT_COMPLEX &&
 521		    spec->vref_mute_led_nid != nid &&
 522		    is_jack_detectable(codec, nid)) {
 523			snd_hda_jack_detect_enable_callback(codec, nid,
 524							    jack_update_power);
 525		} else {
 526			if (def_conf == AC_JACK_PORT_NONE)
 527				stac_toggle_power_map(codec, nid, false, false);
 528			else
 529				stac_toggle_power_map(codec, nid, true, false);
 530		}
 531	}
 532}
 533
 534/*
 535 */
 536
 537static inline bool get_int_hint(struct hda_codec *codec, const char *key,
 538				int *valp)
 539{
 540	return !snd_hda_get_int_hint(codec, key, valp);
 541}
 542
 543/* override some hints from the hwdep entry */
 544static void stac_store_hints(struct hda_codec *codec)
 545{
 
 546	struct sigmatel_spec *spec = codec->spec;
 547	int val;
 548
 549	if (get_int_hint(codec, "gpio_mask", &spec->gpio_mask)) {
 550		spec->eapd_mask = spec->gpio_dir = spec->gpio_data =
 551			spec->gpio_mask;
 552	}
 553	if (get_int_hint(codec, "gpio_dir", &spec->gpio_dir))
 554		spec->gpio_dir &= spec->gpio_mask;
 555	if (get_int_hint(codec, "gpio_data", &spec->gpio_data))
 556		spec->gpio_data &= spec->gpio_mask;
 557	if (get_int_hint(codec, "eapd_mask", &spec->eapd_mask))
 558		spec->eapd_mask &= spec->gpio_mask;
 559	if (get_int_hint(codec, "gpio_mute", &spec->gpio_mute))
 560		spec->gpio_mute &= spec->gpio_mask;
 561	val = snd_hda_get_bool_hint(codec, "eapd_switch");
 562	if (val >= 0)
 563		spec->eapd_switch = val;
 564}
 565
 566/*
 567 * loopback controls
 568 */
 569
 570#define stac_aloopback_info snd_ctl_boolean_mono_info
 571
 572static int stac_aloopback_get(struct snd_kcontrol *kcontrol,
 573			      struct snd_ctl_elem_value *ucontrol)
 574{
 575	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 576	unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 577	struct sigmatel_spec *spec = codec->spec;
 
 578
 579	ucontrol->value.integer.value[0] = !!(spec->aloopback &
 580					      (spec->aloopback_mask << idx));
 581	return 0;
 582}
 583
 584static int stac_aloopback_put(struct snd_kcontrol *kcontrol,
 585			      struct snd_ctl_elem_value *ucontrol)
 586{
 587	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 588	struct sigmatel_spec *spec = codec->spec;
 589	unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 590	unsigned int dac_mode;
 591	unsigned int val, idx_val;
 592
 593	idx_val = spec->aloopback_mask << idx;
 594	if (ucontrol->value.integer.value[0])
 595		val = spec->aloopback | idx_val;
 596	else
 597		val = spec->aloopback & ~idx_val;
 598	if (spec->aloopback == val)
 599		return 0;
 600
 601	spec->aloopback = val;
 602
 603	/* Only return the bits defined by the shift value of the
 604	 * first two bytes of the mask
 605	 */
 606	dac_mode = snd_hda_codec_read(codec, codec->core.afg, 0,
 607				      kcontrol->private_value & 0xFFFF, 0x0);
 608	dac_mode >>= spec->aloopback_shift;
 609
 610	if (spec->aloopback & idx_val) {
 611		snd_hda_power_up(codec);
 612		dac_mode |= idx_val;
 613	} else {
 614		snd_hda_power_down(codec);
 615		dac_mode &= ~idx_val;
 
 
 
 
 
 
 616	}
 617
 618	snd_hda_codec_write_cache(codec, codec->core.afg, 0,
 619		kcontrol->private_value >> 16, dac_mode);
 620
 621	return 1;
 622}
 623
 624#define STAC_ANALOG_LOOPBACK(verb_read, verb_write, cnt) \
 625	{ \
 626		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
 627		.name  = "Analog Loopback", \
 628		.count = cnt, \
 629		.info  = stac_aloopback_info, \
 630		.get   = stac_aloopback_get, \
 631		.put   = stac_aloopback_put, \
 632		.private_value = verb_read | (verb_write << 16), \
 633	}
 634
 635/*
 636 * Mute LED handling on HP laptops
 637 */
 638
 639/* check whether it's a HP laptop with a docking port */
 640static bool hp_bnb2011_with_dock(struct hda_codec *codec)
 641{
 642	if (codec->core.vendor_id != 0x111d7605 &&
 643	    codec->core.vendor_id != 0x111d76d1)
 644		return false;
 645
 646	switch (codec->core.subsystem_id) {
 647	case 0x103c1618:
 648	case 0x103c1619:
 649	case 0x103c161a:
 650	case 0x103c161b:
 651	case 0x103c161c:
 652	case 0x103c161d:
 653	case 0x103c161e:
 654	case 0x103c161f:
 655
 656	case 0x103c162a:
 657	case 0x103c162b:
 658
 659	case 0x103c1630:
 660	case 0x103c1631:
 
 661
 662	case 0x103c1633:
 663	case 0x103c1634:
 664	case 0x103c1635:
 665
 666	case 0x103c3587:
 667	case 0x103c3588:
 668	case 0x103c3589:
 669	case 0x103c358a:
 670
 671	case 0x103c3667:
 672	case 0x103c3668:
 673	case 0x103c3669:
 674
 675		return true;
 676	}
 677	return false;
 678}
 679
 680static bool hp_blike_system(u32 subsystem_id)
 
 681{
 682	switch (subsystem_id) {
 683	case 0x103c1473: /* HP ProBook 6550b */
 684	case 0x103c1520:
 685	case 0x103c1521:
 686	case 0x103c1523:
 687	case 0x103c1524:
 688	case 0x103c1525:
 689	case 0x103c1722:
 690	case 0x103c1723:
 691	case 0x103c1724:
 692	case 0x103c1725:
 693	case 0x103c1726:
 694	case 0x103c1727:
 695	case 0x103c1728:
 696	case 0x103c1729:
 697	case 0x103c172a:
 698	case 0x103c172b:
 699	case 0x103c307e:
 700	case 0x103c307f:
 701	case 0x103c3080:
 702	case 0x103c3081:
 703	case 0x103c7007:
 704	case 0x103c7008:
 705		return true;
 706	}
 707	return false;
 708}
 709
 710static void set_hp_led_gpio(struct hda_codec *codec)
 711{
 712	struct sigmatel_spec *spec = codec->spec;
 713	unsigned int gpio;
 714
 715	if (spec->gpio_led)
 716		return;
 
 
 717
 718	gpio = snd_hda_param_read(codec, codec->core.afg, AC_PAR_GPIO_CAP);
 719	gpio &= AC_GPIO_IO_COUNT;
 720	if (gpio > 3)
 721		spec->gpio_led = 0x08; /* GPIO 3 */
 722	else
 723		spec->gpio_led = 0x01; /* GPIO 0 */
 724}
 725
 726/*
 727 * This method searches for the mute LED GPIO configuration
 728 * provided as OEM string in SMBIOS. The format of that string
 729 * is HP_Mute_LED_P_G or HP_Mute_LED_P
 730 * where P can be 0 or 1 and defines mute LED GPIO control state (low/high)
 731 * that corresponds to the NOT muted state of the master volume
 732 * and G is the index of the GPIO to use as the mute LED control (0..9)
 733 * If _G portion is missing it is assigned based on the codec ID
 734 *
 735 * So, HP B-series like systems may have HP_Mute_LED_0 (current models)
 736 * or  HP_Mute_LED_0_3 (future models) OEM SMBIOS strings
 737 *
 738 *
 739 * The dv-series laptops don't seem to have the HP_Mute_LED* strings in
 740 * SMBIOS - at least the ones I have seen do not have them - which include
 741 * my own system (HP Pavilion dv6-1110ax) and my cousin's
 742 * HP Pavilion dv9500t CTO.
 743 * Need more information on whether it is true across the entire series.
 744 * -- kunal
 745 */
 746static int find_mute_led_cfg(struct hda_codec *codec, int default_polarity)
 747{
 748	struct sigmatel_spec *spec = codec->spec;
 749	const struct dmi_device *dev = NULL;
 750
 751	if (get_int_hint(codec, "gpio_led", &spec->gpio_led)) {
 752		get_int_hint(codec, "gpio_led_polarity",
 753			     &spec->gpio_led_polarity);
 754		return 1;
 755	}
 756
 757	while ((dev = dmi_find_device(DMI_DEV_TYPE_OEM_STRING, NULL, dev))) {
 758		if (sscanf(dev->name, "HP_Mute_LED_%u_%x",
 759			   &spec->gpio_led_polarity,
 760			   &spec->gpio_led) == 2) {
 761			unsigned int max_gpio;
 762			max_gpio = snd_hda_param_read(codec, codec->core.afg,
 763						      AC_PAR_GPIO_CAP);
 764			max_gpio &= AC_GPIO_IO_COUNT;
 765			if (spec->gpio_led < max_gpio)
 766				spec->gpio_led = 1 << spec->gpio_led;
 767			else
 768				spec->vref_mute_led_nid = spec->gpio_led;
 769			return 1;
 770		}
 771		if (sscanf(dev->name, "HP_Mute_LED_%u",
 772			   &spec->gpio_led_polarity) == 1) {
 773			set_hp_led_gpio(codec);
 774			return 1;
 775		}
 776		/* BIOS bug: unfilled OEM string */
 777		if (strstr(dev->name, "HP_Mute_LED_P_G")) {
 778			set_hp_led_gpio(codec);
 779			if (default_polarity >= 0)
 780				spec->gpio_led_polarity = default_polarity;
 781			else
 782				spec->gpio_led_polarity = 1;
 783			return 1;
 784		}
 785	}
 786
 787	/*
 788	 * Fallback case - if we don't find the DMI strings,
 789	 * we statically set the GPIO - if not a B-series system
 790	 * and default polarity is provided
 791	 */
 792	if (!hp_blike_system(codec->core.subsystem_id) &&
 793	    (default_polarity == 0 || default_polarity == 1)) {
 794		set_hp_led_gpio(codec);
 795		spec->gpio_led_polarity = default_polarity;
 796		return 1;
 797	}
 798	return 0;
 799}
 800
 801/* check whether a built-in speaker is included in parsed pins */
 802static bool has_builtin_speaker(struct hda_codec *codec)
 803{
 
 804	struct sigmatel_spec *spec = codec->spec;
 805	const hda_nid_t *nid_pin;
 806	int nids, i;
 807
 808	if (spec->gen.autocfg.line_out_type == AUTO_PIN_SPEAKER_OUT) {
 809		nid_pin = spec->gen.autocfg.line_out_pins;
 810		nids = spec->gen.autocfg.line_outs;
 811	} else {
 812		nid_pin = spec->gen.autocfg.speaker_pins;
 813		nids = spec->gen.autocfg.speaker_outs;
 814	}
 815
 816	for (i = 0; i < nids; i++) {
 817		unsigned int def_conf = snd_hda_codec_get_pincfg(codec, nid_pin[i]);
 818		if (snd_hda_get_input_pin_attr(def_conf) == INPUT_PIN_ATTR_INT)
 819			return true;
 820	}
 821	return false;
 822}
 823
 824/*
 825 * PC beep controls
 826 */
 827
 828/* create PC beep volume controls */
 829static int stac_auto_create_beep_ctls(struct hda_codec *codec,
 830						hda_nid_t nid)
 831{
 
 832	struct sigmatel_spec *spec = codec->spec;
 833	u32 caps = query_amp_caps(codec, nid, HDA_OUTPUT);
 834	struct snd_kcontrol_new *knew;
 835	static const struct snd_kcontrol_new abeep_mute_ctl =
 836		HDA_CODEC_MUTE(NULL, 0, 0, 0);
 837	static const struct snd_kcontrol_new dbeep_mute_ctl =
 838		HDA_CODEC_MUTE_BEEP(NULL, 0, 0, 0);
 839	static const struct snd_kcontrol_new beep_vol_ctl =
 840		HDA_CODEC_VOLUME(NULL, 0, 0, 0);
 841
 842	/* check for mute support for the amp */
 843	if ((caps & AC_AMPCAP_MUTE) >> AC_AMPCAP_MUTE_SHIFT) {
 844		const struct snd_kcontrol_new *temp;
 845		if (spec->anabeep_nid == nid)
 846			temp = &abeep_mute_ctl;
 847		else
 848			temp = &dbeep_mute_ctl;
 849		knew = snd_hda_gen_add_kctl(&spec->gen,
 850					    "Beep Playback Switch", temp);
 851		if (!knew)
 852			return -ENOMEM;
 853		knew->private_value =
 854			HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT);
 855	}
 856
 857	/* check to see if there is volume support for the amp */
 858	if ((caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT) {
 859		knew = snd_hda_gen_add_kctl(&spec->gen,
 860					    "Beep Playback Volume",
 861					    &beep_vol_ctl);
 862		if (!knew)
 863			return -ENOMEM;
 864		knew->private_value =
 865			HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT);
 866	}
 867	return 0;
 868}
 869
 870#ifdef CONFIG_SND_HDA_INPUT_BEEP
 871#define stac_dig_beep_switch_info snd_ctl_boolean_mono_info
 872
 873static int stac_dig_beep_switch_get(struct snd_kcontrol *kcontrol,
 874				    struct snd_ctl_elem_value *ucontrol)
 875{
 876	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 877	ucontrol->value.integer.value[0] = codec->beep->enabled;
 878	return 0;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 879}
 880
 881static int stac_dig_beep_switch_put(struct snd_kcontrol *kcontrol,
 882				    struct snd_ctl_elem_value *ucontrol)
 883{
 884	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 885	return snd_hda_enable_beep_device(codec, ucontrol->value.integer.value[0]);
 
 886}
 887
 888static const struct snd_kcontrol_new stac_dig_beep_ctrl = {
 889	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 890	.name = "Beep Playback Switch",
 891	.info = stac_dig_beep_switch_info,
 892	.get = stac_dig_beep_switch_get,
 893	.put = stac_dig_beep_switch_put,
 894};
 895
 896static int stac_beep_switch_ctl(struct hda_codec *codec)
 897{
 
 898	struct sigmatel_spec *spec = codec->spec;
 899
 900	if (!snd_hda_gen_add_kctl(&spec->gen, NULL, &stac_dig_beep_ctrl))
 901		return -ENOMEM;
 902	return 0;
 903}
 904#endif
 905
 906/*
 907 * SPDIF-out mux controls
 908 */
 909
 910static int stac_smux_enum_info(struct snd_kcontrol *kcontrol,
 911			       struct snd_ctl_elem_info *uinfo)
 912{
 913	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 914	struct sigmatel_spec *spec = codec->spec;
 915	return snd_hda_input_mux_info(&spec->spdif_mux, uinfo);
 
 
 916}
 917
 918static int stac_smux_enum_get(struct snd_kcontrol *kcontrol,
 919			      struct snd_ctl_elem_value *ucontrol)
 
 
 920{
 921	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
 922	struct sigmatel_spec *spec = codec->spec;
 923	unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 924
 925	ucontrol->value.enumerated.item[0] = spec->cur_smux[smux_idx];
 
 926	return 0;
 927}
 928
 929static int stac_smux_enum_put(struct snd_kcontrol *kcontrol,
 930			      struct snd_ctl_elem_value *ucontrol)
 931{
 932	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 933	struct sigmatel_spec *spec = codec->spec;
 934	unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 935
 936	return snd_hda_input_mux_put(codec, &spec->spdif_mux, ucontrol,
 937				     spec->gen.autocfg.dig_out_pins[smux_idx],
 938				     &spec->cur_smux[smux_idx]);
 939}
 940
 941static const struct snd_kcontrol_new stac_smux_mixer = {
 942	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
 943	.name = "IEC958 Playback Source",
 944	/* count set later */
 945	.info = stac_smux_enum_info,
 946	.get = stac_smux_enum_get,
 947	.put = stac_smux_enum_put,
 948};
 949
 950static const char * const stac_spdif_labels[] = {
 951	"Digital Playback", "Analog Mux 1", "Analog Mux 2", NULL
 952};
 953
 954static int stac_create_spdif_mux_ctls(struct hda_codec *codec)
 955{
 956	struct sigmatel_spec *spec = codec->spec;
 957	struct auto_pin_cfg *cfg = &spec->gen.autocfg;
 958	const char * const *labels = spec->spdif_labels;
 959	struct snd_kcontrol_new *kctl;
 960	int i, num_cons;
 961
 962	if (cfg->dig_outs < 1)
 
 
 
 
 
 963		return 0;
 964
 965	num_cons = snd_hda_get_num_conns(codec, cfg->dig_out_pins[0]);
 966	if (num_cons <= 1)
 967		return 0;
 968
 969	if (!labels)
 970		labels = stac_spdif_labels;
 971	for (i = 0; i < num_cons; i++) {
 972		if (snd_BUG_ON(!labels[i]))
 973			return -EINVAL;
 974		snd_hda_add_imux_item(codec, &spec->spdif_mux, labels[i], i, NULL);
 
 
 
 
 
 
 
 975	}
 976
 977	kctl = snd_hda_gen_add_kctl(&spec->gen, NULL, &stac_smux_mixer);
 978	if (!kctl)
 979		return -ENOMEM;
 980	kctl->count = cfg->dig_outs;
 981
 982	return 0;
 983}
 984
 
 
 
 
 
 
 985static const struct hda_verb stac9200_eapd_init[] = {
 986	/* set dac0mux for dac converter */
 987	{0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
 988	{0x08, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
 989	{}
 990};
 991
 992static const struct hda_verb dell_eq_core_init[] = {
 993	/* set master volume to max value without distortion
 994	 * and direct control */
 995	{ 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xec},
 996	{}
 997};
 998
 999static const struct hda_verb stac92hd73xx_core_init[] = {
1000	/* set master volume and direct control */
1001	{ 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
1002	{}
1003};
1004
1005static const struct hda_verb stac92hd83xxx_core_init[] = {
1006	/* power state controls amps */
1007	{ 0x01, AC_VERB_SET_EAPD, 1 << 2},
1008	{}
1009};
1010
1011static const struct hda_verb stac92hd83xxx_hp_zephyr_init[] = {
1012	{ 0x22, 0x785, 0x43 },
1013	{ 0x22, 0x782, 0xe0 },
1014	{ 0x22, 0x795, 0x00 },
1015	{}
1016};
1017
1018static const struct hda_verb stac92hd71bxx_core_init[] = {
1019	/* set master volume and direct control */
1020	{ 0x28, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
1021	{}
1022};
1023
1024static const hda_nid_t stac92hd71bxx_unmute_nids[] = {
1025	/* unmute right and left channels for nodes 0x0f, 0xa, 0x0d */
1026	0x0f, 0x0a, 0x0d, 0
 
 
 
1027};
1028
1029static const struct hda_verb stac925x_core_init[] = {
1030	/* set dac0mux for dac converter */
1031	{ 0x06, AC_VERB_SET_CONNECT_SEL, 0x00},
1032	/* mute the master volume */
1033	{ 0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
1034	{}
1035};
1036
1037static const struct hda_verb stac922x_core_init[] = {
1038	/* set master volume and direct control */
1039	{ 0x16, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
1040	{}
1041};
1042
1043static const struct hda_verb d965_core_init[] = {
 
 
1044	/* unmute node 0x1b */
1045	{ 0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
1046	/* select node 0x03 as DAC */
1047	{ 0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
1048	{}
1049};
1050
1051static const struct hda_verb dell_3st_core_init[] = {
1052	/* don't set delta bit */
1053	{0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
1054	/* unmute node 0x1b */
1055	{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
1056	/* select node 0x03 as DAC */
1057	{0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
1058	{}
1059};
1060
1061static const struct hda_verb stac927x_core_init[] = {
1062	/* set master volume and direct control */
1063	{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
1064	/* enable analog pc beep path */
1065	{ 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
1066	{}
1067};
1068
1069static const struct hda_verb stac927x_volknob_core_init[] = {
1070	/* don't set delta bit */
1071	{0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
1072	/* enable analog pc beep path */
1073	{0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
1074	{}
1075};
1076
1077static const struct hda_verb stac9205_core_init[] = {
1078	/* set master volume and direct control */
1079	{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
1080	/* enable analog pc beep path */
1081	{ 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
1082	{}
1083};
1084
1085static const struct snd_kcontrol_new stac92hd73xx_6ch_loopback =
1086	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 3);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1087
1088static const struct snd_kcontrol_new stac92hd73xx_8ch_loopback =
1089	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 4);
 
 
1090
1091static const struct snd_kcontrol_new stac92hd73xx_10ch_loopback =
1092	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 5);
 
 
1093
1094static const struct snd_kcontrol_new stac92hd71bxx_loopback =
1095	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A0, 2);
1096
1097static const struct snd_kcontrol_new stac9205_loopback =
1098	STAC_ANALOG_LOOPBACK(0xFE0, 0x7E0, 1);
1099
1100static const struct snd_kcontrol_new stac927x_loopback =
1101	STAC_ANALOG_LOOPBACK(0xFEB, 0x7EB, 1);
1102
1103static const struct hda_pintbl ref9200_pin_configs[] = {
1104	{ 0x08, 0x01c47010 },
1105	{ 0x09, 0x01447010 },
1106	{ 0x0d, 0x0221401f },
1107	{ 0x0e, 0x01114010 },
1108	{ 0x0f, 0x02a19020 },
1109	{ 0x10, 0x01a19021 },
1110	{ 0x11, 0x90100140 },
1111	{ 0x12, 0x01813122 },
1112	{}
1113};
1114
1115static const struct hda_pintbl gateway9200_m4_pin_configs[] = {
1116	{ 0x08, 0x400000fe },
1117	{ 0x09, 0x404500f4 },
1118	{ 0x0d, 0x400100f0 },
1119	{ 0x0e, 0x90110010 },
1120	{ 0x0f, 0x400100f1 },
1121	{ 0x10, 0x02a1902e },
1122	{ 0x11, 0x500000f2 },
1123	{ 0x12, 0x500000f3 },
 
 
 
 
1124	{}
1125};
1126
1127static const struct hda_pintbl gateway9200_m4_2_pin_configs[] = {
1128	{ 0x08, 0x400000fe },
1129	{ 0x09, 0x404500f4 },
1130	{ 0x0d, 0x400100f0 },
1131	{ 0x0e, 0x90110010 },
1132	{ 0x0f, 0x400100f1 },
1133	{ 0x10, 0x02a1902e },
1134	{ 0x11, 0x500000f2 },
1135	{ 0x12, 0x500000f3 },
1136	{}
1137};
1138
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1139/*
1140    STAC 9200 pin configs for
1141    102801A8
1142    102801DE
1143    102801E8
1144*/
1145static const struct hda_pintbl dell9200_d21_pin_configs[] = {
1146	{ 0x08, 0x400001f0 },
1147	{ 0x09, 0x400001f1 },
1148	{ 0x0d, 0x02214030 },
1149	{ 0x0e, 0x01014010 },
1150	{ 0x0f, 0x02a19020 },
1151	{ 0x10, 0x01a19021 },
1152	{ 0x11, 0x90100140 },
1153	{ 0x12, 0x01813122 },
1154	{}
1155};
1156
1157/*
1158    STAC 9200 pin configs for
1159    102801C0
1160    102801C1
1161*/
1162static const struct hda_pintbl dell9200_d22_pin_configs[] = {
1163	{ 0x08, 0x400001f0 },
1164	{ 0x09, 0x400001f1 },
1165	{ 0x0d, 0x0221401f },
1166	{ 0x0e, 0x01014010 },
1167	{ 0x0f, 0x01813020 },
1168	{ 0x10, 0x02a19021 },
1169	{ 0x11, 0x90100140 },
1170	{ 0x12, 0x400001f2 },
1171	{}
1172};
1173
1174/*
1175    STAC 9200 pin configs for
1176    102801C4 (Dell Dimension E310)
1177    102801C5
1178    102801C7
1179    102801D9
1180    102801DA
1181    102801E3
1182*/
1183static const struct hda_pintbl dell9200_d23_pin_configs[] = {
1184	{ 0x08, 0x400001f0 },
1185	{ 0x09, 0x400001f1 },
1186	{ 0x0d, 0x0221401f },
1187	{ 0x0e, 0x01014010 },
1188	{ 0x0f, 0x01813020 },
1189	{ 0x10, 0x01a19021 },
1190	{ 0x11, 0x90100140 },
1191	{ 0x12, 0x400001f2 },
1192	{}
1193};
1194
1195
1196/* 
1197    STAC 9200-32 pin configs for
1198    102801B5 (Dell Inspiron 630m)
1199    102801D8 (Dell Inspiron 640m)
1200*/
1201static const struct hda_pintbl dell9200_m21_pin_configs[] = {
1202	{ 0x08, 0x40c003fa },
1203	{ 0x09, 0x03441340 },
1204	{ 0x0d, 0x0321121f },
1205	{ 0x0e, 0x90170310 },
1206	{ 0x0f, 0x408003fb },
1207	{ 0x10, 0x03a11020 },
1208	{ 0x11, 0x401003fc },
1209	{ 0x12, 0x403003fd },
1210	{}
1211};
1212
1213/* 
1214    STAC 9200-32 pin configs for
1215    102801C2 (Dell Latitude D620)
1216    102801C8 
1217    102801CC (Dell Latitude D820)
1218    102801D4 
1219    102801D6 
1220*/
1221static const struct hda_pintbl dell9200_m22_pin_configs[] = {
1222	{ 0x08, 0x40c003fa },
1223	{ 0x09, 0x0144131f },
1224	{ 0x0d, 0x0321121f },
1225	{ 0x0e, 0x90170310 },
1226	{ 0x0f, 0x90a70321 },
1227	{ 0x10, 0x03a11020 },
1228	{ 0x11, 0x401003fb },
1229	{ 0x12, 0x40f000fc },
1230	{}
1231};
1232
1233/* 
1234    STAC 9200-32 pin configs for
1235    102801CE (Dell XPS M1710)
1236    102801CF (Dell Precision M90)
1237*/
1238static const struct hda_pintbl dell9200_m23_pin_configs[] = {
1239	{ 0x08, 0x40c003fa },
1240	{ 0x09, 0x01441340 },
1241	{ 0x0d, 0x0421421f },
1242	{ 0x0e, 0x90170310 },
1243	{ 0x0f, 0x408003fb },
1244	{ 0x10, 0x04a1102e },
1245	{ 0x11, 0x90170311 },
1246	{ 0x12, 0x403003fc },
1247	{}
1248};
1249
1250/*
1251    STAC 9200-32 pin configs for 
1252    102801C9
1253    102801CA
1254    102801CB (Dell Latitude 120L)
1255    102801D3
1256*/
1257static const struct hda_pintbl dell9200_m24_pin_configs[] = {
1258	{ 0x08, 0x40c003fa },
1259	{ 0x09, 0x404003fb },
1260	{ 0x0d, 0x0321121f },
1261	{ 0x0e, 0x90170310 },
1262	{ 0x0f, 0x408003fc },
1263	{ 0x10, 0x03a11020 },
1264	{ 0x11, 0x401003fd },
1265	{ 0x12, 0x403003fe },
1266	{}
1267};
1268
1269/*
1270    STAC 9200-32 pin configs for
1271    102801BD (Dell Inspiron E1505n)
1272    102801EE
1273    102801EF
1274*/
1275static const struct hda_pintbl dell9200_m25_pin_configs[] = {
1276	{ 0x08, 0x40c003fa },
1277	{ 0x09, 0x01441340 },
1278	{ 0x0d, 0x0421121f },
1279	{ 0x0e, 0x90170310 },
1280	{ 0x0f, 0x408003fb },
1281	{ 0x10, 0x04a11020 },
1282	{ 0x11, 0x401003fc },
1283	{ 0x12, 0x403003fd },
1284	{}
1285};
1286
1287/*
1288    STAC 9200-32 pin configs for
1289    102801F5 (Dell Inspiron 1501)
1290    102801F6
1291*/
1292static const struct hda_pintbl dell9200_m26_pin_configs[] = {
1293	{ 0x08, 0x40c003fa },
1294	{ 0x09, 0x404003fb },
1295	{ 0x0d, 0x0421121f },
1296	{ 0x0e, 0x90170310 },
1297	{ 0x0f, 0x408003fc },
1298	{ 0x10, 0x04a11020 },
1299	{ 0x11, 0x401003fd },
1300	{ 0x12, 0x403003fe },
1301	{}
1302};
1303
1304/*
1305    STAC 9200-32
1306    102801CD (Dell Inspiron E1705/9400)
1307*/
1308static const struct hda_pintbl dell9200_m27_pin_configs[] = {
1309	{ 0x08, 0x40c003fa },
1310	{ 0x09, 0x01441340 },
1311	{ 0x0d, 0x0421121f },
1312	{ 0x0e, 0x90170310 },
1313	{ 0x0f, 0x90170310 },
1314	{ 0x10, 0x04a11020 },
1315	{ 0x11, 0x90170310 },
1316	{ 0x12, 0x40f003fc },
1317	{}
1318};
1319
1320static const struct hda_pintbl oqo9200_pin_configs[] = {
1321	{ 0x08, 0x40c000f0 },
1322	{ 0x09, 0x404000f1 },
1323	{ 0x0d, 0x0221121f },
1324	{ 0x0e, 0x02211210 },
1325	{ 0x0f, 0x90170111 },
1326	{ 0x10, 0x90a70120 },
1327	{ 0x11, 0x400000f2 },
1328	{ 0x12, 0x400000f3 },
1329	{}
1330};
1331
1332/*
1333 *  STAC 92HD700
1334 *  18881000 Amigaone X1000
1335 */
1336static const struct hda_pintbl nemo_pin_configs[] = {
1337	{ 0x0a, 0x02214020 },	/* Front panel HP socket */
1338	{ 0x0b, 0x02a19080 },	/* Front Mic */
1339	{ 0x0c, 0x0181304e },	/* Line in */
1340	{ 0x0d, 0x01014010 },	/* Line out */
1341	{ 0x0e, 0x01a19040 },	/* Rear Mic */
1342	{ 0x0f, 0x01011012 },	/* Rear speakers */
1343	{ 0x10, 0x01016011 },	/* Center speaker */
1344	{ 0x11, 0x01012014 },	/* Side speakers (7.1) */
1345	{ 0x12, 0x103301f0 },	/* Motherboard CD line in connector */
1346	{ 0x13, 0x411111f0 },	/* Unused */
1347	{ 0x14, 0x411111f0 },	/* Unused */
1348	{ 0x21, 0x01442170 },	/* S/PDIF line out */
1349	{ 0x22, 0x411111f0 },	/* Unused */
1350	{ 0x23, 0x411111f0 },	/* Unused */
1351	{}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1352};
1353
1354static void stac9200_fixup_panasonic(struct hda_codec *codec,
1355				     const struct hda_fixup *fix, int action)
1356{
1357	struct sigmatel_spec *spec = codec->spec;
1358
1359	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
1360		spec->gpio_mask = spec->gpio_dir = 0x09;
1361		spec->gpio_data = 0x00;
1362		/* CF-74 has no headphone detection, and the driver should *NOT*
1363		 * do detection and HP/speaker toggle because the hardware does it.
1364		 */
1365		spec->gen.suppress_auto_mute = 1;
1366	}
1367}
1368
1369
1370static const struct hda_fixup stac9200_fixups[] = {
1371	[STAC_REF] = {
1372		.type = HDA_FIXUP_PINS,
1373		.v.pins = ref9200_pin_configs,
1374	},
1375	[STAC_9200_OQO] = {
1376		.type = HDA_FIXUP_PINS,
1377		.v.pins = oqo9200_pin_configs,
1378		.chained = true,
1379		.chain_id = STAC_9200_EAPD_INIT,
1380	},
1381	[STAC_9200_DELL_D21] = {
1382		.type = HDA_FIXUP_PINS,
1383		.v.pins = dell9200_d21_pin_configs,
1384	},
1385	[STAC_9200_DELL_D22] = {
1386		.type = HDA_FIXUP_PINS,
1387		.v.pins = dell9200_d22_pin_configs,
1388	},
1389	[STAC_9200_DELL_D23] = {
1390		.type = HDA_FIXUP_PINS,
1391		.v.pins = dell9200_d23_pin_configs,
1392	},
1393	[STAC_9200_DELL_M21] = {
1394		.type = HDA_FIXUP_PINS,
1395		.v.pins = dell9200_m21_pin_configs,
1396	},
1397	[STAC_9200_DELL_M22] = {
1398		.type = HDA_FIXUP_PINS,
1399		.v.pins = dell9200_m22_pin_configs,
1400	},
1401	[STAC_9200_DELL_M23] = {
1402		.type = HDA_FIXUP_PINS,
1403		.v.pins = dell9200_m23_pin_configs,
1404	},
1405	[STAC_9200_DELL_M24] = {
1406		.type = HDA_FIXUP_PINS,
1407		.v.pins = dell9200_m24_pin_configs,
1408	},
1409	[STAC_9200_DELL_M25] = {
1410		.type = HDA_FIXUP_PINS,
1411		.v.pins = dell9200_m25_pin_configs,
1412	},
1413	[STAC_9200_DELL_M26] = {
1414		.type = HDA_FIXUP_PINS,
1415		.v.pins = dell9200_m26_pin_configs,
1416	},
1417	[STAC_9200_DELL_M27] = {
1418		.type = HDA_FIXUP_PINS,
1419		.v.pins = dell9200_m27_pin_configs,
1420	},
1421	[STAC_9200_M4] = {
1422		.type = HDA_FIXUP_PINS,
1423		.v.pins = gateway9200_m4_pin_configs,
1424		.chained = true,
1425		.chain_id = STAC_9200_EAPD_INIT,
1426	},
1427	[STAC_9200_M4_2] = {
1428		.type = HDA_FIXUP_PINS,
1429		.v.pins = gateway9200_m4_2_pin_configs,
1430		.chained = true,
1431		.chain_id = STAC_9200_EAPD_INIT,
1432	},
1433	[STAC_9200_PANASONIC] = {
1434		.type = HDA_FIXUP_FUNC,
1435		.v.func = stac9200_fixup_panasonic,
1436	},
1437	[STAC_9200_EAPD_INIT] = {
1438		.type = HDA_FIXUP_VERBS,
1439		.v.verbs = (const struct hda_verb[]) {
1440			{0x08, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
1441			{}
1442		},
1443	},
1444};
1445
1446static const struct hda_model_fixup stac9200_models[] = {
1447	{ .id = STAC_REF, .name = "ref" },
1448	{ .id = STAC_9200_OQO, .name = "oqo" },
1449	{ .id = STAC_9200_DELL_D21, .name = "dell-d21" },
1450	{ .id = STAC_9200_DELL_D22, .name = "dell-d22" },
1451	{ .id = STAC_9200_DELL_D23, .name = "dell-d23" },
1452	{ .id = STAC_9200_DELL_M21, .name = "dell-m21" },
1453	{ .id = STAC_9200_DELL_M22, .name = "dell-m22" },
1454	{ .id = STAC_9200_DELL_M23, .name = "dell-m23" },
1455	{ .id = STAC_9200_DELL_M24, .name = "dell-m24" },
1456	{ .id = STAC_9200_DELL_M25, .name = "dell-m25" },
1457	{ .id = STAC_9200_DELL_M26, .name = "dell-m26" },
1458	{ .id = STAC_9200_DELL_M27, .name = "dell-m27" },
1459	{ .id = STAC_9200_M4, .name = "gateway-m4" },
1460	{ .id = STAC_9200_M4_2, .name = "gateway-m4-2" },
1461	{ .id = STAC_9200_PANASONIC, .name = "panasonic" },
1462	{}
1463};
1464
1465static const struct snd_pci_quirk stac9200_fixup_tbl[] = {
1466	/* SigmaTel reference board */
1467	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1468		      "DFI LanParty", STAC_REF),
1469	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1470		      "DFI LanParty", STAC_REF),
1471	/* Dell laptops have BIOS problem */
1472	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a8,
1473		      "unknown Dell", STAC_9200_DELL_D21),
1474	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01b5,
1475		      "Dell Inspiron 630m", STAC_9200_DELL_M21),
1476	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bd,
1477		      "Dell Inspiron E1505n", STAC_9200_DELL_M25),
1478	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c0,
1479		      "unknown Dell", STAC_9200_DELL_D22),
1480	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c1,
1481		      "unknown Dell", STAC_9200_DELL_D22),
1482	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c2,
1483		      "Dell Latitude D620", STAC_9200_DELL_M22),
1484	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c5,
1485		      "unknown Dell", STAC_9200_DELL_D23),
1486	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c7,
1487		      "unknown Dell", STAC_9200_DELL_D23),
1488	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c8,
1489		      "unknown Dell", STAC_9200_DELL_M22),
1490	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c9,
1491		      "unknown Dell", STAC_9200_DELL_M24),
1492	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ca,
1493		      "unknown Dell", STAC_9200_DELL_M24),
1494	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cb,
1495		      "Dell Latitude 120L", STAC_9200_DELL_M24),
1496	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cc,
1497		      "Dell Latitude D820", STAC_9200_DELL_M22),
1498	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cd,
1499		      "Dell Inspiron E1705/9400", STAC_9200_DELL_M27),
1500	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ce,
1501		      "Dell XPS M1710", STAC_9200_DELL_M23),
1502	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cf,
1503		      "Dell Precision M90", STAC_9200_DELL_M23),
1504	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d3,
1505		      "unknown Dell", STAC_9200_DELL_M22),
1506	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d4,
1507		      "unknown Dell", STAC_9200_DELL_M22),
1508	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d6,
1509		      "unknown Dell", STAC_9200_DELL_M22),
1510	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d8,
1511		      "Dell Inspiron 640m", STAC_9200_DELL_M21),
1512	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d9,
1513		      "unknown Dell", STAC_9200_DELL_D23),
1514	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01da,
1515		      "unknown Dell", STAC_9200_DELL_D23),
1516	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01de,
1517		      "unknown Dell", STAC_9200_DELL_D21),
1518	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e3,
1519		      "unknown Dell", STAC_9200_DELL_D23),
1520	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e8,
1521		      "unknown Dell", STAC_9200_DELL_D21),
1522	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ee,
1523		      "unknown Dell", STAC_9200_DELL_M25),
1524	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ef,
1525		      "unknown Dell", STAC_9200_DELL_M25),
1526	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f5,
1527		      "Dell Inspiron 1501", STAC_9200_DELL_M26),
1528	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f6,
1529		      "unknown Dell", STAC_9200_DELL_M26),
1530	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0201,
1531		      "Dell Latitude D430", STAC_9200_DELL_M22),
1532	/* Panasonic */
1533	SND_PCI_QUIRK(0x10f7, 0x8338, "Panasonic CF-74", STAC_9200_PANASONIC),
1534	/* Gateway machines needs EAPD to be set on resume */
1535	SND_PCI_QUIRK(0x107b, 0x0205, "Gateway S-7110M", STAC_9200_M4),
1536	SND_PCI_QUIRK(0x107b, 0x0317, "Gateway MT3423, MX341*", STAC_9200_M4_2),
1537	SND_PCI_QUIRK(0x107b, 0x0318, "Gateway ML3019, MT3707", STAC_9200_M4_2),
1538	/* OQO Mobile */
1539	SND_PCI_QUIRK(0x1106, 0x3288, "OQO Model 2", STAC_9200_OQO),
1540	{} /* terminator */
1541};
1542
1543static const struct hda_pintbl ref925x_pin_configs[] = {
1544	{ 0x07, 0x40c003f0 },
1545	{ 0x08, 0x424503f2 },
1546	{ 0x0a, 0x01813022 },
1547	{ 0x0b, 0x02a19021 },
1548	{ 0x0c, 0x90a70320 },
1549	{ 0x0d, 0x02214210 },
1550	{ 0x10, 0x01019020 },
1551	{ 0x11, 0x9033032e },
1552	{}
1553};
1554
1555static const struct hda_pintbl stac925xM1_pin_configs[] = {
1556	{ 0x07, 0x40c003f4 },
1557	{ 0x08, 0x424503f2 },
1558	{ 0x0a, 0x400000f3 },
1559	{ 0x0b, 0x02a19020 },
1560	{ 0x0c, 0x40a000f0 },
1561	{ 0x0d, 0x90100210 },
1562	{ 0x10, 0x400003f1 },
1563	{ 0x11, 0x9033032e },
1564	{}
1565};
1566
1567static const struct hda_pintbl stac925xM1_2_pin_configs[] = {
1568	{ 0x07, 0x40c003f4 },
1569	{ 0x08, 0x424503f2 },
1570	{ 0x0a, 0x400000f3 },
1571	{ 0x0b, 0x02a19020 },
1572	{ 0x0c, 0x40a000f0 },
1573	{ 0x0d, 0x90100210 },
1574	{ 0x10, 0x400003f1 },
1575	{ 0x11, 0x9033032e },
1576	{}
1577};
1578
1579static const struct hda_pintbl stac925xM2_pin_configs[] = {
1580	{ 0x07, 0x40c003f4 },
1581	{ 0x08, 0x424503f2 },
1582	{ 0x0a, 0x400000f3 },
1583	{ 0x0b, 0x02a19020 },
1584	{ 0x0c, 0x40a000f0 },
1585	{ 0x0d, 0x90100210 },
1586	{ 0x10, 0x400003f1 },
1587	{ 0x11, 0x9033032e },
1588	{}
1589};
1590
1591static const struct hda_pintbl stac925xM2_2_pin_configs[] = {
1592	{ 0x07, 0x40c003f4 },
1593	{ 0x08, 0x424503f2 },
1594	{ 0x0a, 0x400000f3 },
1595	{ 0x0b, 0x02a19020 },
1596	{ 0x0c, 0x40a000f0 },
1597	{ 0x0d, 0x90100210 },
1598	{ 0x10, 0x400003f1 },
1599	{ 0x11, 0x9033032e },
1600	{}
1601};
1602
1603static const struct hda_pintbl stac925xM3_pin_configs[] = {
1604	{ 0x07, 0x40c003f4 },
1605	{ 0x08, 0x424503f2 },
1606	{ 0x0a, 0x400000f3 },
1607	{ 0x0b, 0x02a19020 },
1608	{ 0x0c, 0x40a000f0 },
1609	{ 0x0d, 0x90100210 },
1610	{ 0x10, 0x400003f1 },
1611	{ 0x11, 0x503303f3 },
1612	{}
1613};
1614
1615static const struct hda_pintbl stac925xM5_pin_configs[] = {
1616	{ 0x07, 0x40c003f4 },
1617	{ 0x08, 0x424503f2 },
1618	{ 0x0a, 0x400000f3 },
1619	{ 0x0b, 0x02a19020 },
1620	{ 0x0c, 0x40a000f0 },
1621	{ 0x0d, 0x90100210 },
1622	{ 0x10, 0x400003f1 },
1623	{ 0x11, 0x9033032e },
1624	{}
1625};
1626
1627static const struct hda_pintbl stac925xM6_pin_configs[] = {
1628	{ 0x07, 0x40c003f4 },
1629	{ 0x08, 0x424503f2 },
1630	{ 0x0a, 0x400000f3 },
1631	{ 0x0b, 0x02a19020 },
1632	{ 0x0c, 0x40a000f0 },
1633	{ 0x0d, 0x90100210 },
1634	{ 0x10, 0x400003f1 },
1635	{ 0x11, 0x90330320 },
1636	{}
1637};
1638
1639static const struct hda_fixup stac925x_fixups[] = {
1640	[STAC_REF] = {
1641		.type = HDA_FIXUP_PINS,
1642		.v.pins = ref925x_pin_configs,
1643	},
1644	[STAC_M1] = {
1645		.type = HDA_FIXUP_PINS,
1646		.v.pins = stac925xM1_pin_configs,
1647	},
1648	[STAC_M1_2] = {
1649		.type = HDA_FIXUP_PINS,
1650		.v.pins = stac925xM1_2_pin_configs,
1651	},
1652	[STAC_M2] = {
1653		.type = HDA_FIXUP_PINS,
1654		.v.pins = stac925xM2_pin_configs,
1655	},
1656	[STAC_M2_2] = {
1657		.type = HDA_FIXUP_PINS,
1658		.v.pins = stac925xM2_2_pin_configs,
1659	},
1660	[STAC_M3] = {
1661		.type = HDA_FIXUP_PINS,
1662		.v.pins = stac925xM3_pin_configs,
1663	},
1664	[STAC_M5] = {
1665		.type = HDA_FIXUP_PINS,
1666		.v.pins = stac925xM5_pin_configs,
1667	},
1668	[STAC_M6] = {
1669		.type = HDA_FIXUP_PINS,
1670		.v.pins = stac925xM6_pin_configs,
1671	},
1672};
1673
1674static const struct hda_model_fixup stac925x_models[] = {
1675	{ .id = STAC_REF, .name = "ref" },
1676	{ .id = STAC_M1, .name = "m1" },
1677	{ .id = STAC_M1_2, .name = "m1-2" },
1678	{ .id = STAC_M2, .name = "m2" },
1679	{ .id = STAC_M2_2, .name = "m2-2" },
1680	{ .id = STAC_M3, .name = "m3" },
1681	{ .id = STAC_M5, .name = "m5" },
1682	{ .id = STAC_M6, .name = "m6" },
1683	{}
1684};
1685
1686static const struct snd_pci_quirk stac925x_fixup_tbl[] = {
1687	/* SigmaTel reference board */
1688	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, "DFI LanParty", STAC_REF),
1689	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, "DFI LanParty", STAC_REF),
1690	SND_PCI_QUIRK(0x8384, 0x7632, "Stac9202 Reference Board", STAC_REF),
1691
1692	/* Default table for unknown ID */
1693	SND_PCI_QUIRK(0x1002, 0x437b, "Gateway mobile", STAC_M2_2),
1694
1695	/* gateway machines are checked via codec ssid */
1696	SND_PCI_QUIRK(0x107b, 0x0316, "Gateway M255", STAC_M2),
1697	SND_PCI_QUIRK(0x107b, 0x0366, "Gateway MP6954", STAC_M5),
1698	SND_PCI_QUIRK(0x107b, 0x0461, "Gateway NX560XL", STAC_M1),
1699	SND_PCI_QUIRK(0x107b, 0x0681, "Gateway NX860", STAC_M2),
1700	SND_PCI_QUIRK(0x107b, 0x0367, "Gateway MX6453", STAC_M1_2),
1701	/* Not sure about the brand name for those */
1702	SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M1),
1703	SND_PCI_QUIRK(0x107b, 0x0507, "Gateway mobile", STAC_M3),
1704	SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M6),
1705	SND_PCI_QUIRK(0x107b, 0x0685, "Gateway mobile", STAC_M2_2),
1706	{} /* terminator */
1707};
1708
1709static const struct hda_pintbl ref92hd73xx_pin_configs[] = {
1710	// Port A-H
1711	{ 0x0a, 0x02214030 },
1712	{ 0x0b, 0x02a19040 },
1713	{ 0x0c, 0x01a19020 },
1714	{ 0x0d, 0x02214030 },
1715	{ 0x0e, 0x0181302e },
1716	{ 0x0f, 0x01014010 },
1717	{ 0x10, 0x01014020 },
1718	{ 0x11, 0x01014030 },
1719	// CD in
1720	{ 0x12, 0x02319040 },
1721	// Digial Mic ins
1722	{ 0x13, 0x90a000f0 },
1723	{ 0x14, 0x90a000f0 },
1724	// Digital outs
1725	{ 0x22, 0x01452050 },
1726	{ 0x23, 0x01452050 },
1727	{}
1728};
1729
1730static const struct hda_pintbl dell_m6_pin_configs[] = {
1731	{ 0x0a, 0x0321101f },
1732	{ 0x0b, 0x4f00000f },
1733	{ 0x0c, 0x4f0000f0 },
1734	{ 0x0d, 0x90170110 },
1735	{ 0x0e, 0x03a11020 },
1736	{ 0x0f, 0x0321101f },
1737	{ 0x10, 0x4f0000f0 },
1738	{ 0x11, 0x4f0000f0 },
1739	{ 0x12, 0x4f0000f0 },
1740	{ 0x13, 0x90a60160 },
1741	{ 0x14, 0x4f0000f0 },
1742	{ 0x22, 0x4f0000f0 },
1743	{ 0x23, 0x4f0000f0 },
1744	{}
1745};
1746
1747static const struct hda_pintbl alienware_m17x_pin_configs[] = {
1748	{ 0x0a, 0x0321101f },
1749	{ 0x0b, 0x0321101f },
1750	{ 0x0c, 0x03a11020 },
1751	{ 0x0d, 0x03014020 },
1752	{ 0x0e, 0x90170110 },
1753	{ 0x0f, 0x4f0000f0 },
1754	{ 0x10, 0x4f0000f0 },
1755	{ 0x11, 0x4f0000f0 },
1756	{ 0x12, 0x4f0000f0 },
1757	{ 0x13, 0x90a60160 },
1758	{ 0x14, 0x4f0000f0 },
1759	{ 0x22, 0x4f0000f0 },
1760	{ 0x23, 0x904601b0 },
1761	{}
1762};
1763
1764static const struct hda_pintbl intel_dg45id_pin_configs[] = {
1765	// Analog outputs
1766	{ 0x0a, 0x02214230 },
1767	{ 0x0b, 0x02A19240 },
1768	{ 0x0c, 0x01013214 },
1769	{ 0x0d, 0x01014210 },
1770	{ 0x0e, 0x01A19250 },
1771	{ 0x0f, 0x01011212 },
1772	{ 0x10, 0x01016211 },
1773	// Digital output
1774	{ 0x22, 0x01451380 },
1775	{ 0x23, 0x40f000f0 },
1776	{}
1777};
1778
1779static const struct hda_pintbl stac92hd89xx_hp_front_jack_pin_configs[] = {
1780	{ 0x0a, 0x02214030 },
1781	{ 0x0b, 0x02A19010 },
1782	{}
1783};
1784
1785static const struct hda_pintbl stac92hd89xx_hp_z1_g2_right_mic_jack_pin_configs[] = {
1786	{ 0x0e, 0x400000f0 },
1787	{}
1788};
1789
1790static void stac92hd73xx_fixup_ref(struct hda_codec *codec,
1791				   const struct hda_fixup *fix, int action)
1792{
1793	struct sigmatel_spec *spec = codec->spec;
1794
1795	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1796		return;
1797
1798	snd_hda_apply_pincfgs(codec, ref92hd73xx_pin_configs);
1799	spec->gpio_mask = spec->gpio_dir = spec->gpio_data = 0;
1800}
1801
1802static void stac92hd73xx_fixup_dell(struct hda_codec *codec)
1803{
1804	struct sigmatel_spec *spec = codec->spec;
1805
1806	snd_hda_apply_pincfgs(codec, dell_m6_pin_configs);
1807	spec->eapd_switch = 0;
1808}
1809
1810static void stac92hd73xx_fixup_dell_eq(struct hda_codec *codec,
1811				       const struct hda_fixup *fix, int action)
1812{
1813	struct sigmatel_spec *spec = codec->spec;
1814
1815	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1816		return;
1817
1818	stac92hd73xx_fixup_dell(codec);
1819	snd_hda_add_verbs(codec, dell_eq_core_init);
1820	spec->volknob_init = 1;
1821}
1822
1823/* Analog Mics */
1824static void stac92hd73xx_fixup_dell_m6_amic(struct hda_codec *codec,
1825				    const struct hda_fixup *fix, int action)
1826{
1827	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1828		return;
1829
1830	stac92hd73xx_fixup_dell(codec);
1831	snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170);
1832}
1833
1834/* Digital Mics */
1835static void stac92hd73xx_fixup_dell_m6_dmic(struct hda_codec *codec,
1836				    const struct hda_fixup *fix, int action)
1837{
1838	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1839		return;
1840
1841	stac92hd73xx_fixup_dell(codec);
1842	snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160);
1843}
1844
1845/* Both */
1846static void stac92hd73xx_fixup_dell_m6_both(struct hda_codec *codec,
1847				    const struct hda_fixup *fix, int action)
1848{
1849	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1850		return;
1851
1852	stac92hd73xx_fixup_dell(codec);
1853	snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170);
1854	snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160);
1855}
1856
1857static void stac92hd73xx_fixup_alienware_m17x(struct hda_codec *codec,
1858				    const struct hda_fixup *fix, int action)
1859{
1860	struct sigmatel_spec *spec = codec->spec;
1861
1862	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1863		return;
1864
1865	snd_hda_apply_pincfgs(codec, alienware_m17x_pin_configs);
1866	spec->eapd_switch = 0;
1867}
1868
1869static void stac92hd73xx_fixup_no_jd(struct hda_codec *codec,
1870				     const struct hda_fixup *fix, int action)
1871{
1872	if (action == HDA_FIXUP_ACT_PRE_PROBE)
1873		codec->no_jack_detect = 1;
1874}
1875
1876
1877static void stac92hd73xx_disable_automute(struct hda_codec *codec,
1878				     const struct hda_fixup *fix, int action)
1879{
1880	struct sigmatel_spec *spec = codec->spec;
1881
1882	if (action != HDA_FIXUP_ACT_PRE_PROBE)
1883		return;
1884
1885	spec->gen.suppress_auto_mute = 1;
1886}
1887
1888static const struct hda_fixup stac92hd73xx_fixups[] = {
1889	[STAC_92HD73XX_REF] = {
1890		.type = HDA_FIXUP_FUNC,
1891		.v.func = stac92hd73xx_fixup_ref,
1892	},
1893	[STAC_DELL_M6_AMIC] = {
1894		.type = HDA_FIXUP_FUNC,
1895		.v.func = stac92hd73xx_fixup_dell_m6_amic,
1896	},
1897	[STAC_DELL_M6_DMIC] = {
1898		.type = HDA_FIXUP_FUNC,
1899		.v.func = stac92hd73xx_fixup_dell_m6_dmic,
1900	},
1901	[STAC_DELL_M6_BOTH] = {
1902		.type = HDA_FIXUP_FUNC,
1903		.v.func = stac92hd73xx_fixup_dell_m6_both,
1904	},
1905	[STAC_DELL_EQ]	= {
1906		.type = HDA_FIXUP_FUNC,
1907		.v.func = stac92hd73xx_fixup_dell_eq,
1908	},
1909	[STAC_ALIENWARE_M17X] = {
1910		.type = HDA_FIXUP_FUNC,
1911		.v.func = stac92hd73xx_fixup_alienware_m17x,
1912	},
1913	[STAC_ELO_VUPOINT_15MX] = {
1914		.type = HDA_FIXUP_FUNC,
1915		.v.func = stac92hd73xx_disable_automute,
1916	},
1917	[STAC_92HD73XX_INTEL] = {
1918		.type = HDA_FIXUP_PINS,
1919		.v.pins = intel_dg45id_pin_configs,
1920	},
1921	[STAC_92HD73XX_NO_JD] = {
1922		.type = HDA_FIXUP_FUNC,
1923		.v.func = stac92hd73xx_fixup_no_jd,
1924	},
1925	[STAC_92HD89XX_HP_FRONT_JACK] = {
1926		.type = HDA_FIXUP_PINS,
1927		.v.pins = stac92hd89xx_hp_front_jack_pin_configs,
1928	},
1929	[STAC_92HD89XX_HP_Z1_G2_RIGHT_MIC_JACK] = {
1930		.type = HDA_FIXUP_PINS,
1931		.v.pins = stac92hd89xx_hp_z1_g2_right_mic_jack_pin_configs,
1932	},
1933	[STAC_92HD73XX_ASUS_MOBO] = {
1934		.type = HDA_FIXUP_PINS,
1935		.v.pins = (const struct hda_pintbl[]) {
1936			/* enable 5.1 and SPDIF out */
1937			{ 0x0c, 0x01014411 },
1938			{ 0x0d, 0x01014410 },
1939			{ 0x0e, 0x01014412 },
1940			{ 0x22, 0x014b1180 },
1941			{ }
1942		}
1943	},
1944};
1945
1946static const struct hda_model_fixup stac92hd73xx_models[] = {
1947	{ .id = STAC_92HD73XX_NO_JD, .name = "no-jd" },
1948	{ .id = STAC_92HD73XX_REF, .name = "ref" },
1949	{ .id = STAC_92HD73XX_INTEL, .name = "intel" },
1950	{ .id = STAC_DELL_M6_AMIC, .name = "dell-m6-amic" },
1951	{ .id = STAC_DELL_M6_DMIC, .name = "dell-m6-dmic" },
1952	{ .id = STAC_DELL_M6_BOTH, .name = "dell-m6" },
1953	{ .id = STAC_DELL_EQ, .name = "dell-eq" },
1954	{ .id = STAC_ALIENWARE_M17X, .name = "alienware" },
1955	{ .id = STAC_ELO_VUPOINT_15MX, .name = "elo-vupoint-15mx" },
1956	{ .id = STAC_92HD73XX_ASUS_MOBO, .name = "asus-mobo" },
1957	{}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1958};
1959
1960static const struct snd_pci_quirk stac92hd73xx_fixup_tbl[] = {
1961	/* SigmaTel reference board */
1962	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1963				"DFI LanParty", STAC_92HD73XX_REF),
1964	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1965				"DFI LanParty", STAC_92HD73XX_REF),
1966	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5001,
1967				"Intel DP45SG", STAC_92HD73XX_INTEL),
1968	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5002,
1969				"Intel DG45ID", STAC_92HD73XX_INTEL),
1970	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5003,
1971				"Intel DG45FC", STAC_92HD73XX_INTEL),
1972	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0254,
1973				"Dell Studio 1535", STAC_DELL_M6_DMIC),
1974	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0255,
1975				"unknown Dell", STAC_DELL_M6_DMIC),
1976	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0256,
1977				"unknown Dell", STAC_DELL_M6_BOTH),
1978	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0257,
1979				"unknown Dell", STAC_DELL_M6_BOTH),
1980	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025e,
1981				"unknown Dell", STAC_DELL_M6_AMIC),
1982	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025f,
1983				"unknown Dell", STAC_DELL_M6_AMIC),
1984	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0271,
1985				"unknown Dell", STAC_DELL_M6_DMIC),
1986	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0272,
1987				"unknown Dell", STAC_DELL_M6_DMIC),
1988	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x029f,
1989				"Dell Studio 1537", STAC_DELL_M6_DMIC),
1990	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0,
1991				"Dell Studio 17", STAC_DELL_M6_DMIC),
1992	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02be,
1993				"Dell Studio 1555", STAC_DELL_M6_DMIC),
1994	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02bd,
1995				"Dell Studio 1557", STAC_DELL_M6_DMIC),
1996	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02fe,
1997				"Dell Studio XPS 1645", STAC_DELL_M6_DMIC),
1998	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0413,
1999				"Dell Studio 1558", STAC_DELL_M6_DMIC),
2000	/* codec SSID matching */
 
 
 
2001	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a1,
2002		      "Alienware M17x", STAC_ALIENWARE_M17X),
2003	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x043a,
2004		      "Alienware M17x", STAC_ALIENWARE_M17X),
2005	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0490,
2006		      "Alienware M17x R3", STAC_DELL_EQ),
2007	SND_PCI_QUIRK(0x1059, 0x1011,
2008		      "ELO VuPoint 15MX", STAC_ELO_VUPOINT_15MX),
2009	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1927,
2010				"HP Z1 G2", STAC_92HD89XX_HP_Z1_G2_RIGHT_MIC_JACK),
2011	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2b17,
2012				"unknown HP", STAC_92HD89XX_HP_FRONT_JACK),
2013	SND_PCI_QUIRK(PCI_VENDOR_ID_ASUSTEK, 0x83f8, "ASUS AT4NM10",
2014		      STAC_92HD73XX_ASUS_MOBO),
2015	{} /* terminator */
2016};
2017
2018static const struct hda_pintbl ref92hd83xxx_pin_configs[] = {
2019	{ 0x0a, 0x02214030 },
2020	{ 0x0b, 0x02211010 },
2021	{ 0x0c, 0x02a19020 },
2022	{ 0x0d, 0x02170130 },
2023	{ 0x0e, 0x01014050 },
2024	{ 0x0f, 0x01819040 },
2025	{ 0x10, 0x01014020 },
2026	{ 0x11, 0x90a3014e },
2027	{ 0x1f, 0x01451160 },
2028	{ 0x20, 0x98560170 },
2029	{}
2030};
2031
2032static const struct hda_pintbl dell_s14_pin_configs[] = {
2033	{ 0x0a, 0x0221403f },
2034	{ 0x0b, 0x0221101f },
2035	{ 0x0c, 0x02a19020 },
2036	{ 0x0d, 0x90170110 },
2037	{ 0x0e, 0x40f000f0 },
2038	{ 0x0f, 0x40f000f0 },
2039	{ 0x10, 0x40f000f0 },
2040	{ 0x11, 0x90a60160 },
2041	{ 0x1f, 0x40f000f0 },
2042	{ 0x20, 0x40f000f0 },
2043	{}
2044};
2045
2046static const struct hda_pintbl dell_vostro_3500_pin_configs[] = {
2047	{ 0x0a, 0x02a11020 },
2048	{ 0x0b, 0x0221101f },
2049	{ 0x0c, 0x400000f0 },
2050	{ 0x0d, 0x90170110 },
2051	{ 0x0e, 0x400000f1 },
2052	{ 0x0f, 0x400000f2 },
2053	{ 0x10, 0x400000f3 },
2054	{ 0x11, 0x90a60160 },
2055	{ 0x1f, 0x400000f4 },
2056	{ 0x20, 0x400000f5 },
2057	{}
2058};
2059
2060static const struct hda_pintbl hp_dv7_4000_pin_configs[] = {
2061	{ 0x0a, 0x03a12050 },
2062	{ 0x0b, 0x0321201f },
2063	{ 0x0c, 0x40f000f0 },
2064	{ 0x0d, 0x90170110 },
2065	{ 0x0e, 0x40f000f0 },
2066	{ 0x0f, 0x40f000f0 },
2067	{ 0x10, 0x90170110 },
2068	{ 0x11, 0xd5a30140 },
2069	{ 0x1f, 0x40f000f0 },
2070	{ 0x20, 0x40f000f0 },
2071	{}
2072};
2073
2074static const struct hda_pintbl hp_zephyr_pin_configs[] = {
2075	{ 0x0a, 0x01813050 },
2076	{ 0x0b, 0x0421201f },
2077	{ 0x0c, 0x04a1205e },
2078	{ 0x0d, 0x96130310 },
2079	{ 0x0e, 0x96130310 },
2080	{ 0x0f, 0x0101401f },
2081	{ 0x10, 0x1111611f },
2082	{ 0x11, 0xd5a30130 },
2083	{}
2084};
2085
2086static const struct hda_pintbl hp_cNB11_intquad_pin_configs[] = {
2087	{ 0x0a, 0x40f000f0 },
2088	{ 0x0b, 0x0221101f },
2089	{ 0x0c, 0x02a11020 },
2090	{ 0x0d, 0x92170110 },
2091	{ 0x0e, 0x40f000f0 },
2092	{ 0x0f, 0x92170110 },
2093	{ 0x10, 0x40f000f0 },
2094	{ 0x11, 0xd5a30130 },
2095	{ 0x1f, 0x40f000f0 },
2096	{ 0x20, 0x40f000f0 },
2097	{}
2098};
2099
2100static void stac92hd83xxx_fixup_hp(struct hda_codec *codec,
2101				   const struct hda_fixup *fix, int action)
2102{
2103	struct sigmatel_spec *spec = codec->spec;
2104
2105	if (action != HDA_FIXUP_ACT_PRE_PROBE)
2106		return;
2107
2108	if (hp_bnb2011_with_dock(codec)) {
2109		snd_hda_codec_set_pincfg(codec, 0xa, 0x2101201f);
2110		snd_hda_codec_set_pincfg(codec, 0xf, 0x2181205e);
2111	}
2112
2113	if (find_mute_led_cfg(codec, spec->default_polarity))
2114		codec_dbg(codec, "mute LED gpio %d polarity %d\n",
2115				spec->gpio_led,
2116				spec->gpio_led_polarity);
2117
2118	/* allow auto-switching of dock line-in */
2119	spec->gen.line_in_auto_switch = true;
2120}
2121
2122static void stac92hd83xxx_fixup_hp_zephyr(struct hda_codec *codec,
2123				   const struct hda_fixup *fix, int action)
2124{
2125	if (action != HDA_FIXUP_ACT_PRE_PROBE)
2126		return;
2127
2128	snd_hda_apply_pincfgs(codec, hp_zephyr_pin_configs);
2129	snd_hda_add_verbs(codec, stac92hd83xxx_hp_zephyr_init);
2130}
2131
2132static void stac92hd83xxx_fixup_hp_led(struct hda_codec *codec,
2133				   const struct hda_fixup *fix, int action)
2134{
2135	struct sigmatel_spec *spec = codec->spec;
2136
2137	if (action == HDA_FIXUP_ACT_PRE_PROBE)
2138		spec->default_polarity = 0;
2139}
2140
2141static void stac92hd83xxx_fixup_hp_inv_led(struct hda_codec *codec,
2142				   const struct hda_fixup *fix, int action)
2143{
2144	struct sigmatel_spec *spec = codec->spec;
2145
2146	if (action == HDA_FIXUP_ACT_PRE_PROBE)
2147		spec->default_polarity = 1;
2148}
2149
2150static void stac92hd83xxx_fixup_hp_mic_led(struct hda_codec *codec,
2151				   const struct hda_fixup *fix, int action)
2152{
2153	struct sigmatel_spec *spec = codec->spec;
2154
2155	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
2156		spec->mic_mute_led_gpio = 0x08; /* GPIO3 */
2157#ifdef CONFIG_PM
2158		/* resetting controller clears GPIO, so we need to keep on */
2159		codec->core.power_caps &= ~AC_PWRST_CLKSTOP;
2160#endif
2161	}
2162}
2163
2164static void stac92hd83xxx_fixup_hp_led_gpio10(struct hda_codec *codec,
2165				   const struct hda_fixup *fix, int action)
2166{
2167	struct sigmatel_spec *spec = codec->spec;
2168
2169	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
2170		spec->gpio_led = 0x10; /* GPIO4 */
2171		spec->default_polarity = 0;
2172	}
2173}
2174
2175static void stac92hd83xxx_fixup_headset_jack(struct hda_codec *codec,
2176				   const struct hda_fixup *fix, int action)
2177{
2178	struct sigmatel_spec *spec = codec->spec;
2179
2180	if (action == HDA_FIXUP_ACT_PRE_PROBE)
2181		spec->headset_jack = 1;
2182}
2183
2184static void stac92hd83xxx_fixup_gpio10_eapd(struct hda_codec *codec,
2185					    const struct hda_fixup *fix,
2186					    int action)
2187{
2188	struct sigmatel_spec *spec = codec->spec;
2189
2190	if (action != HDA_FIXUP_ACT_PRE_PROBE)
2191		return;
2192	spec->eapd_mask = spec->gpio_mask = spec->gpio_dir =
2193		spec->gpio_data = 0x10;
2194	spec->eapd_switch = 0;
2195}
2196
2197static void hp_envy_ts_fixup_dac_bind(struct hda_codec *codec,
2198					    const struct hda_fixup *fix,
2199					    int action)
2200{
2201	struct sigmatel_spec *spec = codec->spec;
2202	static const hda_nid_t preferred_pairs[] = {
2203		0xd, 0x13,
2204		0
2205	};
2206
2207	if (action != HDA_FIXUP_ACT_PRE_PROBE)
2208		return;
2209
2210	spec->gen.preferred_dacs = preferred_pairs;
2211}
2212
2213static const struct hda_verb hp_bnb13_eq_verbs[] = {
2214	/* 44.1KHz base */
2215	{ 0x22, 0x7A6, 0x3E },
2216	{ 0x22, 0x7A7, 0x68 },
2217	{ 0x22, 0x7A8, 0x17 },
2218	{ 0x22, 0x7A9, 0x3E },
2219	{ 0x22, 0x7AA, 0x68 },
2220	{ 0x22, 0x7AB, 0x17 },
2221	{ 0x22, 0x7AC, 0x00 },
2222	{ 0x22, 0x7AD, 0x80 },
2223	{ 0x22, 0x7A6, 0x83 },
2224	{ 0x22, 0x7A7, 0x2F },
2225	{ 0x22, 0x7A8, 0xD1 },
2226	{ 0x22, 0x7A9, 0x83 },
2227	{ 0x22, 0x7AA, 0x2F },
2228	{ 0x22, 0x7AB, 0xD1 },
2229	{ 0x22, 0x7AC, 0x01 },
2230	{ 0x22, 0x7AD, 0x80 },
2231	{ 0x22, 0x7A6, 0x3E },
2232	{ 0x22, 0x7A7, 0x68 },
2233	{ 0x22, 0x7A8, 0x17 },
2234	{ 0x22, 0x7A9, 0x3E },
2235	{ 0x22, 0x7AA, 0x68 },
2236	{ 0x22, 0x7AB, 0x17 },
2237	{ 0x22, 0x7AC, 0x02 },
2238	{ 0x22, 0x7AD, 0x80 },
2239	{ 0x22, 0x7A6, 0x7C },
2240	{ 0x22, 0x7A7, 0xC6 },
2241	{ 0x22, 0x7A8, 0x0C },
2242	{ 0x22, 0x7A9, 0x7C },
2243	{ 0x22, 0x7AA, 0xC6 },
2244	{ 0x22, 0x7AB, 0x0C },
2245	{ 0x22, 0x7AC, 0x03 },
2246	{ 0x22, 0x7AD, 0x80 },
2247	{ 0x22, 0x7A6, 0xC3 },
2248	{ 0x22, 0x7A7, 0x25 },
2249	{ 0x22, 0x7A8, 0xAF },
2250	{ 0x22, 0x7A9, 0xC3 },
2251	{ 0x22, 0x7AA, 0x25 },
2252	{ 0x22, 0x7AB, 0xAF },
2253	{ 0x22, 0x7AC, 0x04 },
2254	{ 0x22, 0x7AD, 0x80 },
2255	{ 0x22, 0x7A6, 0x3E },
2256	{ 0x22, 0x7A7, 0x85 },
2257	{ 0x22, 0x7A8, 0x73 },
2258	{ 0x22, 0x7A9, 0x3E },
2259	{ 0x22, 0x7AA, 0x85 },
2260	{ 0x22, 0x7AB, 0x73 },
2261	{ 0x22, 0x7AC, 0x05 },
2262	{ 0x22, 0x7AD, 0x80 },
2263	{ 0x22, 0x7A6, 0x85 },
2264	{ 0x22, 0x7A7, 0x39 },
2265	{ 0x22, 0x7A8, 0xC7 },
2266	{ 0x22, 0x7A9, 0x85 },
2267	{ 0x22, 0x7AA, 0x39 },
2268	{ 0x22, 0x7AB, 0xC7 },
2269	{ 0x22, 0x7AC, 0x06 },
2270	{ 0x22, 0x7AD, 0x80 },
2271	{ 0x22, 0x7A6, 0x3C },
2272	{ 0x22, 0x7A7, 0x90 },
2273	{ 0x22, 0x7A8, 0xB0 },
2274	{ 0x22, 0x7A9, 0x3C },
2275	{ 0x22, 0x7AA, 0x90 },
2276	{ 0x22, 0x7AB, 0xB0 },
2277	{ 0x22, 0x7AC, 0x07 },
2278	{ 0x22, 0x7AD, 0x80 },
2279	{ 0x22, 0x7A6, 0x7A },
2280	{ 0x22, 0x7A7, 0xC6 },
2281	{ 0x22, 0x7A8, 0x39 },
2282	{ 0x22, 0x7A9, 0x7A },
2283	{ 0x22, 0x7AA, 0xC6 },
2284	{ 0x22, 0x7AB, 0x39 },
2285	{ 0x22, 0x7AC, 0x08 },
2286	{ 0x22, 0x7AD, 0x80 },
2287	{ 0x22, 0x7A6, 0xC4 },
2288	{ 0x22, 0x7A7, 0xE9 },
2289	{ 0x22, 0x7A8, 0xDC },
2290	{ 0x22, 0x7A9, 0xC4 },
2291	{ 0x22, 0x7AA, 0xE9 },
2292	{ 0x22, 0x7AB, 0xDC },
2293	{ 0x22, 0x7AC, 0x09 },
2294	{ 0x22, 0x7AD, 0x80 },
2295	{ 0x22, 0x7A6, 0x3D },
2296	{ 0x22, 0x7A7, 0xE1 },
2297	{ 0x22, 0x7A8, 0x0D },
2298	{ 0x22, 0x7A9, 0x3D },
2299	{ 0x22, 0x7AA, 0xE1 },
2300	{ 0x22, 0x7AB, 0x0D },
2301	{ 0x22, 0x7AC, 0x0A },
2302	{ 0x22, 0x7AD, 0x80 },
2303	{ 0x22, 0x7A6, 0x89 },
2304	{ 0x22, 0x7A7, 0xB6 },
2305	{ 0x22, 0x7A8, 0xEB },
2306	{ 0x22, 0x7A9, 0x89 },
2307	{ 0x22, 0x7AA, 0xB6 },
2308	{ 0x22, 0x7AB, 0xEB },
2309	{ 0x22, 0x7AC, 0x0B },
2310	{ 0x22, 0x7AD, 0x80 },
2311	{ 0x22, 0x7A6, 0x39 },
2312	{ 0x22, 0x7A7, 0x9D },
2313	{ 0x22, 0x7A8, 0xFE },
2314	{ 0x22, 0x7A9, 0x39 },
2315	{ 0x22, 0x7AA, 0x9D },
2316	{ 0x22, 0x7AB, 0xFE },
2317	{ 0x22, 0x7AC, 0x0C },
2318	{ 0x22, 0x7AD, 0x80 },
2319	{ 0x22, 0x7A6, 0x76 },
2320	{ 0x22, 0x7A7, 0x49 },
2321	{ 0x22, 0x7A8, 0x15 },
2322	{ 0x22, 0x7A9, 0x76 },
2323	{ 0x22, 0x7AA, 0x49 },
2324	{ 0x22, 0x7AB, 0x15 },
2325	{ 0x22, 0x7AC, 0x0D },
2326	{ 0x22, 0x7AD, 0x80 },
2327	{ 0x22, 0x7A6, 0xC8 },
2328	{ 0x22, 0x7A7, 0x80 },
2329	{ 0x22, 0x7A8, 0xF5 },
2330	{ 0x22, 0x7A9, 0xC8 },
2331	{ 0x22, 0x7AA, 0x80 },
2332	{ 0x22, 0x7AB, 0xF5 },
2333	{ 0x22, 0x7AC, 0x0E },
2334	{ 0x22, 0x7AD, 0x80 },
2335	{ 0x22, 0x7A6, 0x40 },
2336	{ 0x22, 0x7A7, 0x00 },
2337	{ 0x22, 0x7A8, 0x00 },
2338	{ 0x22, 0x7A9, 0x40 },
2339	{ 0x22, 0x7AA, 0x00 },
2340	{ 0x22, 0x7AB, 0x00 },
2341	{ 0x22, 0x7AC, 0x0F },
2342	{ 0x22, 0x7AD, 0x80 },
2343	{ 0x22, 0x7A6, 0x90 },
2344	{ 0x22, 0x7A7, 0x68 },
2345	{ 0x22, 0x7A8, 0xF1 },
2346	{ 0x22, 0x7A9, 0x90 },
2347	{ 0x22, 0x7AA, 0x68 },
2348	{ 0x22, 0x7AB, 0xF1 },
2349	{ 0x22, 0x7AC, 0x10 },
2350	{ 0x22, 0x7AD, 0x80 },
2351	{ 0x22, 0x7A6, 0x34 },
2352	{ 0x22, 0x7A7, 0x47 },
2353	{ 0x22, 0x7A8, 0x6C },
2354	{ 0x22, 0x7A9, 0x34 },
2355	{ 0x22, 0x7AA, 0x47 },
2356	{ 0x22, 0x7AB, 0x6C },
2357	{ 0x22, 0x7AC, 0x11 },
2358	{ 0x22, 0x7AD, 0x80 },
2359	{ 0x22, 0x7A6, 0x6F },
2360	{ 0x22, 0x7A7, 0x97 },
2361	{ 0x22, 0x7A8, 0x0F },
2362	{ 0x22, 0x7A9, 0x6F },
2363	{ 0x22, 0x7AA, 0x97 },
2364	{ 0x22, 0x7AB, 0x0F },
2365	{ 0x22, 0x7AC, 0x12 },
2366	{ 0x22, 0x7AD, 0x80 },
2367	{ 0x22, 0x7A6, 0xCB },
2368	{ 0x22, 0x7A7, 0xB8 },
2369	{ 0x22, 0x7A8, 0x94 },
2370	{ 0x22, 0x7A9, 0xCB },
2371	{ 0x22, 0x7AA, 0xB8 },
2372	{ 0x22, 0x7AB, 0x94 },
2373	{ 0x22, 0x7AC, 0x13 },
2374	{ 0x22, 0x7AD, 0x80 },
2375	{ 0x22, 0x7A6, 0x40 },
2376	{ 0x22, 0x7A7, 0x00 },
2377	{ 0x22, 0x7A8, 0x00 },
2378	{ 0x22, 0x7A9, 0x40 },
2379	{ 0x22, 0x7AA, 0x00 },
2380	{ 0x22, 0x7AB, 0x00 },
2381	{ 0x22, 0x7AC, 0x14 },
2382	{ 0x22, 0x7AD, 0x80 },
2383	{ 0x22, 0x7A6, 0x95 },
2384	{ 0x22, 0x7A7, 0x76 },
2385	{ 0x22, 0x7A8, 0x5B },
2386	{ 0x22, 0x7A9, 0x95 },
2387	{ 0x22, 0x7AA, 0x76 },
2388	{ 0x22, 0x7AB, 0x5B },
2389	{ 0x22, 0x7AC, 0x15 },
2390	{ 0x22, 0x7AD, 0x80 },
2391	{ 0x22, 0x7A6, 0x31 },
2392	{ 0x22, 0x7A7, 0xAC },
2393	{ 0x22, 0x7A8, 0x31 },
2394	{ 0x22, 0x7A9, 0x31 },
2395	{ 0x22, 0x7AA, 0xAC },
2396	{ 0x22, 0x7AB, 0x31 },
2397	{ 0x22, 0x7AC, 0x16 },
2398	{ 0x22, 0x7AD, 0x80 },
2399	{ 0x22, 0x7A6, 0x6A },
2400	{ 0x22, 0x7A7, 0x89 },
2401	{ 0x22, 0x7A8, 0xA5 },
2402	{ 0x22, 0x7A9, 0x6A },
2403	{ 0x22, 0x7AA, 0x89 },
2404	{ 0x22, 0x7AB, 0xA5 },
2405	{ 0x22, 0x7AC, 0x17 },
2406	{ 0x22, 0x7AD, 0x80 },
2407	{ 0x22, 0x7A6, 0xCE },
2408	{ 0x22, 0x7A7, 0x53 },
2409	{ 0x22, 0x7A8, 0xCF },
2410	{ 0x22, 0x7A9, 0xCE },
2411	{ 0x22, 0x7AA, 0x53 },
2412	{ 0x22, 0x7AB, 0xCF },
2413	{ 0x22, 0x7AC, 0x18 },
2414	{ 0x22, 0x7AD, 0x80 },
2415	{ 0x22, 0x7A6, 0x40 },
2416	{ 0x22, 0x7A7, 0x00 },
2417	{ 0x22, 0x7A8, 0x00 },
2418	{ 0x22, 0x7A9, 0x40 },
2419	{ 0x22, 0x7AA, 0x00 },
2420	{ 0x22, 0x7AB, 0x00 },
2421	{ 0x22, 0x7AC, 0x19 },
2422	{ 0x22, 0x7AD, 0x80 },
2423	/* 48KHz base */
2424	{ 0x22, 0x7A6, 0x3E },
2425	{ 0x22, 0x7A7, 0x88 },
2426	{ 0x22, 0x7A8, 0xDC },
2427	{ 0x22, 0x7A9, 0x3E },
2428	{ 0x22, 0x7AA, 0x88 },
2429	{ 0x22, 0x7AB, 0xDC },
2430	{ 0x22, 0x7AC, 0x1A },
2431	{ 0x22, 0x7AD, 0x80 },
2432	{ 0x22, 0x7A6, 0x82 },
2433	{ 0x22, 0x7A7, 0xEE },
2434	{ 0x22, 0x7A8, 0x46 },
2435	{ 0x22, 0x7A9, 0x82 },
2436	{ 0x22, 0x7AA, 0xEE },
2437	{ 0x22, 0x7AB, 0x46 },
2438	{ 0x22, 0x7AC, 0x1B },
2439	{ 0x22, 0x7AD, 0x80 },
2440	{ 0x22, 0x7A6, 0x3E },
2441	{ 0x22, 0x7A7, 0x88 },
2442	{ 0x22, 0x7A8, 0xDC },
2443	{ 0x22, 0x7A9, 0x3E },
2444	{ 0x22, 0x7AA, 0x88 },
2445	{ 0x22, 0x7AB, 0xDC },
2446	{ 0x22, 0x7AC, 0x1C },
2447	{ 0x22, 0x7AD, 0x80 },
2448	{ 0x22, 0x7A6, 0x7D },
2449	{ 0x22, 0x7A7, 0x09 },
2450	{ 0x22, 0x7A8, 0x28 },
2451	{ 0x22, 0x7A9, 0x7D },
2452	{ 0x22, 0x7AA, 0x09 },
2453	{ 0x22, 0x7AB, 0x28 },
2454	{ 0x22, 0x7AC, 0x1D },
2455	{ 0x22, 0x7AD, 0x80 },
2456	{ 0x22, 0x7A6, 0xC2 },
2457	{ 0x22, 0x7A7, 0xE5 },
2458	{ 0x22, 0x7A8, 0xB4 },
2459	{ 0x22, 0x7A9, 0xC2 },
2460	{ 0x22, 0x7AA, 0xE5 },
2461	{ 0x22, 0x7AB, 0xB4 },
2462	{ 0x22, 0x7AC, 0x1E },
2463	{ 0x22, 0x7AD, 0x80 },
2464	{ 0x22, 0x7A6, 0x3E },
2465	{ 0x22, 0x7A7, 0xA3 },
2466	{ 0x22, 0x7A8, 0x1F },
2467	{ 0x22, 0x7A9, 0x3E },
2468	{ 0x22, 0x7AA, 0xA3 },
2469	{ 0x22, 0x7AB, 0x1F },
2470	{ 0x22, 0x7AC, 0x1F },
2471	{ 0x22, 0x7AD, 0x80 },
2472	{ 0x22, 0x7A6, 0x84 },
2473	{ 0x22, 0x7A7, 0xCA },
2474	{ 0x22, 0x7A8, 0xF1 },
2475	{ 0x22, 0x7A9, 0x84 },
2476	{ 0x22, 0x7AA, 0xCA },
2477	{ 0x22, 0x7AB, 0xF1 },
2478	{ 0x22, 0x7AC, 0x20 },
2479	{ 0x22, 0x7AD, 0x80 },
2480	{ 0x22, 0x7A6, 0x3C },
2481	{ 0x22, 0x7A7, 0xD5 },
2482	{ 0x22, 0x7A8, 0x9C },
2483	{ 0x22, 0x7A9, 0x3C },
2484	{ 0x22, 0x7AA, 0xD5 },
2485	{ 0x22, 0x7AB, 0x9C },
2486	{ 0x22, 0x7AC, 0x21 },
2487	{ 0x22, 0x7AD, 0x80 },
2488	{ 0x22, 0x7A6, 0x7B },
2489	{ 0x22, 0x7A7, 0x35 },
2490	{ 0x22, 0x7A8, 0x0F },
2491	{ 0x22, 0x7A9, 0x7B },
2492	{ 0x22, 0x7AA, 0x35 },
2493	{ 0x22, 0x7AB, 0x0F },
2494	{ 0x22, 0x7AC, 0x22 },
2495	{ 0x22, 0x7AD, 0x80 },
2496	{ 0x22, 0x7A6, 0xC4 },
2497	{ 0x22, 0x7A7, 0x87 },
2498	{ 0x22, 0x7A8, 0x45 },
2499	{ 0x22, 0x7A9, 0xC4 },
2500	{ 0x22, 0x7AA, 0x87 },
2501	{ 0x22, 0x7AB, 0x45 },
2502	{ 0x22, 0x7AC, 0x23 },
2503	{ 0x22, 0x7AD, 0x80 },
2504	{ 0x22, 0x7A6, 0x3E },
2505	{ 0x22, 0x7A7, 0x0A },
2506	{ 0x22, 0x7A8, 0x78 },
2507	{ 0x22, 0x7A9, 0x3E },
2508	{ 0x22, 0x7AA, 0x0A },
2509	{ 0x22, 0x7AB, 0x78 },
2510	{ 0x22, 0x7AC, 0x24 },
2511	{ 0x22, 0x7AD, 0x80 },
2512	{ 0x22, 0x7A6, 0x88 },
2513	{ 0x22, 0x7A7, 0xE2 },
2514	{ 0x22, 0x7A8, 0x05 },
2515	{ 0x22, 0x7A9, 0x88 },
2516	{ 0x22, 0x7AA, 0xE2 },
2517	{ 0x22, 0x7AB, 0x05 },
2518	{ 0x22, 0x7AC, 0x25 },
2519	{ 0x22, 0x7AD, 0x80 },
2520	{ 0x22, 0x7A6, 0x3A },
2521	{ 0x22, 0x7A7, 0x1A },
2522	{ 0x22, 0x7A8, 0xA3 },
2523	{ 0x22, 0x7A9, 0x3A },
2524	{ 0x22, 0x7AA, 0x1A },
2525	{ 0x22, 0x7AB, 0xA3 },
2526	{ 0x22, 0x7AC, 0x26 },
2527	{ 0x22, 0x7AD, 0x80 },
2528	{ 0x22, 0x7A6, 0x77 },
2529	{ 0x22, 0x7A7, 0x1D },
2530	{ 0x22, 0x7A8, 0xFB },
2531	{ 0x22, 0x7A9, 0x77 },
2532	{ 0x22, 0x7AA, 0x1D },
2533	{ 0x22, 0x7AB, 0xFB },
2534	{ 0x22, 0x7AC, 0x27 },
2535	{ 0x22, 0x7AD, 0x80 },
2536	{ 0x22, 0x7A6, 0xC7 },
2537	{ 0x22, 0x7A7, 0xDA },
2538	{ 0x22, 0x7A8, 0xE5 },
2539	{ 0x22, 0x7A9, 0xC7 },
2540	{ 0x22, 0x7AA, 0xDA },
2541	{ 0x22, 0x7AB, 0xE5 },
2542	{ 0x22, 0x7AC, 0x28 },
2543	{ 0x22, 0x7AD, 0x80 },
2544	{ 0x22, 0x7A6, 0x40 },
2545	{ 0x22, 0x7A7, 0x00 },
2546	{ 0x22, 0x7A8, 0x00 },
2547	{ 0x22, 0x7A9, 0x40 },
2548	{ 0x22, 0x7AA, 0x00 },
2549	{ 0x22, 0x7AB, 0x00 },
2550	{ 0x22, 0x7AC, 0x29 },
2551	{ 0x22, 0x7AD, 0x80 },
2552	{ 0x22, 0x7A6, 0x8E },
2553	{ 0x22, 0x7A7, 0xD7 },
2554	{ 0x22, 0x7A8, 0x22 },
2555	{ 0x22, 0x7A9, 0x8E },
2556	{ 0x22, 0x7AA, 0xD7 },
2557	{ 0x22, 0x7AB, 0x22 },
2558	{ 0x22, 0x7AC, 0x2A },
2559	{ 0x22, 0x7AD, 0x80 },
2560	{ 0x22, 0x7A6, 0x35 },
2561	{ 0x22, 0x7A7, 0x26 },
2562	{ 0x22, 0x7A8, 0xC6 },
2563	{ 0x22, 0x7A9, 0x35 },
2564	{ 0x22, 0x7AA, 0x26 },
2565	{ 0x22, 0x7AB, 0xC6 },
2566	{ 0x22, 0x7AC, 0x2B },
2567	{ 0x22, 0x7AD, 0x80 },
2568	{ 0x22, 0x7A6, 0x71 },
2569	{ 0x22, 0x7A7, 0x28 },
2570	{ 0x22, 0x7A8, 0xDE },
2571	{ 0x22, 0x7A9, 0x71 },
2572	{ 0x22, 0x7AA, 0x28 },
2573	{ 0x22, 0x7AB, 0xDE },
2574	{ 0x22, 0x7AC, 0x2C },
2575	{ 0x22, 0x7AD, 0x80 },
2576	{ 0x22, 0x7A6, 0xCA },
2577	{ 0x22, 0x7A7, 0xD9 },
2578	{ 0x22, 0x7A8, 0x3A },
2579	{ 0x22, 0x7A9, 0xCA },
2580	{ 0x22, 0x7AA, 0xD9 },
2581	{ 0x22, 0x7AB, 0x3A },
2582	{ 0x22, 0x7AC, 0x2D },
2583	{ 0x22, 0x7AD, 0x80 },
2584	{ 0x22, 0x7A6, 0x40 },
2585	{ 0x22, 0x7A7, 0x00 },
2586	{ 0x22, 0x7A8, 0x00 },
2587	{ 0x22, 0x7A9, 0x40 },
2588	{ 0x22, 0x7AA, 0x00 },
2589	{ 0x22, 0x7AB, 0x00 },
2590	{ 0x22, 0x7AC, 0x2E },
2591	{ 0x22, 0x7AD, 0x80 },
2592	{ 0x22, 0x7A6, 0x93 },
2593	{ 0x22, 0x7A7, 0x5E },
2594	{ 0x22, 0x7A8, 0xD8 },
2595	{ 0x22, 0x7A9, 0x93 },
2596	{ 0x22, 0x7AA, 0x5E },
2597	{ 0x22, 0x7AB, 0xD8 },
2598	{ 0x22, 0x7AC, 0x2F },
2599	{ 0x22, 0x7AD, 0x80 },
2600	{ 0x22, 0x7A6, 0x32 },
2601	{ 0x22, 0x7A7, 0xB7 },
2602	{ 0x22, 0x7A8, 0xB1 },
2603	{ 0x22, 0x7A9, 0x32 },
2604	{ 0x22, 0x7AA, 0xB7 },
2605	{ 0x22, 0x7AB, 0xB1 },
2606	{ 0x22, 0x7AC, 0x30 },
2607	{ 0x22, 0x7AD, 0x80 },
2608	{ 0x22, 0x7A6, 0x6C },
2609	{ 0x22, 0x7A7, 0xA1 },
2610	{ 0x22, 0x7A8, 0x28 },
2611	{ 0x22, 0x7A9, 0x6C },
2612	{ 0x22, 0x7AA, 0xA1 },
2613	{ 0x22, 0x7AB, 0x28 },
2614	{ 0x22, 0x7AC, 0x31 },
2615	{ 0x22, 0x7AD, 0x80 },
2616	{ 0x22, 0x7A6, 0xCD },
2617	{ 0x22, 0x7A7, 0x48 },
2618	{ 0x22, 0x7A8, 0x4F },
2619	{ 0x22, 0x7A9, 0xCD },
2620	{ 0x22, 0x7AA, 0x48 },
2621	{ 0x22, 0x7AB, 0x4F },
2622	{ 0x22, 0x7AC, 0x32 },
2623	{ 0x22, 0x7AD, 0x80 },
2624	{ 0x22, 0x7A6, 0x40 },
2625	{ 0x22, 0x7A7, 0x00 },
2626	{ 0x22, 0x7A8, 0x00 },
2627	{ 0x22, 0x7A9, 0x40 },
2628	{ 0x22, 0x7AA, 0x00 },
2629	{ 0x22, 0x7AB, 0x00 },
2630	{ 0x22, 0x7AC, 0x33 },
2631	{ 0x22, 0x7AD, 0x80 },
2632	/* common */
2633	{ 0x22, 0x782, 0xC1 },
2634	{ 0x22, 0x771, 0x2C },
2635	{ 0x22, 0x772, 0x2C },
2636	{ 0x22, 0x788, 0x04 },
2637	{ 0x01, 0x7B0, 0x08 },
2638	{}
2639};
2640
2641static const struct hda_fixup stac92hd83xxx_fixups[] = {
2642	[STAC_92HD83XXX_REF] = {
2643		.type = HDA_FIXUP_PINS,
2644		.v.pins = ref92hd83xxx_pin_configs,
2645	},
2646	[STAC_92HD83XXX_PWR_REF] = {
2647		.type = HDA_FIXUP_PINS,
2648		.v.pins = ref92hd83xxx_pin_configs,
2649	},
2650	[STAC_DELL_S14] = {
2651		.type = HDA_FIXUP_PINS,
2652		.v.pins = dell_s14_pin_configs,
2653	},
2654	[STAC_DELL_VOSTRO_3500] = {
2655		.type = HDA_FIXUP_PINS,
2656		.v.pins = dell_vostro_3500_pin_configs,
2657	},
2658	[STAC_92HD83XXX_HP_cNB11_INTQUAD] = {
2659		.type = HDA_FIXUP_PINS,
2660		.v.pins = hp_cNB11_intquad_pin_configs,
2661		.chained = true,
2662		.chain_id = STAC_92HD83XXX_HP,
2663	},
2664	[STAC_92HD83XXX_HP] = {
2665		.type = HDA_FIXUP_FUNC,
2666		.v.func = stac92hd83xxx_fixup_hp,
2667	},
2668	[STAC_HP_DV7_4000] = {
2669		.type = HDA_FIXUP_PINS,
2670		.v.pins = hp_dv7_4000_pin_configs,
2671		.chained = true,
2672		.chain_id = STAC_92HD83XXX_HP,
2673	},
2674	[STAC_HP_ZEPHYR] = {
2675		.type = HDA_FIXUP_FUNC,
2676		.v.func = stac92hd83xxx_fixup_hp_zephyr,
2677		.chained = true,
2678		.chain_id = STAC_92HD83XXX_HP,
2679	},
2680	[STAC_92HD83XXX_HP_LED] = {
2681		.type = HDA_FIXUP_FUNC,
2682		.v.func = stac92hd83xxx_fixup_hp_led,
2683		.chained = true,
2684		.chain_id = STAC_92HD83XXX_HP,
2685	},
2686	[STAC_92HD83XXX_HP_INV_LED] = {
2687		.type = HDA_FIXUP_FUNC,
2688		.v.func = stac92hd83xxx_fixup_hp_inv_led,
2689		.chained = true,
2690		.chain_id = STAC_92HD83XXX_HP,
2691	},
2692	[STAC_92HD83XXX_HP_MIC_LED] = {
2693		.type = HDA_FIXUP_FUNC,
2694		.v.func = stac92hd83xxx_fixup_hp_mic_led,
2695		.chained = true,
2696		.chain_id = STAC_92HD83XXX_HP,
2697	},
2698	[STAC_HP_LED_GPIO10] = {
2699		.type = HDA_FIXUP_FUNC,
2700		.v.func = stac92hd83xxx_fixup_hp_led_gpio10,
2701		.chained = true,
2702		.chain_id = STAC_92HD83XXX_HP,
2703	},
2704	[STAC_92HD83XXX_HEADSET_JACK] = {
2705		.type = HDA_FIXUP_FUNC,
2706		.v.func = stac92hd83xxx_fixup_headset_jack,
2707	},
2708	[STAC_HP_ENVY_BASS] = {
2709		.type = HDA_FIXUP_PINS,
2710		.v.pins = (const struct hda_pintbl[]) {
2711			{ 0x0f, 0x90170111 },
2712			{}
2713		},
2714	},
2715	[STAC_HP_BNB13_EQ] = {
2716		.type = HDA_FIXUP_VERBS,
2717		.v.verbs = hp_bnb13_eq_verbs,
2718		.chained = true,
2719		.chain_id = STAC_92HD83XXX_HP_MIC_LED,
2720	},
2721	[STAC_HP_ENVY_TS_BASS] = {
2722		.type = HDA_FIXUP_PINS,
2723		.v.pins = (const struct hda_pintbl[]) {
2724			{ 0x10, 0x92170111 },
2725			{}
2726		},
2727	},
2728	[STAC_HP_ENVY_TS_DAC_BIND] = {
2729		.type = HDA_FIXUP_FUNC,
2730		.v.func = hp_envy_ts_fixup_dac_bind,
2731		.chained = true,
2732		.chain_id = STAC_HP_ENVY_TS_BASS,
2733	},
2734	[STAC_92HD83XXX_GPIO10_EAPD] = {
2735		.type = HDA_FIXUP_FUNC,
2736		.v.func = stac92hd83xxx_fixup_gpio10_eapd,
2737	},
2738};
2739
2740static const struct hda_model_fixup stac92hd83xxx_models[] = {
2741	{ .id = STAC_92HD83XXX_REF, .name = "ref" },
2742	{ .id = STAC_92HD83XXX_PWR_REF, .name = "mic-ref" },
2743	{ .id = STAC_DELL_S14, .name = "dell-s14" },
2744	{ .id = STAC_DELL_VOSTRO_3500, .name = "dell-vostro-3500" },
2745	{ .id = STAC_92HD83XXX_HP_cNB11_INTQUAD, .name = "hp_cNB11_intquad" },
2746	{ .id = STAC_HP_DV7_4000, .name = "hp-dv7-4000" },
2747	{ .id = STAC_HP_ZEPHYR, .name = "hp-zephyr" },
2748	{ .id = STAC_92HD83XXX_HP_LED, .name = "hp-led" },
2749	{ .id = STAC_92HD83XXX_HP_INV_LED, .name = "hp-inv-led" },
2750	{ .id = STAC_92HD83XXX_HP_MIC_LED, .name = "hp-mic-led" },
2751	{ .id = STAC_92HD83XXX_HEADSET_JACK, .name = "headset-jack" },
2752	{ .id = STAC_HP_ENVY_BASS, .name = "hp-envy-bass" },
2753	{ .id = STAC_HP_BNB13_EQ, .name = "hp-bnb13-eq" },
2754	{ .id = STAC_HP_ENVY_TS_BASS, .name = "hp-envy-ts-bass" },
2755	{}
2756};
2757
2758static const struct snd_pci_quirk stac92hd83xxx_fixup_tbl[] = {
2759	/* SigmaTel reference board */
2760	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2761		      "DFI LanParty", STAC_92HD83XXX_REF),
2762	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2763		      "DFI LanParty", STAC_92HD83XXX_REF),
2764	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ba,
2765		      "unknown Dell", STAC_DELL_S14),
2766	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0532,
2767		      "Dell Latitude E6230", STAC_92HD83XXX_HEADSET_JACK),
2768	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0533,
2769		      "Dell Latitude E6330", STAC_92HD83XXX_HEADSET_JACK),
2770	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0534,
2771		      "Dell Latitude E6430", STAC_92HD83XXX_HEADSET_JACK),
2772	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0535,
2773		      "Dell Latitude E6530", STAC_92HD83XXX_HEADSET_JACK),
2774	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x053c,
2775		      "Dell Latitude E5430", STAC_92HD83XXX_HEADSET_JACK),
2776	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x053d,
2777		      "Dell Latitude E5530", STAC_92HD83XXX_HEADSET_JACK),
2778	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0549,
2779		      "Dell Latitude E5430", STAC_92HD83XXX_HEADSET_JACK),
2780	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x057d,
2781		      "Dell Latitude E6430s", STAC_92HD83XXX_HEADSET_JACK),
2782	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0584,
2783		      "Dell Latitude E6430U", STAC_92HD83XXX_HEADSET_JACK),
2784	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x1028,
2785		      "Dell Vostro 3500", STAC_DELL_VOSTRO_3500),
2786	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1656,
2787			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2788	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1657,
2789			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2790	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1658,
2791			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2792	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1659,
2793			  "HP Pavilion dv7", STAC_HP_DV7_4000),
2794	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x165A,
2795			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2796	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x165B,
2797			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2798	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1888,
2799			  "HP Envy Spectre", STAC_HP_ENVY_BASS),
2800	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1899,
2801			  "HP Folio 13", STAC_HP_LED_GPIO10),
2802	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x18df,
2803			  "HP Folio", STAC_HP_BNB13_EQ),
2804	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x18F8,
2805			  "HP bNB13", STAC_HP_BNB13_EQ),
2806	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1909,
2807			  "HP bNB13", STAC_HP_BNB13_EQ),
2808	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x190A,
2809			  "HP bNB13", STAC_HP_BNB13_EQ),
2810	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x190e,
2811			  "HP ENVY TS", STAC_HP_ENVY_TS_BASS),
2812	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1967,
2813			  "HP ENVY TS", STAC_HP_ENVY_TS_DAC_BIND),
2814	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1940,
2815			  "HP bNB13", STAC_HP_BNB13_EQ),
2816	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1941,
2817			  "HP bNB13", STAC_HP_BNB13_EQ),
2818	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1942,
2819			  "HP bNB13", STAC_HP_BNB13_EQ),
2820	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1943,
2821			  "HP bNB13", STAC_HP_BNB13_EQ),
2822	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1944,
2823			  "HP bNB13", STAC_HP_BNB13_EQ),
2824	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1945,
2825			  "HP bNB13", STAC_HP_BNB13_EQ),
2826	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1946,
2827			  "HP bNB13", STAC_HP_BNB13_EQ),
2828	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1948,
2829			  "HP bNB13", STAC_HP_BNB13_EQ),
2830	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1949,
2831			  "HP bNB13", STAC_HP_BNB13_EQ),
2832	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x194A,
2833			  "HP bNB13", STAC_HP_BNB13_EQ),
2834	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x194B,
2835			  "HP bNB13", STAC_HP_BNB13_EQ),
2836	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x194C,
2837			  "HP bNB13", STAC_HP_BNB13_EQ),
2838	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x194E,
2839			  "HP bNB13", STAC_HP_BNB13_EQ),
2840	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x194F,
2841			  "HP bNB13", STAC_HP_BNB13_EQ),
2842	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1950,
2843			  "HP bNB13", STAC_HP_BNB13_EQ),
2844	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1951,
2845			  "HP bNB13", STAC_HP_BNB13_EQ),
2846	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x195A,
2847			  "HP bNB13", STAC_HP_BNB13_EQ),
2848	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x195B,
2849			  "HP bNB13", STAC_HP_BNB13_EQ),
2850	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x195C,
2851			  "HP bNB13", STAC_HP_BNB13_EQ),
2852	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1991,
2853			  "HP bNB13", STAC_HP_BNB13_EQ),
2854	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2103,
2855			  "HP bNB13", STAC_HP_BNB13_EQ),
2856	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2104,
2857			  "HP bNB13", STAC_HP_BNB13_EQ),
2858	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2105,
2859			  "HP bNB13", STAC_HP_BNB13_EQ),
2860	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2106,
2861			  "HP bNB13", STAC_HP_BNB13_EQ),
2862	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2107,
2863			  "HP bNB13", STAC_HP_BNB13_EQ),
2864	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2108,
2865			  "HP bNB13", STAC_HP_BNB13_EQ),
2866	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2109,
2867			  "HP bNB13", STAC_HP_BNB13_EQ),
2868	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x210A,
2869			  "HP bNB13", STAC_HP_BNB13_EQ),
2870	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x210B,
2871			  "HP bNB13", STAC_HP_BNB13_EQ),
2872	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x211C,
2873			  "HP bNB13", STAC_HP_BNB13_EQ),
2874	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x211D,
2875			  "HP bNB13", STAC_HP_BNB13_EQ),
2876	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x211E,
2877			  "HP bNB13", STAC_HP_BNB13_EQ),
2878	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x211F,
2879			  "HP bNB13", STAC_HP_BNB13_EQ),
2880	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2120,
2881			  "HP bNB13", STAC_HP_BNB13_EQ),
2882	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2121,
2883			  "HP bNB13", STAC_HP_BNB13_EQ),
2884	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2122,
2885			  "HP bNB13", STAC_HP_BNB13_EQ),
2886	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2123,
2887			  "HP bNB13", STAC_HP_BNB13_EQ),
2888	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x213E,
2889			  "HP bNB13", STAC_HP_BNB13_EQ),
2890	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x213F,
2891			  "HP bNB13", STAC_HP_BNB13_EQ),
2892	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x2140,
2893			  "HP bNB13", STAC_HP_BNB13_EQ),
2894	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x21B2,
2895			  "HP bNB13", STAC_HP_BNB13_EQ),
2896	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x21B3,
2897			  "HP bNB13", STAC_HP_BNB13_EQ),
2898	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x21B5,
2899			  "HP bNB13", STAC_HP_BNB13_EQ),
2900	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x21B6,
2901			  "HP bNB13", STAC_HP_BNB13_EQ),
2902	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xff00, 0x1900,
2903			  "HP", STAC_92HD83XXX_HP_MIC_LED),
2904	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xff00, 0x2000,
2905			  "HP", STAC_92HD83XXX_HP_MIC_LED),
2906	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xff00, 0x2100,
2907			  "HP", STAC_92HD83XXX_HP_MIC_LED),
2908	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3388,
2909			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2910	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3389,
2911			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2912	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355B,
2913			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2914	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355C,
2915			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2916	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355D,
2917			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2918	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355E,
2919			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2920	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355F,
2921			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2922	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3560,
2923			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2924	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358B,
2925			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2926	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358C,
2927			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2928	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358D,
2929			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2930	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3591,
2931			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2932	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3592,
2933			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2934	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3593,
2935			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
2936	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3561,
2937			  "HP", STAC_HP_ZEPHYR),
2938	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3660,
2939			  "HP Mini", STAC_92HD83XXX_HP_LED),
2940	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x144E,
2941			  "HP Pavilion dv5", STAC_92HD83XXX_HP_INV_LED),
2942	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x148a,
2943		      "HP Mini", STAC_92HD83XXX_HP_LED),
2944	SND_PCI_QUIRK_VENDOR(PCI_VENDOR_ID_HP, "HP", STAC_92HD83XXX_HP),
2945	/* match both for 0xfa91 and 0xfa93 */
2946	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_TOSHIBA, 0xfffd, 0xfa91,
2947		      "Toshiba Satellite S50D", STAC_92HD83XXX_GPIO10_EAPD),
2948	{} /* terminator */
2949};
2950
2951/* HP dv7 bass switch - GPIO5 */
2952#define stac_hp_bass_gpio_info	snd_ctl_boolean_mono_info
2953static int stac_hp_bass_gpio_get(struct snd_kcontrol *kcontrol,
2954				 struct snd_ctl_elem_value *ucontrol)
2955{
2956	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2957	struct sigmatel_spec *spec = codec->spec;
2958	ucontrol->value.integer.value[0] = !!(spec->gpio_data & 0x20);
2959	return 0;
2960}
2961
2962static int stac_hp_bass_gpio_put(struct snd_kcontrol *kcontrol,
2963				 struct snd_ctl_elem_value *ucontrol)
2964{
2965	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2966	struct sigmatel_spec *spec = codec->spec;
2967	unsigned int gpio_data;
2968
2969	gpio_data = (spec->gpio_data & ~0x20) |
2970		(ucontrol->value.integer.value[0] ? 0x20 : 0);
2971	if (gpio_data == spec->gpio_data)
2972		return 0;
2973	spec->gpio_data = gpio_data;
2974	stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data);
2975	return 1;
2976}
2977
2978static const struct snd_kcontrol_new stac_hp_bass_sw_ctrl = {
2979	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
2980	.info = stac_hp_bass_gpio_info,
2981	.get = stac_hp_bass_gpio_get,
2982	.put = stac_hp_bass_gpio_put,
2983};
2984
2985static int stac_add_hp_bass_switch(struct hda_codec *codec)
2986{
2987	struct sigmatel_spec *spec = codec->spec;
2988
2989	if (!snd_hda_gen_add_kctl(&spec->gen, "Bass Speaker Playback Switch",
2990				  &stac_hp_bass_sw_ctrl))
2991		return -ENOMEM;
2992
2993	spec->gpio_mask |= 0x20;
2994	spec->gpio_dir |= 0x20;
2995	spec->gpio_data |= 0x20;
2996	return 0;
2997}
2998
2999static const struct hda_pintbl ref92hd71bxx_pin_configs[] = {
3000	{ 0x0a, 0x02214030 },
3001	{ 0x0b, 0x02a19040 },
3002	{ 0x0c, 0x01a19020 },
3003	{ 0x0d, 0x01014010 },
3004	{ 0x0e, 0x0181302e },
3005	{ 0x0f, 0x01014010 },
3006	{ 0x14, 0x01019020 },
3007	{ 0x18, 0x90a000f0 },
3008	{ 0x19, 0x90a000f0 },
3009	{ 0x1e, 0x01452050 },
3010	{ 0x1f, 0x01452050 },
3011	{}
3012};
3013
3014static const struct hda_pintbl dell_m4_1_pin_configs[] = {
3015	{ 0x0a, 0x0421101f },
3016	{ 0x0b, 0x04a11221 },
3017	{ 0x0c, 0x40f000f0 },
3018	{ 0x0d, 0x90170110 },
3019	{ 0x0e, 0x23a1902e },
3020	{ 0x0f, 0x23014250 },
3021	{ 0x14, 0x40f000f0 },
3022	{ 0x18, 0x90a000f0 },
3023	{ 0x19, 0x40f000f0 },
3024	{ 0x1e, 0x4f0000f0 },
3025	{ 0x1f, 0x4f0000f0 },
3026	{}
3027};
3028
3029static const struct hda_pintbl dell_m4_2_pin_configs[] = {
3030	{ 0x0a, 0x0421101f },
3031	{ 0x0b, 0x04a11221 },
3032	{ 0x0c, 0x90a70330 },
3033	{ 0x0d, 0x90170110 },
3034	{ 0x0e, 0x23a1902e },
3035	{ 0x0f, 0x23014250 },
3036	{ 0x14, 0x40f000f0 },
3037	{ 0x18, 0x40f000f0 },
3038	{ 0x19, 0x40f000f0 },
3039	{ 0x1e, 0x044413b0 },
3040	{ 0x1f, 0x044413b0 },
3041	{}
3042};
3043
3044static const struct hda_pintbl dell_m4_3_pin_configs[] = {
3045	{ 0x0a, 0x0421101f },
3046	{ 0x0b, 0x04a11221 },
3047	{ 0x0c, 0x90a70330 },
3048	{ 0x0d, 0x90170110 },
3049	{ 0x0e, 0x40f000f0 },
3050	{ 0x0f, 0x40f000f0 },
3051	{ 0x14, 0x40f000f0 },
3052	{ 0x18, 0x90a000f0 },
3053	{ 0x19, 0x40f000f0 },
3054	{ 0x1e, 0x044413b0 },
3055	{ 0x1f, 0x044413b0 },
3056	{}
3057};
3058
3059static void stac92hd71bxx_fixup_ref(struct hda_codec *codec,
3060				    const struct hda_fixup *fix, int action)
3061{
3062	struct sigmatel_spec *spec = codec->spec;
3063
3064	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3065		return;
3066
3067	snd_hda_apply_pincfgs(codec, ref92hd71bxx_pin_configs);
3068	spec->gpio_mask = spec->gpio_dir = spec->gpio_data = 0;
3069}
3070
3071static void stac92hd71bxx_fixup_hp_m4(struct hda_codec *codec,
3072				      const struct hda_fixup *fix, int action)
3073{
3074	struct sigmatel_spec *spec = codec->spec;
3075	struct hda_jack_callback *jack;
3076
3077	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3078		return;
3079
3080	/* Enable VREF power saving on GPIO1 detect */
3081	snd_hda_codec_write_cache(codec, codec->core.afg, 0,
3082				  AC_VERB_SET_GPIO_UNSOLICITED_RSP_MASK, 0x02);
3083	jack = snd_hda_jack_detect_enable_callback(codec, codec->core.afg,
3084						   stac_vref_event);
3085	if (!IS_ERR(jack))
3086		jack->private_data = 0x02;
3087
3088	spec->gpio_mask |= 0x02;
3089
3090	/* enable internal microphone */
3091	snd_hda_codec_set_pincfg(codec, 0x0e, 0x01813040);
3092}
3093
3094static void stac92hd71bxx_fixup_hp_dv4(struct hda_codec *codec,
3095				       const struct hda_fixup *fix, int action)
3096{
3097	struct sigmatel_spec *spec = codec->spec;
3098
3099	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3100		return;
3101	spec->gpio_led = 0x01;
3102}
3103
3104static void stac92hd71bxx_fixup_hp_dv5(struct hda_codec *codec,
3105				       const struct hda_fixup *fix, int action)
3106{
3107	unsigned int cap;
3108
3109	switch (action) {
3110	case HDA_FIXUP_ACT_PRE_PROBE:
3111		snd_hda_codec_set_pincfg(codec, 0x0d, 0x90170010);
3112		break;
3113
3114	case HDA_FIXUP_ACT_PROBE:
3115		/* enable bass on HP dv7 */
3116		cap = snd_hda_param_read(codec, 0x1, AC_PAR_GPIO_CAP);
3117		cap &= AC_GPIO_IO_COUNT;
3118		if (cap >= 6)
3119			stac_add_hp_bass_switch(codec);
3120		break;
3121	}
3122}
3123
3124static void stac92hd71bxx_fixup_hp_hdx(struct hda_codec *codec,
3125				       const struct hda_fixup *fix, int action)
3126{
3127	struct sigmatel_spec *spec = codec->spec;
3128
3129	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3130		return;
3131	spec->gpio_led = 0x08;
3132}
3133
3134static bool is_hp_output(struct hda_codec *codec, hda_nid_t pin)
3135{
3136	unsigned int pin_cfg = snd_hda_codec_get_pincfg(codec, pin);
3137
3138	/* count line-out, too, as BIOS sets often so */
3139	return get_defcfg_connect(pin_cfg) != AC_JACK_PORT_NONE &&
3140		(get_defcfg_device(pin_cfg) == AC_JACK_LINE_OUT ||
3141		 get_defcfg_device(pin_cfg) == AC_JACK_HP_OUT);
3142}
3143
3144static void fixup_hp_headphone(struct hda_codec *codec, hda_nid_t pin)
3145{
3146	unsigned int pin_cfg = snd_hda_codec_get_pincfg(codec, pin);
3147
3148	/* It was changed in the BIOS to just satisfy MS DTM.
3149	 * Lets turn it back into follower HP
3150	 */
3151	pin_cfg = (pin_cfg & (~AC_DEFCFG_DEVICE)) |
3152		(AC_JACK_HP_OUT << AC_DEFCFG_DEVICE_SHIFT);
3153	pin_cfg = (pin_cfg & (~(AC_DEFCFG_DEF_ASSOC | AC_DEFCFG_SEQUENCE))) |
3154		0x1f;
3155	snd_hda_codec_set_pincfg(codec, pin, pin_cfg);
3156}
3157
3158static void stac92hd71bxx_fixup_hp(struct hda_codec *codec,
3159				   const struct hda_fixup *fix, int action)
3160{
3161	struct sigmatel_spec *spec = codec->spec;
3162
3163	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3164		return;
3165
3166	/* when both output A and F are assigned, these are supposedly
3167	 * dock and built-in headphones; fix both pin configs
3168	 */
3169	if (is_hp_output(codec, 0x0a) && is_hp_output(codec, 0x0f)) {
3170		fixup_hp_headphone(codec, 0x0a);
3171		fixup_hp_headphone(codec, 0x0f);
3172	}
3173
3174	if (find_mute_led_cfg(codec, 1))
3175		codec_dbg(codec, "mute LED gpio %d polarity %d\n",
3176				spec->gpio_led,
3177				spec->gpio_led_polarity);
3178
3179}
3180
3181static const struct hda_fixup stac92hd71bxx_fixups[] = {
3182	[STAC_92HD71BXX_REF] = {
3183		.type = HDA_FIXUP_FUNC,
3184		.v.func = stac92hd71bxx_fixup_ref,
3185	},
3186	[STAC_DELL_M4_1] = {
3187		.type = HDA_FIXUP_PINS,
3188		.v.pins = dell_m4_1_pin_configs,
3189	},
3190	[STAC_DELL_M4_2] = {
3191		.type = HDA_FIXUP_PINS,
3192		.v.pins = dell_m4_2_pin_configs,
3193	},
3194	[STAC_DELL_M4_3] = {
3195		.type = HDA_FIXUP_PINS,
3196		.v.pins = dell_m4_3_pin_configs,
3197	},
3198	[STAC_HP_M4] = {
3199		.type = HDA_FIXUP_FUNC,
3200		.v.func = stac92hd71bxx_fixup_hp_m4,
3201		.chained = true,
3202		.chain_id = STAC_92HD71BXX_HP,
3203	},
3204	[STAC_HP_DV4] = {
3205		.type = HDA_FIXUP_FUNC,
3206		.v.func = stac92hd71bxx_fixup_hp_dv4,
3207		.chained = true,
3208		.chain_id = STAC_HP_DV5,
3209	},
3210	[STAC_HP_DV5] = {
3211		.type = HDA_FIXUP_FUNC,
3212		.v.func = stac92hd71bxx_fixup_hp_dv5,
3213		.chained = true,
3214		.chain_id = STAC_92HD71BXX_HP,
3215	},
3216	[STAC_HP_HDX] = {
3217		.type = HDA_FIXUP_FUNC,
3218		.v.func = stac92hd71bxx_fixup_hp_hdx,
3219		.chained = true,
3220		.chain_id = STAC_92HD71BXX_HP,
3221	},
3222	[STAC_92HD71BXX_HP] = {
3223		.type = HDA_FIXUP_FUNC,
3224		.v.func = stac92hd71bxx_fixup_hp,
3225	},
3226};
3227
3228static const struct hda_model_fixup stac92hd71bxx_models[] = {
3229	{ .id = STAC_92HD71BXX_REF, .name = "ref" },
3230	{ .id = STAC_DELL_M4_1, .name = "dell-m4-1" },
3231	{ .id = STAC_DELL_M4_2, .name = "dell-m4-2" },
3232	{ .id = STAC_DELL_M4_3, .name = "dell-m4-3" },
3233	{ .id = STAC_HP_M4, .name = "hp-m4" },
3234	{ .id = STAC_HP_DV4, .name = "hp-dv4" },
3235	{ .id = STAC_HP_DV5, .name = "hp-dv5" },
3236	{ .id = STAC_HP_HDX, .name = "hp-hdx" },
3237	{ .id = STAC_HP_DV4, .name = "hp-dv4-1222nr" },
3238	{}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3239};
3240
3241static const struct snd_pci_quirk stac92hd71bxx_fixup_tbl[] = {
3242	/* SigmaTel reference board */
3243	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
3244		      "DFI LanParty", STAC_92HD71BXX_REF),
3245	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
3246		      "DFI LanParty", STAC_92HD71BXX_REF),
 
 
3247	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x1720,
3248			  "HP", STAC_HP_DV5),
3249	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3080,
3250		      "HP", STAC_HP_DV5),
3251	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x30f0,
3252		      "HP dv4-7", STAC_HP_DV4),
3253	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3600,
3254		      "HP dv4-7", STAC_HP_DV5),
3255	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3610,
3256		      "HP HDX", STAC_HP_HDX),  /* HDX18 */
3257	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361a,
3258		      "HP mini 1000", STAC_HP_M4),
3259	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361b,
3260		      "HP HDX", STAC_HP_HDX),  /* HDX16 */
3261	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3620,
3262		      "HP dv6", STAC_HP_DV5),
3263	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3061,
3264		      "HP dv6", STAC_HP_DV5), /* HP dv6-1110ax */
3265	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x363e,
3266		      "HP DV6", STAC_HP_DV5),
3267	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x7010,
3268		      "HP", STAC_HP_DV5),
3269	SND_PCI_QUIRK_VENDOR(PCI_VENDOR_ID_HP, "HP", STAC_92HD71BXX_HP),
3270	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0233,
3271				"unknown Dell", STAC_DELL_M4_1),
3272	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0234,
3273				"unknown Dell", STAC_DELL_M4_1),
3274	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0250,
3275				"unknown Dell", STAC_DELL_M4_1),
3276	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024f,
3277				"unknown Dell", STAC_DELL_M4_1),
3278	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024d,
3279				"unknown Dell", STAC_DELL_M4_1),
3280	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0251,
3281				"unknown Dell", STAC_DELL_M4_1),
3282	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0277,
3283				"unknown Dell", STAC_DELL_M4_1),
3284	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0263,
3285				"unknown Dell", STAC_DELL_M4_2),
3286	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0265,
3287				"unknown Dell", STAC_DELL_M4_2),
3288	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0262,
3289				"unknown Dell", STAC_DELL_M4_2),
3290	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0264,
3291				"unknown Dell", STAC_DELL_M4_2),
3292	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02aa,
3293				"unknown Dell", STAC_DELL_M4_3),
3294	{} /* terminator */
3295};
3296
3297static const struct hda_pintbl ref922x_pin_configs[] = {
3298	{ 0x0a, 0x01014010 },
3299	{ 0x0b, 0x01016011 },
3300	{ 0x0c, 0x01012012 },
3301	{ 0x0d, 0x0221401f },
3302	{ 0x0e, 0x01813122 },
3303	{ 0x0f, 0x01011014 },
3304	{ 0x10, 0x01441030 },
3305	{ 0x11, 0x01c41030 },
3306	{ 0x15, 0x40000100 },
3307	{ 0x1b, 0x40000100 },
3308	{}
3309};
3310
3311/*
3312    STAC 922X pin configs for
3313    102801A7
3314    102801AB
3315    102801A9
3316    102801D1
3317    102801D2
3318*/
3319static const struct hda_pintbl dell_922x_d81_pin_configs[] = {
3320	{ 0x0a, 0x02214030 },
3321	{ 0x0b, 0x01a19021 },
3322	{ 0x0c, 0x01111012 },
3323	{ 0x0d, 0x01114010 },
3324	{ 0x0e, 0x02a19020 },
3325	{ 0x0f, 0x01117011 },
3326	{ 0x10, 0x400001f0 },
3327	{ 0x11, 0x400001f1 },
3328	{ 0x15, 0x01813122 },
3329	{ 0x1b, 0x400001f2 },
3330	{}
3331};
3332
3333/*
3334    STAC 922X pin configs for
3335    102801AC
3336    102801D0
3337*/
3338static const struct hda_pintbl dell_922x_d82_pin_configs[] = {
3339	{ 0x0a, 0x02214030 },
3340	{ 0x0b, 0x01a19021 },
3341	{ 0x0c, 0x01111012 },
3342	{ 0x0d, 0x01114010 },
3343	{ 0x0e, 0x02a19020 },
3344	{ 0x0f, 0x01117011 },
3345	{ 0x10, 0x01451140 },
3346	{ 0x11, 0x400001f0 },
3347	{ 0x15, 0x01813122 },
3348	{ 0x1b, 0x400001f1 },
3349	{}
3350};
3351
3352/*
3353    STAC 922X pin configs for
3354    102801BF
3355*/
3356static const struct hda_pintbl dell_922x_m81_pin_configs[] = {
3357	{ 0x0a, 0x0321101f },
3358	{ 0x0b, 0x01112024 },
3359	{ 0x0c, 0x01111222 },
3360	{ 0x0d, 0x91174220 },
3361	{ 0x0e, 0x03a11050 },
3362	{ 0x0f, 0x01116221 },
3363	{ 0x10, 0x90a70330 },
3364	{ 0x11, 0x01452340 },
3365	{ 0x15, 0x40C003f1 },
3366	{ 0x1b, 0x405003f0 },
3367	{}
3368};
3369
3370/*
3371    STAC 9221 A1 pin configs for
3372    102801D7 (Dell XPS M1210)
3373*/
3374static const struct hda_pintbl dell_922x_m82_pin_configs[] = {
3375	{ 0x0a, 0x02211211 },
3376	{ 0x0b, 0x408103ff },
3377	{ 0x0c, 0x02a1123e },
3378	{ 0x0d, 0x90100310 },
3379	{ 0x0e, 0x408003f1 },
3380	{ 0x0f, 0x0221121f },
3381	{ 0x10, 0x03451340 },
3382	{ 0x11, 0x40c003f2 },
3383	{ 0x15, 0x508003f3 },
3384	{ 0x1b, 0x405003f4 },
3385	{}
3386};
3387
3388static const struct hda_pintbl d945gtp3_pin_configs[] = {
3389	{ 0x0a, 0x0221401f },
3390	{ 0x0b, 0x01a19022 },
3391	{ 0x0c, 0x01813021 },
3392	{ 0x0d, 0x01014010 },
3393	{ 0x0e, 0x40000100 },
3394	{ 0x0f, 0x40000100 },
3395	{ 0x10, 0x40000100 },
3396	{ 0x11, 0x40000100 },
3397	{ 0x15, 0x02a19120 },
3398	{ 0x1b, 0x40000100 },
3399	{}
3400};
3401
3402static const struct hda_pintbl d945gtp5_pin_configs[] = {
3403	{ 0x0a, 0x0221401f },
3404	{ 0x0b, 0x01011012 },
3405	{ 0x0c, 0x01813024 },
3406	{ 0x0d, 0x01014010 },
3407	{ 0x0e, 0x01a19021 },
3408	{ 0x0f, 0x01016011 },
3409	{ 0x10, 0x01452130 },
3410	{ 0x11, 0x40000100 },
3411	{ 0x15, 0x02a19320 },
3412	{ 0x1b, 0x40000100 },
3413	{}
3414};
3415
3416static const struct hda_pintbl intel_mac_v1_pin_configs[] = {
3417	{ 0x0a, 0x0121e21f },
3418	{ 0x0b, 0x400000ff },
3419	{ 0x0c, 0x9017e110 },
3420	{ 0x0d, 0x400000fd },
3421	{ 0x0e, 0x400000fe },
3422	{ 0x0f, 0x0181e020 },
3423	{ 0x10, 0x1145e030 },
3424	{ 0x11, 0x11c5e240 },
3425	{ 0x15, 0x400000fc },
3426	{ 0x1b, 0x400000fb },
3427	{}
3428};
3429
3430static const struct hda_pintbl intel_mac_v2_pin_configs[] = {
3431	{ 0x0a, 0x0121e21f },
3432	{ 0x0b, 0x90a7012e },
3433	{ 0x0c, 0x9017e110 },
3434	{ 0x0d, 0x400000fd },
3435	{ 0x0e, 0x400000fe },
3436	{ 0x0f, 0x0181e020 },
3437	{ 0x10, 0x1145e230 },
3438	{ 0x11, 0x500000fa },
3439	{ 0x15, 0x400000fc },
3440	{ 0x1b, 0x400000fb },
3441	{}
3442};
3443
3444static const struct hda_pintbl intel_mac_v3_pin_configs[] = {
3445	{ 0x0a, 0x0121e21f },
3446	{ 0x0b, 0x90a7012e },
3447	{ 0x0c, 0x9017e110 },
3448	{ 0x0d, 0x400000fd },
3449	{ 0x0e, 0x400000fe },
3450	{ 0x0f, 0x0181e020 },
3451	{ 0x10, 0x1145e230 },
3452	{ 0x11, 0x11c5e240 },
3453	{ 0x15, 0x400000fc },
3454	{ 0x1b, 0x400000fb },
3455	{}
3456};
3457
3458static const struct hda_pintbl intel_mac_v4_pin_configs[] = {
3459	{ 0x0a, 0x0321e21f },
3460	{ 0x0b, 0x03a1e02e },
3461	{ 0x0c, 0x9017e110 },
3462	{ 0x0d, 0x9017e11f },
3463	{ 0x0e, 0x400000fe },
3464	{ 0x0f, 0x0381e020 },
3465	{ 0x10, 0x1345e230 },
3466	{ 0x11, 0x13c5e240 },
3467	{ 0x15, 0x400000fc },
3468	{ 0x1b, 0x400000fb },
3469	{}
3470};
3471
3472static const struct hda_pintbl intel_mac_v5_pin_configs[] = {
3473	{ 0x0a, 0x0321e21f },
3474	{ 0x0b, 0x03a1e02e },
3475	{ 0x0c, 0x9017e110 },
3476	{ 0x0d, 0x9017e11f },
3477	{ 0x0e, 0x400000fe },
3478	{ 0x0f, 0x0381e020 },
3479	{ 0x10, 0x1345e230 },
3480	{ 0x11, 0x13c5e240 },
3481	{ 0x15, 0x400000fc },
3482	{ 0x1b, 0x400000fb },
3483	{}
3484};
3485
3486static const struct hda_pintbl ecs202_pin_configs[] = {
3487	{ 0x0a, 0x0221401f },
3488	{ 0x0b, 0x02a19020 },
3489	{ 0x0c, 0x01a19020 },
3490	{ 0x0d, 0x01114010 },
3491	{ 0x0e, 0x408000f0 },
3492	{ 0x0f, 0x01813022 },
3493	{ 0x10, 0x074510a0 },
3494	{ 0x11, 0x40c400f1 },
3495	{ 0x15, 0x9037012e },
3496	{ 0x1b, 0x40e000f2 },
3497	{}
3498};
3499
3500/* codec SSIDs for Intel Mac sharing the same PCI SSID 8384:7680 */
3501static const struct snd_pci_quirk stac922x_intel_mac_fixup_tbl[] = {
3502	SND_PCI_QUIRK(0x0000, 0x0100, "Mac Mini", STAC_INTEL_MAC_V3),
3503	SND_PCI_QUIRK(0x106b, 0x0800, "Mac", STAC_INTEL_MAC_V1),
3504	SND_PCI_QUIRK(0x106b, 0x0600, "Mac", STAC_INTEL_MAC_V2),
3505	SND_PCI_QUIRK(0x106b, 0x0700, "Mac", STAC_INTEL_MAC_V2),
3506	SND_PCI_QUIRK(0x106b, 0x0e00, "Mac", STAC_INTEL_MAC_V3),
3507	SND_PCI_QUIRK(0x106b, 0x0f00, "Mac", STAC_INTEL_MAC_V3),
3508	SND_PCI_QUIRK(0x106b, 0x1600, "Mac", STAC_INTEL_MAC_V3),
3509	SND_PCI_QUIRK(0x106b, 0x1700, "Mac", STAC_INTEL_MAC_V3),
3510	SND_PCI_QUIRK(0x106b, 0x0200, "Mac", STAC_INTEL_MAC_V3),
3511	SND_PCI_QUIRK(0x106b, 0x1e00, "Mac", STAC_INTEL_MAC_V3),
3512	SND_PCI_QUIRK(0x106b, 0x1a00, "Mac", STAC_INTEL_MAC_V4),
3513	SND_PCI_QUIRK(0x106b, 0x0a00, "Mac", STAC_INTEL_MAC_V5),
3514	SND_PCI_QUIRK(0x106b, 0x2200, "Mac", STAC_INTEL_MAC_V5),
3515	{}
3516};
3517
3518static const struct hda_fixup stac922x_fixups[];
3519
3520/* remap the fixup from codec SSID and apply it */
3521static void stac922x_fixup_intel_mac_auto(struct hda_codec *codec,
3522					  const struct hda_fixup *fix,
3523					  int action)
3524{
3525	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3526		return;
3527
3528	codec->fixup_id = HDA_FIXUP_ID_NOT_SET;
3529	snd_hda_pick_fixup(codec, NULL, stac922x_intel_mac_fixup_tbl,
3530			   stac922x_fixups);
3531	if (codec->fixup_id != HDA_FIXUP_ID_NOT_SET)
3532		snd_hda_apply_fixup(codec, action);
3533}
3534
3535static void stac922x_fixup_intel_mac_gpio(struct hda_codec *codec,
3536					  const struct hda_fixup *fix,
3537					  int action)
3538{
3539	struct sigmatel_spec *spec = codec->spec;
3540
3541	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
3542		spec->gpio_mask = spec->gpio_dir = 0x03;
3543		spec->gpio_data = 0x03;
3544	}
3545}
3546
3547static const struct hda_fixup stac922x_fixups[] = {
3548	[STAC_D945_REF] = {
3549		.type = HDA_FIXUP_PINS,
3550		.v.pins = ref922x_pin_configs,
3551	},
3552	[STAC_D945GTP3] = {
3553		.type = HDA_FIXUP_PINS,
3554		.v.pins = d945gtp3_pin_configs,
3555	},
3556	[STAC_D945GTP5] = {
3557		.type = HDA_FIXUP_PINS,
3558		.v.pins = d945gtp5_pin_configs,
3559	},
3560	[STAC_INTEL_MAC_AUTO] = {
3561		.type = HDA_FIXUP_FUNC,
3562		.v.func = stac922x_fixup_intel_mac_auto,
3563	},
3564	[STAC_INTEL_MAC_V1] = {
3565		.type = HDA_FIXUP_PINS,
3566		.v.pins = intel_mac_v1_pin_configs,
3567		.chained = true,
3568		.chain_id = STAC_922X_INTEL_MAC_GPIO,
3569	},
3570	[STAC_INTEL_MAC_V2] = {
3571		.type = HDA_FIXUP_PINS,
3572		.v.pins = intel_mac_v2_pin_configs,
3573		.chained = true,
3574		.chain_id = STAC_922X_INTEL_MAC_GPIO,
3575	},
3576	[STAC_INTEL_MAC_V3] = {
3577		.type = HDA_FIXUP_PINS,
3578		.v.pins = intel_mac_v3_pin_configs,
3579		.chained = true,
3580		.chain_id = STAC_922X_INTEL_MAC_GPIO,
3581	},
3582	[STAC_INTEL_MAC_V4] = {
3583		.type = HDA_FIXUP_PINS,
3584		.v.pins = intel_mac_v4_pin_configs,
3585		.chained = true,
3586		.chain_id = STAC_922X_INTEL_MAC_GPIO,
3587	},
3588	[STAC_INTEL_MAC_V5] = {
3589		.type = HDA_FIXUP_PINS,
3590		.v.pins = intel_mac_v5_pin_configs,
3591		.chained = true,
3592		.chain_id = STAC_922X_INTEL_MAC_GPIO,
3593	},
3594	[STAC_922X_INTEL_MAC_GPIO] = {
3595		.type = HDA_FIXUP_FUNC,
3596		.v.func = stac922x_fixup_intel_mac_gpio,
3597	},
3598	[STAC_ECS_202] = {
3599		.type = HDA_FIXUP_PINS,
3600		.v.pins = ecs202_pin_configs,
3601	},
3602	[STAC_922X_DELL_D81] = {
3603		.type = HDA_FIXUP_PINS,
3604		.v.pins = dell_922x_d81_pin_configs,
3605	},
3606	[STAC_922X_DELL_D82] = {
3607		.type = HDA_FIXUP_PINS,
3608		.v.pins = dell_922x_d82_pin_configs,
3609	},
3610	[STAC_922X_DELL_M81] = {
3611		.type = HDA_FIXUP_PINS,
3612		.v.pins = dell_922x_m81_pin_configs,
3613	},
3614	[STAC_922X_DELL_M82] = {
3615		.type = HDA_FIXUP_PINS,
3616		.v.pins = dell_922x_m82_pin_configs,
3617	},
3618};
3619
3620static const struct hda_model_fixup stac922x_models[] = {
3621	{ .id = STAC_D945_REF, .name = "ref" },
3622	{ .id = STAC_D945GTP5, .name = "5stack" },
3623	{ .id = STAC_D945GTP3, .name = "3stack" },
3624	{ .id = STAC_INTEL_MAC_V1, .name = "intel-mac-v1" },
3625	{ .id = STAC_INTEL_MAC_V2, .name = "intel-mac-v2" },
3626	{ .id = STAC_INTEL_MAC_V3, .name = "intel-mac-v3" },
3627	{ .id = STAC_INTEL_MAC_V4, .name = "intel-mac-v4" },
3628	{ .id = STAC_INTEL_MAC_V5, .name = "intel-mac-v5" },
3629	{ .id = STAC_INTEL_MAC_AUTO, .name = "intel-mac-auto" },
3630	{ .id = STAC_ECS_202, .name = "ecs202" },
3631	{ .id = STAC_922X_DELL_D81, .name = "dell-d81" },
3632	{ .id = STAC_922X_DELL_D82, .name = "dell-d82" },
3633	{ .id = STAC_922X_DELL_M81, .name = "dell-m81" },
3634	{ .id = STAC_922X_DELL_M82, .name = "dell-m82" },
3635	/* for backward compatibility */
3636	{ .id = STAC_INTEL_MAC_V3, .name = "macmini" },
3637	{ .id = STAC_INTEL_MAC_V5, .name = "macbook" },
3638	{ .id = STAC_INTEL_MAC_V3, .name = "macbook-pro-v1" },
3639	{ .id = STAC_INTEL_MAC_V3, .name = "macbook-pro" },
3640	{ .id = STAC_INTEL_MAC_V2, .name = "imac-intel" },
3641	{ .id = STAC_INTEL_MAC_V3, .name = "imac-intel-20" },
3642	{}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
3643};
3644
3645static const struct snd_pci_quirk stac922x_fixup_tbl[] = {
3646	/* SigmaTel reference board */
3647	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
3648		      "DFI LanParty", STAC_D945_REF),
3649	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
3650		      "DFI LanParty", STAC_D945_REF),
3651	/* Intel 945G based systems */
3652	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0101,
3653		      "Intel D945G", STAC_D945GTP3),
3654	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0202,
3655		      "Intel D945G", STAC_D945GTP3),
3656	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0606,
3657		      "Intel D945G", STAC_D945GTP3),
3658	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0601,
3659		      "Intel D945G", STAC_D945GTP3),
3660	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0111,
3661		      "Intel D945G", STAC_D945GTP3),
3662	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1115,
3663		      "Intel D945G", STAC_D945GTP3),
3664	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1116,
3665		      "Intel D945G", STAC_D945GTP3),
3666	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1117,
3667		      "Intel D945G", STAC_D945GTP3),
3668	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1118,
3669		      "Intel D945G", STAC_D945GTP3),
3670	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1119,
3671		      "Intel D945G", STAC_D945GTP3),
3672	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x8826,
3673		      "Intel D945G", STAC_D945GTP3),
3674	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5049,
3675		      "Intel D945G", STAC_D945GTP3),
3676	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5055,
3677		      "Intel D945G", STAC_D945GTP3),
3678	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5048,
3679		      "Intel D945G", STAC_D945GTP3),
3680	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0110,
3681		      "Intel D945G", STAC_D945GTP3),
3682	/* Intel D945G 5-stack systems */
3683	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0404,
3684		      "Intel D945G", STAC_D945GTP5),
3685	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0303,
3686		      "Intel D945G", STAC_D945GTP5),
3687	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0013,
3688		      "Intel D945G", STAC_D945GTP5),
3689	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0417,
3690		      "Intel D945G", STAC_D945GTP5),
3691	/* Intel 945P based systems */
3692	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0b0b,
3693		      "Intel D945P", STAC_D945GTP3),
3694	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0112,
3695		      "Intel D945P", STAC_D945GTP3),
3696	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0d0d,
3697		      "Intel D945P", STAC_D945GTP3),
3698	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0909,
3699		      "Intel D945P", STAC_D945GTP3),
3700	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0505,
3701		      "Intel D945P", STAC_D945GTP3),
3702	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0707,
3703		      "Intel D945P", STAC_D945GTP5),
3704	/* other intel */
3705	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0204,
3706		      "Intel D945", STAC_D945_REF),
3707	/* other systems  */
3708
3709	/* Apple Intel Mac (Mac Mini, MacBook, MacBook Pro...) */
3710	SND_PCI_QUIRK(0x8384, 0x7680, "Mac", STAC_INTEL_MAC_AUTO),
3711
3712	/* Dell systems  */
3713	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a7,
3714		      "unknown Dell", STAC_922X_DELL_D81),
3715	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a9,
3716		      "unknown Dell", STAC_922X_DELL_D81),
3717	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ab,
3718		      "unknown Dell", STAC_922X_DELL_D81),
3719	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ac,
3720		      "unknown Dell", STAC_922X_DELL_D82),
3721	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bf,
3722		      "unknown Dell", STAC_922X_DELL_M81),
3723	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d0,
3724		      "unknown Dell", STAC_922X_DELL_D82),
3725	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d1,
3726		      "unknown Dell", STAC_922X_DELL_D81),
3727	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d2,
3728		      "unknown Dell", STAC_922X_DELL_D81),
3729	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d7,
3730		      "Dell XPS M1210", STAC_922X_DELL_M82),
3731	/* ECS/PC Chips boards */
3732	SND_PCI_QUIRK_MASK(0x1019, 0xf000, 0x2000,
3733		      "ECS/PC chips", STAC_ECS_202),
3734	{} /* terminator */
3735};
3736
3737static const struct hda_pintbl ref927x_pin_configs[] = {
3738	{ 0x0a, 0x02214020 },
3739	{ 0x0b, 0x02a19080 },
3740	{ 0x0c, 0x0181304e },
3741	{ 0x0d, 0x01014010 },
3742	{ 0x0e, 0x01a19040 },
3743	{ 0x0f, 0x01011012 },
3744	{ 0x10, 0x01016011 },
3745	{ 0x11, 0x0101201f },
3746	{ 0x12, 0x183301f0 },
3747	{ 0x13, 0x18a001f0 },
3748	{ 0x14, 0x18a001f0 },
3749	{ 0x21, 0x01442070 },
3750	{ 0x22, 0x01c42190 },
3751	{ 0x23, 0x40000100 },
3752	{}
3753};
3754
3755static const struct hda_pintbl d965_3st_pin_configs[] = {
3756	{ 0x0a, 0x0221401f },
3757	{ 0x0b, 0x02a19120 },
3758	{ 0x0c, 0x40000100 },
3759	{ 0x0d, 0x01014011 },
3760	{ 0x0e, 0x01a19021 },
3761	{ 0x0f, 0x01813024 },
3762	{ 0x10, 0x40000100 },
3763	{ 0x11, 0x40000100 },
3764	{ 0x12, 0x40000100 },
3765	{ 0x13, 0x40000100 },
3766	{ 0x14, 0x40000100 },
3767	{ 0x21, 0x40000100 },
3768	{ 0x22, 0x40000100 },
3769	{ 0x23, 0x40000100 },
3770	{}
3771};
3772
3773static const struct hda_pintbl d965_5st_pin_configs[] = {
3774	{ 0x0a, 0x02214020 },
3775	{ 0x0b, 0x02a19080 },
3776	{ 0x0c, 0x0181304e },
3777	{ 0x0d, 0x01014010 },
3778	{ 0x0e, 0x01a19040 },
3779	{ 0x0f, 0x01011012 },
3780	{ 0x10, 0x01016011 },
3781	{ 0x11, 0x40000100 },
3782	{ 0x12, 0x40000100 },
3783	{ 0x13, 0x40000100 },
3784	{ 0x14, 0x40000100 },
3785	{ 0x21, 0x01442070 },
3786	{ 0x22, 0x40000100 },
3787	{ 0x23, 0x40000100 },
3788	{}
3789};
3790
3791static const struct hda_pintbl d965_5st_no_fp_pin_configs[] = {
3792	{ 0x0a, 0x40000100 },
3793	{ 0x0b, 0x40000100 },
3794	{ 0x0c, 0x0181304e },
3795	{ 0x0d, 0x01014010 },
3796	{ 0x0e, 0x01a19040 },
3797	{ 0x0f, 0x01011012 },
3798	{ 0x10, 0x01016011 },
3799	{ 0x11, 0x40000100 },
3800	{ 0x12, 0x40000100 },
3801	{ 0x13, 0x40000100 },
3802	{ 0x14, 0x40000100 },
3803	{ 0x21, 0x01442070 },
3804	{ 0x22, 0x40000100 },
3805	{ 0x23, 0x40000100 },
3806	{}
3807};
3808
3809static const struct hda_pintbl dell_3st_pin_configs[] = {
3810	{ 0x0a, 0x02211230 },
3811	{ 0x0b, 0x02a11220 },
3812	{ 0x0c, 0x01a19040 },
3813	{ 0x0d, 0x01114210 },
3814	{ 0x0e, 0x01111212 },
3815	{ 0x0f, 0x01116211 },
3816	{ 0x10, 0x01813050 },
3817	{ 0x11, 0x01112214 },
3818	{ 0x12, 0x403003fa },
3819	{ 0x13, 0x90a60040 },
3820	{ 0x14, 0x90a60040 },
3821	{ 0x21, 0x404003fb },
3822	{ 0x22, 0x40c003fc },
3823	{ 0x23, 0x40000100 },
3824	{}
3825};
3826
3827static void stac927x_fixup_ref_no_jd(struct hda_codec *codec,
3828				     const struct hda_fixup *fix, int action)
3829{
3830	/* no jack detecion for ref-no-jd model */
3831	if (action == HDA_FIXUP_ACT_PRE_PROBE)
3832		codec->no_jack_detect = 1;
3833}
3834
3835static void stac927x_fixup_ref(struct hda_codec *codec,
3836			       const struct hda_fixup *fix, int action)
3837{
3838	struct sigmatel_spec *spec = codec->spec;
3839
3840	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
3841		snd_hda_apply_pincfgs(codec, ref927x_pin_configs);
3842		spec->eapd_mask = spec->gpio_mask = 0;
3843		spec->gpio_dir = spec->gpio_data = 0;
3844	}
3845}
3846
3847static void stac927x_fixup_dell_dmic(struct hda_codec *codec,
3848				     const struct hda_fixup *fix, int action)
3849{
3850	struct sigmatel_spec *spec = codec->spec;
3851
3852	if (action != HDA_FIXUP_ACT_PRE_PROBE)
3853		return;
3854
3855	if (codec->core.subsystem_id != 0x1028022f) {
3856		/* GPIO2 High = Enable EAPD */
3857		spec->eapd_mask = spec->gpio_mask = 0x04;
3858		spec->gpio_dir = spec->gpio_data = 0x04;
3859	}
3860
3861	snd_hda_add_verbs(codec, dell_3st_core_init);
3862	spec->volknob_init = 1;
3863}
3864
3865static void stac927x_fixup_volknob(struct hda_codec *codec,
3866				   const struct hda_fixup *fix, int action)
3867{
3868	struct sigmatel_spec *spec = codec->spec;
3869
3870	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
3871		snd_hda_add_verbs(codec, stac927x_volknob_core_init);
3872		spec->volknob_init = 1;
3873	}
3874}
3875
3876static const struct hda_fixup stac927x_fixups[] = {
3877	[STAC_D965_REF_NO_JD] = {
3878		.type = HDA_FIXUP_FUNC,
3879		.v.func = stac927x_fixup_ref_no_jd,
3880		.chained = true,
3881		.chain_id = STAC_D965_REF,
3882	},
3883	[STAC_D965_REF] = {
3884		.type = HDA_FIXUP_FUNC,
3885		.v.func = stac927x_fixup_ref,
3886	},
3887	[STAC_D965_3ST] = {
3888		.type = HDA_FIXUP_PINS,
3889		.v.pins = d965_3st_pin_configs,
3890		.chained = true,
3891		.chain_id = STAC_D965_VERBS,
3892	},
3893	[STAC_D965_5ST] = {
3894		.type = HDA_FIXUP_PINS,
3895		.v.pins = d965_5st_pin_configs,
3896		.chained = true,
3897		.chain_id = STAC_D965_VERBS,
3898	},
3899	[STAC_D965_VERBS] = {
3900		.type = HDA_FIXUP_VERBS,
3901		.v.verbs = d965_core_init,
3902	},
3903	[STAC_D965_5ST_NO_FP] = {
3904		.type = HDA_FIXUP_PINS,
3905		.v.pins = d965_5st_no_fp_pin_configs,
3906	},
3907	[STAC_NEMO_DEFAULT] = {
3908		.type = HDA_FIXUP_PINS,
3909		.v.pins = nemo_pin_configs,
3910	},
3911	[STAC_DELL_3ST] = {
3912		.type = HDA_FIXUP_PINS,
3913		.v.pins = dell_3st_pin_configs,
3914		.chained = true,
3915		.chain_id = STAC_927X_DELL_DMIC,
3916	},
3917	[STAC_DELL_BIOS] = {
3918		.type = HDA_FIXUP_PINS,
3919		.v.pins = (const struct hda_pintbl[]) {
3920			/* correct the front output jack as a hp out */
3921			{ 0x0f, 0x0221101f },
3922			/* correct the front input jack as a mic */
3923			{ 0x0e, 0x02a79130 },
3924			{}
3925		},
3926		.chained = true,
3927		.chain_id = STAC_927X_DELL_DMIC,
3928	},
3929	[STAC_DELL_BIOS_AMIC] = {
3930		.type = HDA_FIXUP_PINS,
3931		.v.pins = (const struct hda_pintbl[]) {
3932			/* configure the analog microphone on some laptops */
3933			{ 0x0c, 0x90a79130 },
3934			{}
3935		},
3936		.chained = true,
3937		.chain_id = STAC_DELL_BIOS,
3938	},
3939	[STAC_DELL_BIOS_SPDIF] = {
3940		.type = HDA_FIXUP_PINS,
3941		.v.pins = (const struct hda_pintbl[]) {
3942			/* correct the device field to SPDIF out */
3943			{ 0x21, 0x01442070 },
3944			{}
3945		},
3946		.chained = true,
3947		.chain_id = STAC_DELL_BIOS,
3948	},
3949	[STAC_927X_DELL_DMIC] = {
3950		.type = HDA_FIXUP_FUNC,
3951		.v.func = stac927x_fixup_dell_dmic,
3952	},
3953	[STAC_927X_VOLKNOB] = {
3954		.type = HDA_FIXUP_FUNC,
3955		.v.func = stac927x_fixup_volknob,
3956	},
3957};
3958
3959static const struct hda_model_fixup stac927x_models[] = {
3960	{ .id = STAC_D965_REF_NO_JD, .name = "ref-no-jd" },
3961	{ .id = STAC_D965_REF, .name = "ref" },
3962	{ .id = STAC_D965_3ST, .name = "3stack" },
3963	{ .id = STAC_D965_5ST, .name = "5stack" },
3964	{ .id = STAC_D965_5ST_NO_FP, .name = "5stack-no-fp" },
3965	{ .id = STAC_DELL_3ST, .name = "dell-3stack" },
3966	{ .id = STAC_DELL_BIOS, .name = "dell-bios" },
3967	{ .id = STAC_NEMO_DEFAULT, .name = "nemo-default" },
3968	{ .id = STAC_DELL_BIOS_AMIC, .name = "dell-bios-amic" },
3969	{ .id = STAC_927X_VOLKNOB, .name = "volknob" },
3970	{}
3971};
3972
3973static const struct snd_pci_quirk stac927x_fixup_tbl[] = {
3974	/* SigmaTel reference board */
3975	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
3976		      "DFI LanParty", STAC_D965_REF),
3977	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
3978		      "DFI LanParty", STAC_D965_REF),
3979	 /* Intel 946 based systems */
3980	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x3d01, "Intel D946", STAC_D965_3ST),
3981	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xa301, "Intel D946", STAC_D965_3ST),
3982	/* 965 based 3 stack systems */
3983	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2100,
3984			   "Intel D965", STAC_D965_3ST),
3985	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2000,
3986			   "Intel D965", STAC_D965_3ST),
3987	/* Dell 3 stack systems */
3988	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01dd, "Dell Dimension E520", STAC_DELL_3ST),
3989	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01ed, "Dell     ", STAC_DELL_3ST),
3990	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f4, "Dell     ", STAC_DELL_3ST),
3991	/* Dell 3 stack systems with verb table in BIOS */
3992	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f3, "Dell Inspiron 1420", STAC_DELL_BIOS),
3993	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f7, "Dell XPS M1730", STAC_DELL_BIOS),
3994	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0227, "Dell Vostro 1400  ", STAC_DELL_BIOS),
3995	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022e, "Dell     ", STAC_DELL_BIOS_SPDIF),
3996	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022f, "Dell Inspiron 1525", STAC_DELL_BIOS),
3997	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0242, "Dell     ", STAC_DELL_BIOS),
3998	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0243, "Dell     ", STAC_DELL_BIOS),
3999	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x02ff, "Dell     ", STAC_DELL_BIOS),
4000	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0209, "Dell XPS 1330", STAC_DELL_BIOS_SPDIF),
4001	/* 965 based 5 stack systems */
4002	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2300,
4003			   "Intel D965", STAC_D965_5ST),
4004	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2500,
4005			   "Intel D965", STAC_D965_5ST),
4006	/* Nemo */
4007	SND_PCI_QUIRK(0x1888, 0x1000, "AmigaOne X1000", STAC_NEMO_DEFAULT),
4008	/* volume-knob fixes */
4009	SND_PCI_QUIRK_VENDOR(0x10cf, "FSC", STAC_927X_VOLKNOB),
4010	{} /* terminator */
4011};
4012
4013static const struct hda_pintbl ref9205_pin_configs[] = {
4014	{ 0x0a, 0x40000100 },
4015	{ 0x0b, 0x40000100 },
4016	{ 0x0c, 0x01016011 },
4017	{ 0x0d, 0x01014010 },
4018	{ 0x0e, 0x01813122 },
4019	{ 0x0f, 0x01a19021 },
4020	{ 0x14, 0x01019020 },
4021	{ 0x16, 0x40000100 },
4022	{ 0x17, 0x90a000f0 },
4023	{ 0x18, 0x90a000f0 },
4024	{ 0x21, 0x01441030 },
4025	{ 0x22, 0x01c41030 },
4026	{}
4027};
4028
4029/*
4030    STAC 9205 pin configs for
4031    102801F1
4032    102801F2
4033    102801FC
4034    102801FD
4035    10280204
4036    1028021F
4037    10280228 (Dell Vostro 1500)
4038    10280229 (Dell Vostro 1700)
4039*/
4040static const struct hda_pintbl dell_9205_m42_pin_configs[] = {
4041	{ 0x0a, 0x0321101F },
4042	{ 0x0b, 0x03A11020 },
4043	{ 0x0c, 0x400003FA },
4044	{ 0x0d, 0x90170310 },
4045	{ 0x0e, 0x400003FB },
4046	{ 0x0f, 0x400003FC },
4047	{ 0x14, 0x400003FD },
4048	{ 0x16, 0x40F000F9 },
4049	{ 0x17, 0x90A60330 },
4050	{ 0x18, 0x400003FF },
4051	{ 0x21, 0x0144131F },
4052	{ 0x22, 0x40C003FE },
4053	{}
4054};
4055
4056/*
4057    STAC 9205 pin configs for
4058    102801F9
4059    102801FA
4060    102801FE
4061    102801FF (Dell Precision M4300)
4062    10280206
4063    10280200
4064    10280201
4065*/
4066static const struct hda_pintbl dell_9205_m43_pin_configs[] = {
4067	{ 0x0a, 0x0321101f },
4068	{ 0x0b, 0x03a11020 },
4069	{ 0x0c, 0x90a70330 },
4070	{ 0x0d, 0x90170310 },
4071	{ 0x0e, 0x400000fe },
4072	{ 0x0f, 0x400000ff },
4073	{ 0x14, 0x400000fd },
4074	{ 0x16, 0x40f000f9 },
4075	{ 0x17, 0x400000fa },
4076	{ 0x18, 0x400000fc },
4077	{ 0x21, 0x0144131f },
4078	{ 0x22, 0x40c003f8 },
4079	/* Enable SPDIF in/out */
4080	{ 0x1f, 0x01441030 },
4081	{ 0x20, 0x1c410030 },
4082	{}
4083};
4084
4085static const struct hda_pintbl dell_9205_m44_pin_configs[] = {
4086	{ 0x0a, 0x0421101f },
4087	{ 0x0b, 0x04a11020 },
4088	{ 0x0c, 0x400003fa },
4089	{ 0x0d, 0x90170310 },
4090	{ 0x0e, 0x400003fb },
4091	{ 0x0f, 0x400003fc },
4092	{ 0x14, 0x400003fd },
4093	{ 0x16, 0x400003f9 },
4094	{ 0x17, 0x90a60330 },
4095	{ 0x18, 0x400003ff },
4096	{ 0x21, 0x01441340 },
4097	{ 0x22, 0x40c003fe },
4098	{}
4099};
4100
4101static void stac9205_fixup_ref(struct hda_codec *codec,
4102			       const struct hda_fixup *fix, int action)
4103{
4104	struct sigmatel_spec *spec = codec->spec;
4105
4106	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
4107		snd_hda_apply_pincfgs(codec, ref9205_pin_configs);
4108		/* SPDIF-In enabled */
4109		spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0;
4110	}
4111}
4112
4113static void stac9205_fixup_dell_m43(struct hda_codec *codec,
4114				    const struct hda_fixup *fix, int action)
4115{
4116	struct sigmatel_spec *spec = codec->spec;
4117	struct hda_jack_callback *jack;
4118
4119	if (action == HDA_FIXUP_ACT_PRE_PROBE) {
4120		snd_hda_apply_pincfgs(codec, dell_9205_m43_pin_configs);
4121
4122		/* Enable unsol response for GPIO4/Dock HP connection */
4123		snd_hda_codec_write_cache(codec, codec->core.afg, 0,
4124			AC_VERB_SET_GPIO_UNSOLICITED_RSP_MASK, 0x10);
4125		jack = snd_hda_jack_detect_enable_callback(codec, codec->core.afg,
4126							   stac_vref_event);
4127		if (!IS_ERR(jack))
4128			jack->private_data = 0x01;
4129
4130		spec->gpio_dir = 0x0b;
4131		spec->eapd_mask = 0x01;
4132		spec->gpio_mask = 0x1b;
4133		spec->gpio_mute = 0x10;
4134		/* GPIO0 High = EAPD, GPIO1 Low = Headphone Mute,
4135		 * GPIO3 Low = DRM
4136		 */
4137		spec->gpio_data = 0x01;
4138	}
4139}
4140
4141static void stac9205_fixup_eapd(struct hda_codec *codec,
4142				const struct hda_fixup *fix, int action)
4143{
4144	struct sigmatel_spec *spec = codec->spec;
4145
4146	if (action == HDA_FIXUP_ACT_PRE_PROBE)
4147		spec->eapd_switch = 0;
4148}
4149
4150static const struct hda_fixup stac9205_fixups[] = {
4151	[STAC_9205_REF] = {
4152		.type = HDA_FIXUP_FUNC,
4153		.v.func = stac9205_fixup_ref,
4154	},
4155	[STAC_9205_DELL_M42] = {
4156		.type = HDA_FIXUP_PINS,
4157		.v.pins = dell_9205_m42_pin_configs,
4158	},
4159	[STAC_9205_DELL_M43] = {
4160		.type = HDA_FIXUP_FUNC,
4161		.v.func = stac9205_fixup_dell_m43,
4162	},
4163	[STAC_9205_DELL_M44] = {
4164		.type = HDA_FIXUP_PINS,
4165		.v.pins = dell_9205_m44_pin_configs,
4166	},
4167	[STAC_9205_EAPD] = {
4168		.type = HDA_FIXUP_FUNC,
4169		.v.func = stac9205_fixup_eapd,
4170	},
4171	{}
4172};
4173
4174static const struct hda_model_fixup stac9205_models[] = {
4175	{ .id = STAC_9205_REF, .name = "ref" },
4176	{ .id = STAC_9205_DELL_M42, .name = "dell-m42" },
4177	{ .id = STAC_9205_DELL_M43, .name = "dell-m43" },
4178	{ .id = STAC_9205_DELL_M44, .name = "dell-m44" },
4179	{ .id = STAC_9205_EAPD, .name = "eapd" },
4180	{}
4181};
4182
4183static const struct snd_pci_quirk stac9205_fixup_tbl[] = {
4184	/* SigmaTel reference board */
4185	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
4186		      "DFI LanParty", STAC_9205_REF),
4187	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xfb30,
4188		      "SigmaTel", STAC_9205_REF),
4189	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
4190		      "DFI LanParty", STAC_9205_REF),
4191	/* Dell */
4192	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f1,
4193		      "unknown Dell", STAC_9205_DELL_M42),
4194	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f2,
4195		      "unknown Dell", STAC_9205_DELL_M42),
4196	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f8,
4197		      "Dell Precision", STAC_9205_DELL_M43),
4198	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f9,
4199		      "Dell Precision", STAC_9205_DELL_M43),
4200	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fa,
4201		      "Dell Precision", STAC_9205_DELL_M43),
4202	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fc,
4203		      "unknown Dell", STAC_9205_DELL_M42),
4204	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fd,
4205		      "unknown Dell", STAC_9205_DELL_M42),
4206	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fe,
4207		      "Dell Precision", STAC_9205_DELL_M43),
4208	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ff,
4209		      "Dell Precision M4300", STAC_9205_DELL_M43),
4210	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0204,
4211		      "unknown Dell", STAC_9205_DELL_M42),
4212	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0206,
4213		      "Dell Precision", STAC_9205_DELL_M43),
4214	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021b,
4215		      "Dell Precision", STAC_9205_DELL_M43),
4216	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021c,
4217		      "Dell Precision", STAC_9205_DELL_M43),
4218	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021f,
4219		      "Dell Inspiron", STAC_9205_DELL_M44),
4220	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0228,
4221		      "Dell Vostro 1500", STAC_9205_DELL_M42),
4222	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0229,
4223		      "Dell Vostro 1700", STAC_9205_DELL_M42),
4224	/* Gateway */
4225	SND_PCI_QUIRK(0x107b, 0x0560, "Gateway T6834c", STAC_9205_EAPD),
4226	SND_PCI_QUIRK(0x107b, 0x0565, "Gateway T1616", STAC_9205_EAPD),
4227	{} /* terminator */
4228};
4229
4230static void stac92hd95_fixup_hp_led(struct hda_codec *codec,
4231				    const struct hda_fixup *fix, int action)
4232{
 
4233	struct sigmatel_spec *spec = codec->spec;
4234
4235	if (action != HDA_FIXUP_ACT_PRE_PROBE)
4236		return;
4237
4238	if (find_mute_led_cfg(codec, spec->default_polarity))
4239		codec_dbg(codec, "mute LED gpio %d polarity %d\n",
4240				spec->gpio_led,
4241				spec->gpio_led_polarity);
4242}
4243
4244static const struct hda_fixup stac92hd95_fixups[] = {
4245	[STAC_92HD95_HP_LED] = {
4246		.type = HDA_FIXUP_FUNC,
4247		.v.func = stac92hd95_fixup_hp_led,
4248	},
4249	[STAC_92HD95_HP_BASS] = {
4250		.type = HDA_FIXUP_VERBS,
4251		.v.verbs = (const struct hda_verb[]) {
4252			{0x1a, 0x795, 0x00}, /* HPF to 100Hz */
4253			{}
4254		},
4255		.chained = true,
4256		.chain_id = STAC_92HD95_HP_LED,
4257	},
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4258};
4259
4260static const struct snd_pci_quirk stac92hd95_fixup_tbl[] = {
4261	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1911, "HP Spectre 13", STAC_92HD95_HP_BASS),
4262	{} /* terminator */
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4263};
4264
4265static const struct hda_model_fixup stac92hd95_models[] = {
4266	{ .id = STAC_92HD95_HP_LED, .name = "hp-led" },
4267	{ .id = STAC_92HD95_HP_BASS, .name = "hp-bass" },
4268	{}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4269};
4270
 
 
 
4271
4272static int stac_parse_auto_config(struct hda_codec *codec)
4273{
4274	struct sigmatel_spec *spec = codec->spec;
4275	int err;
4276	int flags = 0;
 
 
 
 
 
 
 
 
 
4277
4278	if (spec->headset_jack)
4279		flags |= HDA_PINCFG_HEADSET_MIC;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4280
4281	err = snd_hda_parse_pin_defcfg(codec, &spec->gen.autocfg, NULL, flags);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4282	if (err < 0)
4283		return err;
 
 
 
 
 
 
 
 
 
 
 
 
4284
4285	/* add hooks */
4286	spec->gen.pcm_playback_hook = stac_playback_pcm_hook;
4287	spec->gen.pcm_capture_hook = stac_capture_pcm_hook;
4288
4289	spec->gen.automute_hook = stac_update_outputs;
 
 
 
4290
4291	if (spec->gpio_led)
4292		snd_hda_gen_add_mute_led_cdev(codec, stac_vmaster_hook);
 
 
 
 
4293
4294	err = snd_hda_gen_parse_auto_config(codec, &spec->gen.autocfg);
4295	if (err < 0)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4296		return err;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4297
4298	if (spec->vref_mute_led_nid) {
4299		err = snd_hda_gen_fix_pin_power(codec, spec->vref_mute_led_nid);
 
 
 
 
4300		if (err < 0)
4301			return err;
4302	}
4303
4304	/* setup analog beep controls */
4305	if (spec->anabeep_nid > 0) {
4306		err = stac_auto_create_beep_ctls(codec,
4307						 spec->anabeep_nid);
4308		if (err < 0)
4309			return err;
4310	}
4311
4312	/* setup digital beep controls and input device */
4313#ifdef CONFIG_SND_HDA_INPUT_BEEP
4314	if (spec->gen.beep_nid) {
4315		hda_nid_t nid = spec->gen.beep_nid;
4316		unsigned int caps;
4317
4318		err = stac_auto_create_beep_ctls(codec, nid);
 
 
 
4319		if (err < 0)
4320			return err;
4321		if (codec->beep) {
4322			/* IDT/STAC codecs have linear beep tone parameter */
4323			codec->beep->linear_tone = spec->linear_tone_beep;
4324			/* keep power up while beep is enabled */
4325			codec->beep->keep_power_at_enable = 1;
4326			/* if no beep switch is available, make its own one */
4327			caps = query_amp_caps(codec, nid, HDA_OUTPUT);
4328			if (!(caps & AC_AMPCAP_MUTE)) {
4329				err = stac_beep_switch_ctl(codec);
4330				if (err < 0)
4331					return err;
4332			}
4333		}
4334	}
4335#endif
4336
4337	if (spec->aloopback_ctl &&
4338	    snd_hda_get_bool_hint(codec, "loopback") == 1) {
4339		unsigned int wr_verb =
4340			spec->aloopback_ctl->private_value >> 16;
4341		if (snd_hdac_regmap_add_vendor_verb(&codec->core, wr_verb))
4342			return -ENOMEM;
4343		if (!snd_hda_gen_add_kctl(&spec->gen, NULL, spec->aloopback_ctl))
4344			return -ENOMEM;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4345	}
4346
4347	if (spec->have_spdif_mux) {
4348		err = stac_create_spdif_mux_ctls(codec);
 
 
 
 
 
 
 
 
 
 
 
 
 
4349		if (err < 0)
4350			return err;
4351	}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4352
4353	stac_init_power_map(codec);
 
 
 
 
 
 
 
 
 
 
 
4354
4355	return 0;
4356}
4357
4358static int stac_init(struct hda_codec *codec)
 
 
4359{
4360	struct sigmatel_spec *spec = codec->spec;
 
 
4361	int i;
4362
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4363	/* override some hints */
4364	stac_store_hints(codec);
4365
4366	/* set up GPIO */
 
4367	/* turn on EAPD statically when spec->eapd_switch isn't set.
4368	 * otherwise, unsol event will turn it on/off dynamically
4369	 */
4370	if (!spec->eapd_switch)
4371		spec->gpio_data |= spec->eapd_mask;
4372	stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data);
4373
4374	snd_hda_gen_init(codec);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4375
4376	/* sync the power-map */
4377	if (spec->num_pwrs)
4378		snd_hda_codec_write(codec, codec->core.afg, 0,
4379				    AC_VERB_IDT_SET_POWER_MAP,
4380				    spec->power_map_bits);
 
 
 
 
4381
4382	/* power down inactive ADCs */
4383	if (spec->powerdown_adcs) {
4384		for (i = 0; i < spec->gen.num_all_adcs; i++) {
4385			if (spec->active_adcs & (1 << i))
4386				continue;
4387			snd_hda_codec_write(codec, spec->gen.all_adcs[i], 0,
4388					    AC_VERB_SET_POWER_STATE,
4389					    AC_PWRST_D3);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4390		}
4391	}
4392
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4393	return 0;
4394}
4395
4396#define stac_free	snd_hda_gen_free
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4397
4398#ifdef CONFIG_SND_PROC_FS
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4399static void stac92hd_proc_hook(struct snd_info_buffer *buffer,
4400			       struct hda_codec *codec, hda_nid_t nid)
4401{
4402	if (nid == codec->core.afg)
4403		snd_iprintf(buffer, "Power-Map: 0x%02x\n", 
4404			    snd_hda_codec_read(codec, nid, 0,
4405					       AC_VERB_IDT_GET_POWER_MAP, 0));
4406}
4407
4408static void analog_loop_proc_hook(struct snd_info_buffer *buffer,
4409				  struct hda_codec *codec,
4410				  unsigned int verb)
4411{
4412	snd_iprintf(buffer, "Analog Loopback: 0x%02x\n",
4413		    snd_hda_codec_read(codec, codec->core.afg, 0, verb, 0));
4414}
4415
4416/* stac92hd71bxx, stac92hd73xx */
4417static void stac92hd7x_proc_hook(struct snd_info_buffer *buffer,
4418				 struct hda_codec *codec, hda_nid_t nid)
4419{
4420	stac92hd_proc_hook(buffer, codec, nid);
4421	if (nid == codec->core.afg)
4422		analog_loop_proc_hook(buffer, codec, 0xfa0);
4423}
4424
4425static void stac9205_proc_hook(struct snd_info_buffer *buffer,
4426			       struct hda_codec *codec, hda_nid_t nid)
4427{
4428	if (nid == codec->core.afg)
4429		analog_loop_proc_hook(buffer, codec, 0xfe0);
4430}
4431
4432static void stac927x_proc_hook(struct snd_info_buffer *buffer,
4433			       struct hda_codec *codec, hda_nid_t nid)
4434{
4435	if (nid == codec->core.afg)
4436		analog_loop_proc_hook(buffer, codec, 0xfeb);
4437}
4438#else
4439#define stac92hd_proc_hook	NULL
4440#define stac92hd7x_proc_hook	NULL
4441#define stac9205_proc_hook	NULL
4442#define stac927x_proc_hook	NULL
4443#endif
4444
4445#ifdef CONFIG_PM
4446static int stac_suspend(struct hda_codec *codec)
4447{
4448	struct sigmatel_spec *spec = codec->spec;
 
 
 
 
 
 
4449
4450	snd_hda_shutup_pins(codec);
 
 
 
 
4451
4452	if (spec->eapd_mask)
4453		stac_gpio_set(codec, spec->gpio_mask,
4454				spec->gpio_dir, spec->gpio_data &
4455				~spec->eapd_mask);
 
4456
4457	return 0;
 
 
 
 
 
 
 
 
 
 
 
 
4458}
4459#else
4460#define stac_suspend		NULL
 
 
4461#endif /* CONFIG_PM */
4462
4463static const struct hda_codec_ops stac_patch_ops = {
4464	.build_controls = snd_hda_gen_build_controls,
4465	.build_pcms = snd_hda_gen_build_pcms,
4466	.init = stac_init,
4467	.free = stac_free,
4468	.unsol_event = snd_hda_jack_unsol_event,
4469#ifdef CONFIG_PM
4470	.suspend = stac_suspend,
4471#endif
4472};
4473
4474static int alloc_stac_spec(struct hda_codec *codec)
4475{
4476	struct sigmatel_spec *spec;
 
4477
4478	spec = kzalloc(sizeof(*spec), GFP_KERNEL);
4479	if (!spec)
4480		return -ENOMEM;
4481	snd_hda_gen_spec_init(&spec->gen);
4482	codec->spec = spec;
4483	codec->no_trigger_sense = 1; /* seems common with STAC/IDT codecs */
4484	spec->gen.dac_min_mute = true;
4485	codec->patch_ops = stac_patch_ops;
4486	return 0;
 
 
 
 
 
 
 
 
 
 
4487}
4488
 
 
 
 
 
 
 
 
 
 
 
 
 
4489static int patch_stac9200(struct hda_codec *codec)
4490{
4491	struct sigmatel_spec *spec;
4492	int err;
4493
4494	err = alloc_stac_spec(codec);
4495	if (err < 0)
4496		return err;
4497
4498	spec = codec->spec;
 
4499	spec->linear_tone_beep = 1;
4500	spec->gen.own_eapd_ctl = 1;
4501
4502	codec->power_filter = snd_hda_codec_eapd_power_filter;
 
 
 
 
 
 
 
 
4503
4504	snd_hda_add_verbs(codec, stac9200_eapd_init);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4505
4506	snd_hda_pick_fixup(codec, stac9200_models, stac9200_fixup_tbl,
4507			   stac9200_fixups);
4508	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
4509
4510	err = stac_parse_auto_config(codec);
4511	if (err < 0) {
4512		stac_free(codec);
4513		return err;
4514	}
4515
4516	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
 
 
 
 
 
 
4517
4518	return 0;
4519}
4520
4521static int patch_stac925x(struct hda_codec *codec)
4522{
4523	struct sigmatel_spec *spec;
4524	int err;
4525
4526	err = alloc_stac_spec(codec);
4527	if (err < 0)
4528		return err;
4529
4530	spec = codec->spec;
 
4531	spec->linear_tone_beep = 1;
4532	spec->gen.own_eapd_ctl = 1;
 
4533
4534	snd_hda_add_verbs(codec, stac925x_core_init);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4535
4536	snd_hda_pick_fixup(codec, stac925x_models, stac925x_fixup_tbl,
4537			   stac925x_fixups);
4538	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4539
4540	err = stac_parse_auto_config(codec);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4541	if (err < 0) {
4542		stac_free(codec);
4543		return err;
4544	}
4545
4546	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
4547
4548	return 0;
4549}
4550
4551static int patch_stac92hd73xx(struct hda_codec *codec)
4552{
4553	struct sigmatel_spec *spec;
4554	int err;
 
4555	int num_dacs;
4556
4557	err = alloc_stac_spec(codec);
4558	if (err < 0)
4559		return err;
4560
4561	spec = codec->spec;
4562	/* enable power_save_node only for new 92HD89xx chips, as it causes
4563	 * click noises on old 92HD73xx chips.
4564	 */
4565	if ((codec->core.vendor_id & 0xfffffff0) != 0x111d7670)
4566		codec->power_save_node = 1;
4567	spec->linear_tone_beep = 0;
4568	spec->gen.mixer_nid = 0x1d;
4569	spec->have_spdif_mux = 1;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4570
4571	num_dacs = snd_hda_get_num_conns(codec, 0x0a) - 1;
4572	if (num_dacs < 3 || num_dacs > 5) {
4573		codec_warn(codec,
4574			   "Could not determine number of channels defaulting to DAC count\n");
4575		num_dacs = 5;
4576	}
4577
4578	switch (num_dacs) {
4579	case 0x3: /* 6 Channel */
4580		spec->aloopback_ctl = &stac92hd73xx_6ch_loopback;
4581		break;
4582	case 0x4: /* 8 Channel */
4583		spec->aloopback_ctl = &stac92hd73xx_8ch_loopback;
4584		break;
4585	case 0x5: /* 10 Channel */
4586		spec->aloopback_ctl = &stac92hd73xx_10ch_loopback;
4587		break;
4588	}
 
4589
4590	spec->aloopback_mask = 0x01;
4591	spec->aloopback_shift = 8;
4592
4593	spec->gen.beep_nid = 0x1c; /* digital beep */
4594
4595	/* GPIO0 High = Enable EAPD */
4596	spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1;
4597	spec->gpio_data = 0x01;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4598
4599	spec->eapd_switch = 1;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4600
4601	spec->num_pwrs = ARRAY_SIZE(stac92hd73xx_pwr_nids);
4602	spec->pwr_nids = stac92hd73xx_pwr_nids;
4603
4604	spec->gen.own_eapd_ctl = 1;
4605	spec->gen.power_down_unused = 1;
4606
4607	snd_hda_pick_fixup(codec, stac92hd73xx_models, stac92hd73xx_fixup_tbl,
4608			   stac92hd73xx_fixups);
4609	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
4610
4611	if (!spec->volknob_init)
4612		snd_hda_add_verbs(codec, stac92hd73xx_core_init);
 
 
 
4613
4614	err = stac_parse_auto_config(codec);
4615	if (err < 0) {
4616		stac_free(codec);
4617		return err;
4618	}
4619
4620	/* Don't GPIO-mute speakers if there are no internal speakers, because
4621	 * the GPIO might be necessary for Headphone
4622	 */
4623	if (spec->eapd_switch && !has_builtin_speaker(codec))
4624		spec->eapd_switch = 0;
4625
4626	codec->proc_widget_hook = stac92hd7x_proc_hook;
4627
4628	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4629
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4630	return 0;
4631}
4632
4633static void stac_setup_gpio(struct hda_codec *codec)
4634{
4635	struct sigmatel_spec *spec = codec->spec;
 
 
4636
4637	spec->gpio_mask |= spec->eapd_mask;
4638	if (spec->gpio_led) {
4639		if (!spec->vref_mute_led_nid) {
4640			spec->gpio_mask |= spec->gpio_led;
4641			spec->gpio_dir |= spec->gpio_led;
4642			spec->gpio_data |= spec->gpio_led;
4643		} else {
4644			codec->power_filter = stac_vref_led_power_filter;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4645		}
4646	}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4647
4648	if (spec->mic_mute_led_gpio) {
4649		spec->gpio_mask |= spec->mic_mute_led_gpio;
4650		spec->gpio_dir |= spec->mic_mute_led_gpio;
4651		spec->mic_enabled = 0;
4652		spec->gpio_data |= spec->mic_mute_led_gpio;
4653		snd_hda_gen_add_micmute_led_cdev(codec, stac_capture_led_update);
4654	}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4655}
4656
4657static int patch_stac92hd83xxx(struct hda_codec *codec)
4658{
4659	struct sigmatel_spec *spec;
 
4660	int err;
4661
4662	err = alloc_stac_spec(codec);
4663	if (err < 0)
4664		return err;
 
 
 
 
 
4665
4666	/* longer delay needed for D3 */
4667	codec->core.power_caps &= ~AC_PWRST_EPSS;
4668
4669	spec = codec->spec;
4670	codec->power_save_node = 1;
4671	spec->linear_tone_beep = 0;
4672	spec->gen.own_eapd_ctl = 1;
4673	spec->gen.power_down_unused = 1;
4674	spec->gen.mixer_nid = 0x1b;
4675
4676	spec->gen.beep_nid = 0x21; /* digital beep */
 
 
4677	spec->pwr_nids = stac92hd83xxx_pwr_nids;
4678	spec->num_pwrs = ARRAY_SIZE(stac92hd83xxx_pwr_nids);
4679	spec->default_polarity = -1; /* no default cfg */
 
4680
4681	snd_hda_add_verbs(codec, stac92hd83xxx_core_init);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4682
4683	snd_hda_pick_fixup(codec, stac92hd83xxx_models, stac92hd83xxx_fixup_tbl,
4684			   stac92hd83xxx_fixups);
4685	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
4686
4687	stac_setup_gpio(codec);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4688
4689	err = stac_parse_auto_config(codec);
4690	if (err < 0) {
4691		stac_free(codec);
4692		return err;
4693	}
4694
4695	codec->proc_widget_hook = stac92hd_proc_hook;
4696
4697	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
4698
4699	return 0;
4700}
4701
4702static const hda_nid_t stac92hd95_pwr_nids[] = {
4703	0x0a, 0x0b, 0x0c, 0x0d
4704};
4705
4706static int patch_stac92hd95(struct hda_codec *codec)
4707{
4708	struct sigmatel_spec *spec;
4709	int err;
4710
4711	err = alloc_stac_spec(codec);
4712	if (err < 0)
4713		return err;
4714
4715	/* longer delay needed for D3 */
4716	codec->core.power_caps &= ~AC_PWRST_EPSS;
 
 
 
4717
4718	spec = codec->spec;
4719	codec->power_save_node = 1;
4720	spec->linear_tone_beep = 0;
4721	spec->gen.own_eapd_ctl = 1;
4722	spec->gen.power_down_unused = 1;
 
 
 
 
 
 
 
4723
4724	spec->gen.beep_nid = 0x19; /* digital beep */
4725	spec->pwr_nids = stac92hd95_pwr_nids;
4726	spec->num_pwrs = ARRAY_SIZE(stac92hd95_pwr_nids);
4727	spec->default_polarity = 0;
 
 
 
 
 
 
4728
4729	snd_hda_pick_fixup(codec, stac92hd95_models, stac92hd95_fixup_tbl,
4730			   stac92hd95_fixups);
4731	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
4732
4733	stac_setup_gpio(codec);
 
 
 
 
 
 
 
4734
4735	err = stac_parse_auto_config(codec);
4736	if (err < 0) {
4737		stac_free(codec);
4738		return err;
4739	}
 
4740
4741	codec->proc_widget_hook = stac92hd_proc_hook;
 
 
4742
4743	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
 
 
4744
 
 
 
4745	return 0;
4746}
4747
4748static int patch_stac92hd71bxx(struct hda_codec *codec)
4749{
4750	struct sigmatel_spec *spec;
4751	const hda_nid_t *unmute_nids = stac92hd71bxx_unmute_nids;
4752	int err;
 
4753
4754	err = alloc_stac_spec(codec);
4755	if (err < 0)
4756		return err;
4757
4758	spec = codec->spec;
4759	/* disabled power_save_node since it causes noises on a Dell machine */
4760	/* codec->power_save_node = 1; */
4761	spec->linear_tone_beep = 0;
4762	spec->gen.own_eapd_ctl = 1;
4763	spec->gen.power_down_unused = 1;
4764	spec->gen.mixer_nid = 0x17;
4765	spec->have_spdif_mux = 1;
4766
4767	/* GPIO0 = EAPD */
4768	spec->gpio_mask = 0x01;
4769	spec->gpio_dir = 0x01;
4770	spec->gpio_data = 0x01;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4771
4772	switch (codec->core.vendor_id) {
4773	case 0x111d76b6: /* 4 Port without Analog Mixer */
4774	case 0x111d76b7:
4775		unmute_nids++;
 
 
 
 
 
 
 
 
4776		break;
4777	case 0x111d7608: /* 5 Port with Analog Mixer */
4778		if ((codec->core.revision_id & 0xf) == 0 ||
4779		    (codec->core.revision_id & 0xf) == 1)
 
 
 
 
 
 
 
 
 
 
 
 
 
4780			spec->stream_delay = 40; /* 40 milliseconds */
4781
4782		/* disable VSW */
4783		unmute_nids++;
 
4784		snd_hda_codec_set_pincfg(codec, 0x0f, 0x40f000f0);
4785		snd_hda_codec_set_pincfg(codec, 0x19, 0x40f000f3);
 
 
 
 
4786		break;
4787	case 0x111d7603: /* 6 Port with Analog Mixer */
4788		if ((codec->core.revision_id & 0xf) == 1)
4789			spec->stream_delay = 40; /* 40 milliseconds */
4790
 
 
 
 
 
 
 
4791		break;
4792	}
4793
4794	if (get_wcaps_type(get_wcaps(codec, 0x28)) == AC_WID_VOL_KNB)
4795		snd_hda_add_verbs(codec, stac92hd71bxx_core_init);
4796
4797	if (get_wcaps(codec, 0xa) & AC_WCAP_IN_AMP) {
4798		const hda_nid_t *p;
4799		for (p = unmute_nids; *p; p++)
4800			snd_hda_codec_amp_init_stereo(codec, *p, HDA_INPUT, 0,
4801						      0xff, 0x00);
4802	}
4803
4804	spec->aloopback_ctl = &stac92hd71bxx_loopback;
4805	spec->aloopback_mask = 0x50;
4806	spec->aloopback_shift = 0;
4807
4808	spec->powerdown_adcs = 1;
4809	spec->gen.beep_nid = 0x26; /* digital beep */
4810	spec->num_pwrs = ARRAY_SIZE(stac92hd71bxx_pwr_nids);
 
 
4811	spec->pwr_nids = stac92hd71bxx_pwr_nids;
4812
4813	snd_hda_pick_fixup(codec, stac92hd71bxx_models, stac92hd71bxx_fixup_tbl,
4814			   stac92hd71bxx_fixups);
4815	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4816
4817	stac_setup_gpio(codec);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4818
4819	err = stac_parse_auto_config(codec);
4820	if (err < 0) {
4821		stac_free(codec);
4822		return err;
4823	}
4824
4825	codec->proc_widget_hook = stac92hd7x_proc_hook;
 
 
 
 
 
 
 
 
4826
4827	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
4828
4829	return 0;
4830}
4831
4832static int patch_stac922x(struct hda_codec *codec)
4833{
4834	struct sigmatel_spec *spec;
4835	int err;
4836
4837	err = alloc_stac_spec(codec);
4838	if (err < 0)
4839		return err;
4840
4841	spec = codec->spec;
 
4842	spec->linear_tone_beep = 1;
4843	spec->gen.own_eapd_ctl = 1;
 
 
 
 
 
 
 
 
 
 
 
 
4844
4845	snd_hda_add_verbs(codec, stac922x_core_init);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4846
4847	/* Fix Mux capture level; max to 2 */
4848	snd_hda_override_amp_caps(codec, 0x12, HDA_OUTPUT,
4849				  (0 << AC_AMPCAP_OFFSET_SHIFT) |
4850				  (2 << AC_AMPCAP_NUM_STEPS_SHIFT) |
4851				  (0x27 << AC_AMPCAP_STEP_SIZE_SHIFT) |
4852				  (0 << AC_AMPCAP_MUTE_SHIFT));
 
4853
4854	snd_hda_pick_fixup(codec, stac922x_models, stac922x_fixup_tbl,
4855			   stac922x_fixups);
4856	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
 
 
 
 
 
 
4857
4858	err = stac_parse_auto_config(codec);
 
 
 
 
 
 
 
 
 
 
 
4859	if (err < 0) {
4860		stac_free(codec);
4861		return err;
4862	}
4863
4864	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
 
 
 
 
 
 
 
4865
4866	return 0;
4867}
4868
4869static const char * const stac927x_spdif_labels[] = {
4870	"Digital Playback", "ADAT", "Analog Mux 1",
4871	"Analog Mux 2", "Analog Mux 3", NULL
4872};
4873
4874static int patch_stac927x(struct hda_codec *codec)
4875{
4876	struct sigmatel_spec *spec;
4877	int err;
4878
4879	err = alloc_stac_spec(codec);
4880	if (err < 0)
4881		return err;
4882
4883	spec = codec->spec;
 
4884	spec->linear_tone_beep = 1;
4885	spec->gen.own_eapd_ctl = 1;
4886	spec->have_spdif_mux = 1;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4887	spec->spdif_labels = stac927x_spdif_labels;
 
 
4888
4889	spec->gen.beep_nid = 0x23; /* digital beep */
 
 
 
 
4890
4891	/* GPIO0 High = Enable EAPD */
4892	spec->eapd_mask = spec->gpio_mask = 0x01;
4893	spec->gpio_dir = spec->gpio_data = 0x01;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4894
4895	spec->aloopback_ctl = &stac927x_loopback;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4896	spec->aloopback_mask = 0x40;
4897	spec->aloopback_shift = 0;
4898	spec->eapd_switch = 1;
4899
4900	snd_hda_pick_fixup(codec, stac927x_models, stac927x_fixup_tbl,
4901			   stac927x_fixups);
4902	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
4903
4904	if (!spec->volknob_init)
4905		snd_hda_add_verbs(codec, stac927x_core_init);
4906
4907	err = stac_parse_auto_config(codec);
 
 
4908	if (err < 0) {
4909		stac_free(codec);
4910		return err;
4911	}
4912
 
 
4913	codec->proc_widget_hook = stac927x_proc_hook;
4914
4915	/*
4916	 * !!FIXME!!
4917	 * The STAC927x seem to require fairly long delays for certain
4918	 * command sequences.  With too short delays (even if the answer
4919	 * is set to RIRB properly), it results in the silence output
4920	 * on some hardwares like Dell.
4921	 *
4922	 * The below flag enables the longer delay (see get_response
4923	 * in hda_intel.c).
4924	 */
4925	codec->bus->core.needs_damn_long_delay = 1;
4926
4927	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
 
 
4928
4929	return 0;
4930}
4931
4932static int patch_stac9205(struct hda_codec *codec)
4933{
4934	struct sigmatel_spec *spec;
4935	int err;
4936
4937	err = alloc_stac_spec(codec);
4938	if (err < 0)
4939		return err;
4940
4941	spec = codec->spec;
 
4942	spec->linear_tone_beep = 1;
4943	spec->gen.own_eapd_ctl = 1;
4944	spec->have_spdif_mux = 1;
4945
4946	spec->gen.beep_nid = 0x23; /* digital beep */
 
 
 
 
 
 
 
 
4947
4948	snd_hda_add_verbs(codec, stac9205_core_init);
4949	spec->aloopback_ctl = &stac9205_loopback;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4950
4951	spec->aloopback_mask = 0x40;
4952	spec->aloopback_shift = 0;
 
 
 
 
4953	
4954	/* GPIO0 High = EAPD */
4955	spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1;
4956	spec->gpio_data = 0x01;
 
 
4957
4958	/* Turn on/off EAPD per HP plugging */
4959	spec->eapd_switch = 1;
 
 
 
 
 
4960
4961	snd_hda_pick_fixup(codec, stac9205_models, stac9205_fixup_tbl,
4962			   stac9205_fixups);
4963	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
4964
4965	err = stac_parse_auto_config(codec);
 
 
 
 
 
 
 
 
 
4966	if (err < 0) {
4967		stac_free(codec);
4968		return err;
4969	}
4970
4971	codec->proc_widget_hook = stac9205_proc_hook;
4972
4973	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
4974
4975	return 0;
4976}
4977
4978/*
4979 * STAC9872 hack
4980 */
4981
4982static const struct hda_verb stac9872_core_init[] = {
4983	{0x15, AC_VERB_SET_CONNECT_SEL, 0x1}, /* mic-sel: 0a,0d,14,02 */
4984	{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Mic-in -> 0x9 */
4985	{}
4986};
4987
4988static const struct hda_pintbl stac9872_vaio_pin_configs[] = {
4989	{ 0x0a, 0x03211020 },
4990	{ 0x0b, 0x411111f0 },
4991	{ 0x0c, 0x411111f0 },
4992	{ 0x0d, 0x03a15030 },
4993	{ 0x0e, 0x411111f0 },
4994	{ 0x0f, 0x90170110 },
4995	{ 0x11, 0x411111f0 },
4996	{ 0x13, 0x411111f0 },
4997	{ 0x14, 0x90a7013e },
4998	{}
4999};
5000
5001static const struct hda_model_fixup stac9872_models[] = {
5002	{ .id = STAC_9872_VAIO, .name = "vaio" },
5003	{}
5004};
5005
5006static const struct hda_fixup stac9872_fixups[] = {
5007	[STAC_9872_VAIO] = {
5008		.type = HDA_FIXUP_PINS,
5009		.v.pins = stac9872_vaio_pin_configs,
5010	},
 
 
 
 
 
 
 
 
5011};
5012
5013static const struct snd_pci_quirk stac9872_fixup_tbl[] = {
 
 
 
 
 
 
 
 
 
5014	SND_PCI_QUIRK_MASK(0x104d, 0xfff0, 0x81e0,
5015			   "Sony VAIO F/S", STAC_9872_VAIO),
5016	{} /* terminator */
5017};
5018
5019static int patch_stac9872(struct hda_codec *codec)
5020{
5021	struct sigmatel_spec *spec;
5022	int err;
5023
5024	err = alloc_stac_spec(codec);
5025	if (err < 0)
5026		return err;
5027
5028	spec = codec->spec;
5029	spec->linear_tone_beep = 1;
5030	spec->gen.own_eapd_ctl = 1;
 
5031
5032	snd_hda_add_verbs(codec, stac9872_core_init);
 
 
 
 
 
 
 
 
5033
5034	snd_hda_pick_fixup(codec, stac9872_models, stac9872_fixup_tbl,
5035			   stac9872_fixups);
5036	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PRE_PROBE);
 
 
 
 
 
 
5037
5038	err = stac_parse_auto_config(codec);
5039	if (err < 0) {
5040		stac_free(codec);
5041		return -EINVAL;
5042	}
5043
5044	snd_hda_apply_fixup(codec, HDA_FIXUP_ACT_PROBE);
5045
5046	return 0;
5047}
5048
5049
5050/*
5051 * patch entries
5052 */
5053static const struct hda_device_id snd_hda_id_sigmatel[] = {
5054	HDA_CODEC_ENTRY(0x83847690, "STAC9200", patch_stac9200),
5055	HDA_CODEC_ENTRY(0x83847882, "STAC9220 A1", patch_stac922x),
5056	HDA_CODEC_ENTRY(0x83847680, "STAC9221 A1", patch_stac922x),
5057	HDA_CODEC_ENTRY(0x83847880, "STAC9220 A2", patch_stac922x),
5058	HDA_CODEC_ENTRY(0x83847681, "STAC9220D/9223D A2", patch_stac922x),
5059	HDA_CODEC_ENTRY(0x83847682, "STAC9221 A2", patch_stac922x),
5060	HDA_CODEC_ENTRY(0x83847683, "STAC9221D A2", patch_stac922x),
5061	HDA_CODEC_ENTRY(0x83847618, "STAC9227", patch_stac927x),
5062	HDA_CODEC_ENTRY(0x83847619, "STAC9227", patch_stac927x),
5063	HDA_CODEC_ENTRY(0x83847638, "STAC92HD700", patch_stac927x),
5064	HDA_CODEC_ENTRY(0x83847616, "STAC9228", patch_stac927x),
5065	HDA_CODEC_ENTRY(0x83847617, "STAC9228", patch_stac927x),
5066	HDA_CODEC_ENTRY(0x83847614, "STAC9229", patch_stac927x),
5067	HDA_CODEC_ENTRY(0x83847615, "STAC9229", patch_stac927x),
5068	HDA_CODEC_ENTRY(0x83847620, "STAC9274", patch_stac927x),
5069	HDA_CODEC_ENTRY(0x83847621, "STAC9274D", patch_stac927x),
5070	HDA_CODEC_ENTRY(0x83847622, "STAC9273X", patch_stac927x),
5071	HDA_CODEC_ENTRY(0x83847623, "STAC9273D", patch_stac927x),
5072	HDA_CODEC_ENTRY(0x83847624, "STAC9272X", patch_stac927x),
5073	HDA_CODEC_ENTRY(0x83847625, "STAC9272D", patch_stac927x),
5074	HDA_CODEC_ENTRY(0x83847626, "STAC9271X", patch_stac927x),
5075	HDA_CODEC_ENTRY(0x83847627, "STAC9271D", patch_stac927x),
5076	HDA_CODEC_ENTRY(0x83847628, "STAC9274X5NH", patch_stac927x),
5077	HDA_CODEC_ENTRY(0x83847629, "STAC9274D5NH", patch_stac927x),
5078	HDA_CODEC_ENTRY(0x83847632, "STAC9202",  patch_stac925x),
5079	HDA_CODEC_ENTRY(0x83847633, "STAC9202D", patch_stac925x),
5080	HDA_CODEC_ENTRY(0x83847634, "STAC9250", patch_stac925x),
5081	HDA_CODEC_ENTRY(0x83847635, "STAC9250D", patch_stac925x),
5082	HDA_CODEC_ENTRY(0x83847636, "STAC9251", patch_stac925x),
5083	HDA_CODEC_ENTRY(0x83847637, "STAC9250D", patch_stac925x),
5084	HDA_CODEC_ENTRY(0x83847645, "92HD206X", patch_stac927x),
5085	HDA_CODEC_ENTRY(0x83847646, "92HD206D", patch_stac927x),
5086	/* The following does not take into account .id=0x83847661 when subsys =
5087	 * 104D0C00 which is STAC9225s. Because of this, some SZ Notebooks are
5088	 * currently not fully supported.
5089	 */
5090	HDA_CODEC_ENTRY(0x83847661, "CXD9872RD/K", patch_stac9872),
5091	HDA_CODEC_ENTRY(0x83847662, "STAC9872AK", patch_stac9872),
5092	HDA_CODEC_ENTRY(0x83847664, "CXD9872AKD", patch_stac9872),
5093	HDA_CODEC_ENTRY(0x83847698, "STAC9205", patch_stac9205),
5094	HDA_CODEC_ENTRY(0x838476a0, "STAC9205", patch_stac9205),
5095	HDA_CODEC_ENTRY(0x838476a1, "STAC9205D", patch_stac9205),
5096	HDA_CODEC_ENTRY(0x838476a2, "STAC9204", patch_stac9205),
5097	HDA_CODEC_ENTRY(0x838476a3, "STAC9204D", patch_stac9205),
5098	HDA_CODEC_ENTRY(0x838476a4, "STAC9255", patch_stac9205),
5099	HDA_CODEC_ENTRY(0x838476a5, "STAC9255D", patch_stac9205),
5100	HDA_CODEC_ENTRY(0x838476a6, "STAC9254", patch_stac9205),
5101	HDA_CODEC_ENTRY(0x838476a7, "STAC9254D", patch_stac9205),
5102	HDA_CODEC_ENTRY(0x111d7603, "92HD75B3X5", patch_stac92hd71bxx),
5103	HDA_CODEC_ENTRY(0x111d7604, "92HD83C1X5", patch_stac92hd83xxx),
5104	HDA_CODEC_ENTRY(0x111d76d4, "92HD83C1C5", patch_stac92hd83xxx),
5105	HDA_CODEC_ENTRY(0x111d7605, "92HD81B1X5", patch_stac92hd83xxx),
5106	HDA_CODEC_ENTRY(0x111d76d5, "92HD81B1C5", patch_stac92hd83xxx),
5107	HDA_CODEC_ENTRY(0x111d76d1, "92HD87B1/3", patch_stac92hd83xxx),
5108	HDA_CODEC_ENTRY(0x111d76d9, "92HD87B2/4", patch_stac92hd83xxx),
5109	HDA_CODEC_ENTRY(0x111d7666, "92HD88B3", patch_stac92hd83xxx),
5110	HDA_CODEC_ENTRY(0x111d7667, "92HD88B1", patch_stac92hd83xxx),
5111	HDA_CODEC_ENTRY(0x111d7668, "92HD88B2", patch_stac92hd83xxx),
5112	HDA_CODEC_ENTRY(0x111d7669, "92HD88B4", patch_stac92hd83xxx),
5113	HDA_CODEC_ENTRY(0x111d7608, "92HD75B2X5", patch_stac92hd71bxx),
5114	HDA_CODEC_ENTRY(0x111d7674, "92HD73D1X5", patch_stac92hd73xx),
5115	HDA_CODEC_ENTRY(0x111d7675, "92HD73C1X5", patch_stac92hd73xx),
5116	HDA_CODEC_ENTRY(0x111d7676, "92HD73E1X5", patch_stac92hd73xx),
5117	HDA_CODEC_ENTRY(0x111d7695, "92HD95", patch_stac92hd95),
5118	HDA_CODEC_ENTRY(0x111d76b0, "92HD71B8X", patch_stac92hd71bxx),
5119	HDA_CODEC_ENTRY(0x111d76b1, "92HD71B8X", patch_stac92hd71bxx),
5120	HDA_CODEC_ENTRY(0x111d76b2, "92HD71B7X", patch_stac92hd71bxx),
5121	HDA_CODEC_ENTRY(0x111d76b3, "92HD71B7X", patch_stac92hd71bxx),
5122	HDA_CODEC_ENTRY(0x111d76b4, "92HD71B6X", patch_stac92hd71bxx),
5123	HDA_CODEC_ENTRY(0x111d76b5, "92HD71B6X", patch_stac92hd71bxx),
5124	HDA_CODEC_ENTRY(0x111d76b6, "92HD71B5X", patch_stac92hd71bxx),
5125	HDA_CODEC_ENTRY(0x111d76b7, "92HD71B5X", patch_stac92hd71bxx),
5126	HDA_CODEC_ENTRY(0x111d76c0, "92HD89C3", patch_stac92hd73xx),
5127	HDA_CODEC_ENTRY(0x111d76c1, "92HD89C2", patch_stac92hd73xx),
5128	HDA_CODEC_ENTRY(0x111d76c2, "92HD89C1", patch_stac92hd73xx),
5129	HDA_CODEC_ENTRY(0x111d76c3, "92HD89B3", patch_stac92hd73xx),
5130	HDA_CODEC_ENTRY(0x111d76c4, "92HD89B2", patch_stac92hd73xx),
5131	HDA_CODEC_ENTRY(0x111d76c5, "92HD89B1", patch_stac92hd73xx),
5132	HDA_CODEC_ENTRY(0x111d76c6, "92HD89E3", patch_stac92hd73xx),
5133	HDA_CODEC_ENTRY(0x111d76c7, "92HD89E2", patch_stac92hd73xx),
5134	HDA_CODEC_ENTRY(0x111d76c8, "92HD89E1", patch_stac92hd73xx),
5135	HDA_CODEC_ENTRY(0x111d76c9, "92HD89D3", patch_stac92hd73xx),
5136	HDA_CODEC_ENTRY(0x111d76ca, "92HD89D2", patch_stac92hd73xx),
5137	HDA_CODEC_ENTRY(0x111d76cb, "92HD89D1", patch_stac92hd73xx),
5138	HDA_CODEC_ENTRY(0x111d76cc, "92HD89F3", patch_stac92hd73xx),
5139	HDA_CODEC_ENTRY(0x111d76cd, "92HD89F2", patch_stac92hd73xx),
5140	HDA_CODEC_ENTRY(0x111d76ce, "92HD89F1", patch_stac92hd73xx),
5141	HDA_CODEC_ENTRY(0x111d76df, "92HD93BXX", patch_stac92hd83xxx),
5142	HDA_CODEC_ENTRY(0x111d76e0, "92HD91BXX", patch_stac92hd83xxx),
5143	HDA_CODEC_ENTRY(0x111d76e3, "92HD98BXX", patch_stac92hd83xxx),
5144	HDA_CODEC_ENTRY(0x111d76e5, "92HD99BXX", patch_stac92hd83xxx),
5145	HDA_CODEC_ENTRY(0x111d76e7, "92HD90BXX", patch_stac92hd83xxx),
5146	HDA_CODEC_ENTRY(0x111d76e8, "92HD66B1X5", patch_stac92hd83xxx),
5147	HDA_CODEC_ENTRY(0x111d76e9, "92HD66B2X5", patch_stac92hd83xxx),
5148	HDA_CODEC_ENTRY(0x111d76ea, "92HD66B3X5", patch_stac92hd83xxx),
5149	HDA_CODEC_ENTRY(0x111d76eb, "92HD66C1X5", patch_stac92hd83xxx),
5150	HDA_CODEC_ENTRY(0x111d76ec, "92HD66C2X5", patch_stac92hd83xxx),
5151	HDA_CODEC_ENTRY(0x111d76ed, "92HD66C3X5", patch_stac92hd83xxx),
5152	HDA_CODEC_ENTRY(0x111d76ee, "92HD66B1X3", patch_stac92hd83xxx),
5153	HDA_CODEC_ENTRY(0x111d76ef, "92HD66B2X3", patch_stac92hd83xxx),
5154	HDA_CODEC_ENTRY(0x111d76f0, "92HD66B3X3", patch_stac92hd83xxx),
5155	HDA_CODEC_ENTRY(0x111d76f1, "92HD66C1X3", patch_stac92hd83xxx),
5156	HDA_CODEC_ENTRY(0x111d76f2, "92HD66C2X3", patch_stac92hd83xxx),
5157	HDA_CODEC_ENTRY(0x111d76f3, "92HD66C3/65", patch_stac92hd83xxx),
5158	{} /* terminator */
5159};
5160MODULE_DEVICE_TABLE(hdaudio, snd_hda_id_sigmatel);
 
 
5161
5162MODULE_LICENSE("GPL");
5163MODULE_DESCRIPTION("IDT/Sigmatel HD-audio codec");
5164
5165static struct hda_codec_driver sigmatel_driver = {
5166	.id = snd_hda_id_sigmatel,
 
5167};
5168
5169module_hda_codec_driver(sigmatel_driver);
 
 
 
 
 
 
 
 
 
 
 
v3.5.6
 
   1/*
   2 * Universal Interface for Intel High Definition Audio Codec
   3 *
   4 * HD audio interface patch for SigmaTel STAC92xx
   5 *
   6 * Copyright (c) 2005 Embedded Alley Solutions, Inc.
   7 * Matt Porter <mporter@embeddedalley.com>
   8 *
   9 * Based on patch_cmedia.c and patch_realtek.c
  10 * Copyright (c) 2004 Takashi Iwai <tiwai@suse.de>
  11 *
  12 *  This driver is free software; you can redistribute it and/or modify
  13 *  it under the terms of the GNU General Public License as published by
  14 *  the Free Software Foundation; either version 2 of the License, or
  15 *  (at your option) any later version.
  16 *
  17 *  This driver is distributed in the hope that it will be useful,
  18 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
  19 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  20 *  GNU General Public License for more details.
  21 *
  22 *  You should have received a copy of the GNU General Public License
  23 *  along with this program; if not, write to the Free Software
  24 *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
  25 */
  26
  27#include <linux/init.h>
  28#include <linux/delay.h>
  29#include <linux/slab.h>
  30#include <linux/pci.h>
  31#include <linux/dmi.h>
  32#include <linux/module.h>
  33#include <sound/core.h>
  34#include <sound/asoundef.h>
  35#include <sound/jack.h>
  36#include <sound/tlv.h>
  37#include "hda_codec.h"
  38#include "hda_local.h"
  39#include "hda_auto_parser.h"
  40#include "hda_beep.h"
  41#include "hda_jack.h"
 
  42
  43enum {
  44	STAC_VREF_EVENT	= 1,
  45	STAC_INSERT_EVENT,
  46	STAC_PWR_EVENT,
  47	STAC_HP_EVENT,
  48	STAC_LO_EVENT,
  49	STAC_MIC_EVENT,
  50};
  51
  52enum {
  53	STAC_AUTO,
  54	STAC_REF,
  55	STAC_9200_OQO,
  56	STAC_9200_DELL_D21,
  57	STAC_9200_DELL_D22,
  58	STAC_9200_DELL_D23,
  59	STAC_9200_DELL_M21,
  60	STAC_9200_DELL_M22,
  61	STAC_9200_DELL_M23,
  62	STAC_9200_DELL_M24,
  63	STAC_9200_DELL_M25,
  64	STAC_9200_DELL_M26,
  65	STAC_9200_DELL_M27,
  66	STAC_9200_M4,
  67	STAC_9200_M4_2,
  68	STAC_9200_PANASONIC,
 
  69	STAC_9200_MODELS
  70};
  71
  72enum {
  73	STAC_9205_AUTO,
  74	STAC_9205_REF,
  75	STAC_9205_DELL_M42,
  76	STAC_9205_DELL_M43,
  77	STAC_9205_DELL_M44,
  78	STAC_9205_EAPD,
  79	STAC_9205_MODELS
  80};
  81
  82enum {
  83	STAC_92HD73XX_AUTO,
  84	STAC_92HD73XX_NO_JD, /* no jack-detection */
  85	STAC_92HD73XX_REF,
  86	STAC_92HD73XX_INTEL,
  87	STAC_DELL_M6_AMIC,
  88	STAC_DELL_M6_DMIC,
  89	STAC_DELL_M6_BOTH,
  90	STAC_DELL_EQ,
  91	STAC_ALIENWARE_M17X,
 
 
 
 
  92	STAC_92HD73XX_MODELS
  93};
  94
  95enum {
  96	STAC_92HD83XXX_AUTO,
  97	STAC_92HD83XXX_REF,
  98	STAC_92HD83XXX_PWR_REF,
  99	STAC_DELL_S14,
 100	STAC_DELL_VOSTRO_3500,
 101	STAC_92HD83XXX_HP_cNB11_INTQUAD,
 102	STAC_HP_DV7_4000,
 103	STAC_HP_ZEPHYR,
 104	STAC_92HD83XXX_HP_LED,
 105	STAC_92HD83XXX_HP_INV_LED,
 
 
 
 
 
 
 
 
 
 106	STAC_92HD83XXX_MODELS
 107};
 108
 109enum {
 110	STAC_92HD71BXX_AUTO,
 111	STAC_92HD71BXX_REF,
 112	STAC_DELL_M4_1,
 113	STAC_DELL_M4_2,
 114	STAC_DELL_M4_3,
 115	STAC_HP_M4,
 116	STAC_HP_DV4,
 117	STAC_HP_DV5,
 118	STAC_HP_HDX,
 119	STAC_HP_DV4_1222NR,
 
 
 120	STAC_92HD71BXX_MODELS
 121};
 122
 123enum {
 124	STAC_925x_AUTO,
 
 
 
 
 
 125	STAC_925x_REF,
 126	STAC_M1,
 127	STAC_M1_2,
 128	STAC_M2,
 129	STAC_M2_2,
 130	STAC_M3,
 131	STAC_M5,
 132	STAC_M6,
 133	STAC_925x_MODELS
 134};
 135
 136enum {
 137	STAC_922X_AUTO,
 138	STAC_D945_REF,
 139	STAC_D945GTP3,
 140	STAC_D945GTP5,
 141	STAC_INTEL_MAC_V1,
 142	STAC_INTEL_MAC_V2,
 143	STAC_INTEL_MAC_V3,
 144	STAC_INTEL_MAC_V4,
 145	STAC_INTEL_MAC_V5,
 146	STAC_INTEL_MAC_AUTO, /* This model is selected if no module parameter
 147			      * is given, one of the above models will be
 148			      * chosen according to the subsystem id. */
 149	/* for backward compatibility */
 150	STAC_MACMINI,
 151	STAC_MACBOOK,
 152	STAC_MACBOOK_PRO_V1,
 153	STAC_MACBOOK_PRO_V2,
 154	STAC_IMAC_INTEL,
 155	STAC_IMAC_INTEL_20,
 156	STAC_ECS_202,
 157	STAC_922X_DELL_D81,
 158	STAC_922X_DELL_D82,
 159	STAC_922X_DELL_M81,
 160	STAC_922X_DELL_M82,
 
 161	STAC_922X_MODELS
 162};
 163
 164enum {
 165	STAC_927X_AUTO,
 166	STAC_D965_REF_NO_JD, /* no jack-detection */
 167	STAC_D965_REF,
 168	STAC_D965_3ST,
 169	STAC_D965_5ST,
 170	STAC_D965_5ST_NO_FP,
 
 171	STAC_DELL_3ST,
 172	STAC_DELL_BIOS,
 
 
 
 
 173	STAC_927X_VOLKNOB,
 174	STAC_927X_MODELS
 175};
 176
 177enum {
 178	STAC_9872_AUTO,
 179	STAC_9872_VAIO,
 180	STAC_9872_MODELS
 181};
 182
 183struct sigmatel_mic_route {
 184	hda_nid_t pin;
 185	signed char mux_idx;
 186	signed char dmux_idx;
 187};
 188
 189#define MAX_PINS_NUM 16
 190#define MAX_ADCS_NUM 4
 191#define MAX_DMICS_NUM 4
 192
 193struct sigmatel_spec {
 194	struct snd_kcontrol_new *mixers[4];
 195	unsigned int num_mixers;
 196
 197	int board_config;
 198	unsigned int eapd_switch: 1;
 199	unsigned int surr_switch: 1;
 200	unsigned int alt_switch: 1;
 201	unsigned int hp_detect: 1;
 202	unsigned int spdif_mute: 1;
 203	unsigned int check_volume_offset:1;
 204	unsigned int auto_mic:1;
 205	unsigned int linear_tone_beep:1;
 
 
 
 
 206
 207	/* gpio lines */
 208	unsigned int eapd_mask;
 209	unsigned int gpio_mask;
 210	unsigned int gpio_dir;
 211	unsigned int gpio_data;
 212	unsigned int gpio_mute;
 213	unsigned int gpio_led;
 214	unsigned int gpio_led_polarity;
 215	unsigned int vref_mute_led_nid; /* pin NID for mute-LED vref control */
 216	unsigned int vref_led;
 
 
 
 
 217
 218	/* stream */
 219	unsigned int stream_delay;
 220
 221	/* analog loopback */
 222	const struct snd_kcontrol_new *aloopback_ctl;
 
 223	unsigned char aloopback_mask;
 224	unsigned char aloopback_shift;
 225
 226	/* power management */
 227	unsigned int power_map_bits;
 228	unsigned int num_pwrs;
 229	const hda_nid_t *pwr_nids;
 230	const hda_nid_t *dac_list;
 231
 232	/* playback */
 233	struct hda_input_mux *mono_mux;
 234	unsigned int cur_mmux;
 235	struct hda_multi_out multiout;
 236	hda_nid_t dac_nids[5];
 237	hda_nid_t hp_dacs[5];
 238	hda_nid_t speaker_dacs[5];
 239
 240	int volume_offset;
 241
 242	/* capture */
 243	const hda_nid_t *adc_nids;
 244	unsigned int num_adcs;
 245	const hda_nid_t *mux_nids;
 246	unsigned int num_muxes;
 247	const hda_nid_t *dmic_nids;
 248	unsigned int num_dmics;
 249	const hda_nid_t *dmux_nids;
 250	unsigned int num_dmuxes;
 251	const hda_nid_t *smux_nids;
 252	unsigned int num_smuxes;
 253	unsigned int num_analog_muxes;
 254
 255	const unsigned long *capvols; /* amp-volume attr: HDA_COMPOSE_AMP_VAL() */
 256	const unsigned long *capsws; /* amp-mute attr: HDA_COMPOSE_AMP_VAL() */
 257	unsigned int num_caps; /* number of capture volume/switch elements */
 258
 259	struct sigmatel_mic_route ext_mic;
 260	struct sigmatel_mic_route int_mic;
 261	struct sigmatel_mic_route dock_mic;
 262
 
 263	const char * const *spdif_labels;
 264
 265	hda_nid_t dig_in_nid;
 266	hda_nid_t mono_nid;
 267	hda_nid_t anabeep_nid;
 268	hda_nid_t digbeep_nid;
 269
 270	/* pin widgets */
 271	const hda_nid_t *pin_nids;
 272	unsigned int num_pins;
 273
 274	/* codec specific stuff */
 275	const struct hda_verb *init;
 276	const struct snd_kcontrol_new *mixer;
 277
 278	/* capture source */
 279	struct hda_input_mux *dinput_mux;
 280	unsigned int cur_dmux[2];
 281	struct hda_input_mux *input_mux;
 282	unsigned int cur_mux[3];
 283	struct hda_input_mux *sinput_mux;
 284	unsigned int cur_smux[2];
 285	unsigned int cur_amux;
 286	hda_nid_t *amp_nids;
 287	unsigned int powerdown_adcs;
 288
 289	/* i/o switches */
 290	unsigned int io_switch[2];
 291	unsigned int clfe_swap;
 292	hda_nid_t line_switch;	/* shared line-in for input and output */
 293	hda_nid_t mic_switch;	/* shared mic-in for input and output */
 294	hda_nid_t hp_switch; /* NID of HP as line-out */
 295	unsigned int aloopback;
 296
 297	struct hda_pcm pcm_rec[2];	/* PCM information */
 298
 299	/* dynamic controls and input_mux */
 300	struct auto_pin_cfg autocfg;
 301	struct snd_array kctls;
 302	struct hda_input_mux private_dimux;
 303	struct hda_input_mux private_imux;
 304	struct hda_input_mux private_smux;
 305	struct hda_input_mux private_mono_mux;
 306
 307	/* auto spec */
 308	unsigned auto_pin_cnt;
 309	hda_nid_t auto_pin_nids[MAX_PINS_NUM];
 310	unsigned auto_adc_cnt;
 311	hda_nid_t auto_adc_nids[MAX_ADCS_NUM];
 312	hda_nid_t auto_mux_nids[MAX_ADCS_NUM];
 313	hda_nid_t auto_dmux_nids[MAX_ADCS_NUM];
 314	unsigned long auto_capvols[MAX_ADCS_NUM];
 315	unsigned auto_dmic_cnt;
 316	hda_nid_t auto_dmic_nids[MAX_DMICS_NUM];
 317
 318	struct hda_vmaster_mute_hook vmaster_mute;
 319};
 320
 321#define AC_VERB_IDT_SET_POWER_MAP	0x7ec
 322#define AC_VERB_IDT_GET_POWER_MAP	0xfec
 323
 324static const hda_nid_t stac9200_adc_nids[1] = {
 325        0x03,
 326};
 327
 328static const hda_nid_t stac9200_mux_nids[1] = {
 329        0x0c,
 330};
 331
 332static const hda_nid_t stac9200_dac_nids[1] = {
 333        0x02,
 334};
 335
 336static const hda_nid_t stac92hd73xx_pwr_nids[8] = {
 337	0x0a, 0x0b, 0x0c, 0xd, 0x0e,
 338	0x0f, 0x10, 0x11
 339};
 340
 341static const hda_nid_t stac92hd73xx_slave_dig_outs[2] = {
 342	0x26, 0,
 343};
 344
 345static const hda_nid_t stac92hd73xx_adc_nids[2] = {
 346	0x1a, 0x1b
 347};
 348
 349#define STAC92HD73XX_NUM_DMICS	2
 350static const hda_nid_t stac92hd73xx_dmic_nids[STAC92HD73XX_NUM_DMICS + 1] = {
 351	0x13, 0x14, 0
 352};
 353
 354#define STAC92HD73_DAC_COUNT 5
 355
 356static const hda_nid_t stac92hd73xx_mux_nids[2] = {
 357	0x20, 0x21,
 358};
 359
 360static const hda_nid_t stac92hd73xx_dmux_nids[2] = {
 361	0x20, 0x21,
 362};
 363
 364static const hda_nid_t stac92hd73xx_smux_nids[2] = {
 365	0x22, 0x23,
 366};
 367
 368#define STAC92HD73XX_NUM_CAPS	2
 369static const unsigned long stac92hd73xx_capvols[] = {
 370	HDA_COMPOSE_AMP_VAL(0x20, 3, 0, HDA_OUTPUT),
 371	HDA_COMPOSE_AMP_VAL(0x21, 3, 0, HDA_OUTPUT),
 372};
 373#define stac92hd73xx_capsws	stac92hd73xx_capvols
 374
 375#define STAC92HD83_DAC_COUNT 3
 376
 377static const hda_nid_t stac92hd83xxx_pwr_nids[7] = {
 378	0x0a, 0x0b, 0x0c, 0xd, 0x0e,
 379	0x0f, 0x10
 380};
 381
 382static const hda_nid_t stac92hd83xxx_slave_dig_outs[2] = {
 383	0x1e, 0,
 384};
 385
 386static const hda_nid_t stac92hd83xxx_dmic_nids[] = {
 387		0x11, 0x20,
 388};
 389
 390static const hda_nid_t stac92hd71bxx_pwr_nids[3] = {
 391	0x0a, 0x0d, 0x0f
 392};
 393
 394static const hda_nid_t stac92hd71bxx_adc_nids[2] = {
 395	0x12, 0x13,
 396};
 397
 398static const hda_nid_t stac92hd71bxx_mux_nids[2] = {
 399	0x1a, 0x1b
 400};
 
 
 
 
 
 
 
 
 
 401
 402static const hda_nid_t stac92hd71bxx_dmux_nids[2] = {
 403	0x1c, 0x1d,
 404};
 
 
 
 
 405
 406static const hda_nid_t stac92hd71bxx_smux_nids[2] = {
 407	0x24, 0x25,
 408};
 409
 410#define STAC92HD71BXX_NUM_DMICS	2
 411static const hda_nid_t stac92hd71bxx_dmic_nids[STAC92HD71BXX_NUM_DMICS + 1] = {
 412	0x18, 0x19, 0
 413};
 
 
 414
 415static const hda_nid_t stac92hd71bxx_dmic_5port_nids[STAC92HD71BXX_NUM_DMICS] = {
 416	0x18, 0
 417};
 
 
 
 
 
 
 
 
 
 
 
 418
 419static const hda_nid_t stac92hd71bxx_slave_dig_outs[2] = {
 420	0x22, 0
 421};
 
 422
 423#define STAC92HD71BXX_NUM_CAPS		2
 424static const unsigned long stac92hd71bxx_capvols[] = {
 425	HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_OUTPUT),
 426	HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
 427};
 428#define stac92hd71bxx_capsws	stac92hd71bxx_capvols
 429
 430static const hda_nid_t stac925x_adc_nids[1] = {
 431        0x03,
 432};
 433
 434static const hda_nid_t stac925x_mux_nids[1] = {
 435        0x0f,
 436};
 437
 438static const hda_nid_t stac925x_dac_nids[1] = {
 439        0x02,
 440};
 441
 442#define STAC925X_NUM_DMICS	1
 443static const hda_nid_t stac925x_dmic_nids[STAC925X_NUM_DMICS + 1] = {
 444	0x15, 0
 445};
 446
 447static const hda_nid_t stac925x_dmux_nids[1] = {
 448	0x14,
 449};
 450
 451static const unsigned long stac925x_capvols[] = {
 452	HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_OUTPUT),
 453};
 454static const unsigned long stac925x_capsws[] = {
 455	HDA_COMPOSE_AMP_VAL(0x14, 3, 0, HDA_OUTPUT),
 456};
 457
 458static const hda_nid_t stac922x_adc_nids[2] = {
 459        0x06, 0x07,
 460};
 461
 462static const hda_nid_t stac922x_mux_nids[2] = {
 463        0x12, 0x13,
 464};
 465
 466#define STAC922X_NUM_CAPS	2
 467static const unsigned long stac922x_capvols[] = {
 468	HDA_COMPOSE_AMP_VAL(0x17, 3, 0, HDA_INPUT),
 469	HDA_COMPOSE_AMP_VAL(0x18, 3, 0, HDA_INPUT),
 470};
 471#define stac922x_capsws		stac922x_capvols
 472
 473static const hda_nid_t stac927x_slave_dig_outs[2] = {
 474	0x1f, 0,
 475};
 
 
 
 
 476
 477static const hda_nid_t stac927x_adc_nids[3] = {
 478        0x07, 0x08, 0x09
 479};
 
 480
 481static const hda_nid_t stac927x_mux_nids[3] = {
 482        0x15, 0x16, 0x17
 483};
 484
 485static const hda_nid_t stac927x_smux_nids[1] = {
 486	0x21,
 487};
 488
 489static const hda_nid_t stac927x_dac_nids[6] = {
 490	0x02, 0x03, 0x04, 0x05, 0x06, 0
 491};
 492
 493static const hda_nid_t stac927x_dmux_nids[1] = {
 494	0x1b,
 495};
 496
 497#define STAC927X_NUM_DMICS 2
 498static const hda_nid_t stac927x_dmic_nids[STAC927X_NUM_DMICS + 1] = {
 499	0x13, 0x14, 0
 500};
 501
 502#define STAC927X_NUM_CAPS	3
 503static const unsigned long stac927x_capvols[] = {
 504	HDA_COMPOSE_AMP_VAL(0x18, 3, 0, HDA_INPUT),
 505	HDA_COMPOSE_AMP_VAL(0x19, 3, 0, HDA_INPUT),
 506	HDA_COMPOSE_AMP_VAL(0x1a, 3, 0, HDA_INPUT),
 507};
 508static const unsigned long stac927x_capsws[] = {
 509	HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_OUTPUT),
 510	HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_OUTPUT),
 511	HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
 512};
 513
 514static const char * const stac927x_spdif_labels[5] = {
 515	"Digital Playback", "ADAT", "Analog Mux 1",
 516	"Analog Mux 2", "Analog Mux 3"
 517};
 518
 519static const hda_nid_t stac9205_adc_nids[2] = {
 520        0x12, 0x13
 521};
 522
 523static const hda_nid_t stac9205_mux_nids[2] = {
 524        0x19, 0x1a
 525};
 526
 527static const hda_nid_t stac9205_dmux_nids[1] = {
 528	0x1d,
 529};
 
 
 
 
 
 
 
 
 
 
 530
 531static const hda_nid_t stac9205_smux_nids[1] = {
 532	0x21,
 533};
 
 
 534
 535#define STAC9205_NUM_DMICS	2
 536static const hda_nid_t stac9205_dmic_nids[STAC9205_NUM_DMICS + 1] = {
 537        0x17, 0x18, 0
 538};
 539
 540#define STAC9205_NUM_CAPS	2
 541static const unsigned long stac9205_capvols[] = {
 542	HDA_COMPOSE_AMP_VAL(0x1b, 3, 0, HDA_INPUT),
 543	HDA_COMPOSE_AMP_VAL(0x1c, 3, 0, HDA_INPUT),
 544};
 545static const unsigned long stac9205_capsws[] = {
 546	HDA_COMPOSE_AMP_VAL(0x1d, 3, 0, HDA_OUTPUT),
 547	HDA_COMPOSE_AMP_VAL(0x1e, 3, 0, HDA_OUTPUT),
 548};
 549
 550static const hda_nid_t stac9200_pin_nids[8] = {
 551	0x08, 0x09, 0x0d, 0x0e, 
 552	0x0f, 0x10, 0x11, 0x12,
 553};
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 554
 555static const hda_nid_t stac925x_pin_nids[8] = {
 556	0x07, 0x08, 0x0a, 0x0b, 
 557	0x0c, 0x0d, 0x10, 0x11,
 558};
 
 559
 560static const hda_nid_t stac922x_pin_nids[10] = {
 561	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
 562	0x0f, 0x10, 0x11, 0x15, 0x1b,
 563};
 
 
 564
 565static const hda_nid_t stac92hd73xx_pin_nids[13] = {
 566	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
 567	0x0f, 0x10, 0x11, 0x12, 0x13,
 568	0x14, 0x22, 0x23
 569};
 570
 571#define STAC92HD71BXX_NUM_PINS 13
 572static const hda_nid_t stac92hd71bxx_pin_nids_4port[STAC92HD71BXX_NUM_PINS] = {
 573	0x0a, 0x0b, 0x0c, 0x0d, 0x00,
 574	0x00, 0x14, 0x18, 0x19, 0x1e,
 575	0x1f, 0x20, 0x27
 576};
 577static const hda_nid_t stac92hd71bxx_pin_nids_6port[STAC92HD71BXX_NUM_PINS] = {
 578	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
 579	0x0f, 0x14, 0x18, 0x19, 0x1e,
 580	0x1f, 0x20, 0x27
 581};
 582
 583static const hda_nid_t stac927x_pin_nids[14] = {
 584	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
 585	0x0f, 0x10, 0x11, 0x12, 0x13,
 586	0x14, 0x21, 0x22, 0x23,
 587};
 588
 589static const hda_nid_t stac9205_pin_nids[12] = {
 590	0x0a, 0x0b, 0x0c, 0x0d, 0x0e,
 591	0x0f, 0x14, 0x16, 0x17, 0x18,
 592	0x21, 0x22,
 593};
 594
 595static int stac92xx_dmux_enum_info(struct snd_kcontrol *kcontrol,
 596				   struct snd_ctl_elem_info *uinfo)
 
 597{
 598	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 599	struct sigmatel_spec *spec = codec->spec;
 600	return snd_hda_input_mux_info(spec->dinput_mux, uinfo);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 601}
 602
 603static int stac92xx_dmux_enum_get(struct snd_kcontrol *kcontrol,
 604				  struct snd_ctl_elem_value *ucontrol)
 605{
 606	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 607	struct sigmatel_spec *spec = codec->spec;
 608	unsigned int dmux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 609
 610	ucontrol->value.enumerated.item[0] = spec->cur_dmux[dmux_idx];
 611	return 0;
 
 
 
 612}
 613
 614static int stac92xx_dmux_enum_put(struct snd_kcontrol *kcontrol,
 615				  struct snd_ctl_elem_value *ucontrol)
 
 
 616{
 617	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 618	struct sigmatel_spec *spec = codec->spec;
 619	unsigned int dmux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 620
 621	return snd_hda_input_mux_put(codec, spec->dinput_mux, ucontrol,
 622			spec->dmux_nids[dmux_idx], &spec->cur_dmux[dmux_idx]);
 
 
 
 
 
 623}
 624
 625static int stac92xx_smux_enum_info(struct snd_kcontrol *kcontrol,
 626				   struct snd_ctl_elem_info *uinfo)
 627{
 628	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 629	struct sigmatel_spec *spec = codec->spec;
 630	return snd_hda_input_mux_info(spec->sinput_mux, uinfo);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 631}
 632
 633static int stac92xx_smux_enum_get(struct snd_kcontrol *kcontrol,
 634				  struct snd_ctl_elem_value *ucontrol)
 
 
 
 
 
 
 635{
 636	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 
 637	struct sigmatel_spec *spec = codec->spec;
 638	unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 639
 640	ucontrol->value.enumerated.item[0] = spec->cur_smux[smux_idx];
 
 641	return 0;
 642}
 643
 644static int stac92xx_smux_enum_put(struct snd_kcontrol *kcontrol,
 645				  struct snd_ctl_elem_value *ucontrol)
 646{
 647	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 648	struct sigmatel_spec *spec = codec->spec;
 649	struct hda_input_mux *smux = &spec->private_smux;
 650	unsigned int smux_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 651	int err, val;
 652	hda_nid_t nid;
 
 
 
 
 
 
 
 
 
 653
 654	err = snd_hda_input_mux_put(codec, spec->sinput_mux, ucontrol,
 655			spec->smux_nids[smux_idx], &spec->cur_smux[smux_idx]);
 656	if (err < 0)
 657		return err;
 
 
 658
 659	if (spec->spdif_mute) {
 660		if (smux_idx == 0)
 661			nid = spec->multiout.dig_out_nid;
 662		else
 663			nid = codec->slave_dig_outs[smux_idx - 1];
 664		if (spec->cur_smux[smux_idx] == smux->num_items - 1)
 665			val = HDA_AMP_MUTE;
 666		else
 667			val = 0;
 668		/* un/mute SPDIF out */
 669		snd_hda_codec_amp_stereo(codec, nid, HDA_OUTPUT, 0,
 670					 HDA_AMP_MUTE, val);
 671	}
 672	return 0;
 
 
 
 
 673}
 674
 675static int stac_vrefout_set(struct hda_codec *codec,
 676					hda_nid_t nid, unsigned int new_vref)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 677{
 678	int error, pinctl;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 679
 680	snd_printdd("%s, nid %x ctl %x\n", __func__, nid, new_vref);
 681	pinctl = snd_hda_codec_read(codec, nid, 0,
 682				AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
 683
 684	if (pinctl < 0)
 685		return pinctl;
 
 686
 687	pinctl &= 0xff;
 688	pinctl &= ~AC_PINCTL_VREFEN;
 689	pinctl |= (new_vref & AC_PINCTL_VREFEN);
 
 690
 691	error = snd_hda_set_pin_ctl_cache(codec, nid, pinctl);
 692	if (error < 0)
 693		return error;
 694
 695	return 1;
 
 
 696}
 697
 698static unsigned int stac92xx_vref_set(struct hda_codec *codec,
 699					hda_nid_t nid, unsigned int new_vref)
 700{
 701	int error;
 702	unsigned int pincfg;
 703	pincfg = snd_hda_codec_read(codec, nid, 0,
 704				AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 705
 706	pincfg &= 0xff;
 707	pincfg &= ~(AC_PINCTL_VREFEN | AC_PINCTL_IN_EN | AC_PINCTL_OUT_EN);
 708	pincfg |= new_vref;
 
 709
 710	if (new_vref == AC_PINCTL_VREF_HIZ)
 711		pincfg |= AC_PINCTL_OUT_EN;
 712	else
 713		pincfg |= AC_PINCTL_IN_EN;
 714
 715	error = snd_hda_set_pin_ctl_cache(codec, nid, pincfg);
 716	if (error < 0)
 717		return error;
 
 718	else
 719		return 1;
 720}
 721
 722static unsigned int stac92xx_vref_get(struct hda_codec *codec, hda_nid_t nid)
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 723{
 724	unsigned int vref;
 725	vref = snd_hda_codec_read(codec, nid, 0,
 726				AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
 727	vref &= AC_PINCTL_VREFEN;
 728	return vref;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 729}
 730
 731static int stac92xx_mux_enum_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
 
 732{
 733	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 734	struct sigmatel_spec *spec = codec->spec;
 735	return snd_hda_input_mux_info(spec->input_mux, uinfo);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 736}
 737
 738static int stac92xx_mux_enum_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
 
 
 
 
 
 
 739{
 740	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 741	struct sigmatel_spec *spec = codec->spec;
 742	unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 743
 744	ucontrol->value.enumerated.item[0] = spec->cur_mux[adc_idx];
 
 
 
 
 
 
 
 
 
 745	return 0;
 746}
 747
 748static int stac92xx_mux_enum_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
 
 
 
 
 749{
 750	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 751	struct sigmatel_spec *spec = codec->spec;
 752	unsigned int adc_idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 753	const struct hda_input_mux *imux = spec->input_mux;
 754	unsigned int idx, prev_idx, didx;
 755
 756	idx = ucontrol->value.enumerated.item[0];
 757	if (idx >= imux->num_items)
 758		idx = imux->num_items - 1;
 759	prev_idx = spec->cur_mux[adc_idx];
 760	if (prev_idx == idx)
 761		return 0;
 762	if (idx < spec->num_analog_muxes) {
 763		snd_hda_codec_write_cache(codec, spec->mux_nids[adc_idx], 0,
 764					  AC_VERB_SET_CONNECT_SEL,
 765					  imux->items[idx].index);
 766		if (prev_idx >= spec->num_analog_muxes &&
 767		    spec->mux_nids[adc_idx] != spec->dmux_nids[adc_idx]) {
 768			imux = spec->dinput_mux;
 769			/* 0 = analog */
 770			snd_hda_codec_write_cache(codec,
 771						  spec->dmux_nids[adc_idx], 0,
 772						  AC_VERB_SET_CONNECT_SEL,
 773						  imux->items[0].index);
 774		}
 775	} else {
 776		imux = spec->dinput_mux;
 777		/* first dimux item is hardcoded to select analog imux,
 778		 * so lets skip it
 779		 */
 780		didx = idx - spec->num_analog_muxes + 1;
 781		snd_hda_codec_write_cache(codec, spec->dmux_nids[adc_idx], 0,
 782					  AC_VERB_SET_CONNECT_SEL,
 783					  imux->items[didx].index);
 784	}
 785	spec->cur_mux[adc_idx] = idx;
 786	return 1;
 787}
 788
 789static int stac92xx_mono_mux_enum_info(struct snd_kcontrol *kcontrol,
 790	struct snd_ctl_elem_info *uinfo)
 791{
 792	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 793	struct sigmatel_spec *spec = codec->spec;
 794	return snd_hda_input_mux_info(spec->mono_mux, uinfo);
 795}
 796
 797static int stac92xx_mono_mux_enum_get(struct snd_kcontrol *kcontrol,
 798	struct snd_ctl_elem_value *ucontrol)
 
 
 
 
 
 
 
 799{
 800	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 801	struct sigmatel_spec *spec = codec->spec;
 802
 803	ucontrol->value.enumerated.item[0] = spec->cur_mmux;
 
 804	return 0;
 805}
 
 806
 807static int stac92xx_mono_mux_enum_put(struct snd_kcontrol *kcontrol,
 808	struct snd_ctl_elem_value *ucontrol)
 
 
 
 
 809{
 810	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 811	struct sigmatel_spec *spec = codec->spec;
 812
 813	return snd_hda_input_mux_put(codec, spec->mono_mux, ucontrol,
 814				     spec->mono_nid, &spec->cur_mmux);
 815}
 816
 817#define stac92xx_aloopback_info snd_ctl_boolean_mono_info
 818
 819static int stac92xx_aloopback_get(struct snd_kcontrol *kcontrol,
 820	struct snd_ctl_elem_value *ucontrol)
 821{
 822	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 823	unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 824	struct sigmatel_spec *spec = codec->spec;
 
 825
 826	ucontrol->value.integer.value[0] = !!(spec->aloopback &
 827					      (spec->aloopback_mask << idx));
 828	return 0;
 829}
 830
 831static int stac92xx_aloopback_put(struct snd_kcontrol *kcontrol,
 832		struct snd_ctl_elem_value *ucontrol)
 833{
 834	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
 835	struct sigmatel_spec *spec = codec->spec;
 836	unsigned int idx = snd_ctl_get_ioffidx(kcontrol, &ucontrol->id);
 837	unsigned int dac_mode;
 838	unsigned int val, idx_val;
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 839
 840	idx_val = spec->aloopback_mask << idx;
 841	if (ucontrol->value.integer.value[0])
 842		val = spec->aloopback | idx_val;
 843	else
 844		val = spec->aloopback & ~idx_val;
 845	if (spec->aloopback == val)
 846		return 0;
 847
 848	spec->aloopback = val;
 
 
 849
 850	/* Only return the bits defined by the shift value of the
 851	 * first two bytes of the mask
 852	 */
 853	dac_mode = snd_hda_codec_read(codec, codec->afg, 0,
 854				      kcontrol->private_value & 0xFFFF, 0x0);
 855	dac_mode >>= spec->aloopback_shift;
 856
 857	if (spec->aloopback & idx_val) {
 858		snd_hda_power_up(codec);
 859		dac_mode |= idx_val;
 860	} else {
 861		snd_hda_power_down(codec);
 862		dac_mode &= ~idx_val;
 863	}
 864
 865	snd_hda_codec_write_cache(codec, codec->afg, 0,
 866		kcontrol->private_value >> 16, dac_mode);
 
 
 867
 868	return 1;
 869}
 870
 871static const struct hda_verb stac9200_core_init[] = {
 872	/* set dac0mux for dac converter */
 873	{ 0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
 874	{}
 875};
 876
 877static const struct hda_verb stac9200_eapd_init[] = {
 878	/* set dac0mux for dac converter */
 879	{0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
 880	{0x08, AC_VERB_SET_EAPD_BTLENABLE, 0x02},
 881	{}
 882};
 883
 884static const struct hda_verb dell_eq_core_init[] = {
 885	/* set master volume to max value without distortion
 886	 * and direct control */
 887	{ 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xec},
 888	{}
 889};
 890
 891static const struct hda_verb stac92hd73xx_core_init[] = {
 892	/* set master volume and direct control */
 893	{ 0x1f, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 894	{}
 895};
 896
 897static const struct hda_verb stac92hd83xxx_core_init[] = {
 898	/* power state controls amps */
 899	{ 0x01, AC_VERB_SET_EAPD, 1 << 2},
 900	{}
 901};
 902
 903static const struct hda_verb stac92hd83xxx_hp_zephyr_init[] = {
 904	{ 0x22, 0x785, 0x43 },
 905	{ 0x22, 0x782, 0xe0 },
 906	{ 0x22, 0x795, 0x00 },
 907	{}
 908};
 909
 910static const struct hda_verb stac92hd71bxx_core_init[] = {
 911	/* set master volume and direct control */
 912	{ 0x28, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 913	{}
 914};
 915
 916static const struct hda_verb stac92hd71bxx_unmute_core_init[] = {
 917	/* unmute right and left channels for nodes 0x0f, 0xa, 0x0d */
 918	{ 0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
 919	{ 0x0a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
 920	{ 0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
 921	{}
 922};
 923
 924static const struct hda_verb stac925x_core_init[] = {
 925	/* set dac0mux for dac converter */
 926	{ 0x06, AC_VERB_SET_CONNECT_SEL, 0x00},
 927	/* mute the master volume */
 928	{ 0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE },
 929	{}
 930};
 931
 932static const struct hda_verb stac922x_core_init[] = {
 933	/* set master volume and direct control */	
 934	{ 0x16, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 935	{}
 936};
 937
 938static const struct hda_verb d965_core_init[] = {
 939	/* set master volume and direct control */	
 940	{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 941	/* unmute node 0x1b */
 942	{ 0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
 943	/* select node 0x03 as DAC */	
 944	{ 0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
 945	{}
 946};
 947
 948static const struct hda_verb dell_3st_core_init[] = {
 949	/* don't set delta bit */
 950	{0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
 951	/* unmute node 0x1b */
 952	{0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0xb000},
 953	/* select node 0x03 as DAC */
 954	{0x0b, AC_VERB_SET_CONNECT_SEL, 0x01},
 955	{}
 956};
 957
 958static const struct hda_verb stac927x_core_init[] = {
 959	/* set master volume and direct control */	
 960	{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 961	/* enable analog pc beep path */
 962	{ 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
 963	{}
 964};
 965
 966static const struct hda_verb stac927x_volknob_core_init[] = {
 967	/* don't set delta bit */
 968	{0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0x7f},
 969	/* enable analog pc beep path */
 970	{0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
 971	{}
 972};
 973
 974static const struct hda_verb stac9205_core_init[] = {
 975	/* set master volume and direct control */	
 976	{ 0x24, AC_VERB_SET_VOLUME_KNOB_CONTROL, 0xff},
 977	/* enable analog pc beep path */
 978	{ 0x01, AC_VERB_SET_DIGI_CONVERT_2, 1 << 5},
 979	{}
 980};
 981
 982#define STAC_MONO_MUX \
 983	{ \
 984		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
 985		.name = "Mono Mux", \
 986		.count = 1, \
 987		.info = stac92xx_mono_mux_enum_info, \
 988		.get = stac92xx_mono_mux_enum_get, \
 989		.put = stac92xx_mono_mux_enum_put, \
 990	}
 991
 992#define STAC_ANALOG_LOOPBACK(verb_read, verb_write, cnt) \
 993	{ \
 994		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
 995		.name  = "Analog Loopback", \
 996		.count = cnt, \
 997		.info  = stac92xx_aloopback_info, \
 998		.get   = stac92xx_aloopback_get, \
 999		.put   = stac92xx_aloopback_put, \
1000		.private_value = verb_read | (verb_write << 16), \
1001	}
1002
1003#define DC_BIAS(xname, idx, nid) \
1004	{ \
1005		.iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
1006		.name = xname, \
1007		.index = idx, \
1008		.info = stac92xx_dc_bias_info, \
1009		.get = stac92xx_dc_bias_get, \
1010		.put = stac92xx_dc_bias_put, \
1011		.private_value = nid, \
1012	}
1013
1014static const struct snd_kcontrol_new stac9200_mixer[] = {
1015	HDA_CODEC_VOLUME_MIN_MUTE("PCM Playback Volume", 0xb, 0, HDA_OUTPUT),
1016	HDA_CODEC_MUTE("PCM Playback Switch", 0xb, 0, HDA_OUTPUT),
1017	HDA_CODEC_VOLUME("Capture Volume", 0x0a, 0, HDA_OUTPUT),
1018	HDA_CODEC_MUTE("Capture Switch", 0x0a, 0, HDA_OUTPUT),
1019	{ } /* end */
1020};
1021
1022static const struct snd_kcontrol_new stac92hd73xx_6ch_loopback[] = {
1023	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 3),
1024	{}
1025};
1026
1027static const struct snd_kcontrol_new stac92hd73xx_8ch_loopback[] = {
1028	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 4),
1029	{}
1030};
1031
1032static const struct snd_kcontrol_new stac92hd73xx_10ch_loopback[] = {
1033	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A1, 5),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1034	{}
1035};
1036
1037
1038static const struct snd_kcontrol_new stac92hd71bxx_loopback[] = {
1039	STAC_ANALOG_LOOPBACK(0xFA0, 0x7A0, 2)
1040};
1041
1042static const struct snd_kcontrol_new stac925x_mixer[] = {
1043	HDA_CODEC_VOLUME_MIN_MUTE("PCM Playback Volume", 0xe, 0, HDA_OUTPUT),
1044	HDA_CODEC_MUTE("PCM Playback Switch", 0x0e, 0, HDA_OUTPUT),
1045	{ } /* end */
1046};
1047
1048static const struct snd_kcontrol_new stac9205_loopback[] = {
1049	STAC_ANALOG_LOOPBACK(0xFE0, 0x7E0, 1),
1050	{}
1051};
1052
1053static const struct snd_kcontrol_new stac927x_loopback[] = {
1054	STAC_ANALOG_LOOPBACK(0xFEB, 0x7EB, 1),
 
 
 
 
 
 
 
1055	{}
1056};
1057
1058static struct snd_kcontrol_new stac_dmux_mixer = {
1059	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1060	.name = "Digital Input Source",
1061	/* count set later */
1062	.info = stac92xx_dmux_enum_info,
1063	.get = stac92xx_dmux_enum_get,
1064	.put = stac92xx_dmux_enum_put,
1065};
1066
1067static struct snd_kcontrol_new stac_smux_mixer = {
1068	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
1069	.name = "IEC958 Playback Source",
1070	/* count set later */
1071	.info = stac92xx_smux_enum_info,
1072	.get = stac92xx_smux_enum_get,
1073	.put = stac92xx_smux_enum_put,
1074};
1075
1076static const char * const slave_pfxs[] = {
1077	"Front", "Surround", "Center", "LFE", "Side",
1078	"Headphone", "Speaker", "IEC958", "PCM",
1079	NULL
1080};
1081
1082static void stac92xx_update_led_status(struct hda_codec *codec, int enabled);
1083
1084static void stac92xx_vmaster_hook(void *private_data, int val)
1085{
1086	stac92xx_update_led_status(private_data, val);
1087}
1088
1089static void stac92xx_free_kctls(struct hda_codec *codec);
1090
1091static int stac92xx_build_controls(struct hda_codec *codec)
1092{
1093	struct sigmatel_spec *spec = codec->spec;
1094	unsigned int vmaster_tlv[4];
1095	int err;
1096	int i;
1097
1098	if (spec->mixer) {
1099		err = snd_hda_add_new_ctls(codec, spec->mixer);
1100		if (err < 0)
1101			return err;
1102	}
1103
1104	for (i = 0; i < spec->num_mixers; i++) {
1105		err = snd_hda_add_new_ctls(codec, spec->mixers[i]);
1106		if (err < 0)
1107			return err;
1108	}
1109	if (!spec->auto_mic && spec->num_dmuxes > 0 &&
1110	    snd_hda_get_bool_hint(codec, "separate_dmux") == 1) {
1111		stac_dmux_mixer.count = spec->num_dmuxes;
1112		err = snd_hda_ctl_add(codec, 0,
1113				  snd_ctl_new1(&stac_dmux_mixer, codec));
1114		if (err < 0)
1115			return err;
1116	}
1117	if (spec->num_smuxes > 0) {
1118		int wcaps = get_wcaps(codec, spec->multiout.dig_out_nid);
1119		struct hda_input_mux *smux = &spec->private_smux;
1120		/* check for mute support on SPDIF out */
1121		if (wcaps & AC_WCAP_OUT_AMP) {
1122			snd_hda_add_imux_item(smux, "Off", 0, NULL);
1123			spec->spdif_mute = 1;
1124		}
1125		stac_smux_mixer.count = spec->num_smuxes;
1126		err = snd_hda_ctl_add(codec, 0,
1127				  snd_ctl_new1(&stac_smux_mixer, codec));
1128		if (err < 0)
1129			return err;
1130	}
1131
1132	if (spec->multiout.dig_out_nid) {
1133		err = snd_hda_create_spdif_out_ctls(codec,
1134						    spec->multiout.dig_out_nid,
1135						    spec->multiout.dig_out_nid);
1136		if (err < 0)
1137			return err;
1138		err = snd_hda_create_spdif_share_sw(codec,
1139						    &spec->multiout);
1140		if (err < 0)
1141			return err;
1142		spec->multiout.share_spdif = 1;
1143	}
1144	if (spec->dig_in_nid && !(spec->gpio_dir & 0x01)) {
1145		err = snd_hda_create_spdif_in_ctls(codec, spec->dig_in_nid);
1146		if (err < 0)
1147			return err;
1148	}
1149
1150	/* if we have no master control, let's create it */
1151	snd_hda_set_vmaster_tlv(codec, spec->multiout.dac_nids[0],
1152				HDA_OUTPUT, vmaster_tlv);
1153	/* correct volume offset */
1154	vmaster_tlv[2] += vmaster_tlv[3] * spec->volume_offset;
1155	/* minimum value is actually mute */
1156	vmaster_tlv[3] |= TLV_DB_SCALE_MUTE;
1157	err = snd_hda_add_vmaster(codec, "Master Playback Volume",
1158				  vmaster_tlv, slave_pfxs,
1159				  "Playback Volume");
1160	if (err < 0)
1161		return err;
1162
1163	err = __snd_hda_add_vmaster(codec, "Master Playback Switch",
1164				    NULL, slave_pfxs,
1165				    "Playback Switch", true,
1166				    &spec->vmaster_mute.sw_kctl);
1167	if (err < 0)
1168		return err;
1169
1170	if (spec->gpio_led) {
1171		spec->vmaster_mute.hook = stac92xx_vmaster_hook;
1172		err = snd_hda_add_vmaster_hook(codec, &spec->vmaster_mute, true);
1173		if (err < 0)
1174			return err;
1175	}
1176
1177	if (spec->aloopback_ctl &&
1178	    snd_hda_get_bool_hint(codec, "loopback") == 1) {
1179		err = snd_hda_add_new_ctls(codec, spec->aloopback_ctl);
1180		if (err < 0)
1181			return err;
1182	}
1183
1184	stac92xx_free_kctls(codec); /* no longer needed */
1185
1186	err = snd_hda_jack_add_kctls(codec, &spec->autocfg);
1187	if (err < 0)
1188		return err;
1189
1190	return 0;	
1191}
1192
1193static const unsigned int ref9200_pin_configs[8] = {
1194	0x01c47010, 0x01447010, 0x0221401f, 0x01114010,
1195	0x02a19020, 0x01a19021, 0x90100140, 0x01813122,
1196};
1197
1198static const unsigned int gateway9200_m4_pin_configs[8] = {
1199	0x400000fe, 0x404500f4, 0x400100f0, 0x90110010,
1200	0x400100f1, 0x02a1902e, 0x500000f2, 0x500000f3,
1201};
1202static const unsigned int gateway9200_m4_2_pin_configs[8] = {
1203	0x400000fe, 0x404500f4, 0x400100f0, 0x90110010,
1204	0x400100f1, 0x02a1902e, 0x500000f2, 0x500000f3,
1205};
1206
1207/*
1208    STAC 9200 pin configs for
1209    102801A8
1210    102801DE
1211    102801E8
1212*/
1213static const unsigned int dell9200_d21_pin_configs[8] = {
1214	0x400001f0, 0x400001f1, 0x02214030, 0x01014010, 
1215	0x02a19020, 0x01a19021, 0x90100140, 0x01813122,
 
 
 
 
 
 
 
1216};
1217
1218/* 
1219    STAC 9200 pin configs for
1220    102801C0
1221    102801C1
1222*/
1223static const unsigned int dell9200_d22_pin_configs[8] = {
1224	0x400001f0, 0x400001f1, 0x0221401f, 0x01014010, 
1225	0x01813020, 0x02a19021, 0x90100140, 0x400001f2,
 
 
 
 
 
 
 
1226};
1227
1228/* 
1229    STAC 9200 pin configs for
1230    102801C4 (Dell Dimension E310)
1231    102801C5
1232    102801C7
1233    102801D9
1234    102801DA
1235    102801E3
1236*/
1237static const unsigned int dell9200_d23_pin_configs[8] = {
1238	0x400001f0, 0x400001f1, 0x0221401f, 0x01014010, 
1239	0x01813020, 0x01a19021, 0x90100140, 0x400001f2, 
 
 
 
 
 
 
 
1240};
1241
1242
1243/* 
1244    STAC 9200-32 pin configs for
1245    102801B5 (Dell Inspiron 630m)
1246    102801D8 (Dell Inspiron 640m)
1247*/
1248static const unsigned int dell9200_m21_pin_configs[8] = {
1249	0x40c003fa, 0x03441340, 0x0321121f, 0x90170310,
1250	0x408003fb, 0x03a11020, 0x401003fc, 0x403003fd,
 
 
 
 
 
 
 
1251};
1252
1253/* 
1254    STAC 9200-32 pin configs for
1255    102801C2 (Dell Latitude D620)
1256    102801C8 
1257    102801CC (Dell Latitude D820)
1258    102801D4 
1259    102801D6 
1260*/
1261static const unsigned int dell9200_m22_pin_configs[8] = {
1262	0x40c003fa, 0x0144131f, 0x0321121f, 0x90170310, 
1263	0x90a70321, 0x03a11020, 0x401003fb, 0x40f000fc,
 
 
 
 
 
 
 
1264};
1265
1266/* 
1267    STAC 9200-32 pin configs for
1268    102801CE (Dell XPS M1710)
1269    102801CF (Dell Precision M90)
1270*/
1271static const unsigned int dell9200_m23_pin_configs[8] = {
1272	0x40c003fa, 0x01441340, 0x0421421f, 0x90170310,
1273	0x408003fb, 0x04a1102e, 0x90170311, 0x403003fc,
 
 
 
 
 
 
 
1274};
1275
1276/*
1277    STAC 9200-32 pin configs for 
1278    102801C9
1279    102801CA
1280    102801CB (Dell Latitude 120L)
1281    102801D3
1282*/
1283static const unsigned int dell9200_m24_pin_configs[8] = {
1284	0x40c003fa, 0x404003fb, 0x0321121f, 0x90170310, 
1285	0x408003fc, 0x03a11020, 0x401003fd, 0x403003fe, 
 
 
 
 
 
 
 
1286};
1287
1288/*
1289    STAC 9200-32 pin configs for
1290    102801BD (Dell Inspiron E1505n)
1291    102801EE
1292    102801EF
1293*/
1294static const unsigned int dell9200_m25_pin_configs[8] = {
1295	0x40c003fa, 0x01441340, 0x0421121f, 0x90170310, 
1296	0x408003fb, 0x04a11020, 0x401003fc, 0x403003fd,
 
 
 
 
 
 
 
1297};
1298
1299/*
1300    STAC 9200-32 pin configs for
1301    102801F5 (Dell Inspiron 1501)
1302    102801F6
1303*/
1304static const unsigned int dell9200_m26_pin_configs[8] = {
1305	0x40c003fa, 0x404003fb, 0x0421121f, 0x90170310, 
1306	0x408003fc, 0x04a11020, 0x401003fd, 0x403003fe,
 
 
 
 
 
 
 
1307};
1308
1309/*
1310    STAC 9200-32
1311    102801CD (Dell Inspiron E1705/9400)
1312*/
1313static const unsigned int dell9200_m27_pin_configs[8] = {
1314	0x40c003fa, 0x01441340, 0x0421121f, 0x90170310,
1315	0x90170310, 0x04a11020, 0x90170310, 0x40f003fc,
1316};
1317
1318static const unsigned int oqo9200_pin_configs[8] = {
1319	0x40c000f0, 0x404000f1, 0x0221121f, 0x02211210,
1320	0x90170111, 0x90a70120, 0x400000f2, 0x400000f3,
 
 
1321};
1322
 
 
 
 
 
 
 
 
 
 
 
1323
1324static const unsigned int *stac9200_brd_tbl[STAC_9200_MODELS] = {
1325	[STAC_REF] = ref9200_pin_configs,
1326	[STAC_9200_OQO] = oqo9200_pin_configs,
1327	[STAC_9200_DELL_D21] = dell9200_d21_pin_configs,
1328	[STAC_9200_DELL_D22] = dell9200_d22_pin_configs,
1329	[STAC_9200_DELL_D23] = dell9200_d23_pin_configs,
1330	[STAC_9200_DELL_M21] = dell9200_m21_pin_configs,
1331	[STAC_9200_DELL_M22] = dell9200_m22_pin_configs,
1332	[STAC_9200_DELL_M23] = dell9200_m23_pin_configs,
1333	[STAC_9200_DELL_M24] = dell9200_m24_pin_configs,
1334	[STAC_9200_DELL_M25] = dell9200_m25_pin_configs,
1335	[STAC_9200_DELL_M26] = dell9200_m26_pin_configs,
1336	[STAC_9200_DELL_M27] = dell9200_m27_pin_configs,
1337	[STAC_9200_M4] = gateway9200_m4_pin_configs,
1338	[STAC_9200_M4_2] = gateway9200_m4_2_pin_configs,
1339	[STAC_9200_PANASONIC] = ref9200_pin_configs,
1340};
1341
1342static const char * const stac9200_models[STAC_9200_MODELS] = {
1343	[STAC_AUTO] = "auto",
1344	[STAC_REF] = "ref",
1345	[STAC_9200_OQO] = "oqo",
1346	[STAC_9200_DELL_D21] = "dell-d21",
1347	[STAC_9200_DELL_D22] = "dell-d22",
1348	[STAC_9200_DELL_D23] = "dell-d23",
1349	[STAC_9200_DELL_M21] = "dell-m21",
1350	[STAC_9200_DELL_M22] = "dell-m22",
1351	[STAC_9200_DELL_M23] = "dell-m23",
1352	[STAC_9200_DELL_M24] = "dell-m24",
1353	[STAC_9200_DELL_M25] = "dell-m25",
1354	[STAC_9200_DELL_M26] = "dell-m26",
1355	[STAC_9200_DELL_M27] = "dell-m27",
1356	[STAC_9200_M4] = "gateway-m4",
1357	[STAC_9200_M4_2] = "gateway-m4-2",
1358	[STAC_9200_PANASONIC] = "panasonic",
1359};
1360
1361static const struct snd_pci_quirk stac9200_cfg_tbl[] = {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1362	/* SigmaTel reference board */
1363	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1364		      "DFI LanParty", STAC_REF),
1365	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1366		      "DFI LanParty", STAC_REF),
1367	/* Dell laptops have BIOS problem */
1368	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a8,
1369		      "unknown Dell", STAC_9200_DELL_D21),
1370	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01b5,
1371		      "Dell Inspiron 630m", STAC_9200_DELL_M21),
1372	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bd,
1373		      "Dell Inspiron E1505n", STAC_9200_DELL_M25),
1374	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c0,
1375		      "unknown Dell", STAC_9200_DELL_D22),
1376	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c1,
1377		      "unknown Dell", STAC_9200_DELL_D22),
1378	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c2,
1379		      "Dell Latitude D620", STAC_9200_DELL_M22),
1380	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c5,
1381		      "unknown Dell", STAC_9200_DELL_D23),
1382	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c7,
1383		      "unknown Dell", STAC_9200_DELL_D23),
1384	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c8,
1385		      "unknown Dell", STAC_9200_DELL_M22),
1386	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01c9,
1387		      "unknown Dell", STAC_9200_DELL_M24),
1388	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ca,
1389		      "unknown Dell", STAC_9200_DELL_M24),
1390	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cb,
1391		      "Dell Latitude 120L", STAC_9200_DELL_M24),
1392	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cc,
1393		      "Dell Latitude D820", STAC_9200_DELL_M22),
1394	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cd,
1395		      "Dell Inspiron E1705/9400", STAC_9200_DELL_M27),
1396	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ce,
1397		      "Dell XPS M1710", STAC_9200_DELL_M23),
1398	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01cf,
1399		      "Dell Precision M90", STAC_9200_DELL_M23),
1400	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d3,
1401		      "unknown Dell", STAC_9200_DELL_M22),
1402	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d4,
1403		      "unknown Dell", STAC_9200_DELL_M22),
1404	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d6,
1405		      "unknown Dell", STAC_9200_DELL_M22),
1406	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d8,
1407		      "Dell Inspiron 640m", STAC_9200_DELL_M21),
1408	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d9,
1409		      "unknown Dell", STAC_9200_DELL_D23),
1410	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01da,
1411		      "unknown Dell", STAC_9200_DELL_D23),
1412	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01de,
1413		      "unknown Dell", STAC_9200_DELL_D21),
1414	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e3,
1415		      "unknown Dell", STAC_9200_DELL_D23),
1416	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01e8,
1417		      "unknown Dell", STAC_9200_DELL_D21),
1418	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ee,
1419		      "unknown Dell", STAC_9200_DELL_M25),
1420	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ef,
1421		      "unknown Dell", STAC_9200_DELL_M25),
1422	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f5,
1423		      "Dell Inspiron 1501", STAC_9200_DELL_M26),
1424	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f6,
1425		      "unknown Dell", STAC_9200_DELL_M26),
 
 
1426	/* Panasonic */
1427	SND_PCI_QUIRK(0x10f7, 0x8338, "Panasonic CF-74", STAC_9200_PANASONIC),
1428	/* Gateway machines needs EAPD to be set on resume */
1429	SND_PCI_QUIRK(0x107b, 0x0205, "Gateway S-7110M", STAC_9200_M4),
1430	SND_PCI_QUIRK(0x107b, 0x0317, "Gateway MT3423, MX341*", STAC_9200_M4_2),
1431	SND_PCI_QUIRK(0x107b, 0x0318, "Gateway ML3019, MT3707", STAC_9200_M4_2),
1432	/* OQO Mobile */
1433	SND_PCI_QUIRK(0x1106, 0x3288, "OQO Model 2", STAC_9200_OQO),
1434	{} /* terminator */
1435};
1436
1437static const unsigned int ref925x_pin_configs[8] = {
1438	0x40c003f0, 0x424503f2, 0x01813022, 0x02a19021,
1439	0x90a70320, 0x02214210, 0x01019020, 0x9033032e,
 
 
 
 
 
 
 
1440};
1441
1442static const unsigned int stac925xM1_pin_configs[8] = {
1443	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1444	0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
 
 
 
 
 
 
 
1445};
1446
1447static const unsigned int stac925xM1_2_pin_configs[8] = {
1448	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1449	0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
 
 
 
 
 
 
 
1450};
1451
1452static const unsigned int stac925xM2_pin_configs[8] = {
1453	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1454	0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
 
 
 
 
 
 
 
1455};
1456
1457static const unsigned int stac925xM2_2_pin_configs[8] = {
1458	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1459	0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
 
 
 
 
 
 
 
1460};
1461
1462static const unsigned int stac925xM3_pin_configs[8] = {
1463	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1464	0x40a000f0, 0x90100210, 0x400003f1, 0x503303f3,
 
 
 
 
 
 
 
1465};
1466
1467static const unsigned int stac925xM5_pin_configs[8] = {
1468	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1469	0x40a000f0, 0x90100210, 0x400003f1, 0x9033032e,
 
 
 
 
 
 
 
1470};
1471
1472static const unsigned int stac925xM6_pin_configs[8] = {
1473	0x40c003f4, 0x424503f2, 0x400000f3, 0x02a19020,
1474	0x40a000f0, 0x90100210, 0x400003f1, 0x90330320,
 
 
 
 
 
 
 
1475};
1476
1477static const unsigned int *stac925x_brd_tbl[STAC_925x_MODELS] = {
1478	[STAC_REF] = ref925x_pin_configs,
1479	[STAC_M1] = stac925xM1_pin_configs,
1480	[STAC_M1_2] = stac925xM1_2_pin_configs,
1481	[STAC_M2] = stac925xM2_pin_configs,
1482	[STAC_M2_2] = stac925xM2_2_pin_configs,
1483	[STAC_M3] = stac925xM3_pin_configs,
1484	[STAC_M5] = stac925xM5_pin_configs,
1485	[STAC_M6] = stac925xM6_pin_configs,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1486};
1487
1488static const char * const stac925x_models[STAC_925x_MODELS] = {
1489	[STAC_925x_AUTO] = "auto",
1490	[STAC_REF] = "ref",
1491	[STAC_M1] = "m1",
1492	[STAC_M1_2] = "m1-2",
1493	[STAC_M2] = "m2",
1494	[STAC_M2_2] = "m2-2",
1495	[STAC_M3] = "m3",
1496	[STAC_M5] = "m5",
1497	[STAC_M6] = "m6",
1498};
1499
1500static const struct snd_pci_quirk stac925x_codec_id_cfg_tbl[] = {
 
 
 
 
 
 
 
 
 
1501	SND_PCI_QUIRK(0x107b, 0x0316, "Gateway M255", STAC_M2),
1502	SND_PCI_QUIRK(0x107b, 0x0366, "Gateway MP6954", STAC_M5),
1503	SND_PCI_QUIRK(0x107b, 0x0461, "Gateway NX560XL", STAC_M1),
1504	SND_PCI_QUIRK(0x107b, 0x0681, "Gateway NX860", STAC_M2),
1505	SND_PCI_QUIRK(0x107b, 0x0367, "Gateway MX6453", STAC_M1_2),
1506	/* Not sure about the brand name for those */
1507	SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M1),
1508	SND_PCI_QUIRK(0x107b, 0x0507, "Gateway mobile", STAC_M3),
1509	SND_PCI_QUIRK(0x107b, 0x0281, "Gateway mobile", STAC_M6),
1510	SND_PCI_QUIRK(0x107b, 0x0685, "Gateway mobile", STAC_M2_2),
1511	{} /* terminator */
1512};
1513
1514static const struct snd_pci_quirk stac925x_cfg_tbl[] = {
1515	/* SigmaTel reference board */
1516	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668, "DFI LanParty", STAC_REF),
1517	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101, "DFI LanParty", STAC_REF),
1518	SND_PCI_QUIRK(0x8384, 0x7632, "Stac9202 Reference Board", STAC_REF),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1519
1520	/* Default table for unknown ID */
1521	SND_PCI_QUIRK(0x1002, 0x437b, "Gateway mobile", STAC_M2_2),
1522
1523	{} /* terminator */
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1524};
1525
1526static const unsigned int ref92hd73xx_pin_configs[13] = {
1527	0x02214030, 0x02a19040, 0x01a19020, 0x02214030,
1528	0x0181302e, 0x01014010, 0x01014020, 0x01014030,
1529	0x02319040, 0x90a000f0, 0x90a000f0, 0x01452050,
1530	0x01452050,
1531};
1532
1533static const unsigned int dell_m6_pin_configs[13] = {
1534	0x0321101f, 0x4f00000f, 0x4f0000f0, 0x90170110,
1535	0x03a11020, 0x0321101f, 0x4f0000f0, 0x4f0000f0,
1536	0x4f0000f0, 0x90a60160, 0x4f0000f0, 0x4f0000f0,
1537	0x4f0000f0,
1538};
1539
1540static const unsigned int alienware_m17x_pin_configs[13] = {
1541	0x0321101f, 0x0321101f, 0x03a11020, 0x03014020,
1542	0x90170110, 0x4f0000f0, 0x4f0000f0, 0x4f0000f0,
1543	0x4f0000f0, 0x90a60160, 0x4f0000f0, 0x4f0000f0,
1544	0x904601b0,
1545};
1546
1547static const unsigned int intel_dg45id_pin_configs[13] = {
1548	0x02214230, 0x02A19240, 0x01013214, 0x01014210,
1549	0x01A19250, 0x01011212, 0x01016211
1550};
1551
1552static const unsigned int *stac92hd73xx_brd_tbl[STAC_92HD73XX_MODELS] = {
1553	[STAC_92HD73XX_REF]	= ref92hd73xx_pin_configs,
1554	[STAC_DELL_M6_AMIC]	= dell_m6_pin_configs,
1555	[STAC_DELL_M6_DMIC]	= dell_m6_pin_configs,
1556	[STAC_DELL_M6_BOTH]	= dell_m6_pin_configs,
1557	[STAC_DELL_EQ]	= dell_m6_pin_configs,
1558	[STAC_ALIENWARE_M17X]	= alienware_m17x_pin_configs,
1559	[STAC_92HD73XX_INTEL]	= intel_dg45id_pin_configs,
1560};
1561
1562static const char * const stac92hd73xx_models[STAC_92HD73XX_MODELS] = {
1563	[STAC_92HD73XX_AUTO] = "auto",
1564	[STAC_92HD73XX_NO_JD] = "no-jd",
1565	[STAC_92HD73XX_REF] = "ref",
1566	[STAC_92HD73XX_INTEL] = "intel",
1567	[STAC_DELL_M6_AMIC] = "dell-m6-amic",
1568	[STAC_DELL_M6_DMIC] = "dell-m6-dmic",
1569	[STAC_DELL_M6_BOTH] = "dell-m6",
1570	[STAC_DELL_EQ] = "dell-eq",
1571	[STAC_ALIENWARE_M17X] = "alienware",
1572};
1573
1574static const struct snd_pci_quirk stac92hd73xx_cfg_tbl[] = {
1575	/* SigmaTel reference board */
1576	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1577				"DFI LanParty", STAC_92HD73XX_REF),
1578	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1579				"DFI LanParty", STAC_92HD73XX_REF),
 
 
1580	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5002,
1581				"Intel DG45ID", STAC_92HD73XX_INTEL),
1582	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5003,
1583				"Intel DG45FC", STAC_92HD73XX_INTEL),
1584	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0254,
1585				"Dell Studio 1535", STAC_DELL_M6_DMIC),
1586	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0255,
1587				"unknown Dell", STAC_DELL_M6_DMIC),
1588	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0256,
1589				"unknown Dell", STAC_DELL_M6_BOTH),
1590	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0257,
1591				"unknown Dell", STAC_DELL_M6_BOTH),
1592	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025e,
1593				"unknown Dell", STAC_DELL_M6_AMIC),
1594	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x025f,
1595				"unknown Dell", STAC_DELL_M6_AMIC),
1596	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0271,
1597				"unknown Dell", STAC_DELL_M6_DMIC),
1598	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0272,
1599				"unknown Dell", STAC_DELL_M6_DMIC),
1600	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x029f,
1601				"Dell Studio 1537", STAC_DELL_M6_DMIC),
1602	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a0,
1603				"Dell Studio 17", STAC_DELL_M6_DMIC),
1604	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02be,
1605				"Dell Studio 1555", STAC_DELL_M6_DMIC),
1606	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02bd,
1607				"Dell Studio 1557", STAC_DELL_M6_DMIC),
1608	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02fe,
1609				"Dell Studio XPS 1645", STAC_DELL_M6_DMIC),
1610	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0413,
1611				"Dell Studio 1558", STAC_DELL_M6_DMIC),
1612	{} /* terminator */
1613};
1614
1615static const struct snd_pci_quirk stac92hd73xx_codec_id_cfg_tbl[] = {
1616	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02a1,
1617		      "Alienware M17x", STAC_ALIENWARE_M17X),
1618	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x043a,
1619		      "Alienware M17x", STAC_ALIENWARE_M17X),
1620	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0490,
1621		      "Alienware M17x R3", STAC_DELL_EQ),
 
 
 
 
 
 
 
 
1622	{} /* terminator */
1623};
1624
1625static const unsigned int ref92hd83xxx_pin_configs[10] = {
1626	0x02214030, 0x02211010, 0x02a19020, 0x02170130,
1627	0x01014050, 0x01819040, 0x01014020, 0x90a3014e,
1628	0x01451160, 0x98560170,
 
 
 
 
 
 
 
 
1629};
1630
1631static const unsigned int dell_s14_pin_configs[10] = {
1632	0x0221403f, 0x0221101f, 0x02a19020, 0x90170110,
1633	0x40f000f0, 0x40f000f0, 0x40f000f0, 0x90a60160,
1634	0x40f000f0, 0x40f000f0,
 
 
 
 
 
 
 
 
1635};
1636
1637static const unsigned int dell_vostro_3500_pin_configs[10] = {
1638	0x02a11020, 0x0221101f, 0x400000f0, 0x90170110,
1639	0x400000f1, 0x400000f2, 0x400000f3, 0x90a60160,
1640	0x400000f4, 0x400000f5,
 
 
 
 
 
 
 
 
1641};
1642
1643static const unsigned int hp_dv7_4000_pin_configs[10] = {
1644	0x03a12050, 0x0321201f, 0x40f000f0, 0x90170110,
1645	0x40f000f0, 0x40f000f0, 0x90170110, 0xd5a30140,
1646	0x40f000f0, 0x40f000f0,
 
 
 
 
 
 
 
 
1647};
1648
1649static const unsigned int hp_zephyr_pin_configs[10] = {
1650	0x01813050, 0x0421201f, 0x04a1205e, 0x96130310,
1651	0x96130310, 0x0101401f, 0x1111611f, 0xd5a30130,
1652	0, 0,
 
 
 
 
 
 
1653};
1654
1655static const unsigned int hp_cNB11_intquad_pin_configs[10] = {
1656	0x40f000f0, 0x0221101f, 0x02a11020, 0x92170110,
1657	0x40f000f0, 0x92170110, 0x40f000f0, 0xd5a30130,
1658	0x40f000f0, 0x40f000f0,
 
 
 
 
 
 
 
 
1659};
1660
1661static const unsigned int *stac92hd83xxx_brd_tbl[STAC_92HD83XXX_MODELS] = {
1662	[STAC_92HD83XXX_REF] = ref92hd83xxx_pin_configs,
1663	[STAC_92HD83XXX_PWR_REF] = ref92hd83xxx_pin_configs,
1664	[STAC_DELL_S14] = dell_s14_pin_configs,
1665	[STAC_DELL_VOSTRO_3500] = dell_vostro_3500_pin_configs,
1666	[STAC_92HD83XXX_HP_cNB11_INTQUAD] = hp_cNB11_intquad_pin_configs,
1667	[STAC_HP_DV7_4000] = hp_dv7_4000_pin_configs,
1668	[STAC_HP_ZEPHYR] = hp_zephyr_pin_configs,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1669};
1670
1671static const char * const stac92hd83xxx_models[STAC_92HD83XXX_MODELS] = {
1672	[STAC_92HD83XXX_AUTO] = "auto",
1673	[STAC_92HD83XXX_REF] = "ref",
1674	[STAC_92HD83XXX_PWR_REF] = "mic-ref",
1675	[STAC_DELL_S14] = "dell-s14",
1676	[STAC_DELL_VOSTRO_3500] = "dell-vostro-3500",
1677	[STAC_92HD83XXX_HP_cNB11_INTQUAD] = "hp_cNB11_intquad",
1678	[STAC_HP_DV7_4000] = "hp-dv7-4000",
1679	[STAC_HP_ZEPHYR] = "hp-zephyr",
1680	[STAC_92HD83XXX_HP_LED] = "hp-led",
1681	[STAC_92HD83XXX_HP_INV_LED] = "hp-inv-led",
 
 
 
 
 
1682};
1683
1684static const struct snd_pci_quirk stac92hd83xxx_cfg_tbl[] = {
1685	/* SigmaTel reference board */
1686	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1687		      "DFI LanParty", STAC_92HD83XXX_REF),
1688	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1689		      "DFI LanParty", STAC_92HD83XXX_REF),
1690	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02ba,
1691		      "unknown Dell", STAC_DELL_S14),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1692	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x1028,
1693		      "Dell Vostro 3500", STAC_DELL_VOSTRO_3500),
1694	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1656,
1695			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1696	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1657,
1697			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1698	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1658,
1699			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1700	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x1659,
1701			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1702	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x165A,
1703			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1704	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x165B,
1705			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1706	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3388,
1707			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1708	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3389,
1709			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1710	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355B,
1711			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1712	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355C,
1713			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1714	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355D,
1715			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1716	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355E,
1717			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1718	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x355F,
1719			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1720	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3560,
1721			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1722	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358B,
1723			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1724	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358C,
1725			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1726	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x358D,
1727			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1728	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3591,
1729			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1730	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3592,
1731			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1732	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3593,
1733			  "HP", STAC_92HD83XXX_HP_cNB11_INTQUAD),
1734	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3561,
1735			  "HP", STAC_HP_ZEPHYR),
1736	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3660,
1737			  "HP Mini", STAC_92HD83XXX_HP_LED),
 
 
 
 
 
 
 
 
1738	{} /* terminator */
1739};
1740
1741static const struct snd_pci_quirk stac92hd83xxx_codec_id_cfg_tbl[] = {
1742	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3561,
1743			  "HP", STAC_HP_ZEPHYR),
1744	{} /* terminator */
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1745};
1746
1747static const unsigned int ref92hd71bxx_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1748	0x02214030, 0x02a19040, 0x01a19020, 0x01014010,
1749	0x0181302e, 0x01014010, 0x01019020, 0x90a000f0,
1750	0x90a000f0, 0x01452050, 0x01452050, 0x00000000,
1751	0x00000000
1752};
1753
1754static const unsigned int dell_m4_1_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1755	0x0421101f, 0x04a11221, 0x40f000f0, 0x90170110,
1756	0x23a1902e, 0x23014250, 0x40f000f0, 0x90a000f0,
1757	0x40f000f0, 0x4f0000f0, 0x4f0000f0, 0x00000000,
1758	0x00000000
1759};
1760
1761static const unsigned int dell_m4_2_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1762	0x0421101f, 0x04a11221, 0x90a70330, 0x90170110,
1763	0x23a1902e, 0x23014250, 0x40f000f0, 0x40f000f0,
1764	0x40f000f0, 0x044413b0, 0x044413b0, 0x00000000,
1765	0x00000000
1766};
1767
1768static const unsigned int dell_m4_3_pin_configs[STAC92HD71BXX_NUM_PINS] = {
1769	0x0421101f, 0x04a11221, 0x90a70330, 0x90170110,
1770	0x40f000f0, 0x40f000f0, 0x40f000f0, 0x90a000f0,
1771	0x40f000f0, 0x044413b0, 0x044413b0, 0x00000000,
1772	0x00000000
1773};
1774
1775static const unsigned int *stac92hd71bxx_brd_tbl[STAC_92HD71BXX_MODELS] = {
1776	[STAC_92HD71BXX_REF] = ref92hd71bxx_pin_configs,
1777	[STAC_DELL_M4_1]	= dell_m4_1_pin_configs,
1778	[STAC_DELL_M4_2]	= dell_m4_2_pin_configs,
1779	[STAC_DELL_M4_3]	= dell_m4_3_pin_configs,
1780	[STAC_HP_M4]		= NULL,
1781	[STAC_HP_DV4]		= NULL,
1782	[STAC_HP_DV5]		= NULL,
1783	[STAC_HP_HDX]           = NULL,
1784	[STAC_HP_DV4_1222NR]	= NULL,
1785};
1786
1787static const char * const stac92hd71bxx_models[STAC_92HD71BXX_MODELS] = {
1788	[STAC_92HD71BXX_AUTO] = "auto",
1789	[STAC_92HD71BXX_REF] = "ref",
1790	[STAC_DELL_M4_1] = "dell-m4-1",
1791	[STAC_DELL_M4_2] = "dell-m4-2",
1792	[STAC_DELL_M4_3] = "dell-m4-3",
1793	[STAC_HP_M4] = "hp-m4",
1794	[STAC_HP_DV4] = "hp-dv4",
1795	[STAC_HP_DV5] = "hp-dv5",
1796	[STAC_HP_HDX] = "hp-hdx",
1797	[STAC_HP_DV4_1222NR] = "hp-dv4-1222nr",
1798};
1799
1800static const struct snd_pci_quirk stac92hd71bxx_cfg_tbl[] = {
1801	/* SigmaTel reference board */
1802	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
1803		      "DFI LanParty", STAC_92HD71BXX_REF),
1804	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
1805		      "DFI LanParty", STAC_92HD71BXX_REF),
1806	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x30fb,
1807		      "HP dv4-1222nr", STAC_HP_DV4_1222NR),
1808	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x1720,
1809			  "HP", STAC_HP_DV5),
1810	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3080,
1811		      "HP", STAC_HP_DV5),
1812	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x30f0,
1813		      "HP dv4-7", STAC_HP_DV4),
1814	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3600,
1815		      "HP dv4-7", STAC_HP_DV5),
1816	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3610,
1817		      "HP HDX", STAC_HP_HDX),  /* HDX18 */
1818	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361a,
1819		      "HP mini 1000", STAC_HP_M4),
1820	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x361b,
1821		      "HP HDX", STAC_HP_HDX),  /* HDX16 */
1822	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x3620,
1823		      "HP dv6", STAC_HP_DV5),
1824	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x3061,
1825		      "HP dv6", STAC_HP_DV5), /* HP dv6-1110ax */
1826	SND_PCI_QUIRK(PCI_VENDOR_ID_HP, 0x363e,
1827		      "HP DV6", STAC_HP_DV5),
1828	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_HP, 0xfff0, 0x7010,
1829		      "HP", STAC_HP_DV5),
 
1830	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0233,
1831				"unknown Dell", STAC_DELL_M4_1),
1832	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0234,
1833				"unknown Dell", STAC_DELL_M4_1),
1834	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0250,
1835				"unknown Dell", STAC_DELL_M4_1),
1836	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024f,
1837				"unknown Dell", STAC_DELL_M4_1),
1838	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x024d,
1839				"unknown Dell", STAC_DELL_M4_1),
1840	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0251,
1841				"unknown Dell", STAC_DELL_M4_1),
1842	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0277,
1843				"unknown Dell", STAC_DELL_M4_1),
1844	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0263,
1845				"unknown Dell", STAC_DELL_M4_2),
1846	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0265,
1847				"unknown Dell", STAC_DELL_M4_2),
1848	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0262,
1849				"unknown Dell", STAC_DELL_M4_2),
1850	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0264,
1851				"unknown Dell", STAC_DELL_M4_2),
1852	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x02aa,
1853				"unknown Dell", STAC_DELL_M4_3),
1854	{} /* terminator */
1855};
1856
1857static const unsigned int ref922x_pin_configs[10] = {
1858	0x01014010, 0x01016011, 0x01012012, 0x0221401f,
1859	0x01813122, 0x01011014, 0x01441030, 0x01c41030,
1860	0x40000100, 0x40000100,
 
 
 
 
 
 
 
 
1861};
1862
1863/*
1864    STAC 922X pin configs for
1865    102801A7
1866    102801AB
1867    102801A9
1868    102801D1
1869    102801D2
1870*/
1871static const unsigned int dell_922x_d81_pin_configs[10] = {
1872	0x02214030, 0x01a19021, 0x01111012, 0x01114010,
1873	0x02a19020, 0x01117011, 0x400001f0, 0x400001f1,
1874	0x01813122, 0x400001f2,
 
 
 
 
 
 
 
 
1875};
1876
1877/*
1878    STAC 922X pin configs for
1879    102801AC
1880    102801D0
1881*/
1882static const unsigned int dell_922x_d82_pin_configs[10] = {
1883	0x02214030, 0x01a19021, 0x01111012, 0x01114010,
1884	0x02a19020, 0x01117011, 0x01451140, 0x400001f0,
1885	0x01813122, 0x400001f1,
 
 
 
 
 
 
 
 
1886};
1887
1888/*
1889    STAC 922X pin configs for
1890    102801BF
1891*/
1892static const unsigned int dell_922x_m81_pin_configs[10] = {
1893	0x0321101f, 0x01112024, 0x01111222, 0x91174220,
1894	0x03a11050, 0x01116221, 0x90a70330, 0x01452340, 
1895	0x40C003f1, 0x405003f0,
 
 
 
 
 
 
 
 
1896};
1897
1898/*
1899    STAC 9221 A1 pin configs for
1900    102801D7 (Dell XPS M1210)
1901*/
1902static const unsigned int dell_922x_m82_pin_configs[10] = {
1903	0x02211211, 0x408103ff, 0x02a1123e, 0x90100310, 
1904	0x408003f1, 0x0221121f, 0x03451340, 0x40c003f2, 
1905	0x508003f3, 0x405003f4, 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1906};
1907
1908static const unsigned int d945gtp3_pin_configs[10] = {
1909	0x0221401f, 0x01a19022, 0x01813021, 0x01014010,
1910	0x40000100, 0x40000100, 0x40000100, 0x40000100,
1911	0x02a19120, 0x40000100,
 
 
 
 
 
 
 
 
1912};
1913
1914static const unsigned int d945gtp5_pin_configs[10] = {
1915	0x0221401f, 0x01011012, 0x01813024, 0x01014010,
1916	0x01a19021, 0x01016011, 0x01452130, 0x40000100,
1917	0x02a19320, 0x40000100,
 
 
 
 
 
 
 
 
1918};
1919
1920static const unsigned int intel_mac_v1_pin_configs[10] = {
1921	0x0121e21f, 0x400000ff, 0x9017e110, 0x400000fd,
1922	0x400000fe, 0x0181e020, 0x1145e030, 0x11c5e240,
1923	0x400000fc, 0x400000fb,
 
 
 
 
 
 
 
 
1924};
1925
1926static const unsigned int intel_mac_v2_pin_configs[10] = {
1927	0x0121e21f, 0x90a7012e, 0x9017e110, 0x400000fd,
1928	0x400000fe, 0x0181e020, 0x1145e230, 0x500000fa,
1929	0x400000fc, 0x400000fb,
 
 
 
 
 
 
 
 
1930};
1931
1932static const unsigned int intel_mac_v3_pin_configs[10] = {
1933	0x0121e21f, 0x90a7012e, 0x9017e110, 0x400000fd,
1934	0x400000fe, 0x0181e020, 0x1145e230, 0x11c5e240,
1935	0x400000fc, 0x400000fb,
 
 
 
 
 
 
 
 
1936};
1937
1938static const unsigned int intel_mac_v4_pin_configs[10] = {
1939	0x0321e21f, 0x03a1e02e, 0x9017e110, 0x9017e11f,
1940	0x400000fe, 0x0381e020, 0x1345e230, 0x13c5e240,
1941	0x400000fc, 0x400000fb,
 
 
 
 
 
 
 
 
1942};
1943
1944static const unsigned int intel_mac_v5_pin_configs[10] = {
1945	0x0321e21f, 0x03a1e02e, 0x9017e110, 0x9017e11f,
1946	0x400000fe, 0x0381e020, 0x1345e230, 0x13c5e240,
1947	0x400000fc, 0x400000fb,
 
 
 
 
 
 
 
 
1948};
1949
1950static const unsigned int ecs202_pin_configs[10] = {
1951	0x0221401f, 0x02a19020, 0x01a19020, 0x01114010,
1952	0x408000f0, 0x01813022, 0x074510a0, 0x40c400f1,
1953	0x9037012e, 0x40e000f2,
 
 
 
 
 
 
 
 
 
 
 
 
1954};
1955
1956static const unsigned int *stac922x_brd_tbl[STAC_922X_MODELS] = {
1957	[STAC_D945_REF] = ref922x_pin_configs,
1958	[STAC_D945GTP3] = d945gtp3_pin_configs,
1959	[STAC_D945GTP5] = d945gtp5_pin_configs,
1960	[STAC_INTEL_MAC_V1] = intel_mac_v1_pin_configs,
1961	[STAC_INTEL_MAC_V2] = intel_mac_v2_pin_configs,
1962	[STAC_INTEL_MAC_V3] = intel_mac_v3_pin_configs,
1963	[STAC_INTEL_MAC_V4] = intel_mac_v4_pin_configs,
1964	[STAC_INTEL_MAC_V5] = intel_mac_v5_pin_configs,
1965	[STAC_INTEL_MAC_AUTO] = intel_mac_v3_pin_configs,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1966	/* for backward compatibility */
1967	[STAC_MACMINI] = intel_mac_v3_pin_configs,
1968	[STAC_MACBOOK] = intel_mac_v5_pin_configs,
1969	[STAC_MACBOOK_PRO_V1] = intel_mac_v3_pin_configs,
1970	[STAC_MACBOOK_PRO_V2] = intel_mac_v3_pin_configs,
1971	[STAC_IMAC_INTEL] = intel_mac_v2_pin_configs,
1972	[STAC_IMAC_INTEL_20] = intel_mac_v3_pin_configs,
1973	[STAC_ECS_202] = ecs202_pin_configs,
1974	[STAC_922X_DELL_D81] = dell_922x_d81_pin_configs,
1975	[STAC_922X_DELL_D82] = dell_922x_d82_pin_configs,	
1976	[STAC_922X_DELL_M81] = dell_922x_m81_pin_configs,
1977	[STAC_922X_DELL_M82] = dell_922x_m82_pin_configs,	
1978};
1979
1980static const char * const stac922x_models[STAC_922X_MODELS] = {
1981	[STAC_922X_AUTO] = "auto",
1982	[STAC_D945_REF]	= "ref",
1983	[STAC_D945GTP5]	= "5stack",
1984	[STAC_D945GTP3]	= "3stack",
1985	[STAC_INTEL_MAC_V1] = "intel-mac-v1",
1986	[STAC_INTEL_MAC_V2] = "intel-mac-v2",
1987	[STAC_INTEL_MAC_V3] = "intel-mac-v3",
1988	[STAC_INTEL_MAC_V4] = "intel-mac-v4",
1989	[STAC_INTEL_MAC_V5] = "intel-mac-v5",
1990	[STAC_INTEL_MAC_AUTO] = "intel-mac-auto",
1991	/* for backward compatibility */
1992	[STAC_MACMINI]	= "macmini",
1993	[STAC_MACBOOK]	= "macbook",
1994	[STAC_MACBOOK_PRO_V1]	= "macbook-pro-v1",
1995	[STAC_MACBOOK_PRO_V2]	= "macbook-pro",
1996	[STAC_IMAC_INTEL] = "imac-intel",
1997	[STAC_IMAC_INTEL_20] = "imac-intel-20",
1998	[STAC_ECS_202] = "ecs202",
1999	[STAC_922X_DELL_D81] = "dell-d81",
2000	[STAC_922X_DELL_D82] = "dell-d82",
2001	[STAC_922X_DELL_M81] = "dell-m81",
2002	[STAC_922X_DELL_M82] = "dell-m82",
2003};
2004
2005static const struct snd_pci_quirk stac922x_cfg_tbl[] = {
2006	/* SigmaTel reference board */
2007	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2008		      "DFI LanParty", STAC_D945_REF),
2009	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2010		      "DFI LanParty", STAC_D945_REF),
2011	/* Intel 945G based systems */
2012	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0101,
2013		      "Intel D945G", STAC_D945GTP3),
2014	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0202,
2015		      "Intel D945G", STAC_D945GTP3),
2016	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0606,
2017		      "Intel D945G", STAC_D945GTP3),
2018	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0601,
2019		      "Intel D945G", STAC_D945GTP3),
2020	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0111,
2021		      "Intel D945G", STAC_D945GTP3),
2022	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1115,
2023		      "Intel D945G", STAC_D945GTP3),
2024	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1116,
2025		      "Intel D945G", STAC_D945GTP3),
2026	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1117,
2027		      "Intel D945G", STAC_D945GTP3),
2028	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1118,
2029		      "Intel D945G", STAC_D945GTP3),
2030	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x1119,
2031		      "Intel D945G", STAC_D945GTP3),
2032	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x8826,
2033		      "Intel D945G", STAC_D945GTP3),
2034	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5049,
2035		      "Intel D945G", STAC_D945GTP3),
2036	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5055,
2037		      "Intel D945G", STAC_D945GTP3),
2038	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x5048,
2039		      "Intel D945G", STAC_D945GTP3),
2040	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0110,
2041		      "Intel D945G", STAC_D945GTP3),
2042	/* Intel D945G 5-stack systems */
2043	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0404,
2044		      "Intel D945G", STAC_D945GTP5),
2045	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0303,
2046		      "Intel D945G", STAC_D945GTP5),
2047	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0013,
2048		      "Intel D945G", STAC_D945GTP5),
2049	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0417,
2050		      "Intel D945G", STAC_D945GTP5),
2051	/* Intel 945P based systems */
2052	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0b0b,
2053		      "Intel D945P", STAC_D945GTP3),
2054	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0112,
2055		      "Intel D945P", STAC_D945GTP3),
2056	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0d0d,
2057		      "Intel D945P", STAC_D945GTP3),
2058	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0909,
2059		      "Intel D945P", STAC_D945GTP3),
2060	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0505,
2061		      "Intel D945P", STAC_D945GTP3),
2062	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0707,
2063		      "Intel D945P", STAC_D945GTP5),
2064	/* other intel */
2065	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x0204,
2066		      "Intel D945", STAC_D945_REF),
2067	/* other systems  */
 
2068	/* Apple Intel Mac (Mac Mini, MacBook, MacBook Pro...) */
2069	SND_PCI_QUIRK(0x8384, 0x7680,
2070		      "Mac", STAC_INTEL_MAC_AUTO),
2071	/* Dell systems  */
2072	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a7,
2073		      "unknown Dell", STAC_922X_DELL_D81),
2074	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01a9,
2075		      "unknown Dell", STAC_922X_DELL_D81),
2076	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ab,
2077		      "unknown Dell", STAC_922X_DELL_D81),
2078	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ac,
2079		      "unknown Dell", STAC_922X_DELL_D82),
2080	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01bf,
2081		      "unknown Dell", STAC_922X_DELL_M81),
2082	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d0,
2083		      "unknown Dell", STAC_922X_DELL_D82),
2084	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d1,
2085		      "unknown Dell", STAC_922X_DELL_D81),
2086	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d2,
2087		      "unknown Dell", STAC_922X_DELL_D81),
2088	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01d7,
2089		      "Dell XPS M1210", STAC_922X_DELL_M82),
2090	/* ECS/PC Chips boards */
2091	SND_PCI_QUIRK_MASK(0x1019, 0xf000, 0x2000,
2092		      "ECS/PC chips", STAC_ECS_202),
2093	{} /* terminator */
2094};
2095
2096static const unsigned int ref927x_pin_configs[14] = {
2097	0x02214020, 0x02a19080, 0x0181304e, 0x01014010,
2098	0x01a19040, 0x01011012, 0x01016011, 0x0101201f, 
2099	0x183301f0, 0x18a001f0, 0x18a001f0, 0x01442070,
2100	0x01c42190, 0x40000100,
2101};
2102
2103static const unsigned int d965_3st_pin_configs[14] = {
2104	0x0221401f, 0x02a19120, 0x40000100, 0x01014011,
2105	0x01a19021, 0x01813024, 0x40000100, 0x40000100,
2106	0x40000100, 0x40000100, 0x40000100, 0x40000100,
2107	0x40000100, 0x40000100
2108};
2109
2110static const unsigned int d965_5st_pin_configs[14] = {
2111	0x02214020, 0x02a19080, 0x0181304e, 0x01014010,
2112	0x01a19040, 0x01011012, 0x01016011, 0x40000100,
2113	0x40000100, 0x40000100, 0x40000100, 0x01442070,
2114	0x40000100, 0x40000100
2115};
2116
2117static const unsigned int d965_5st_no_fp_pin_configs[14] = {
2118	0x40000100, 0x40000100, 0x0181304e, 0x01014010,
2119	0x01a19040, 0x01011012, 0x01016011, 0x40000100,
2120	0x40000100, 0x40000100, 0x40000100, 0x01442070,
2121	0x40000100, 0x40000100
2122};
2123
2124static const unsigned int dell_3st_pin_configs[14] = {
2125	0x02211230, 0x02a11220, 0x01a19040, 0x01114210,
2126	0x01111212, 0x01116211, 0x01813050, 0x01112214,
2127	0x403003fa, 0x90a60040, 0x90a60040, 0x404003fb,
2128	0x40c003fc, 0x40000100
2129};
2130
2131static const unsigned int *stac927x_brd_tbl[STAC_927X_MODELS] = {
2132	[STAC_D965_REF_NO_JD] = ref927x_pin_configs,
2133	[STAC_D965_REF]  = ref927x_pin_configs,
2134	[STAC_D965_3ST]  = d965_3st_pin_configs,
2135	[STAC_D965_5ST]  = d965_5st_pin_configs,
2136	[STAC_D965_5ST_NO_FP]  = d965_5st_no_fp_pin_configs,
2137	[STAC_DELL_3ST]  = dell_3st_pin_configs,
2138	[STAC_DELL_BIOS] = NULL,
2139	[STAC_927X_VOLKNOB] = NULL,
2140};
2141
2142static const char * const stac927x_models[STAC_927X_MODELS] = {
2143	[STAC_927X_AUTO]	= "auto",
2144	[STAC_D965_REF_NO_JD]	= "ref-no-jd",
2145	[STAC_D965_REF]		= "ref",
2146	[STAC_D965_3ST]		= "3stack",
2147	[STAC_D965_5ST]		= "5stack",
2148	[STAC_D965_5ST_NO_FP]	= "5stack-no-fp",
2149	[STAC_DELL_3ST]		= "dell-3stack",
2150	[STAC_DELL_BIOS]	= "dell-bios",
2151	[STAC_927X_VOLKNOB]	= "volknob",
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2152};
2153
2154static const struct snd_pci_quirk stac927x_cfg_tbl[] = {
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2155	/* SigmaTel reference board */
2156	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2157		      "DFI LanParty", STAC_D965_REF),
2158	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2159		      "DFI LanParty", STAC_D965_REF),
2160	 /* Intel 946 based systems */
2161	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x3d01, "Intel D946", STAC_D965_3ST),
2162	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xa301, "Intel D946", STAC_D965_3ST),
2163	/* 965 based 3 stack systems */
2164	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2100,
2165			   "Intel D965", STAC_D965_3ST),
2166	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2000,
2167			   "Intel D965", STAC_D965_3ST),
2168	/* Dell 3 stack systems */
2169	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01dd, "Dell Dimension E520", STAC_DELL_3ST),
2170	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01ed, "Dell     ", STAC_DELL_3ST),
2171	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f4, "Dell     ", STAC_DELL_3ST),
2172	/* Dell 3 stack systems with verb table in BIOS */
2173	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f3, "Dell Inspiron 1420", STAC_DELL_BIOS),
2174	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x01f7, "Dell XPS M1730", STAC_DELL_BIOS),
2175	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0227, "Dell Vostro 1400  ", STAC_DELL_BIOS),
2176	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022e, "Dell     ", STAC_DELL_BIOS),
2177	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x022f, "Dell Inspiron 1525", STAC_DELL_BIOS),
2178	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0242, "Dell     ", STAC_DELL_BIOS),
2179	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0243, "Dell     ", STAC_DELL_BIOS),
2180	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x02ff, "Dell     ", STAC_DELL_BIOS),
2181	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL,  0x0209, "Dell XPS 1330", STAC_DELL_BIOS),
2182	/* 965 based 5 stack systems */
2183	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2300,
2184			   "Intel D965", STAC_D965_5ST),
2185	SND_PCI_QUIRK_MASK(PCI_VENDOR_ID_INTEL, 0xff00, 0x2500,
2186			   "Intel D965", STAC_D965_5ST),
 
 
2187	/* volume-knob fixes */
2188	SND_PCI_QUIRK_VENDOR(0x10cf, "FSC", STAC_927X_VOLKNOB),
2189	{} /* terminator */
2190};
2191
2192static const unsigned int ref9205_pin_configs[12] = {
2193	0x40000100, 0x40000100, 0x01016011, 0x01014010,
2194	0x01813122, 0x01a19021, 0x01019020, 0x40000100,
2195	0x90a000f0, 0x90a000f0, 0x01441030, 0x01c41030
 
 
 
 
 
 
 
 
 
 
2196};
2197
2198/*
2199    STAC 9205 pin configs for
2200    102801F1
2201    102801F2
2202    102801FC
2203    102801FD
2204    10280204
2205    1028021F
2206    10280228 (Dell Vostro 1500)
2207    10280229 (Dell Vostro 1700)
2208*/
2209static const unsigned int dell_9205_m42_pin_configs[12] = {
2210	0x0321101F, 0x03A11020, 0x400003FA, 0x90170310,
2211	0x400003FB, 0x400003FC, 0x400003FD, 0x40F000F9,
2212	0x90A60330, 0x400003FF, 0x0144131F, 0x40C003FE,
 
 
 
 
 
 
 
 
 
 
2213};
2214
2215/*
2216    STAC 9205 pin configs for
2217    102801F9
2218    102801FA
2219    102801FE
2220    102801FF (Dell Precision M4300)
2221    10280206
2222    10280200
2223    10280201
2224*/
2225static const unsigned int dell_9205_m43_pin_configs[12] = {
2226	0x0321101f, 0x03a11020, 0x90a70330, 0x90170310,
2227	0x400000fe, 0x400000ff, 0x400000fd, 0x40f000f9,
2228	0x400000fa, 0x400000fc, 0x0144131f, 0x40c003f8,
 
 
 
 
 
 
 
 
 
 
 
 
 
2229};
2230
2231static const unsigned int dell_9205_m44_pin_configs[12] = {
2232	0x0421101f, 0x04a11020, 0x400003fa, 0x90170310,
2233	0x400003fb, 0x400003fc, 0x400003fd, 0x400003f9,
2234	0x90a60330, 0x400003ff, 0x01441340, 0x40c003fe,
 
 
 
 
 
 
 
 
 
 
2235};
2236
2237static const unsigned int *stac9205_brd_tbl[STAC_9205_MODELS] = {
2238	[STAC_9205_REF] = ref9205_pin_configs,
2239	[STAC_9205_DELL_M42] = dell_9205_m42_pin_configs,
2240	[STAC_9205_DELL_M43] = dell_9205_m43_pin_configs,
2241	[STAC_9205_DELL_M44] = dell_9205_m44_pin_configs,
2242	[STAC_9205_EAPD] = NULL,
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
2243};
2244
2245static const char * const stac9205_models[STAC_9205_MODELS] = {
2246	[STAC_9205_AUTO] = "auto",
2247	[STAC_9205_REF] = "ref",
2248	[STAC_9205_DELL_M42] = "dell-m42",
2249	[STAC_9205_DELL_M43] = "dell-m43",
2250	[STAC_9205_DELL_M44] = "dell-m44",
2251	[STAC_9205_EAPD] = "eapd",
2252};
2253
2254static const struct snd_pci_quirk stac9205_cfg_tbl[] = {
2255	/* SigmaTel reference board */
2256	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0x2668,
2257		      "DFI LanParty", STAC_9205_REF),
2258	SND_PCI_QUIRK(PCI_VENDOR_ID_INTEL, 0xfb30,
2259		      "SigmaTel", STAC_9205_REF),
2260	SND_PCI_QUIRK(PCI_VENDOR_ID_DFI, 0x3101,
2261		      "DFI LanParty", STAC_9205_REF),
2262	/* Dell */
2263	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f1,
2264		      "unknown Dell", STAC_9205_DELL_M42),
2265	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f2,
2266		      "unknown Dell", STAC_9205_DELL_M42),
2267	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f8,
2268		      "Dell Precision", STAC_9205_DELL_M43),
2269	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01f9,
2270		      "Dell Precision", STAC_9205_DELL_M43),
2271	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fa,
2272		      "Dell Precision", STAC_9205_DELL_M43),
2273	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fc,
2274		      "unknown Dell", STAC_9205_DELL_M42),
2275	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fd,
2276		      "unknown Dell", STAC_9205_DELL_M42),
2277	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01fe,
2278		      "Dell Precision", STAC_9205_DELL_M43),
2279	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x01ff,
2280		      "Dell Precision M4300", STAC_9205_DELL_M43),
2281	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0204,
2282		      "unknown Dell", STAC_9205_DELL_M42),
2283	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0206,
2284		      "Dell Precision", STAC_9205_DELL_M43),
2285	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021b,
2286		      "Dell Precision", STAC_9205_DELL_M43),
2287	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021c,
2288		      "Dell Precision", STAC_9205_DELL_M43),
2289	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x021f,
2290		      "Dell Inspiron", STAC_9205_DELL_M44),
2291	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0228,
2292		      "Dell Vostro 1500", STAC_9205_DELL_M42),
2293	SND_PCI_QUIRK(PCI_VENDOR_ID_DELL, 0x0229,
2294		      "Dell Vostro 1700", STAC_9205_DELL_M42),
2295	/* Gateway */
2296	SND_PCI_QUIRK(0x107b, 0x0560, "Gateway T6834c", STAC_9205_EAPD),
2297	SND_PCI_QUIRK(0x107b, 0x0565, "Gateway T1616", STAC_9205_EAPD),
2298	{} /* terminator */
2299};
2300
2301static void stac92xx_set_config_regs(struct hda_codec *codec,
2302				     const unsigned int *pincfgs)
2303{
2304	int i;
2305	struct sigmatel_spec *spec = codec->spec;
2306
2307	if (!pincfgs)
2308		return;
2309
2310	for (i = 0; i < spec->num_pins; i++)
2311		if (spec->pin_nids[i] && pincfgs[i])
2312			snd_hda_codec_set_pincfg(codec, spec->pin_nids[i],
2313						 pincfgs[i]);
2314}
2315
2316/*
2317 * Analog playback callbacks
2318 */
2319static int stac92xx_playback_pcm_open(struct hda_pcm_stream *hinfo,
2320				      struct hda_codec *codec,
2321				      struct snd_pcm_substream *substream)
2322{
2323	struct sigmatel_spec *spec = codec->spec;
2324	if (spec->stream_delay)
2325		msleep(spec->stream_delay);
2326	return snd_hda_multi_out_analog_open(codec, &spec->multiout, substream,
2327					     hinfo);
2328}
2329
2330static int stac92xx_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2331					 struct hda_codec *codec,
2332					 unsigned int stream_tag,
2333					 unsigned int format,
2334					 struct snd_pcm_substream *substream)
2335{
2336	struct sigmatel_spec *spec = codec->spec;
2337	return snd_hda_multi_out_analog_prepare(codec, &spec->multiout, stream_tag, format, substream);
2338}
2339
2340static int stac92xx_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2341					struct hda_codec *codec,
2342					struct snd_pcm_substream *substream)
2343{
2344	struct sigmatel_spec *spec = codec->spec;
2345	return snd_hda_multi_out_analog_cleanup(codec, &spec->multiout);
2346}
2347
2348/*
2349 * Digital playback callbacks
2350 */
2351static int stac92xx_dig_playback_pcm_open(struct hda_pcm_stream *hinfo,
2352					  struct hda_codec *codec,
2353					  struct snd_pcm_substream *substream)
2354{
2355	struct sigmatel_spec *spec = codec->spec;
2356	return snd_hda_multi_out_dig_open(codec, &spec->multiout);
2357}
2358
2359static int stac92xx_dig_playback_pcm_close(struct hda_pcm_stream *hinfo,
2360					   struct hda_codec *codec,
2361					   struct snd_pcm_substream *substream)
2362{
2363	struct sigmatel_spec *spec = codec->spec;
2364	return snd_hda_multi_out_dig_close(codec, &spec->multiout);
2365}
2366
2367static int stac92xx_dig_playback_pcm_prepare(struct hda_pcm_stream *hinfo,
2368					 struct hda_codec *codec,
2369					 unsigned int stream_tag,
2370					 unsigned int format,
2371					 struct snd_pcm_substream *substream)
2372{
2373	struct sigmatel_spec *spec = codec->spec;
2374	return snd_hda_multi_out_dig_prepare(codec, &spec->multiout,
2375					     stream_tag, format, substream);
2376}
2377
2378static int stac92xx_dig_playback_pcm_cleanup(struct hda_pcm_stream *hinfo,
2379					struct hda_codec *codec,
2380					struct snd_pcm_substream *substream)
2381{
2382	struct sigmatel_spec *spec = codec->spec;
2383	return snd_hda_multi_out_dig_cleanup(codec, &spec->multiout);
2384}
2385
2386
2387/*
2388 * Analog capture callbacks
2389 */
2390static int stac92xx_capture_pcm_prepare(struct hda_pcm_stream *hinfo,
2391					struct hda_codec *codec,
2392					unsigned int stream_tag,
2393					unsigned int format,
2394					struct snd_pcm_substream *substream)
2395{
2396	struct sigmatel_spec *spec = codec->spec;
2397	hda_nid_t nid = spec->adc_nids[substream->number];
2398
2399	if (spec->powerdown_adcs) {
2400		msleep(40);
2401		snd_hda_codec_write(codec, nid, 0,
2402			AC_VERB_SET_POWER_STATE, AC_PWRST_D0);
2403	}
2404	snd_hda_codec_setup_stream(codec, nid, stream_tag, 0, format);
2405	return 0;
2406}
2407
2408static int stac92xx_capture_pcm_cleanup(struct hda_pcm_stream *hinfo,
2409					struct hda_codec *codec,
2410					struct snd_pcm_substream *substream)
2411{
2412	struct sigmatel_spec *spec = codec->spec;
2413	hda_nid_t nid = spec->adc_nids[substream->number];
2414
2415	snd_hda_codec_cleanup_stream(codec, nid);
2416	if (spec->powerdown_adcs)
2417		snd_hda_codec_write(codec, nid, 0,
2418			AC_VERB_SET_POWER_STATE, AC_PWRST_D3);
2419	return 0;
2420}
2421
2422static const struct hda_pcm_stream stac92xx_pcm_digital_playback = {
2423	.substreams = 1,
2424	.channels_min = 2,
2425	.channels_max = 2,
2426	/* NID is set in stac92xx_build_pcms */
2427	.ops = {
2428		.open = stac92xx_dig_playback_pcm_open,
2429		.close = stac92xx_dig_playback_pcm_close,
2430		.prepare = stac92xx_dig_playback_pcm_prepare,
2431		.cleanup = stac92xx_dig_playback_pcm_cleanup
2432	},
2433};
2434
2435static const struct hda_pcm_stream stac92xx_pcm_digital_capture = {
2436	.substreams = 1,
2437	.channels_min = 2,
2438	.channels_max = 2,
2439	/* NID is set in stac92xx_build_pcms */
2440};
2441
2442static const struct hda_pcm_stream stac92xx_pcm_analog_playback = {
2443	.substreams = 1,
2444	.channels_min = 2,
2445	.channels_max = 8,
2446	.nid = 0x02, /* NID to query formats and rates */
2447	.ops = {
2448		.open = stac92xx_playback_pcm_open,
2449		.prepare = stac92xx_playback_pcm_prepare,
2450		.cleanup = stac92xx_playback_pcm_cleanup
2451	},
2452};
2453
2454static const struct hda_pcm_stream stac92xx_pcm_analog_alt_playback = {
2455	.substreams = 1,
2456	.channels_min = 2,
2457	.channels_max = 2,
2458	.nid = 0x06, /* NID to query formats and rates */
2459	.ops = {
2460		.open = stac92xx_playback_pcm_open,
2461		.prepare = stac92xx_playback_pcm_prepare,
2462		.cleanup = stac92xx_playback_pcm_cleanup
2463	},
2464};
2465
2466static const struct hda_pcm_stream stac92xx_pcm_analog_capture = {
2467	.channels_min = 2,
2468	.channels_max = 2,
2469	/* NID + .substreams is set in stac92xx_build_pcms */
2470	.ops = {
2471		.prepare = stac92xx_capture_pcm_prepare,
2472		.cleanup = stac92xx_capture_pcm_cleanup
2473	},
2474};
2475
2476static int stac92xx_build_pcms(struct hda_codec *codec)
2477{
2478	struct sigmatel_spec *spec = codec->spec;
2479	struct hda_pcm *info = spec->pcm_rec;
2480
2481	codec->num_pcms = 1;
2482	codec->pcm_info = info;
2483
2484	info->name = "STAC92xx Analog";
2485	info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_analog_playback;
2486	info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid =
2487		spec->multiout.dac_nids[0];
2488	info->stream[SNDRV_PCM_STREAM_CAPTURE] = stac92xx_pcm_analog_capture;
2489	info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->adc_nids[0];
2490	info->stream[SNDRV_PCM_STREAM_CAPTURE].substreams = spec->num_adcs;
2491
2492	if (spec->alt_switch) {
2493		codec->num_pcms++;
2494		info++;
2495		info->name = "STAC92xx Analog Alt";
2496		info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_analog_alt_playback;
2497	}
2498
2499	if (spec->multiout.dig_out_nid || spec->dig_in_nid) {
2500		codec->num_pcms++;
2501		info++;
2502		info->name = "STAC92xx Digital";
2503		info->pcm_type = spec->autocfg.dig_out_type[0];
2504		if (spec->multiout.dig_out_nid) {
2505			info->stream[SNDRV_PCM_STREAM_PLAYBACK] = stac92xx_pcm_digital_playback;
2506			info->stream[SNDRV_PCM_STREAM_PLAYBACK].nid = spec->multiout.dig_out_nid;
2507		}
2508		if (spec->dig_in_nid) {
2509			info->stream[SNDRV_PCM_STREAM_CAPTURE] = stac92xx_pcm_digital_capture;
2510			info->stream[SNDRV_PCM_STREAM_CAPTURE].nid = spec->dig_in_nid;
2511		}
2512	}
2513
2514	return 0;
2515}
2516
2517static void stac92xx_auto_set_pinctl(struct hda_codec *codec, hda_nid_t nid, int pin_type)
2518
2519{
2520	snd_hda_set_pin_ctl_cache(codec, nid, pin_type);
2521}
2522
2523#define stac92xx_hp_switch_info		snd_ctl_boolean_mono_info
2524
2525static int stac92xx_hp_switch_get(struct snd_kcontrol *kcontrol,
2526			struct snd_ctl_elem_value *ucontrol)
2527{
2528	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2529	struct sigmatel_spec *spec = codec->spec;
2530
2531	ucontrol->value.integer.value[0] = !!spec->hp_switch;
2532	return 0;
2533}
2534
2535static void stac_issue_unsol_event(struct hda_codec *codec, hda_nid_t nid);
2536
2537static int stac92xx_hp_switch_put(struct snd_kcontrol *kcontrol,
2538			struct snd_ctl_elem_value *ucontrol)
2539{
2540	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2541	struct sigmatel_spec *spec = codec->spec;
2542	int nid = kcontrol->private_value;
2543 
2544	spec->hp_switch = ucontrol->value.integer.value[0] ? nid : 0;
2545
2546	/* check to be sure that the ports are up to date with
2547	 * switch changes
2548	 */
2549	stac_issue_unsol_event(codec, nid);
2550
2551	return 1;
2552}
2553
2554static int stac92xx_dc_bias_info(struct snd_kcontrol *kcontrol,
2555				struct snd_ctl_elem_info *uinfo)
2556{
2557	int i;
2558	static const char * const texts[] = {
2559		"Mic In", "Line In", "Line Out"
2560	};
2561
2562	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2563	struct sigmatel_spec *spec = codec->spec;
2564	hda_nid_t nid = kcontrol->private_value;
2565
2566	if (nid == spec->mic_switch || nid == spec->line_switch)
2567		i = 3;
2568	else
2569		i = 2;
2570
2571	uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2572	uinfo->value.enumerated.items = i;
2573	uinfo->count = 1;
2574	if (uinfo->value.enumerated.item >= i)
2575		uinfo->value.enumerated.item = i-1;
2576	strcpy(uinfo->value.enumerated.name,
2577		texts[uinfo->value.enumerated.item]);
2578
2579	return 0;
2580}
2581
2582static int stac92xx_dc_bias_get(struct snd_kcontrol *kcontrol,
2583				struct snd_ctl_elem_value *ucontrol)
2584{
2585	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2586	hda_nid_t nid = kcontrol->private_value;
2587	unsigned int vref = stac92xx_vref_get(codec, nid);
2588
2589	if (vref == snd_hda_get_default_vref(codec, nid))
2590		ucontrol->value.enumerated.item[0] = 0;
2591	else if (vref == AC_PINCTL_VREF_GRD)
2592		ucontrol->value.enumerated.item[0] = 1;
2593	else if (vref == AC_PINCTL_VREF_HIZ)
2594		ucontrol->value.enumerated.item[0] = 2;
2595
2596	return 0;
2597}
2598
2599static int stac92xx_dc_bias_put(struct snd_kcontrol *kcontrol,
2600				struct snd_ctl_elem_value *ucontrol)
2601{
2602	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2603	unsigned int new_vref = 0;
2604	int error;
2605	hda_nid_t nid = kcontrol->private_value;
2606
2607	if (ucontrol->value.enumerated.item[0] == 0)
2608		new_vref = snd_hda_get_default_vref(codec, nid);
2609	else if (ucontrol->value.enumerated.item[0] == 1)
2610		new_vref = AC_PINCTL_VREF_GRD;
2611	else if (ucontrol->value.enumerated.item[0] == 2)
2612		new_vref = AC_PINCTL_VREF_HIZ;
2613	else
2614		return 0;
2615
2616	if (new_vref != stac92xx_vref_get(codec, nid)) {
2617		error = stac92xx_vref_set(codec, nid, new_vref);
2618		return error;
2619	}
2620
2621	return 0;
2622}
2623
2624static int stac92xx_io_switch_info(struct snd_kcontrol *kcontrol,
2625				struct snd_ctl_elem_info *uinfo)
2626{
2627	char *texts[2];
2628	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2629	struct sigmatel_spec *spec = codec->spec;
2630
2631	if (kcontrol->private_value == spec->line_switch)
2632		texts[0] = "Line In";
2633	else
2634		texts[0] = "Mic In";
2635	texts[1] = "Line Out";
2636	uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
2637	uinfo->value.enumerated.items = 2;
2638	uinfo->count = 1;
2639
2640	if (uinfo->value.enumerated.item >= 2)
2641		uinfo->value.enumerated.item = 1;
2642	strcpy(uinfo->value.enumerated.name,
2643		texts[uinfo->value.enumerated.item]);
2644
2645	return 0;
2646}
2647
2648static int stac92xx_io_switch_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2649{
2650	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2651	struct sigmatel_spec *spec = codec->spec;
2652	hda_nid_t nid = kcontrol->private_value;
2653	int io_idx = (nid == spec->mic_switch) ? 1 : 0;
2654
2655	ucontrol->value.enumerated.item[0] = spec->io_switch[io_idx];
2656	return 0;
2657}
2658
2659static int stac92xx_io_switch_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
2660{
2661        struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2662	struct sigmatel_spec *spec = codec->spec;
2663	hda_nid_t nid = kcontrol->private_value;
2664	int io_idx = (nid == spec->mic_switch) ? 1 : 0;
2665	unsigned short val = !!ucontrol->value.enumerated.item[0];
2666
2667	spec->io_switch[io_idx] = val;
2668
2669	if (val)
2670		stac92xx_auto_set_pinctl(codec, nid, AC_PINCTL_OUT_EN);
2671	else {
2672		unsigned int pinctl = AC_PINCTL_IN_EN;
2673		if (io_idx) /* set VREF for mic */
2674			pinctl |= snd_hda_get_default_vref(codec, nid);
2675		stac92xx_auto_set_pinctl(codec, nid, pinctl);
2676	}
2677
2678	/* check the auto-mute again: we need to mute/unmute the speaker
2679	 * appropriately according to the pin direction
2680	 */
2681	if (spec->hp_detect)
2682		stac_issue_unsol_event(codec, nid);
2683
2684        return 1;
2685}
2686
2687#define stac92xx_clfe_switch_info snd_ctl_boolean_mono_info
2688
2689static int stac92xx_clfe_switch_get(struct snd_kcontrol *kcontrol,
2690		struct snd_ctl_elem_value *ucontrol)
2691{
2692	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2693	struct sigmatel_spec *spec = codec->spec;
2694
2695	ucontrol->value.integer.value[0] = spec->clfe_swap;
2696	return 0;
2697}
2698
2699static int stac92xx_clfe_switch_put(struct snd_kcontrol *kcontrol,
2700		struct snd_ctl_elem_value *ucontrol)
2701{
2702	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
2703	struct sigmatel_spec *spec = codec->spec;
2704	hda_nid_t nid = kcontrol->private_value & 0xff;
2705	unsigned int val = !!ucontrol->value.integer.value[0];
2706
2707	if (spec->clfe_swap == val)
2708		return 0;
2709
2710	spec->clfe_swap = val;
2711
2712	snd_hda_codec_write_cache(codec, nid, 0, AC_VERB_SET_EAPD_BTLENABLE,
2713		spec->clfe_swap ? 0x4 : 0x0);
2714
2715	return 1;
2716}
2717
2718#define STAC_CODEC_HP_SWITCH(xname) \
2719	{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2720	  .name = xname, \
2721	  .index = 0, \
2722	  .info = stac92xx_hp_switch_info, \
2723	  .get = stac92xx_hp_switch_get, \
2724	  .put = stac92xx_hp_switch_put, \
2725	}
2726
2727#define STAC_CODEC_IO_SWITCH(xname, xpval) \
2728	{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2729	  .name = xname, \
2730	  .index = 0, \
2731          .info = stac92xx_io_switch_info, \
2732          .get = stac92xx_io_switch_get, \
2733          .put = stac92xx_io_switch_put, \
2734          .private_value = xpval, \
2735	}
2736
2737#define STAC_CODEC_CLFE_SWITCH(xname, xpval) \
2738	{ .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
2739	  .name = xname, \
2740	  .index = 0, \
2741	  .info = stac92xx_clfe_switch_info, \
2742	  .get = stac92xx_clfe_switch_get, \
2743	  .put = stac92xx_clfe_switch_put, \
2744	  .private_value = xpval, \
2745	}
2746
2747enum {
2748	STAC_CTL_WIDGET_VOL,
2749	STAC_CTL_WIDGET_MUTE,
2750	STAC_CTL_WIDGET_MUTE_BEEP,
2751	STAC_CTL_WIDGET_MONO_MUX,
2752	STAC_CTL_WIDGET_HP_SWITCH,
2753	STAC_CTL_WIDGET_IO_SWITCH,
2754	STAC_CTL_WIDGET_CLFE_SWITCH,
2755	STAC_CTL_WIDGET_DC_BIAS
2756};
2757
2758static const struct snd_kcontrol_new stac92xx_control_templates[] = {
2759	HDA_CODEC_VOLUME(NULL, 0, 0, 0),
2760	HDA_CODEC_MUTE(NULL, 0, 0, 0),
2761	HDA_CODEC_MUTE_BEEP(NULL, 0, 0, 0),
2762	STAC_MONO_MUX,
2763	STAC_CODEC_HP_SWITCH(NULL),
2764	STAC_CODEC_IO_SWITCH(NULL, 0),
2765	STAC_CODEC_CLFE_SWITCH(NULL, 0),
2766	DC_BIAS(NULL, 0, 0),
2767};
2768
2769/* add dynamic controls */
2770static struct snd_kcontrol_new *
2771stac_control_new(struct sigmatel_spec *spec,
2772		 const struct snd_kcontrol_new *ktemp,
2773		 const char *name,
2774		 unsigned int subdev)
2775{
2776	struct snd_kcontrol_new *knew;
2777
2778	snd_array_init(&spec->kctls, sizeof(*knew), 32);
2779	knew = snd_array_new(&spec->kctls);
2780	if (!knew)
2781		return NULL;
2782	*knew = *ktemp;
2783	knew->name = kstrdup(name, GFP_KERNEL);
2784	if (!knew->name) {
2785		/* roolback */
2786		memset(knew, 0, sizeof(*knew));
2787		spec->kctls.alloced--;
2788		return NULL;
2789	}
2790	knew->subdevice = subdev;
2791	return knew;
2792}
2793
2794static int stac92xx_add_control_temp(struct sigmatel_spec *spec,
2795				     const struct snd_kcontrol_new *ktemp,
2796				     int idx, const char *name,
2797				     unsigned long val)
2798{
2799	struct snd_kcontrol_new *knew = stac_control_new(spec, ktemp, name,
2800							 HDA_SUBDEV_AMP_FLAG);
2801	if (!knew)
2802		return -ENOMEM;
2803	knew->index = idx;
2804	knew->private_value = val;
2805	return 0;
2806}
2807
2808static inline int stac92xx_add_control_idx(struct sigmatel_spec *spec,
2809					   int type, int idx, const char *name,
2810					   unsigned long val)
2811{
2812	return stac92xx_add_control_temp(spec,
2813					 &stac92xx_control_templates[type],
2814					 idx, name, val);
2815}
2816
2817
2818/* add dynamic controls */
2819static inline int stac92xx_add_control(struct sigmatel_spec *spec, int type,
2820				       const char *name, unsigned long val)
2821{
2822	return stac92xx_add_control_idx(spec, type, 0, name, val);
2823}
2824
2825static const struct snd_kcontrol_new stac_input_src_temp = {
2826	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
2827	.name = "Input Source",
2828	.info = stac92xx_mux_enum_info,
2829	.get = stac92xx_mux_enum_get,
2830	.put = stac92xx_mux_enum_put,
2831};
2832
2833static inline int stac92xx_add_jack_mode_control(struct hda_codec *codec,
2834						hda_nid_t nid, int idx)
2835{
2836	int def_conf = snd_hda_codec_get_pincfg(codec, nid);
2837	int control = 0;
2838	struct sigmatel_spec *spec = codec->spec;
2839	char name[22];
2840
2841	if (snd_hda_get_input_pin_attr(def_conf) != INPUT_PIN_ATTR_INT) {
2842		if (snd_hda_get_default_vref(codec, nid) == AC_PINCTL_VREF_GRD
2843			&& nid == spec->line_switch)
2844			control = STAC_CTL_WIDGET_IO_SWITCH;
2845		else if (snd_hda_query_pin_caps(codec, nid)
2846			& (AC_PINCAP_VREF_GRD << AC_PINCAP_VREF_SHIFT))
2847			control = STAC_CTL_WIDGET_DC_BIAS;
2848		else if (nid == spec->mic_switch)
2849			control = STAC_CTL_WIDGET_IO_SWITCH;
2850	}
2851
2852	if (control) {
2853		snd_hda_get_pin_label(codec, nid, &spec->autocfg,
2854				      name, sizeof(name), NULL);
2855		return stac92xx_add_control(codec->spec, control,
2856					strcat(name, " Jack Mode"), nid);
2857	}
2858
2859	return 0;
2860}
2861
2862static int stac92xx_add_input_source(struct sigmatel_spec *spec)
2863{
2864	struct snd_kcontrol_new *knew;
2865	struct hda_input_mux *imux = &spec->private_imux;
2866
2867	if (spec->auto_mic)
2868		return 0; /* no need for input source */
2869	if (!spec->num_adcs || imux->num_items <= 1)
2870		return 0; /* no need for input source control */
2871	knew = stac_control_new(spec, &stac_input_src_temp,
2872				stac_input_src_temp.name, 0);
2873	if (!knew)
2874		return -ENOMEM;
2875	knew->count = spec->num_adcs;
2876	return 0;
2877}
2878
2879/* check whether the line-input can be used as line-out */
2880static hda_nid_t check_line_out_switch(struct hda_codec *codec)
2881{
2882	struct sigmatel_spec *spec = codec->spec;
2883	struct auto_pin_cfg *cfg = &spec->autocfg;
2884	hda_nid_t nid;
2885	unsigned int pincap;
2886	int i;
2887
2888	if (cfg->line_out_type != AUTO_PIN_LINE_OUT)
2889		return 0;
2890	for (i = 0; i < cfg->num_inputs; i++) {
2891		if (cfg->inputs[i].type == AUTO_PIN_LINE_IN) {
2892			nid = cfg->inputs[i].pin;
2893			pincap = snd_hda_query_pin_caps(codec, nid);
2894			if (pincap & AC_PINCAP_OUT)
2895				return nid;
2896		}
2897	}
2898	return 0;
2899}
2900
2901static hda_nid_t get_unassigned_dac(struct hda_codec *codec, hda_nid_t nid);
2902
2903/* check whether the mic-input can be used as line-out */
2904static hda_nid_t check_mic_out_switch(struct hda_codec *codec, hda_nid_t *dac)
2905{
2906	struct sigmatel_spec *spec = codec->spec;
2907	struct auto_pin_cfg *cfg = &spec->autocfg;
2908	unsigned int def_conf, pincap;
2909	int i;
2910
2911	*dac = 0;
2912	if (cfg->line_out_type != AUTO_PIN_LINE_OUT)
2913		return 0;
2914	for (i = 0; i < cfg->num_inputs; i++) {
2915		hda_nid_t nid = cfg->inputs[i].pin;
2916		if (cfg->inputs[i].type != AUTO_PIN_MIC)
2917			continue;
2918		def_conf = snd_hda_codec_get_pincfg(codec, nid);
2919		/* some laptops have an internal analog microphone
2920		 * which can't be used as a output */
2921		if (snd_hda_get_input_pin_attr(def_conf) != INPUT_PIN_ATTR_INT) {
2922			pincap = snd_hda_query_pin_caps(codec, nid);
2923			if (pincap & AC_PINCAP_OUT) {
2924				*dac = get_unassigned_dac(codec, nid);
2925				if (*dac)
2926					return nid;
2927			}
2928		}
2929	}
2930	return 0;
2931}
2932
2933static int is_in_dac_nids(struct sigmatel_spec *spec, hda_nid_t nid)
2934{
2935	int i;
2936	
2937	for (i = 0; i < spec->multiout.num_dacs; i++) {
2938		if (spec->multiout.dac_nids[i] == nid)
2939			return 1;
2940	}
2941
2942	return 0;
2943}
2944
2945static int check_all_dac_nids(struct sigmatel_spec *spec, hda_nid_t nid)
2946{
2947	int i;
2948	if (is_in_dac_nids(spec, nid))
2949		return 1;
2950	for (i = 0; i < spec->autocfg.hp_outs; i++)
2951		if (spec->hp_dacs[i] == nid)
2952			return 1;
2953	for (i = 0; i < spec->autocfg.speaker_outs; i++)
2954		if (spec->speaker_dacs[i] == nid)
2955			return 1;
2956	return 0;
2957}
2958
2959static hda_nid_t get_unassigned_dac(struct hda_codec *codec, hda_nid_t nid)
2960{
2961	struct sigmatel_spec *spec = codec->spec;
2962	struct auto_pin_cfg *cfg = &spec->autocfg;
2963	int j, conn_len;
2964	hda_nid_t conn[HDA_MAX_CONNECTIONS], fallback_dac;
2965	unsigned int wcaps, wtype;
2966
2967	conn_len = snd_hda_get_connections(codec, nid, conn,
2968					   HDA_MAX_CONNECTIONS);
2969	/* 92HD88: trace back up the link of nids to find the DAC */
2970	while (conn_len == 1 && (get_wcaps_type(get_wcaps(codec, conn[0]))
2971					!= AC_WID_AUD_OUT)) {
2972		nid = conn[0];
2973		conn_len = snd_hda_get_connections(codec, nid, conn,
2974			HDA_MAX_CONNECTIONS);
2975	}
2976	for (j = 0; j < conn_len; j++) {
2977		wcaps = get_wcaps(codec, conn[j]);
2978		wtype = get_wcaps_type(wcaps);
2979		/* we check only analog outputs */
2980		if (wtype != AC_WID_AUD_OUT || (wcaps & AC_WCAP_DIGITAL))
2981			continue;
2982		/* if this route has a free DAC, assign it */
2983		if (!check_all_dac_nids(spec, conn[j])) {
2984			if (conn_len > 1) {
2985				/* select this DAC in the pin's input mux */
2986				snd_hda_codec_write_cache(codec, nid, 0,
2987						  AC_VERB_SET_CONNECT_SEL, j);
2988			}
2989			return conn[j];
2990		}
2991	}
2992
2993	/* if all DACs are already assigned, connect to the primary DAC,
2994	   unless we're assigning a secondary headphone */
2995	fallback_dac = spec->multiout.dac_nids[0];
2996	if (spec->multiout.hp_nid) {
2997		for (j = 0; j < cfg->hp_outs; j++)
2998			if (cfg->hp_pins[j] == nid) {
2999				fallback_dac = spec->multiout.hp_nid;
3000				break;
3001			}
3002	}
3003
3004	if (conn_len > 1) {
3005		for (j = 0; j < conn_len; j++) {
3006			if (conn[j] == fallback_dac) {
3007				snd_hda_codec_write_cache(codec, nid, 0,
3008						  AC_VERB_SET_CONNECT_SEL, j);
3009				break;
3010			}
3011		}
3012	}
3013	return 0;
3014}
3015
3016static int add_spec_dacs(struct sigmatel_spec *spec, hda_nid_t nid);
3017static int add_spec_extra_dacs(struct sigmatel_spec *spec, hda_nid_t nid);
3018
3019/*
3020 * Fill in the dac_nids table from the parsed pin configuration
3021 * This function only works when every pin in line_out_pins[]
3022 * contains atleast one DAC in its connection list. Some 92xx
3023 * codecs are not connected directly to a DAC, such as the 9200
3024 * and 9202/925x. For those, dac_nids[] must be hard-coded.
3025 */
3026static int stac92xx_auto_fill_dac_nids(struct hda_codec *codec)
3027{
3028	struct sigmatel_spec *spec = codec->spec;
3029	struct auto_pin_cfg *cfg = &spec->autocfg;
3030	int i;
3031	hda_nid_t nid, dac;
3032	
3033	for (i = 0; i < cfg->line_outs; i++) {
3034		nid = cfg->line_out_pins[i];
3035		dac = get_unassigned_dac(codec, nid);
3036		if (!dac) {
3037			if (spec->multiout.num_dacs > 0) {
3038				/* we have already working output pins,
3039				 * so let's drop the broken ones again
3040				 */
3041				cfg->line_outs = spec->multiout.num_dacs;
3042				break;
3043			}
3044			/* error out, no available DAC found */
3045			snd_printk(KERN_ERR
3046				   "%s: No available DAC for pin 0x%x\n",
3047				   __func__, nid);
3048			return -ENODEV;
3049		}
3050		add_spec_dacs(spec, dac);
3051	}
3052
3053	for (i = 0; i < cfg->hp_outs; i++) {
3054		nid = cfg->hp_pins[i];
3055		dac = get_unassigned_dac(codec, nid);
3056		if (dac) {
3057			if (!spec->multiout.hp_nid)
3058				spec->multiout.hp_nid = dac;
3059			else
3060				add_spec_extra_dacs(spec, dac);
3061		}
3062		spec->hp_dacs[i] = dac;
3063	}
3064
3065	for (i = 0; i < cfg->speaker_outs; i++) {
3066		nid = cfg->speaker_pins[i];
3067		dac = get_unassigned_dac(codec, nid);
3068		if (dac)
3069			add_spec_extra_dacs(spec, dac);
3070		spec->speaker_dacs[i] = dac;
3071	}
3072
3073	/* add line-in as output */
3074	nid = check_line_out_switch(codec);
3075	if (nid) {
3076		dac = get_unassigned_dac(codec, nid);
3077		if (dac) {
3078			snd_printdd("STAC: Add line-in 0x%x as output %d\n",
3079				    nid, cfg->line_outs);
3080			cfg->line_out_pins[cfg->line_outs] = nid;
3081			cfg->line_outs++;
3082			spec->line_switch = nid;
3083			add_spec_dacs(spec, dac);
3084		}
3085	}
3086	/* add mic as output */
3087	nid = check_mic_out_switch(codec, &dac);
3088	if (nid && dac) {
3089		snd_printdd("STAC: Add mic-in 0x%x as output %d\n",
3090			    nid, cfg->line_outs);
3091		cfg->line_out_pins[cfg->line_outs] = nid;
3092		cfg->line_outs++;
3093		spec->mic_switch = nid;
3094		add_spec_dacs(spec, dac);
3095	}
3096
3097	snd_printd("stac92xx: dac_nids=%d (0x%x/0x%x/0x%x/0x%x/0x%x)\n",
3098		   spec->multiout.num_dacs,
3099		   spec->multiout.dac_nids[0],
3100		   spec->multiout.dac_nids[1],
3101		   spec->multiout.dac_nids[2],
3102		   spec->multiout.dac_nids[3],
3103		   spec->multiout.dac_nids[4]);
3104
3105	return 0;
3106}
3107
3108/* create volume control/switch for the given prefx type */
3109static int create_controls_idx(struct hda_codec *codec, const char *pfx,
3110			       int idx, hda_nid_t nid, int chs)
3111{
3112	struct sigmatel_spec *spec = codec->spec;
3113	char name[32];
3114	int err;
3115
3116	if (!spec->check_volume_offset) {
3117		unsigned int caps, step, nums, db_scale;
3118		caps = query_amp_caps(codec, nid, HDA_OUTPUT);
3119		step = (caps & AC_AMPCAP_STEP_SIZE) >>
3120			AC_AMPCAP_STEP_SIZE_SHIFT;
3121		step = (step + 1) * 25; /* in .01dB unit */
3122		nums = (caps & AC_AMPCAP_NUM_STEPS) >>
3123			AC_AMPCAP_NUM_STEPS_SHIFT;
3124		db_scale = nums * step;
3125		/* if dB scale is over -64dB, and finer enough,
3126		 * let's reduce it to half
3127		 */
3128		if (db_scale > 6400 && nums >= 0x1f)
3129			spec->volume_offset = nums / 2;
3130		spec->check_volume_offset = 1;
3131	}
3132
3133	sprintf(name, "%s Playback Volume", pfx);
3134	err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_VOL, idx, name,
3135		HDA_COMPOSE_AMP_VAL_OFS(nid, chs, 0, HDA_OUTPUT,
3136					spec->volume_offset));
3137	if (err < 0)
3138		return err;
3139	sprintf(name, "%s Playback Switch", pfx);
3140	err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_MUTE, idx, name,
3141				   HDA_COMPOSE_AMP_VAL(nid, chs, 0, HDA_OUTPUT));
3142	if (err < 0)
3143		return err;
3144	return 0;
3145}
3146
3147#define create_controls(codec, pfx, nid, chs) \
3148	create_controls_idx(codec, pfx, 0, nid, chs)
3149
3150static int add_spec_dacs(struct sigmatel_spec *spec, hda_nid_t nid)
3151{
3152	if (spec->multiout.num_dacs > 4) {
3153		printk(KERN_WARNING "stac92xx: No space for DAC 0x%x\n", nid);
3154		return 1;
3155	} else {
3156		snd_BUG_ON(spec->multiout.dac_nids != spec->dac_nids);
3157		spec->dac_nids[spec->multiout.num_dacs] = nid;
3158		spec->multiout.num_dacs++;
3159	}
3160	return 0;
3161}
3162
3163static int add_spec_extra_dacs(struct sigmatel_spec *spec, hda_nid_t nid)
3164{
3165	int i;
3166	for (i = 0; i < ARRAY_SIZE(spec->multiout.extra_out_nid); i++) {
3167		if (!spec->multiout.extra_out_nid[i]) {
3168			spec->multiout.extra_out_nid[i] = nid;
3169			return 0;
3170		}
3171	}
3172	printk(KERN_WARNING "stac92xx: No space for extra DAC 0x%x\n", nid);
3173	return 1;
3174}
3175
3176/* Create output controls
3177 * The mixer elements are named depending on the given type (AUTO_PIN_XXX_OUT)
3178 */
3179static int create_multi_out_ctls(struct hda_codec *codec, int num_outs,
3180				 const hda_nid_t *pins,
3181				 const hda_nid_t *dac_nids,
3182				 int type)
3183{
3184	struct sigmatel_spec *spec = codec->spec;
3185	static const char * const chname[4] = {
3186		"Front", "Surround", NULL /*CLFE*/, "Side"
3187	};
3188	hda_nid_t nid;
3189	int i, err;
3190	unsigned int wid_caps;
3191
3192	for (i = 0; i < num_outs && i < ARRAY_SIZE(chname); i++) {
3193		if (type == AUTO_PIN_HP_OUT && !spec->hp_detect) {
3194			if (is_jack_detectable(codec, pins[i]))
3195				spec->hp_detect = 1;
3196		}
3197		nid = dac_nids[i];
3198		if (!nid)
3199			continue;
3200		if (type != AUTO_PIN_HP_OUT && i == 2) {
3201			/* Center/LFE */
3202			err = create_controls(codec, "Center", nid, 1);
3203			if (err < 0)
3204				return err;
3205			err = create_controls(codec, "LFE", nid, 2);
3206			if (err < 0)
3207				return err;
3208
3209			wid_caps = get_wcaps(codec, nid);
3210
3211			if (wid_caps & AC_WCAP_LR_SWAP) {
3212				err = stac92xx_add_control(spec,
3213					STAC_CTL_WIDGET_CLFE_SWITCH,
3214					"Swap Center/LFE Playback Switch", nid);
3215
3216				if (err < 0)
3217					return err;
3218			}
3219
3220		} else {
3221			const char *name;
3222			int idx;
3223			switch (type) {
3224			case AUTO_PIN_HP_OUT:
3225				name = "Headphone";
3226				idx = i;
3227				break;
3228			case AUTO_PIN_SPEAKER_OUT:
3229				name = "Speaker";
3230				idx = i;
3231				break;
3232			default:
3233				name = chname[i];
3234				idx = 0;
3235				break;
3236			}
3237			err = create_controls_idx(codec, name, idx, nid, 3);
3238			if (err < 0)
3239				return err;
3240		}
3241	}
3242	return 0;
3243}
3244
3245static int stac92xx_add_capvol_ctls(struct hda_codec *codec, unsigned long vol,
3246				    unsigned long sw, int idx)
3247{
3248	int err;
3249	err = stac92xx_add_control_idx(codec->spec, STAC_CTL_WIDGET_VOL, idx,
3250				       "Capture Volume", vol);
3251	if (err < 0)
3252		return err;
3253	err = stac92xx_add_control_idx(codec->spec, STAC_CTL_WIDGET_MUTE, idx,
3254				       "Capture Switch", sw);
3255	if (err < 0)
3256		return err;
3257	return 0;
3258}
3259
3260/* add playback controls from the parsed DAC table */
3261static int stac92xx_auto_create_multi_out_ctls(struct hda_codec *codec,
3262					       const struct auto_pin_cfg *cfg)
3263{
3264	struct sigmatel_spec *spec = codec->spec;
3265	hda_nid_t nid;
3266	int err;
3267	int idx;
3268
3269	err = create_multi_out_ctls(codec, cfg->line_outs, cfg->line_out_pins,
3270				    spec->multiout.dac_nids,
3271				    cfg->line_out_type);
3272	if (err < 0)
3273		return err;
3274
3275	if (cfg->hp_outs > 1 && cfg->line_out_type == AUTO_PIN_LINE_OUT) {
3276		err = stac92xx_add_control(spec,
3277			STAC_CTL_WIDGET_HP_SWITCH,
3278			"Headphone as Line Out Switch",
3279			cfg->hp_pins[cfg->hp_outs - 1]);
3280		if (err < 0)
3281			return err;
3282	}
3283
3284	for (idx = 0; idx < cfg->num_inputs; idx++) {
3285		if (cfg->inputs[idx].type > AUTO_PIN_LINE_IN)
3286			break;
3287		nid = cfg->inputs[idx].pin;
3288		err = stac92xx_add_jack_mode_control(codec, nid, idx);
3289		if (err < 0)
3290			return err;
3291	}
3292
3293	return 0;
3294}
3295
3296/* add playback controls for Speaker and HP outputs */
3297static int stac92xx_auto_create_hp_ctls(struct hda_codec *codec,
3298					struct auto_pin_cfg *cfg)
3299{
3300	struct sigmatel_spec *spec = codec->spec;
3301	int err;
3302
3303	err = create_multi_out_ctls(codec, cfg->hp_outs, cfg->hp_pins,
3304				    spec->hp_dacs, AUTO_PIN_HP_OUT);
3305	if (err < 0)
3306		return err;
3307
3308	err = create_multi_out_ctls(codec, cfg->speaker_outs, cfg->speaker_pins,
3309				    spec->speaker_dacs, AUTO_PIN_SPEAKER_OUT);
3310	if (err < 0)
3311		return err;
3312
3313	return 0;
3314}
3315
3316/* labels for mono mux outputs */
3317static const char * const stac92xx_mono_labels[4] = {
3318	"DAC0", "DAC1", "Mixer", "DAC2"
3319};
3320
3321/* create mono mux for mono out on capable codecs */
3322static int stac92xx_auto_create_mono_output_ctls(struct hda_codec *codec)
3323{
3324	struct sigmatel_spec *spec = codec->spec;
3325	struct hda_input_mux *mono_mux = &spec->private_mono_mux;
3326	int i, num_cons;
3327	hda_nid_t con_lst[ARRAY_SIZE(stac92xx_mono_labels)];
3328
3329	num_cons = snd_hda_get_connections(codec,
3330				spec->mono_nid,
3331				con_lst,
3332				HDA_MAX_NUM_INPUTS);
3333	if (num_cons <= 0 || num_cons > ARRAY_SIZE(stac92xx_mono_labels))
3334		return -EINVAL;
3335
3336	for (i = 0; i < num_cons; i++)
3337		snd_hda_add_imux_item(mono_mux, stac92xx_mono_labels[i], i,
3338				      NULL);
3339
3340	return stac92xx_add_control(spec, STAC_CTL_WIDGET_MONO_MUX,
3341				"Mono Mux", spec->mono_nid);
3342}
3343
3344/* create PC beep volume controls */
3345static int stac92xx_auto_create_beep_ctls(struct hda_codec *codec,
3346						hda_nid_t nid)
3347{
3348	struct sigmatel_spec *spec = codec->spec;
3349	u32 caps = query_amp_caps(codec, nid, HDA_OUTPUT);
3350	int err, type = STAC_CTL_WIDGET_MUTE_BEEP;
3351
3352	if (spec->anabeep_nid == nid)
3353		type = STAC_CTL_WIDGET_MUTE;
3354
3355	/* check for mute support for the the amp */
3356	if ((caps & AC_AMPCAP_MUTE) >> AC_AMPCAP_MUTE_SHIFT) {
3357		err = stac92xx_add_control(spec, type,
3358			"Beep Playback Switch",
3359			HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT));
3360			if (err < 0)
3361				return err;
3362	}
3363
3364	/* check to see if there is volume support for the amp */
3365	if ((caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT) {
3366		err = stac92xx_add_control(spec, STAC_CTL_WIDGET_VOL,
3367			"Beep Playback Volume",
3368			HDA_COMPOSE_AMP_VAL(nid, 1, 0, HDA_OUTPUT));
3369			if (err < 0)
3370				return err;
3371	}
3372	return 0;
3373}
3374
3375#ifdef CONFIG_SND_HDA_INPUT_BEEP
3376#define stac92xx_dig_beep_switch_info snd_ctl_boolean_mono_info
3377
3378static int stac92xx_dig_beep_switch_get(struct snd_kcontrol *kcontrol,
3379					struct snd_ctl_elem_value *ucontrol)
3380{
3381	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3382	ucontrol->value.integer.value[0] = codec->beep->enabled;
3383	return 0;
3384}
3385
3386static int stac92xx_dig_beep_switch_put(struct snd_kcontrol *kcontrol,
3387					struct snd_ctl_elem_value *ucontrol)
3388{
3389	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
3390	return snd_hda_enable_beep_device(codec, ucontrol->value.integer.value[0]);
3391}
3392
3393static const struct snd_kcontrol_new stac92xx_dig_beep_ctrl = {
3394	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
3395	.info = stac92xx_dig_beep_switch_info,
3396	.get = stac92xx_dig_beep_switch_get,
3397	.put = stac92xx_dig_beep_switch_put,
3398};
3399
3400static int stac92xx_beep_switch_ctl(struct hda_codec *codec)
3401{
3402	return stac92xx_add_control_temp(codec->spec, &stac92xx_dig_beep_ctrl,
3403					 0, "Beep Playback Switch", 0);
3404}
3405#endif
3406
3407static int stac92xx_auto_create_mux_input_ctls(struct hda_codec *codec)
3408{
3409	struct sigmatel_spec *spec = codec->spec;
3410	int i, j, err = 0;
3411
3412	for (i = 0; i < spec->num_muxes; i++) {
3413		hda_nid_t nid;
3414		unsigned int wcaps;
3415		unsigned long val;
3416
3417		nid = spec->mux_nids[i];
3418		wcaps = get_wcaps(codec, nid);
3419		if (!(wcaps & AC_WCAP_OUT_AMP))
3420			continue;
3421
3422		/* check whether already the same control was created as
3423		 * normal Capture Volume.
3424		 */
3425		val = HDA_COMPOSE_AMP_VAL(nid, 3, 0, HDA_OUTPUT);
3426		for (j = 0; j < spec->num_caps; j++) {
3427			if (spec->capvols[j] == val)
3428				break;
3429		}
3430		if (j < spec->num_caps)
3431			continue;
3432
3433		err = stac92xx_add_control_idx(spec, STAC_CTL_WIDGET_VOL, i,
3434					       "Mux Capture Volume", val);
3435		if (err < 0)
3436			return err;
3437	}
3438	return 0;
3439};
3440
3441static const char * const stac92xx_spdif_labels[3] = {
3442	"Digital Playback", "Analog Mux 1", "Analog Mux 2",
3443};
3444
3445static int stac92xx_auto_create_spdif_mux_ctls(struct hda_codec *codec)
3446{
3447	struct sigmatel_spec *spec = codec->spec;
3448	struct hda_input_mux *spdif_mux = &spec->private_smux;
3449	const char * const *labels = spec->spdif_labels;
3450	int i, num_cons;
3451	hda_nid_t con_lst[HDA_MAX_NUM_INPUTS];
3452
3453	num_cons = snd_hda_get_connections(codec,
3454				spec->smux_nids[0],
3455				con_lst,
3456				HDA_MAX_NUM_INPUTS);
3457	if (num_cons <= 0)
3458		return -EINVAL;
3459
3460	if (!labels)
3461		labels = stac92xx_spdif_labels;
3462
3463	for (i = 0; i < num_cons; i++)
3464		snd_hda_add_imux_item(spdif_mux, labels[i], i, NULL);
3465
3466	return 0;
3467}
3468
3469/* labels for dmic mux inputs */
3470static const char * const stac92xx_dmic_labels[5] = {
3471	"Analog Inputs", "Digital Mic 1", "Digital Mic 2",
3472	"Digital Mic 3", "Digital Mic 4"
3473};
3474
3475static hda_nid_t get_connected_node(struct hda_codec *codec, hda_nid_t mux,
3476				    int idx)
3477{
3478	hda_nid_t conn[HDA_MAX_NUM_INPUTS];
3479	int nums;
3480	nums = snd_hda_get_connections(codec, mux, conn, ARRAY_SIZE(conn));
3481	if (idx >= 0 && idx < nums)
3482		return conn[idx];
3483	return 0;
3484}
3485
3486/* look for NID recursively */
3487#define get_connection_index(codec, mux, nid) \
3488	snd_hda_get_conn_index(codec, mux, nid, 1)
3489
3490/* create a volume assigned to the given pin (only if supported) */
3491/* return 1 if the volume control is created */
3492static int create_elem_capture_vol(struct hda_codec *codec, hda_nid_t nid,
3493				   const char *label, int idx, int direction)
3494{
3495	unsigned int caps, nums;
3496	char name[32];
3497	int err;
3498
3499	if (direction == HDA_OUTPUT)
3500		caps = AC_WCAP_OUT_AMP;
3501	else
3502		caps = AC_WCAP_IN_AMP;
3503	if (!(get_wcaps(codec, nid) & caps))
3504		return 0;
3505	caps = query_amp_caps(codec, nid, direction);
3506	nums = (caps & AC_AMPCAP_NUM_STEPS) >> AC_AMPCAP_NUM_STEPS_SHIFT;
3507	if (!nums)
3508		return 0;
3509	snprintf(name, sizeof(name), "%s Capture Volume", label);
3510	err = stac92xx_add_control_idx(codec->spec, STAC_CTL_WIDGET_VOL, idx, name,
3511				       HDA_COMPOSE_AMP_VAL(nid, 3, 0, direction));
3512	if (err < 0)
3513		return err;
3514	return 1;
3515}
3516
3517/* create playback/capture controls for input pins on dmic capable codecs */
3518static int stac92xx_auto_create_dmic_input_ctls(struct hda_codec *codec,
3519						const struct auto_pin_cfg *cfg)
3520{
3521	struct sigmatel_spec *spec = codec->spec;
3522	struct hda_input_mux *imux = &spec->private_imux;
3523	struct hda_input_mux *dimux = &spec->private_dimux;
3524	int err, i;
3525	unsigned int def_conf;
3526
3527	snd_hda_add_imux_item(dimux, stac92xx_dmic_labels[0], 0, NULL);
 
 
3528
3529	for (i = 0; i < spec->num_dmics; i++) {
3530		hda_nid_t nid;
3531		int index, type_idx;
3532		char label[32];
3533
3534		nid = spec->dmic_nids[i];
3535		if (get_wcaps_type(get_wcaps(codec, nid)) != AC_WID_PIN)
3536			continue;
3537		def_conf = snd_hda_codec_get_pincfg(codec, nid);
3538		if (get_defcfg_connect(def_conf) == AC_JACK_PORT_NONE)
3539			continue;
3540
3541		index = get_connection_index(codec, spec->dmux_nids[0], nid);
3542		if (index < 0)
3543			continue;
3544
3545		snd_hda_get_pin_label(codec, nid, &spec->autocfg,
3546				      label, sizeof(label), NULL);
3547		snd_hda_add_imux_item(dimux, label, index, &type_idx);
3548		if (snd_hda_get_bool_hint(codec, "separate_dmux") != 1)
3549			snd_hda_add_imux_item(imux, label, index, &type_idx);
3550
3551		err = create_elem_capture_vol(codec, nid, label, type_idx,
3552					      HDA_INPUT);
3553		if (err < 0)
3554			return err;
3555		if (!err) {
3556			err = create_elem_capture_vol(codec, nid, label,
3557						      type_idx, HDA_OUTPUT);
3558			if (err < 0)
3559				return err;
3560			if (!err) {
3561				nid = get_connected_node(codec,
3562						spec->dmux_nids[0], index);
3563				if (nid)
3564					err = create_elem_capture_vol(codec,
3565							nid, label,
3566							type_idx, HDA_INPUT);
3567				if (err < 0)
3568					return err;
3569			}
3570		}
3571	}
3572
3573	return 0;
3574}
3575
3576static int check_mic_pin(struct hda_codec *codec, hda_nid_t nid,
3577			 hda_nid_t *fixed, hda_nid_t *ext, hda_nid_t *dock)
3578{
3579	unsigned int cfg;
3580	unsigned int type;
3581
3582	if (!nid)
3583		return 0;
3584	cfg = snd_hda_codec_get_pincfg(codec, nid);
3585	type = get_defcfg_device(cfg);
3586	switch (snd_hda_get_input_pin_attr(cfg)) {
3587	case INPUT_PIN_ATTR_INT:
3588		if (*fixed)
3589			return 1; /* already occupied */
3590		if (type != AC_JACK_MIC_IN)
3591			return 1; /* invalid type */
3592		*fixed = nid;
3593		break;
3594	case INPUT_PIN_ATTR_UNUSED:
3595		break;
3596	case INPUT_PIN_ATTR_DOCK:
3597		if (*dock)
3598			return 1; /* already occupied */
3599		if (type != AC_JACK_MIC_IN && type != AC_JACK_LINE_IN)
3600			return 1; /* invalid type */
3601		*dock = nid;
3602		break;
3603	default:
3604		if (*ext)
3605			return 1; /* already occupied */
3606		if (type != AC_JACK_MIC_IN)
3607			return 1; /* invalid type */
3608		*ext = nid;
3609		break;
3610	}
3611	return 0;
3612}
3613
3614static int set_mic_route(struct hda_codec *codec,
3615			 struct sigmatel_mic_route *mic,
3616			 hda_nid_t pin)
3617{
3618	struct sigmatel_spec *spec = codec->spec;
3619	struct auto_pin_cfg *cfg = &spec->autocfg;
3620	int i;
3621
3622	mic->pin = pin;
3623	if (pin == 0)
3624		return 0;
3625	for (i = 0; i < cfg->num_inputs; i++) {
3626		if (pin == cfg->inputs[i].pin)
3627			break;
3628	}
3629	if (i < cfg->num_inputs && cfg->inputs[i].type == AUTO_PIN_MIC) {
3630		/* analog pin */
3631		i = get_connection_index(codec, spec->mux_nids[0], pin);
3632		if (i < 0)
3633			return -1;
3634		mic->mux_idx = i;
3635		mic->dmux_idx = -1;
3636		if (spec->dmux_nids)
3637			mic->dmux_idx = get_connection_index(codec,
3638							     spec->dmux_nids[0],
3639							     spec->mux_nids[0]);
3640	}  else if (spec->dmux_nids) {
3641		/* digital pin */
3642		i = get_connection_index(codec, spec->dmux_nids[0], pin);
3643		if (i < 0)
3644			return -1;
3645		mic->dmux_idx = i;
3646		mic->mux_idx = -1;
3647		if (spec->mux_nids)
3648			mic->mux_idx = get_connection_index(codec,
3649							    spec->mux_nids[0],
3650							    spec->dmux_nids[0]);
3651	}
3652	return 0;
3653}
3654
3655/* return non-zero if the device is for automatic mic switch */
3656static int stac_check_auto_mic(struct hda_codec *codec)
3657{
3658	struct sigmatel_spec *spec = codec->spec;
3659	struct auto_pin_cfg *cfg = &spec->autocfg;
3660	hda_nid_t fixed, ext, dock;
3661	int i;
3662
3663	fixed = ext = dock = 0;
3664	for (i = 0; i < cfg->num_inputs; i++)
3665		if (check_mic_pin(codec, cfg->inputs[i].pin,
3666		    &fixed, &ext, &dock))
3667			return 0;
3668	for (i = 0; i < spec->num_dmics; i++)
3669		if (check_mic_pin(codec, spec->dmic_nids[i],
3670		    &fixed, &ext, &dock))
3671			return 0;
3672	if (!fixed || (!ext && !dock))
3673		return 0; /* no input to switch */
3674	if (!is_jack_detectable(codec, ext))
3675		return 0; /* no unsol support */
3676	if (set_mic_route(codec, &spec->ext_mic, ext) ||
3677	    set_mic_route(codec, &spec->int_mic, fixed) ||
3678	    set_mic_route(codec, &spec->dock_mic, dock))
3679		return 0; /* something is wrong */
3680	return 1;
3681}
3682
3683/* create playback/capture controls for input pins */
3684static int stac92xx_auto_create_analog_input_ctls(struct hda_codec *codec, const struct auto_pin_cfg *cfg)
3685{
3686	struct sigmatel_spec *spec = codec->spec;
3687	struct hda_input_mux *imux = &spec->private_imux;
3688	int i, j;
3689	const char *label;
3690
3691	for (i = 0; i < cfg->num_inputs; i++) {
3692		hda_nid_t nid = cfg->inputs[i].pin;
3693		int index, err, type_idx;
3694
3695		index = -1;
3696		for (j = 0; j < spec->num_muxes; j++) {
3697			index = get_connection_index(codec, spec->mux_nids[j],
3698						     nid);
3699			if (index >= 0)
3700				break;
3701		}
3702		if (index < 0)
3703			continue;
3704
3705		label = hda_get_autocfg_input_label(codec, cfg, i);
3706		snd_hda_add_imux_item(imux, label, index, &type_idx);
3707
3708		err = create_elem_capture_vol(codec, nid,
3709					      label, type_idx,
3710					      HDA_INPUT);
3711		if (err < 0)
3712			return err;
3713	}
3714	spec->num_analog_muxes = imux->num_items;
3715
3716	if (imux->num_items) {
3717		/*
3718		 * Set the current input for the muxes.
3719		 * The STAC9221 has two input muxes with identical source
3720		 * NID lists.  Hopefully this won't get confused.
3721		 */
3722		for (i = 0; i < spec->num_muxes; i++) {
3723			snd_hda_codec_write_cache(codec, spec->mux_nids[i], 0,
3724						  AC_VERB_SET_CONNECT_SEL,
3725						  imux->items[0].index);
3726		}
3727	}
3728
3729	return 0;
3730}
3731
3732static void stac92xx_auto_init_multi_out(struct hda_codec *codec)
3733{
3734	struct sigmatel_spec *spec = codec->spec;
3735	int i;
3736
3737	for (i = 0; i < spec->autocfg.line_outs; i++) {
3738		hda_nid_t nid = spec->autocfg.line_out_pins[i];
3739		stac92xx_auto_set_pinctl(codec, nid, AC_PINCTL_OUT_EN);
3740	}
3741}
3742
3743static void stac92xx_auto_init_hp_out(struct hda_codec *codec)
3744{
3745	struct sigmatel_spec *spec = codec->spec;
3746	int i;
3747
3748	for (i = 0; i < spec->autocfg.hp_outs; i++) {
3749		hda_nid_t pin;
3750		pin = spec->autocfg.hp_pins[i];
3751		if (pin) /* connect to front */
3752			stac92xx_auto_set_pinctl(codec, pin, AC_PINCTL_OUT_EN | AC_PINCTL_HP_EN);
3753	}
3754	for (i = 0; i < spec->autocfg.speaker_outs; i++) {
3755		hda_nid_t pin;
3756		pin = spec->autocfg.speaker_pins[i];
3757		if (pin) /* connect to front */
3758			stac92xx_auto_set_pinctl(codec, pin, AC_PINCTL_OUT_EN);
3759	}
3760}
3761
3762static int is_dual_headphones(struct hda_codec *codec)
3763{
3764	struct sigmatel_spec *spec = codec->spec;
3765	int i, valid_hps;
3766
3767	if (spec->autocfg.line_out_type != AUTO_PIN_SPEAKER_OUT ||
3768	    spec->autocfg.hp_outs <= 1)
3769		return 0;
3770	valid_hps = 0;
3771	for (i = 0; i < spec->autocfg.hp_outs; i++) {
3772		hda_nid_t nid = spec->autocfg.hp_pins[i];
3773		unsigned int cfg = snd_hda_codec_get_pincfg(codec, nid);
3774		if (get_defcfg_location(cfg) & AC_JACK_LOC_SEPARATE)
3775			continue;
3776		valid_hps++;
3777	}
3778	return (valid_hps > 1);
3779}
3780
3781
3782static int stac92xx_parse_auto_config(struct hda_codec *codec)
3783{
3784	struct sigmatel_spec *spec = codec->spec;
3785	hda_nid_t dig_out = 0, dig_in = 0;
3786	int hp_swap = 0;
3787	int i, err;
3788
3789	if ((err = snd_hda_parse_pin_def_config(codec,
3790						&spec->autocfg,
3791						spec->dmic_nids)) < 0)
3792		return err;
3793	if (! spec->autocfg.line_outs)
3794		return 0; /* can't find valid pin config */
3795
3796	/* If we have no real line-out pin and multiple hp-outs, HPs should
3797	 * be set up as multi-channel outputs.
3798	 */
3799	if (is_dual_headphones(codec)) {
3800		/* Copy hp_outs to line_outs, backup line_outs in
3801		 * speaker_outs so that the following routines can handle
3802		 * HP pins as primary outputs.
3803		 */
3804		snd_printdd("stac92xx: Enabling multi-HPs workaround\n");
3805		memcpy(spec->autocfg.speaker_pins, spec->autocfg.line_out_pins,
3806		       sizeof(spec->autocfg.line_out_pins));
3807		spec->autocfg.speaker_outs = spec->autocfg.line_outs;
3808		memcpy(spec->autocfg.line_out_pins, spec->autocfg.hp_pins,
3809		       sizeof(spec->autocfg.hp_pins));
3810		spec->autocfg.line_outs = spec->autocfg.hp_outs;
3811		spec->autocfg.line_out_type = AUTO_PIN_HP_OUT;
3812		spec->autocfg.hp_outs = 0;
3813		hp_swap = 1;
3814	}
3815	if (spec->autocfg.mono_out_pin) {
3816		int dir = get_wcaps(codec, spec->autocfg.mono_out_pin) &
3817			(AC_WCAP_OUT_AMP | AC_WCAP_IN_AMP);
3818		u32 caps = query_amp_caps(codec,
3819				spec->autocfg.mono_out_pin, dir);
3820		hda_nid_t conn_list[1];
3821
3822		/* get the mixer node and then the mono mux if it exists */
3823		if (snd_hda_get_connections(codec,
3824				spec->autocfg.mono_out_pin, conn_list, 1) &&
3825				snd_hda_get_connections(codec, conn_list[0],
3826				conn_list, 1) > 0) {
3827
3828				int wcaps = get_wcaps(codec, conn_list[0]);
3829				int wid_type = get_wcaps_type(wcaps);
3830				/* LR swap check, some stac925x have a mux that
3831 				 * changes the DACs output path instead of the
3832 				 * mono-mux path.
3833 				 */
3834				if (wid_type == AC_WID_AUD_SEL &&
3835						!(wcaps & AC_WCAP_LR_SWAP))
3836					spec->mono_nid = conn_list[0];
3837		}
3838		if (dir) {
3839			hda_nid_t nid = spec->autocfg.mono_out_pin;
3840
3841			/* most mono outs have a least a mute/unmute switch */
3842			dir = (dir & AC_WCAP_OUT_AMP) ? HDA_OUTPUT : HDA_INPUT;
3843			err = stac92xx_add_control(spec, STAC_CTL_WIDGET_MUTE,
3844				"Mono Playback Switch",
3845				HDA_COMPOSE_AMP_VAL(nid, 1, 0, dir));
3846			if (err < 0)
3847				return err;
3848			/* check for volume support for the amp */
3849			if ((caps & AC_AMPCAP_NUM_STEPS)
3850					>> AC_AMPCAP_NUM_STEPS_SHIFT) {
3851				err = stac92xx_add_control(spec,
3852					STAC_CTL_WIDGET_VOL,
3853					"Mono Playback Volume",
3854				HDA_COMPOSE_AMP_VAL(nid, 1, 0, dir));
3855				if (err < 0)
3856					return err;
3857			}
3858		}
3859
3860		stac92xx_auto_set_pinctl(codec, spec->autocfg.mono_out_pin,
3861					 AC_PINCTL_OUT_EN);
3862	}
3863
3864	if (!spec->multiout.num_dacs) {
3865		err = stac92xx_auto_fill_dac_nids(codec);
3866		if (err < 0)
3867			return err;
3868		err = stac92xx_auto_create_multi_out_ctls(codec,
3869							  &spec->autocfg);
3870		if (err < 0)
3871			return err;
3872	}
3873
3874	/* setup analog beep controls */
3875	if (spec->anabeep_nid > 0) {
3876		err = stac92xx_auto_create_beep_ctls(codec,
3877			spec->anabeep_nid);
3878		if (err < 0)
3879			return err;
3880	}
3881
3882	/* setup digital beep controls and input device */
3883#ifdef CONFIG_SND_HDA_INPUT_BEEP
3884	if (spec->digbeep_nid > 0) {
3885		hda_nid_t nid = spec->digbeep_nid;
3886		unsigned int caps;
3887
3888		err = stac92xx_auto_create_beep_ctls(codec, nid);
3889		if (err < 0)
3890			return err;
3891		err = snd_hda_attach_beep_device(codec, nid);
3892		if (err < 0)
3893			return err;
3894		if (codec->beep) {
3895			/* IDT/STAC codecs have linear beep tone parameter */
3896			codec->beep->linear_tone = spec->linear_tone_beep;
 
 
3897			/* if no beep switch is available, make its own one */
3898			caps = query_amp_caps(codec, nid, HDA_OUTPUT);
3899			if (!(caps & AC_AMPCAP_MUTE)) {
3900				err = stac92xx_beep_switch_ctl(codec);
3901				if (err < 0)
3902					return err;
3903			}
3904		}
3905	}
3906#endif
3907
3908	err = stac92xx_auto_create_hp_ctls(codec, &spec->autocfg);
3909	if (err < 0)
3910		return err;
3911
3912	/* All output parsing done, now restore the swapped hp pins */
3913	if (hp_swap) {
3914		memcpy(spec->autocfg.hp_pins, spec->autocfg.line_out_pins,
3915		       sizeof(spec->autocfg.hp_pins));
3916		spec->autocfg.hp_outs = spec->autocfg.line_outs;
3917		spec->autocfg.line_out_type = AUTO_PIN_HP_OUT;
3918		spec->autocfg.line_outs = 0;
3919	}
3920
3921	if (stac_check_auto_mic(codec)) {
3922		spec->auto_mic = 1;
3923		/* only one capture for auto-mic */
3924		spec->num_adcs = 1;
3925		spec->num_caps = 1;
3926		spec->num_muxes = 1;
3927	}
3928
3929	for (i = 0; i < spec->num_caps; i++) {
3930		err = stac92xx_add_capvol_ctls(codec, spec->capvols[i],
3931					       spec->capsws[i], i);
3932		if (err < 0)
3933			return err;
3934	}
3935
3936	err = stac92xx_auto_create_analog_input_ctls(codec, &spec->autocfg);
3937	if (err < 0)
3938		return err;
3939
3940	if (spec->mono_nid > 0) {
3941		err = stac92xx_auto_create_mono_output_ctls(codec);
3942		if (err < 0)
3943			return err;
3944	}
3945	if (spec->num_dmics > 0 && !spec->dinput_mux)
3946		if ((err = stac92xx_auto_create_dmic_input_ctls(codec,
3947						&spec->autocfg)) < 0)
3948			return err;
3949	if (spec->num_muxes > 0) {
3950		err = stac92xx_auto_create_mux_input_ctls(codec);
3951		if (err < 0)
3952			return err;
3953	}
3954	if (spec->num_smuxes > 0) {
3955		err = stac92xx_auto_create_spdif_mux_ctls(codec);
3956		if (err < 0)
3957			return err;
3958	}
3959
3960	err = stac92xx_add_input_source(spec);
3961	if (err < 0)
3962		return err;
3963
3964	spec->multiout.max_channels = spec->multiout.num_dacs * 2;
3965	if (spec->multiout.max_channels > 2)
3966		spec->surr_switch = 1;
3967
3968	/* find digital out and in converters */
3969	for (i = codec->start_nid; i < codec->start_nid + codec->num_nodes; i++) {
3970		unsigned int wid_caps = get_wcaps(codec, i);
3971		if (wid_caps & AC_WCAP_DIGITAL) {
3972			switch (get_wcaps_type(wid_caps)) {
3973			case AC_WID_AUD_OUT:
3974				if (!dig_out)
3975					dig_out = i;
3976				break;
3977			case AC_WID_AUD_IN:
3978				if (!dig_in)
3979					dig_in = i;
3980				break;
3981			}
3982		}
3983	}
3984	if (spec->autocfg.dig_outs)
3985		spec->multiout.dig_out_nid = dig_out;
3986	if (dig_in && spec->autocfg.dig_in_pin)
3987		spec->dig_in_nid = dig_in;
3988
3989	if (spec->kctls.list)
3990		spec->mixers[spec->num_mixers++] = spec->kctls.list;
3991
3992	spec->input_mux = &spec->private_imux;
3993	if (!spec->dinput_mux)
3994		spec->dinput_mux = &spec->private_dimux;
3995	spec->sinput_mux = &spec->private_smux;
3996	spec->mono_mux = &spec->private_mono_mux;
3997	return 1;
3998}
3999
4000/* add playback controls for HP output */
4001static int stac9200_auto_create_hp_ctls(struct hda_codec *codec,
4002					struct auto_pin_cfg *cfg)
4003{
4004	struct sigmatel_spec *spec = codec->spec;
4005	hda_nid_t pin = cfg->hp_pins[0];
4006
4007	if (! pin)
4008		return 0;
4009
4010	if (is_jack_detectable(codec, pin))
4011		spec->hp_detect = 1;
4012
4013	return 0;
4014}
4015
4016/* add playback controls for LFE output */
4017static int stac9200_auto_create_lfe_ctls(struct hda_codec *codec,
4018					struct auto_pin_cfg *cfg)
4019{
4020	struct sigmatel_spec *spec = codec->spec;
4021	int err;
4022	hda_nid_t lfe_pin = 0x0;
4023	int i;
4024
4025	/*
4026	 * search speaker outs and line outs for a mono speaker pin
4027	 * with an amp.  If one is found, add LFE controls
4028	 * for it.
4029	 */
4030	for (i = 0; i < spec->autocfg.speaker_outs && lfe_pin == 0x0; i++) {
4031		hda_nid_t pin = spec->autocfg.speaker_pins[i];
4032		unsigned int wcaps = get_wcaps(codec, pin);
4033		wcaps &= (AC_WCAP_STEREO | AC_WCAP_OUT_AMP);
4034		if (wcaps == AC_WCAP_OUT_AMP)
4035			/* found a mono speaker with an amp, must be lfe */
4036			lfe_pin = pin;
4037	}
4038
4039	/* if speaker_outs is 0, then speakers may be in line_outs */
4040	if (lfe_pin == 0 && spec->autocfg.speaker_outs == 0) {
4041		for (i = 0; i < spec->autocfg.line_outs && lfe_pin == 0x0; i++) {
4042			hda_nid_t pin = spec->autocfg.line_out_pins[i];
4043			unsigned int defcfg;
4044			defcfg = snd_hda_codec_get_pincfg(codec, pin);
4045			if (get_defcfg_device(defcfg) == AC_JACK_SPEAKER) {
4046				unsigned int wcaps = get_wcaps(codec, pin);
4047				wcaps &= (AC_WCAP_STEREO | AC_WCAP_OUT_AMP);
4048				if (wcaps == AC_WCAP_OUT_AMP)
4049					/* found a mono speaker with an amp,
4050					   must be lfe */
4051					lfe_pin = pin;
4052			}
4053		}
4054	}
4055
4056	if (lfe_pin) {
4057		err = create_controls(codec, "LFE", lfe_pin, 1);
4058		if (err < 0)
4059			return err;
4060	}
4061
4062	return 0;
4063}
4064
4065static int stac9200_parse_auto_config(struct hda_codec *codec)
4066{
4067	struct sigmatel_spec *spec = codec->spec;
4068	int err;
4069
4070	if ((err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, NULL)) < 0)
4071		return err;
4072
4073	if ((err = stac92xx_auto_create_analog_input_ctls(codec, &spec->autocfg)) < 0)
4074		return err;
4075
4076	if ((err = stac9200_auto_create_hp_ctls(codec, &spec->autocfg)) < 0)
4077		return err;
4078
4079	if ((err = stac9200_auto_create_lfe_ctls(codec, &spec->autocfg)) < 0)
4080		return err;
4081
4082	if (spec->num_muxes > 0) {
4083		err = stac92xx_auto_create_mux_input_ctls(codec);
4084		if (err < 0)
4085			return err;
4086	}
4087
4088	err = stac92xx_add_input_source(spec);
4089	if (err < 0)
4090		return err;
4091
4092	if (spec->autocfg.dig_outs)
4093		spec->multiout.dig_out_nid = 0x05;
4094	if (spec->autocfg.dig_in_pin)
4095		spec->dig_in_nid = 0x04;
4096
4097	if (spec->kctls.list)
4098		spec->mixers[spec->num_mixers++] = spec->kctls.list;
4099
4100	spec->input_mux = &spec->private_imux;
4101	spec->dinput_mux = &spec->private_dimux;
4102
4103	return 1;
4104}
4105
4106/*
4107 * Early 2006 Intel Macintoshes with STAC9220X5 codecs seem to have a
4108 * funky external mute control using GPIO pins.
4109 */
4110
4111static void stac_gpio_set(struct hda_codec *codec, unsigned int mask,
4112			  unsigned int dir_mask, unsigned int data)
4113{
4114	unsigned int gpiostate, gpiomask, gpiodir;
4115
4116	snd_printdd("%s msk %x dir %x gpio %x\n", __func__, mask, dir_mask, data);
4117
4118	gpiostate = snd_hda_codec_read(codec, codec->afg, 0,
4119				       AC_VERB_GET_GPIO_DATA, 0);
4120	gpiostate = (gpiostate & ~dir_mask) | (data & dir_mask);
4121
4122	gpiomask = snd_hda_codec_read(codec, codec->afg, 0,
4123				      AC_VERB_GET_GPIO_MASK, 0);
4124	gpiomask |= mask;
4125
4126	gpiodir = snd_hda_codec_read(codec, codec->afg, 0,
4127				     AC_VERB_GET_GPIO_DIRECTION, 0);
4128	gpiodir |= dir_mask;
4129
4130	/* Configure GPIOx as CMOS */
4131	snd_hda_codec_write(codec, codec->afg, 0, 0x7e7, 0);
4132
4133	snd_hda_codec_write(codec, codec->afg, 0,
4134			    AC_VERB_SET_GPIO_MASK, gpiomask);
4135	snd_hda_codec_read(codec, codec->afg, 0,
4136			   AC_VERB_SET_GPIO_DIRECTION, gpiodir); /* sync */
4137
4138	msleep(1);
4139
4140	snd_hda_codec_read(codec, codec->afg, 0,
4141			   AC_VERB_SET_GPIO_DATA, gpiostate); /* sync */
4142}
4143
4144static int stac_add_event(struct hda_codec *codec, hda_nid_t nid,
4145			  unsigned char type, int data)
4146{
4147	struct hda_jack_tbl *event;
4148
4149	event = snd_hda_jack_tbl_new(codec, nid);
4150	if (!event)
4151		return -ENOMEM;
4152	event->action = type;
4153	event->private_data = data;
4154
4155	return 0;
4156}
4157
4158/* check if given nid is a valid pin and no other events are assigned
4159 * to it.  If OK, assign the event, set the unsol flag, and returns 1.
4160 * Otherwise, returns zero.
4161 */
4162static int enable_pin_detect(struct hda_codec *codec, hda_nid_t nid,
4163			     unsigned int type)
4164{
4165	struct hda_jack_tbl *event;
4166
4167	if (!is_jack_detectable(codec, nid))
4168		return 0;
4169	event = snd_hda_jack_tbl_new(codec, nid);
4170	if (!event)
4171		return -ENOMEM;
4172	if (event->action && event->action != type)
4173		return 0;
4174	event->action = type;
4175	snd_hda_jack_detect_enable(codec, nid, 0);
4176	return 1;
4177}
4178
4179static int is_nid_out_jack_pin(struct auto_pin_cfg *cfg, hda_nid_t nid)
4180{
4181	int i;
4182	for (i = 0; i < cfg->hp_outs; i++)
4183		if (cfg->hp_pins[i] == nid)
4184			return 1; /* nid is a HP-Out */
4185	for (i = 0; i < cfg->line_outs; i++)
4186		if (cfg->line_out_pins[i] == nid)
4187			return 1; /* nid is a line-Out */
4188	return 0; /* nid is not a HP-Out */
4189};
4190
4191static void stac92xx_power_down(struct hda_codec *codec)
4192{
4193	struct sigmatel_spec *spec = codec->spec;
4194
4195	/* power down inactive DACs */
4196	const hda_nid_t *dac;
4197	for (dac = spec->dac_list; *dac; dac++)
4198		if (!check_all_dac_nids(spec, *dac))
4199			snd_hda_codec_write(codec, *dac, 0,
4200					AC_VERB_SET_POWER_STATE, AC_PWRST_D3);
4201}
4202
4203static void stac_toggle_power_map(struct hda_codec *codec, hda_nid_t nid,
4204				  int enable);
4205
4206static inline int get_int_hint(struct hda_codec *codec, const char *key,
4207			       int *valp)
4208{
4209	const char *p;
4210	p = snd_hda_get_hint(codec, key);
4211	if (p) {
4212		unsigned long val;
4213		if (!strict_strtoul(p, 0, &val)) {
4214			*valp = val;
4215			return 1;
4216		}
4217	}
4218	return 0;
4219}
4220
4221/* override some hints from the hwdep entry */
4222static void stac_store_hints(struct hda_codec *codec)
4223{
4224	struct sigmatel_spec *spec = codec->spec;
4225	int val;
4226
4227	val = snd_hda_get_bool_hint(codec, "hp_detect");
4228	if (val >= 0)
4229		spec->hp_detect = val;
4230	if (get_int_hint(codec, "gpio_mask", &spec->gpio_mask)) {
4231		spec->eapd_mask = spec->gpio_dir = spec->gpio_data =
4232			spec->gpio_mask;
4233	}
4234	if (get_int_hint(codec, "gpio_dir", &spec->gpio_dir))
4235		spec->gpio_mask &= spec->gpio_mask;
4236	if (get_int_hint(codec, "gpio_data", &spec->gpio_data))
4237		spec->gpio_dir &= spec->gpio_mask;
4238	if (get_int_hint(codec, "eapd_mask", &spec->eapd_mask))
4239		spec->eapd_mask &= spec->gpio_mask;
4240	if (get_int_hint(codec, "gpio_mute", &spec->gpio_mute))
4241		spec->gpio_mute &= spec->gpio_mask;
4242	val = snd_hda_get_bool_hint(codec, "eapd_switch");
4243	if (val >= 0)
4244		spec->eapd_switch = val;
4245}
4246
4247static void stac_issue_unsol_events(struct hda_codec *codec, int num_pins,
4248				    const hda_nid_t *pins)
4249{
4250	while (num_pins--)
4251		stac_issue_unsol_event(codec, *pins++);
4252}
4253
4254/* fake event to set up pins */
4255static void stac_fake_hp_events(struct hda_codec *codec)
4256{
4257	struct sigmatel_spec *spec = codec->spec;
4258
4259	if (spec->autocfg.hp_outs)
4260		stac_issue_unsol_events(codec, spec->autocfg.hp_outs,
4261					spec->autocfg.hp_pins);
4262	if (spec->autocfg.line_outs &&
4263	    spec->autocfg.line_out_pins[0] != spec->autocfg.hp_pins[0])
4264		stac_issue_unsol_events(codec, spec->autocfg.line_outs,
4265					spec->autocfg.line_out_pins);
4266}
4267
4268static int stac92xx_init(struct hda_codec *codec)
4269{
4270	struct sigmatel_spec *spec = codec->spec;
4271	struct auto_pin_cfg *cfg = &spec->autocfg;
4272	unsigned int gpio;
4273	int i;
4274
4275	snd_hda_sequence_write(codec, spec->init);
4276
4277	/* power down adcs initially */
4278	if (spec->powerdown_adcs)
4279		for (i = 0; i < spec->num_adcs; i++)
4280			snd_hda_codec_write(codec,
4281				spec->adc_nids[i], 0,
4282				AC_VERB_SET_POWER_STATE, AC_PWRST_D3);
4283
4284	/* override some hints */
4285	stac_store_hints(codec);
4286
4287	/* set up GPIO */
4288	gpio = spec->gpio_data;
4289	/* turn on EAPD statically when spec->eapd_switch isn't set.
4290	 * otherwise, unsol event will turn it on/off dynamically
4291	 */
4292	if (!spec->eapd_switch)
4293		gpio |= spec->eapd_mask;
4294	stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, gpio);
4295
4296	/* set up pins */
4297	if (spec->hp_detect) {
4298		/* Enable unsolicited responses on the HP widget */
4299		for (i = 0; i < cfg->hp_outs; i++) {
4300			hda_nid_t nid = cfg->hp_pins[i];
4301			enable_pin_detect(codec, nid, STAC_HP_EVENT);
4302		}
4303		if (cfg->line_out_type == AUTO_PIN_LINE_OUT &&
4304		    cfg->speaker_outs > 0) {
4305			/* enable pin-detect for line-outs as well */
4306			for (i = 0; i < cfg->line_outs; i++) {
4307				hda_nid_t nid = cfg->line_out_pins[i];
4308				enable_pin_detect(codec, nid, STAC_LO_EVENT);
4309			}
4310		}
4311
4312		/* force to enable the first line-out; the others are set up
4313		 * in unsol_event
4314		 */
4315		stac92xx_auto_set_pinctl(codec, spec->autocfg.line_out_pins[0],
4316				AC_PINCTL_OUT_EN);
4317		/* fake event to set up pins */
4318		stac_fake_hp_events(codec);
4319	} else {
4320		stac92xx_auto_init_multi_out(codec);
4321		stac92xx_auto_init_hp_out(codec);
4322		for (i = 0; i < cfg->hp_outs; i++)
4323			stac_toggle_power_map(codec, cfg->hp_pins[i], 1);
4324	}
4325	if (spec->auto_mic) {
4326		/* initialize connection to analog input */
4327		if (spec->dmux_nids)
4328			snd_hda_codec_write_cache(codec, spec->dmux_nids[0], 0,
4329					  AC_VERB_SET_CONNECT_SEL, 0);
4330		if (enable_pin_detect(codec, spec->ext_mic.pin, STAC_MIC_EVENT))
4331			stac_issue_unsol_event(codec, spec->ext_mic.pin);
4332		if (enable_pin_detect(codec, spec->dock_mic.pin,
4333		    STAC_MIC_EVENT))
4334			stac_issue_unsol_event(codec, spec->dock_mic.pin);
4335	}
4336	for (i = 0; i < cfg->num_inputs; i++) {
4337		hda_nid_t nid = cfg->inputs[i].pin;
4338		int type = cfg->inputs[i].type;
4339		unsigned int pinctl, conf;
4340		if (type == AUTO_PIN_MIC) {
4341			/* for mic pins, force to initialize */
4342			pinctl = snd_hda_get_default_vref(codec, nid);
4343			pinctl |= AC_PINCTL_IN_EN;
4344			stac92xx_auto_set_pinctl(codec, nid, pinctl);
4345		} else {
4346			pinctl = snd_hda_codec_read(codec, nid, 0,
4347					AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
4348			/* if PINCTL already set then skip */
4349			/* Also, if both INPUT and OUTPUT are set,
4350			 * it must be a BIOS bug; need to override, too
4351			 */
4352			if (!(pinctl & AC_PINCTL_IN_EN) ||
4353			    (pinctl & AC_PINCTL_OUT_EN)) {
4354				pinctl &= ~AC_PINCTL_OUT_EN;
4355				pinctl |= AC_PINCTL_IN_EN;
4356				stac92xx_auto_set_pinctl(codec, nid, pinctl);
4357			}
4358		}
4359		conf = snd_hda_codec_get_pincfg(codec, nid);
4360		if (get_defcfg_connect(conf) != AC_JACK_PORT_FIXED) {
4361			if (enable_pin_detect(codec, nid, STAC_INSERT_EVENT))
4362				stac_issue_unsol_event(codec, nid);
4363		}
4364	}
4365	for (i = 0; i < spec->num_dmics; i++)
4366		stac92xx_auto_set_pinctl(codec, spec->dmic_nids[i],
4367					AC_PINCTL_IN_EN);
4368	if (cfg->dig_out_pins[0])
4369		stac92xx_auto_set_pinctl(codec, cfg->dig_out_pins[0],
4370					 AC_PINCTL_OUT_EN);
4371	if (cfg->dig_in_pin)
4372		stac92xx_auto_set_pinctl(codec, cfg->dig_in_pin,
4373					 AC_PINCTL_IN_EN);
4374	for (i = 0; i < spec->num_pwrs; i++)  {
4375		hda_nid_t nid = spec->pwr_nids[i];
4376		unsigned int pinctl, def_conf;
4377
4378		def_conf = snd_hda_codec_get_pincfg(codec, nid);
4379		def_conf = get_defcfg_connect(def_conf);
4380		if (def_conf == AC_JACK_PORT_NONE) {
4381			/* power off unused ports */
4382			stac_toggle_power_map(codec, nid, 0);
4383			continue;
4384		}
4385		if (def_conf == AC_JACK_PORT_FIXED) {
4386			/* no need for jack detection for fixed pins */
4387			stac_toggle_power_map(codec, nid, 1);
4388			continue;
4389		}
4390		/* power on when no jack detection is available */
4391		/* or when the VREF is used for controlling LED */
4392		if (!spec->hp_detect ||
4393		    spec->vref_mute_led_nid == nid ||
4394		    !is_jack_detectable(codec, nid)) {
4395			stac_toggle_power_map(codec, nid, 1);
4396			continue;
4397		}
4398
4399		if (is_nid_out_jack_pin(cfg, nid))
4400			continue; /* already has an unsol event */
4401
4402		pinctl = snd_hda_codec_read(codec, nid, 0,
4403					    AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
4404		/* outputs are only ports capable of power management
4405		 * any attempts on powering down a input port cause the
4406		 * referenced VREF to act quirky.
4407		 */
4408		if (pinctl & AC_PINCTL_IN_EN) {
4409			stac_toggle_power_map(codec, nid, 1);
4410			continue;
4411		}
4412		if (enable_pin_detect(codec, nid, STAC_PWR_EVENT)) {
4413			stac_issue_unsol_event(codec, nid);
4414			continue;
4415		}
4416		/* none of the above, turn the port OFF */
4417		stac_toggle_power_map(codec, nid, 0);
4418	}
4419
4420	snd_hda_jack_report_sync(codec);
4421
4422	/* sync mute LED */
4423	if (spec->gpio_led) {
4424		if (spec->vmaster_mute.hook)
4425			snd_hda_sync_vmaster_hook(&spec->vmaster_mute);
4426		else /* the very first init call doesn't have vmaster yet */
4427			stac92xx_update_led_status(codec, false);
4428	}
4429
4430	/* sync the power-map */
4431	if (spec->num_pwrs)
4432		snd_hda_codec_write(codec, codec->afg, 0,
4433				    AC_VERB_IDT_SET_POWER_MAP,
4434				    spec->power_map_bits);
4435	if (spec->dac_list)
4436		stac92xx_power_down(codec);
4437	return 0;
4438}
4439
4440static void stac92xx_free_kctls(struct hda_codec *codec)
4441{
4442	struct sigmatel_spec *spec = codec->spec;
4443
4444	if (spec->kctls.list) {
4445		struct snd_kcontrol_new *kctl = spec->kctls.list;
4446		int i;
4447		for (i = 0; i < spec->kctls.used; i++)
4448			kfree(kctl[i].name);
4449	}
4450	snd_array_free(&spec->kctls);
4451}
4452
4453static void stac92xx_shutup_pins(struct hda_codec *codec)
4454{
4455	unsigned int i, def_conf;
4456
4457	if (codec->bus->shutdown)
4458		return;
4459	for (i = 0; i < codec->init_pins.used; i++) {
4460		struct hda_pincfg *pin = snd_array_elem(&codec->init_pins, i);
4461		def_conf = snd_hda_codec_get_pincfg(codec, pin->nid);
4462		if (get_defcfg_connect(def_conf) != AC_JACK_PORT_NONE)
4463			snd_hda_set_pin_ctl(codec, pin->nid, 0);
4464	}
4465}
4466
4467static void stac92xx_shutup(struct hda_codec *codec)
4468{
4469	struct sigmatel_spec *spec = codec->spec;
4470
4471	stac92xx_shutup_pins(codec);
4472
4473	if (spec->eapd_mask)
4474		stac_gpio_set(codec, spec->gpio_mask,
4475				spec->gpio_dir, spec->gpio_data &
4476				~spec->eapd_mask);
4477}
4478
4479static void stac92xx_free(struct hda_codec *codec)
4480{
4481	struct sigmatel_spec *spec = codec->spec;
4482
4483	if (! spec)
4484		return;
4485
4486	stac92xx_shutup(codec);
4487
4488	kfree(spec);
4489	snd_hda_detach_beep_device(codec);
4490}
4491
4492static void stac92xx_set_pinctl(struct hda_codec *codec, hda_nid_t nid,
4493				unsigned int flag)
4494{
4495	unsigned int old_ctl, pin_ctl;
4496
4497	pin_ctl = snd_hda_codec_read(codec, nid,
4498			0, AC_VERB_GET_PIN_WIDGET_CONTROL, 0x00);
4499
4500	if (pin_ctl & AC_PINCTL_IN_EN) {
4501		/*
4502		 * we need to check the current set-up direction of
4503		 * shared input pins since they can be switched via
4504		 * "xxx as Output" mixer switch
4505		 */
4506		struct sigmatel_spec *spec = codec->spec;
4507		if (nid == spec->line_switch || nid == spec->mic_switch)
4508			return;
4509	}
4510
4511	old_ctl = pin_ctl;
4512	/* if setting pin direction bits, clear the current
4513	   direction bits first */
4514	if (flag & (AC_PINCTL_IN_EN | AC_PINCTL_OUT_EN))
4515		pin_ctl &= ~(AC_PINCTL_IN_EN | AC_PINCTL_OUT_EN);
4516	
4517	pin_ctl |= flag;
4518	if (old_ctl != pin_ctl)
4519		snd_hda_set_pin_ctl_cache(codec, nid, pin_ctl);
4520}
4521
4522static void stac92xx_reset_pinctl(struct hda_codec *codec, hda_nid_t nid,
4523				  unsigned int flag)
4524{
4525	unsigned int pin_ctl = snd_hda_codec_read(codec, nid,
4526			0, AC_VERB_GET_PIN_WIDGET_CONTROL, 0x00);
4527	if (pin_ctl & flag)
4528		snd_hda_set_pin_ctl_cache(codec, nid, pin_ctl & ~flag);
4529}
4530
4531static inline int get_pin_presence(struct hda_codec *codec, hda_nid_t nid)
4532{
4533	if (!nid)
4534		return 0;
4535	return snd_hda_jack_detect(codec, nid);
4536}
4537
4538static void stac92xx_line_out_detect(struct hda_codec *codec,
4539				     int presence)
4540{
4541	struct sigmatel_spec *spec = codec->spec;
4542	struct auto_pin_cfg *cfg = &spec->autocfg;
4543	int i;
4544
4545	for (i = 0; i < cfg->line_outs; i++) {
4546		if (presence)
4547			break;
4548		presence = get_pin_presence(codec, cfg->line_out_pins[i]);
4549		if (presence) {
4550			unsigned int pinctl;
4551			pinctl = snd_hda_codec_read(codec,
4552						    cfg->line_out_pins[i], 0,
4553					    AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
4554			if (pinctl & AC_PINCTL_IN_EN)
4555				presence = 0; /* mic- or line-input */
4556		}
4557	}
4558
4559	if (presence) {
4560		/* disable speakers */
4561		for (i = 0; i < cfg->speaker_outs; i++)
4562			stac92xx_reset_pinctl(codec, cfg->speaker_pins[i],
4563						AC_PINCTL_OUT_EN);
4564		if (spec->eapd_mask && spec->eapd_switch)
4565			stac_gpio_set(codec, spec->gpio_mask,
4566				spec->gpio_dir, spec->gpio_data &
4567				~spec->eapd_mask);
4568	} else {
4569		/* enable speakers */
4570		for (i = 0; i < cfg->speaker_outs; i++)
4571			stac92xx_set_pinctl(codec, cfg->speaker_pins[i],
4572						AC_PINCTL_OUT_EN);
4573		if (spec->eapd_mask && spec->eapd_switch)
4574			stac_gpio_set(codec, spec->gpio_mask,
4575				spec->gpio_dir, spec->gpio_data |
4576				spec->eapd_mask);
4577	}
4578} 
4579
4580/* return non-zero if the hp-pin of the given array index isn't
4581 * a jack-detection target
4582 */
4583static int no_hp_sensing(struct sigmatel_spec *spec, int i)
4584{
4585	struct auto_pin_cfg *cfg = &spec->autocfg;
4586
4587	/* ignore sensing of shared line and mic jacks */
4588	if (cfg->hp_pins[i] == spec->line_switch)
4589		return 1;
4590	if (cfg->hp_pins[i] == spec->mic_switch)
4591		return 1;
4592	/* ignore if the pin is set as line-out */
4593	if (cfg->hp_pins[i] == spec->hp_switch)
4594		return 1;
4595	return 0;
4596}
4597
4598static void stac92xx_hp_detect(struct hda_codec *codec)
4599{
4600	struct sigmatel_spec *spec = codec->spec;
4601	struct auto_pin_cfg *cfg = &spec->autocfg;
4602	int i, presence;
4603
4604	presence = 0;
4605	if (spec->gpio_mute)
4606		presence = !(snd_hda_codec_read(codec, codec->afg, 0,
4607			AC_VERB_GET_GPIO_DATA, 0) & spec->gpio_mute);
4608
4609	for (i = 0; i < cfg->hp_outs; i++) {
4610		if (presence)
4611			break;
4612		if (no_hp_sensing(spec, i))
4613			continue;
4614		presence = get_pin_presence(codec, cfg->hp_pins[i]);
4615		if (presence) {
4616			unsigned int pinctl;
4617			pinctl = snd_hda_codec_read(codec, cfg->hp_pins[i], 0,
4618					    AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
4619			if (pinctl & AC_PINCTL_IN_EN)
4620				presence = 0; /* mic- or line-input */
4621		}
4622	}
4623
4624	if (presence) {
4625		/* disable lineouts */
4626		if (spec->hp_switch)
4627			stac92xx_reset_pinctl(codec, spec->hp_switch,
4628					      AC_PINCTL_OUT_EN);
4629		for (i = 0; i < cfg->line_outs; i++)
4630			stac92xx_reset_pinctl(codec, cfg->line_out_pins[i],
4631						AC_PINCTL_OUT_EN);
4632	} else {
4633		/* enable lineouts */
4634		if (spec->hp_switch)
4635			stac92xx_set_pinctl(codec, spec->hp_switch,
4636					    AC_PINCTL_OUT_EN);
4637		for (i = 0; i < cfg->line_outs; i++)
4638			stac92xx_set_pinctl(codec, cfg->line_out_pins[i],
4639						AC_PINCTL_OUT_EN);
4640	}
4641	stac92xx_line_out_detect(codec, presence);
4642	/* toggle hp outs */
4643	for (i = 0; i < cfg->hp_outs; i++) {
4644		unsigned int val = AC_PINCTL_OUT_EN | AC_PINCTL_HP_EN;
4645		if (no_hp_sensing(spec, i))
4646			continue;
4647		if (1 /*presence*/)
4648			stac92xx_set_pinctl(codec, cfg->hp_pins[i], val);
4649#if 0 /* FIXME */
4650/* Resetting the pinctl like below may lead to (a sort of) regressions
4651 * on some devices since they use the HP pin actually for line/speaker
4652 * outs although the default pin config shows a different pin (that is
4653 * wrong and useless).
4654 *
4655 * So, it's basically a problem of default pin configs, likely a BIOS issue.
4656 * But, disabling the code below just works around it, and I'm too tired of
4657 * bug reports with such devices... 
4658 */
4659		else
4660			stac92xx_reset_pinctl(codec, cfg->hp_pins[i], val);
4661#endif /* FIXME */
4662	}
4663} 
4664
4665static void stac_toggle_power_map(struct hda_codec *codec, hda_nid_t nid,
4666				  int enable)
4667{
4668	struct sigmatel_spec *spec = codec->spec;
4669	unsigned int idx, val;
4670
4671	for (idx = 0; idx < spec->num_pwrs; idx++) {
4672		if (spec->pwr_nids[idx] == nid)
4673			break;
4674	}
4675	if (idx >= spec->num_pwrs)
4676		return;
4677
4678	idx = 1 << idx;
4679
4680	val = spec->power_map_bits;
4681	if (enable)
4682		val &= ~idx;
4683	else
4684		val |= idx;
4685
4686	/* power down unused output ports */
4687	if (val != spec->power_map_bits) {
4688		spec->power_map_bits = val;
4689		snd_hda_codec_write(codec, codec->afg, 0,
4690				    AC_VERB_IDT_SET_POWER_MAP, val);
4691	}
4692}
4693
4694static void stac92xx_pin_sense(struct hda_codec *codec, hda_nid_t nid)
4695{
4696	stac_toggle_power_map(codec, nid, get_pin_presence(codec, nid));
4697}
4698
4699/* get the pin connection (fixed, none, etc) */
4700static unsigned int stac_get_defcfg_connect(struct hda_codec *codec, int idx)
4701{
4702	struct sigmatel_spec *spec = codec->spec;
4703	unsigned int cfg;
4704
4705	cfg = snd_hda_codec_get_pincfg(codec, spec->pin_nids[idx]);
4706	return get_defcfg_connect(cfg);
4707}
4708
4709static int stac92xx_connected_ports(struct hda_codec *codec,
4710				    const hda_nid_t *nids, int num_nids)
4711{
4712	struct sigmatel_spec *spec = codec->spec;
4713	int idx, num;
4714	unsigned int def_conf;
4715
4716	for (num = 0; num < num_nids; num++) {
4717		for (idx = 0; idx < spec->num_pins; idx++)
4718			if (spec->pin_nids[idx] == nids[num])
4719				break;
4720		if (idx >= spec->num_pins)
4721			break;
4722		def_conf = stac_get_defcfg_connect(codec, idx);
4723		if (def_conf == AC_JACK_PORT_NONE)
4724			break;
4725	}
4726	return num;
4727}
4728
4729static void stac92xx_mic_detect(struct hda_codec *codec)
4730{
4731	struct sigmatel_spec *spec = codec->spec;
4732	struct sigmatel_mic_route *mic;
4733
4734	if (get_pin_presence(codec, spec->ext_mic.pin))
4735		mic = &spec->ext_mic;
4736	else if (get_pin_presence(codec, spec->dock_mic.pin))
4737		mic = &spec->dock_mic;
4738	else
4739		mic = &spec->int_mic;
4740	if (mic->dmux_idx >= 0)
4741		snd_hda_codec_write_cache(codec, spec->dmux_nids[0], 0,
4742					  AC_VERB_SET_CONNECT_SEL,
4743					  mic->dmux_idx);
4744	if (mic->mux_idx >= 0)
4745		snd_hda_codec_write_cache(codec, spec->mux_nids[0], 0,
4746					  AC_VERB_SET_CONNECT_SEL,
4747					  mic->mux_idx);
4748}
4749
4750static void handle_unsol_event(struct hda_codec *codec,
4751			       struct hda_jack_tbl *event)
4752{
4753	struct sigmatel_spec *spec = codec->spec;
4754	int data;
4755
4756	switch (event->action) {
4757	case STAC_HP_EVENT:
4758	case STAC_LO_EVENT:
4759		stac92xx_hp_detect(codec);
4760		break;
4761	case STAC_MIC_EVENT:
4762		stac92xx_mic_detect(codec);
4763		break;
4764	}
4765
4766	switch (event->action) {
4767	case STAC_HP_EVENT:
4768	case STAC_LO_EVENT:
4769	case STAC_MIC_EVENT:
4770	case STAC_INSERT_EVENT:
4771	case STAC_PWR_EVENT:
4772		if (spec->num_pwrs > 0)
4773			stac92xx_pin_sense(codec, event->nid);
4774
4775		switch (codec->subsystem_id) {
4776		case 0x103c308f:
4777			if (event->nid == 0xb) {
4778				int pin = AC_PINCTL_IN_EN;
4779
4780				if (get_pin_presence(codec, 0xa)
4781						&& get_pin_presence(codec, 0xb))
4782					pin |= AC_PINCTL_VREF_80;
4783				if (!get_pin_presence(codec, 0xb))
4784					pin |= AC_PINCTL_VREF_80;
4785
4786				/* toggle VREF state based on mic + hp pin
4787				 * status
4788				 */
4789				stac92xx_auto_set_pinctl(codec, 0x0a, pin);
4790			}
4791		}
4792		break;
4793	case STAC_VREF_EVENT:
4794		data = snd_hda_codec_read(codec, codec->afg, 0,
4795					  AC_VERB_GET_GPIO_DATA, 0);
4796		/* toggle VREF state based on GPIOx status */
4797		snd_hda_codec_write(codec, codec->afg, 0, 0x7e0,
4798				    !!(data & (1 << event->private_data)));
4799		break;
4800	}
4801}
4802
4803static void stac_issue_unsol_event(struct hda_codec *codec, hda_nid_t nid)
4804{
4805	struct hda_jack_tbl *event = snd_hda_jack_tbl_get(codec, nid);
4806	if (!event)
4807		return;
4808	handle_unsol_event(codec, event);
4809}
4810
4811static void stac92xx_unsol_event(struct hda_codec *codec, unsigned int res)
4812{
4813	struct hda_jack_tbl *event;
4814	int tag;
4815
4816	tag = (res >> 26) & 0x7f;
4817	event = snd_hda_jack_tbl_get_from_tag(codec, tag);
4818	if (!event)
4819		return;
4820	event->jack_dirty = 1;
4821	handle_unsol_event(codec, event);
4822	snd_hda_jack_report_sync(codec);
4823}
4824
4825static int hp_blike_system(u32 subsystem_id);
4826
4827static void set_hp_led_gpio(struct hda_codec *codec)
4828{
4829	struct sigmatel_spec *spec = codec->spec;
4830	unsigned int gpio;
4831
4832	if (spec->gpio_led)
4833		return;
4834
4835	gpio = snd_hda_param_read(codec, codec->afg, AC_PAR_GPIO_CAP);
4836	gpio &= AC_GPIO_IO_COUNT;
4837	if (gpio > 3)
4838		spec->gpio_led = 0x08; /* GPIO 3 */
4839	else
4840		spec->gpio_led = 0x01; /* GPIO 0 */
4841}
4842
4843/*
4844 * This method searches for the mute LED GPIO configuration
4845 * provided as OEM string in SMBIOS. The format of that string
4846 * is HP_Mute_LED_P_G or HP_Mute_LED_P
4847 * where P can be 0 or 1 and defines mute LED GPIO control state (low/high)
4848 * that corresponds to the NOT muted state of the master volume
4849 * and G is the index of the GPIO to use as the mute LED control (0..9)
4850 * If _G portion is missing it is assigned based on the codec ID
4851 *
4852 * So, HP B-series like systems may have HP_Mute_LED_0 (current models)
4853 * or  HP_Mute_LED_0_3 (future models) OEM SMBIOS strings
4854 *
4855 *
4856 * The dv-series laptops don't seem to have the HP_Mute_LED* strings in
4857 * SMBIOS - at least the ones I have seen do not have them - which include
4858 * my own system (HP Pavilion dv6-1110ax) and my cousin's
4859 * HP Pavilion dv9500t CTO.
4860 * Need more information on whether it is true across the entire series.
4861 * -- kunal
4862 */
4863static int find_mute_led_cfg(struct hda_codec *codec, int default_polarity)
4864{
4865	struct sigmatel_spec *spec = codec->spec;
4866	const struct dmi_device *dev = NULL;
4867
4868	if (get_int_hint(codec, "gpio_led", &spec->gpio_led)) {
4869		get_int_hint(codec, "gpio_led_polarity",
4870			     &spec->gpio_led_polarity);
4871		return 1;
4872	}
4873	if ((codec->subsystem_id >> 16) == PCI_VENDOR_ID_HP) {
4874		while ((dev = dmi_find_device(DMI_DEV_TYPE_OEM_STRING,
4875								NULL, dev))) {
4876			if (sscanf(dev->name, "HP_Mute_LED_%d_%x",
4877				  &spec->gpio_led_polarity,
4878				  &spec->gpio_led) == 2) {
4879				unsigned int max_gpio;
4880				max_gpio = snd_hda_param_read(codec, codec->afg,
4881							      AC_PAR_GPIO_CAP);
4882				max_gpio &= AC_GPIO_IO_COUNT;
4883				if (spec->gpio_led < max_gpio)
4884					spec->gpio_led = 1 << spec->gpio_led;
4885				else
4886					spec->vref_mute_led_nid = spec->gpio_led;
4887				return 1;
4888			}
4889			if (sscanf(dev->name, "HP_Mute_LED_%d",
4890				  &spec->gpio_led_polarity) == 1) {
4891				set_hp_led_gpio(codec);
4892				return 1;
4893			}
4894			/* BIOS bug: unfilled OEM string */
4895			if (strstr(dev->name, "HP_Mute_LED_P_G")) {
4896				set_hp_led_gpio(codec);
4897				switch (codec->subsystem_id) {
4898				case 0x103c148a:
4899					spec->gpio_led_polarity = 0;
4900					break;
4901				default:
4902					spec->gpio_led_polarity = 1;
4903					break;
4904				}
4905				return 1;
4906			}
4907		}
4908
4909		/*
4910		 * Fallback case - if we don't find the DMI strings,
4911		 * we statically set the GPIO - if not a B-series system
4912		 * and default polarity is provided
4913		 */
4914		if (!hp_blike_system(codec->subsystem_id) &&
4915			(default_polarity == 0 || default_polarity == 1)) {
4916			set_hp_led_gpio(codec);
4917			spec->gpio_led_polarity = default_polarity;
4918			return 1;
4919		}
4920	}
4921	return 0;
4922}
4923
4924static int hp_blike_system(u32 subsystem_id)
4925{
4926	switch (subsystem_id) {
4927	case 0x103c1520:
4928	case 0x103c1521:
4929	case 0x103c1523:
4930	case 0x103c1524:
4931	case 0x103c1525:
4932	case 0x103c1722:
4933	case 0x103c1723:
4934	case 0x103c1724:
4935	case 0x103c1725:
4936	case 0x103c1726:
4937	case 0x103c1727:
4938	case 0x103c1728:
4939	case 0x103c1729:
4940	case 0x103c172a:
4941	case 0x103c172b:
4942	case 0x103c307e:
4943	case 0x103c307f:
4944	case 0x103c3080:
4945	case 0x103c3081:
4946	case 0x103c7007:
4947	case 0x103c7008:
4948		return 1;
4949	}
4950	return 0;
4951}
4952
4953#ifdef CONFIG_PROC_FS
4954static void stac92hd_proc_hook(struct snd_info_buffer *buffer,
4955			       struct hda_codec *codec, hda_nid_t nid)
4956{
4957	if (nid == codec->afg)
4958		snd_iprintf(buffer, "Power-Map: 0x%02x\n", 
4959			    snd_hda_codec_read(codec, nid, 0,
4960					       AC_VERB_IDT_GET_POWER_MAP, 0));
4961}
4962
4963static void analog_loop_proc_hook(struct snd_info_buffer *buffer,
4964				  struct hda_codec *codec,
4965				  unsigned int verb)
4966{
4967	snd_iprintf(buffer, "Analog Loopback: 0x%02x\n",
4968		    snd_hda_codec_read(codec, codec->afg, 0, verb, 0));
4969}
4970
4971/* stac92hd71bxx, stac92hd73xx */
4972static void stac92hd7x_proc_hook(struct snd_info_buffer *buffer,
4973				 struct hda_codec *codec, hda_nid_t nid)
4974{
4975	stac92hd_proc_hook(buffer, codec, nid);
4976	if (nid == codec->afg)
4977		analog_loop_proc_hook(buffer, codec, 0xfa0);
4978}
4979
4980static void stac9205_proc_hook(struct snd_info_buffer *buffer,
4981			       struct hda_codec *codec, hda_nid_t nid)
4982{
4983	if (nid == codec->afg)
4984		analog_loop_proc_hook(buffer, codec, 0xfe0);
4985}
4986
4987static void stac927x_proc_hook(struct snd_info_buffer *buffer,
4988			       struct hda_codec *codec, hda_nid_t nid)
4989{
4990	if (nid == codec->afg)
4991		analog_loop_proc_hook(buffer, codec, 0xfeb);
4992}
4993#else
4994#define stac92hd_proc_hook	NULL
4995#define stac92hd7x_proc_hook	NULL
4996#define stac9205_proc_hook	NULL
4997#define stac927x_proc_hook	NULL
4998#endif
4999
5000#ifdef CONFIG_PM
5001static int stac92xx_resume(struct hda_codec *codec)
5002{
5003	stac92xx_init(codec);
5004	snd_hda_codec_resume_amp(codec);
5005	snd_hda_codec_resume_cache(codec);
5006	/* fake event to set up pins again to override cached values */
5007	stac_fake_hp_events(codec);
5008	return 0;
5009}
5010
5011static int stac92xx_suspend(struct hda_codec *codec, pm_message_t state)
5012{
5013	stac92xx_shutup(codec);
5014	return 0;
5015}
5016
5017static void stac92xx_set_power_state(struct hda_codec *codec, hda_nid_t fg,
5018				unsigned int power_state)
5019{
5020	unsigned int afg_power_state = power_state;
5021	struct sigmatel_spec *spec = codec->spec;
5022
5023	if (power_state == AC_PWRST_D3) {
5024		if (spec->vref_mute_led_nid) {
5025			/* with vref-out pin used for mute led control
5026			 * codec AFG is prevented from D3 state
5027			 */
5028			afg_power_state = AC_PWRST_D1;
5029		}
5030		/* this delay seems necessary to avoid click noise at power-down */
5031		msleep(100);
5032	}
5033	snd_hda_codec_read(codec, fg, 0, AC_VERB_SET_POWER_STATE,
5034			afg_power_state);
5035	snd_hda_codec_set_power_to_all(codec, fg, power_state, true);
5036}
5037#else
5038#define stac92xx_suspend	NULL
5039#define stac92xx_resume		NULL
5040#define stac92xx_set_power_state NULL
5041#endif /* CONFIG_PM */
5042
5043/* update mute-LED accoring to the master switch */
5044static void stac92xx_update_led_status(struct hda_codec *codec, int enabled)
 
 
 
 
 
 
 
 
 
 
5045{
5046	struct sigmatel_spec *spec = codec->spec;
5047	int muted = !enabled;
5048
5049	if (!spec->gpio_led)
5050		return;
5051
5052	/* LED state is inverted on these systems */
5053	if (spec->gpio_led_polarity)
5054		muted = !muted;
5055
5056	if (!spec->vref_mute_led_nid) {
5057		if (muted)
5058			spec->gpio_data |= spec->gpio_led;
5059		else
5060			spec->gpio_data &= ~spec->gpio_led;
5061		stac_gpio_set(codec, spec->gpio_mask,
5062				spec->gpio_dir, spec->gpio_data);
5063	} else {
5064		spec->vref_led = muted ? AC_PINCTL_VREF_50 : AC_PINCTL_VREF_GRD;
5065		stac_vrefout_set(codec,	spec->vref_mute_led_nid,
5066				 spec->vref_led);
5067	}
5068}
5069
5070static const struct hda_codec_ops stac92xx_patch_ops = {
5071	.build_controls = stac92xx_build_controls,
5072	.build_pcms = stac92xx_build_pcms,
5073	.init = stac92xx_init,
5074	.free = stac92xx_free,
5075	.unsol_event = stac92xx_unsol_event,
5076#ifdef CONFIG_PM
5077	.suspend = stac92xx_suspend,
5078	.resume = stac92xx_resume,
5079#endif
5080	.reboot_notify = stac92xx_shutup,
5081};
5082
5083static int patch_stac9200(struct hda_codec *codec)
5084{
5085	struct sigmatel_spec *spec;
5086	int err;
5087
5088	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5089	if (spec == NULL)
5090		return -ENOMEM;
5091
5092	codec->no_trigger_sense = 1;
5093	codec->spec = spec;
5094	spec->linear_tone_beep = 1;
5095	spec->num_pins = ARRAY_SIZE(stac9200_pin_nids);
5096	spec->pin_nids = stac9200_pin_nids;
5097	spec->board_config = snd_hda_check_board_config(codec, STAC_9200_MODELS,
5098							stac9200_models,
5099							stac9200_cfg_tbl);
5100	if (spec->board_config < 0)
5101		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5102			    codec->chip_name);
5103	else
5104		stac92xx_set_config_regs(codec,
5105					 stac9200_brd_tbl[spec->board_config]);
5106
5107	spec->multiout.max_channels = 2;
5108	spec->multiout.num_dacs = 1;
5109	spec->multiout.dac_nids = stac9200_dac_nids;
5110	spec->adc_nids = stac9200_adc_nids;
5111	spec->mux_nids = stac9200_mux_nids;
5112	spec->num_muxes = 1;
5113	spec->num_dmics = 0;
5114	spec->num_adcs = 1;
5115	spec->num_pwrs = 0;
5116
5117	if (spec->board_config == STAC_9200_M4 ||
5118	    spec->board_config == STAC_9200_M4_2 ||
5119	    spec->board_config == STAC_9200_OQO)
5120		spec->init = stac9200_eapd_init;
5121	else
5122		spec->init = stac9200_core_init;
5123	spec->mixer = stac9200_mixer;
5124
5125	if (spec->board_config == STAC_9200_PANASONIC) {
5126		spec->gpio_mask = spec->gpio_dir = 0x09;
5127		spec->gpio_data = 0x00;
5128	}
5129
5130	err = stac9200_parse_auto_config(codec);
5131	if (err < 0) {
5132		stac92xx_free(codec);
5133		return err;
5134	}
5135
5136	/* CF-74 has no headphone detection, and the driver should *NOT*
5137	 * do detection and HP/speaker toggle because the hardware does it.
5138	 */
5139	if (spec->board_config == STAC_9200_PANASONIC)
5140		spec->hp_detect = 0;
5141
5142	codec->patch_ops = stac92xx_patch_ops;
5143
5144	return 0;
5145}
5146
5147static int patch_stac925x(struct hda_codec *codec)
5148{
5149	struct sigmatel_spec *spec;
5150	int err;
5151
5152	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5153	if (spec == NULL)
5154		return -ENOMEM;
5155
5156	codec->no_trigger_sense = 1;
5157	codec->spec = spec;
5158	spec->linear_tone_beep = 1;
5159	spec->num_pins = ARRAY_SIZE(stac925x_pin_nids);
5160	spec->pin_nids = stac925x_pin_nids;
5161
5162	/* Check first for codec ID */
5163	spec->board_config = snd_hda_check_board_codec_sid_config(codec,
5164							STAC_925x_MODELS,
5165							stac925x_models,
5166							stac925x_codec_id_cfg_tbl);
5167
5168	/* Now checks for PCI ID, if codec ID is not found */
5169	if (spec->board_config < 0)
5170		spec->board_config = snd_hda_check_board_config(codec,
5171							STAC_925x_MODELS,
5172							stac925x_models,
5173							stac925x_cfg_tbl);
5174 again:
5175	if (spec->board_config < 0)
5176		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5177			    codec->chip_name);
5178	else
5179		stac92xx_set_config_regs(codec,
5180					 stac925x_brd_tbl[spec->board_config]);
5181
5182	spec->multiout.max_channels = 2;
5183	spec->multiout.num_dacs = 1;
5184	spec->multiout.dac_nids = stac925x_dac_nids;
5185	spec->adc_nids = stac925x_adc_nids;
5186	spec->mux_nids = stac925x_mux_nids;
5187	spec->num_muxes = 1;
5188	spec->num_adcs = 1;
5189	spec->num_pwrs = 0;
5190	switch (codec->vendor_id) {
5191	case 0x83847632: /* STAC9202  */
5192	case 0x83847633: /* STAC9202D */
5193	case 0x83847636: /* STAC9251  */
5194	case 0x83847637: /* STAC9251D */
5195		spec->num_dmics = STAC925X_NUM_DMICS;
5196		spec->dmic_nids = stac925x_dmic_nids;
5197		spec->num_dmuxes = ARRAY_SIZE(stac925x_dmux_nids);
5198		spec->dmux_nids = stac925x_dmux_nids;
5199		break;
5200	default:
5201		spec->num_dmics = 0;
5202		break;
5203	}
5204
5205	spec->init = stac925x_core_init;
5206	spec->mixer = stac925x_mixer;
5207	spec->num_caps = 1;
5208	spec->capvols = stac925x_capvols;
5209	spec->capsws = stac925x_capsws;
5210
5211	err = stac92xx_parse_auto_config(codec);
5212	if (!err) {
5213		if (spec->board_config < 0) {
5214			printk(KERN_WARNING "hda_codec: No auto-config is "
5215			       "available, default to model=ref\n");
5216			spec->board_config = STAC_925x_REF;
5217			goto again;
5218		}
5219		err = -EINVAL;
5220	}
5221	if (err < 0) {
5222		stac92xx_free(codec);
5223		return err;
5224	}
5225
5226	codec->patch_ops = stac92xx_patch_ops;
5227
5228	return 0;
5229}
5230
5231static int patch_stac92hd73xx(struct hda_codec *codec)
5232{
5233	struct sigmatel_spec *spec;
5234	hda_nid_t conn[STAC92HD73_DAC_COUNT + 2];
5235	int err = 0;
5236	int num_dacs;
5237
5238	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5239	if (spec == NULL)
5240		return -ENOMEM;
5241
5242	codec->no_trigger_sense = 1;
5243	codec->spec = spec;
 
 
 
 
5244	spec->linear_tone_beep = 0;
5245	codec->slave_dig_outs = stac92hd73xx_slave_dig_outs;
5246	spec->num_pins = ARRAY_SIZE(stac92hd73xx_pin_nids);
5247	spec->pin_nids = stac92hd73xx_pin_nids;
5248	spec->board_config = snd_hda_check_board_config(codec,
5249							STAC_92HD73XX_MODELS,
5250							stac92hd73xx_models,
5251							stac92hd73xx_cfg_tbl);
5252	/* check codec subsystem id if not found */
5253	if (spec->board_config < 0)
5254		spec->board_config =
5255			snd_hda_check_board_codec_sid_config(codec,
5256				STAC_92HD73XX_MODELS, stac92hd73xx_models,
5257				stac92hd73xx_codec_id_cfg_tbl);
5258again:
5259	if (spec->board_config < 0)
5260		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5261			    codec->chip_name);
5262	else
5263		stac92xx_set_config_regs(codec,
5264				stac92hd73xx_brd_tbl[spec->board_config]);
5265
5266	num_dacs = snd_hda_get_connections(codec, 0x0a,
5267			conn, STAC92HD73_DAC_COUNT + 2) - 1;
5268
 
5269	if (num_dacs < 3 || num_dacs > 5) {
5270		printk(KERN_WARNING "hda_codec: Could not determine "
5271		       "number of channels defaulting to DAC count\n");
5272		num_dacs = STAC92HD73_DAC_COUNT;
5273	}
5274	spec->init = stac92hd73xx_core_init;
5275	switch (num_dacs) {
5276	case 0x3: /* 6 Channel */
5277		spec->aloopback_ctl = stac92hd73xx_6ch_loopback;
5278		break;
5279	case 0x4: /* 8 Channel */
5280		spec->aloopback_ctl = stac92hd73xx_8ch_loopback;
5281		break;
5282	case 0x5: /* 10 Channel */
5283		spec->aloopback_ctl = stac92hd73xx_10ch_loopback;
5284		break;
5285	}
5286	spec->multiout.dac_nids = spec->dac_nids;
5287
5288	spec->aloopback_mask = 0x01;
5289	spec->aloopback_shift = 8;
5290
5291	spec->digbeep_nid = 0x1c;
5292	spec->mux_nids = stac92hd73xx_mux_nids;
5293	spec->adc_nids = stac92hd73xx_adc_nids;
5294	spec->dmic_nids = stac92hd73xx_dmic_nids;
5295	spec->dmux_nids = stac92hd73xx_dmux_nids;
5296	spec->smux_nids = stac92hd73xx_smux_nids;
5297
5298	spec->num_muxes = ARRAY_SIZE(stac92hd73xx_mux_nids);
5299	spec->num_adcs = ARRAY_SIZE(stac92hd73xx_adc_nids);
5300	spec->num_dmuxes = ARRAY_SIZE(stac92hd73xx_dmux_nids);
5301
5302	spec->num_caps = STAC92HD73XX_NUM_CAPS;
5303	spec->capvols = stac92hd73xx_capvols;
5304	spec->capsws = stac92hd73xx_capsws;
5305
5306	switch (spec->board_config) {
5307	case STAC_DELL_EQ:
5308		spec->init = dell_eq_core_init;
5309		/* fallthru */
5310	case STAC_DELL_M6_AMIC:
5311	case STAC_DELL_M6_DMIC:
5312	case STAC_DELL_M6_BOTH:
5313		spec->num_smuxes = 0;
5314		spec->eapd_switch = 0;
5315
5316		switch (spec->board_config) {
5317		case STAC_DELL_M6_AMIC: /* Analog Mics */
5318			snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170);
5319			spec->num_dmics = 0;
5320			break;
5321		case STAC_DELL_M6_DMIC: /* Digital Mics */
5322			snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160);
5323			spec->num_dmics = 1;
5324			break;
5325		case STAC_DELL_M6_BOTH: /* Both */
5326			snd_hda_codec_set_pincfg(codec, 0x0b, 0x90A70170);
5327			snd_hda_codec_set_pincfg(codec, 0x13, 0x90A60160);
5328			spec->num_dmics = 1;
5329			break;
5330		}
5331		break;
5332	case STAC_ALIENWARE_M17X:
5333		spec->num_dmics = STAC92HD73XX_NUM_DMICS;
5334		spec->num_smuxes = ARRAY_SIZE(stac92hd73xx_smux_nids);
5335		spec->eapd_switch = 0;
5336		break;
5337	default:
5338		spec->num_dmics = STAC92HD73XX_NUM_DMICS;
5339		spec->num_smuxes = ARRAY_SIZE(stac92hd73xx_smux_nids);
5340		spec->eapd_switch = 1;
5341		break;
5342	}
5343	if (spec->board_config != STAC_92HD73XX_REF) {
5344		/* GPIO0 High = Enable EAPD */
5345		spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1;
5346		spec->gpio_data = 0x01;
5347	}
5348
5349	spec->num_pwrs = ARRAY_SIZE(stac92hd73xx_pwr_nids);
5350	spec->pwr_nids = stac92hd73xx_pwr_nids;
5351
5352	err = stac92xx_parse_auto_config(codec);
 
5353
5354	if (!err) {
5355		if (spec->board_config < 0) {
5356			printk(KERN_WARNING "hda_codec: No auto-config is "
5357			       "available, default to model=ref\n");
5358			spec->board_config = STAC_92HD73XX_REF;
5359			goto again;
5360		}
5361		err = -EINVAL;
5362	}
5363
 
5364	if (err < 0) {
5365		stac92xx_free(codec);
5366		return err;
5367	}
5368
5369	if (spec->board_config == STAC_92HD73XX_NO_JD)
5370		spec->hp_detect = 0;
5371
5372	codec->patch_ops = stac92xx_patch_ops;
 
5373
5374	codec->proc_widget_hook = stac92hd7x_proc_hook;
5375
5376	return 0;
5377}
5378
5379static int hp_bnb2011_with_dock(struct hda_codec *codec)
5380{
5381	if (codec->vendor_id != 0x111d7605 &&
5382	    codec->vendor_id != 0x111d76d1)
5383		return 0;
5384
5385	switch (codec->subsystem_id) {
5386	case 0x103c1618:
5387	case 0x103c1619:
5388	case 0x103c161a:
5389	case 0x103c161b:
5390	case 0x103c161c:
5391	case 0x103c161d:
5392	case 0x103c161e:
5393	case 0x103c161f:
5394
5395	case 0x103c162a:
5396	case 0x103c162b:
5397
5398	case 0x103c1630:
5399	case 0x103c1631:
5400
5401	case 0x103c1633:
5402	case 0x103c1634:
5403	case 0x103c1635:
5404
5405	case 0x103c3587:
5406	case 0x103c3588:
5407	case 0x103c3589:
5408	case 0x103c358a:
5409
5410	case 0x103c3667:
5411	case 0x103c3668:
5412	case 0x103c3669:
5413
5414		return 1;
5415	}
5416	return 0;
5417}
5418
5419static void stac92hd8x_add_pin(struct hda_codec *codec, hda_nid_t nid)
5420{
5421	struct sigmatel_spec *spec = codec->spec;
5422	unsigned int def_conf = snd_hda_codec_get_pincfg(codec, nid);
5423	int i;
5424
5425	spec->auto_pin_nids[spec->auto_pin_cnt] = nid;
5426	spec->auto_pin_cnt++;
5427
5428	if (get_defcfg_device(def_conf) == AC_JACK_MIC_IN &&
5429	    get_defcfg_connect(def_conf) != AC_JACK_PORT_NONE) {
5430		for (i = 0; i < ARRAY_SIZE(stac92hd83xxx_dmic_nids); i++) {
5431			if (nid == stac92hd83xxx_dmic_nids[i]) {
5432				spec->auto_dmic_nids[spec->auto_dmic_cnt] = nid;
5433				spec->auto_dmic_cnt++;
5434			}
5435		}
5436	}
5437}
5438
5439static void stac92hd8x_add_adc(struct hda_codec *codec, hda_nid_t nid)
5440{
5441	struct sigmatel_spec *spec = codec->spec;
5442
5443	spec->auto_adc_nids[spec->auto_adc_cnt] = nid;
5444	spec->auto_adc_cnt++;
5445}
5446
5447static void stac92hd8x_add_mux(struct hda_codec *codec, hda_nid_t nid)
5448{
5449	int i, j;
5450	struct sigmatel_spec *spec = codec->spec;
5451
5452	for (i = 0; i < spec->auto_adc_cnt; i++) {
5453		if (get_connection_index(codec,
5454				spec->auto_adc_nids[i], nid) >= 0) {
5455			/* mux and volume for adc_nids[i] */
5456			if (!spec->auto_mux_nids[i]) {
5457				spec->auto_mux_nids[i] = nid;
5458				/* 92hd codecs capture volume is in mux */
5459				spec->auto_capvols[i] = HDA_COMPOSE_AMP_VAL(nid,
5460							3, 0, HDA_OUTPUT);
5461			}
5462			for (j = 0; j < spec->auto_dmic_cnt; j++) {
5463				if (get_connection_index(codec, nid,
5464						spec->auto_dmic_nids[j]) >= 0) {
5465					/* dmux for adc_nids[i] */
5466					if (!spec->auto_dmux_nids[i])
5467						spec->auto_dmux_nids[i] = nid;
5468					break;
5469				}
5470			}
5471			break;
5472		}
5473	}
5474}
5475
5476static void stac92hd8x_fill_auto_spec(struct hda_codec *codec)
5477{
5478	hda_nid_t nid, end_nid;
5479	unsigned int wid_caps, wid_type;
5480	struct sigmatel_spec *spec = codec->spec;
5481
5482	end_nid = codec->start_nid + codec->num_nodes;
5483
5484	for (nid = codec->start_nid; nid < end_nid; nid++) {
5485		wid_caps = get_wcaps(codec, nid);
5486		wid_type = get_wcaps_type(wid_caps);
5487
5488		if (wid_type == AC_WID_PIN)
5489			stac92hd8x_add_pin(codec, nid);
5490
5491		if (wid_type == AC_WID_AUD_IN && !(wid_caps & AC_WCAP_DIGITAL))
5492			stac92hd8x_add_adc(codec, nid);
 
 
 
 
5493	}
5494
5495	for (nid = codec->start_nid; nid < end_nid; nid++) {
5496		wid_caps = get_wcaps(codec, nid);
5497		wid_type = get_wcaps_type(wid_caps);
5498
5499		if (wid_type == AC_WID_AUD_SEL)
5500			stac92hd8x_add_mux(codec, nid);
5501	}
5502
5503	spec->pin_nids = spec->auto_pin_nids;
5504	spec->num_pins = spec->auto_pin_cnt;
5505	spec->adc_nids = spec->auto_adc_nids;
5506	spec->num_adcs = spec->auto_adc_cnt;
5507	spec->capvols = spec->auto_capvols;
5508	spec->capsws = spec->auto_capvols;
5509	spec->num_caps = spec->auto_adc_cnt;
5510	spec->mux_nids = spec->auto_mux_nids;
5511	spec->num_muxes = spec->auto_adc_cnt;
5512	spec->dmux_nids = spec->auto_dmux_nids;
5513	spec->num_dmuxes = spec->auto_adc_cnt;
5514	spec->dmic_nids = spec->auto_dmic_nids;
5515	spec->num_dmics = spec->auto_dmic_cnt;
5516}
5517
5518static int patch_stac92hd83xxx(struct hda_codec *codec)
5519{
5520	struct sigmatel_spec *spec;
5521	int default_polarity = -1; /* no default cfg */
5522	int err;
5523
5524	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5525	if (spec == NULL)
5526		return -ENOMEM;
5527
5528	if (hp_bnb2011_with_dock(codec)) {
5529		snd_hda_codec_set_pincfg(codec, 0xa, 0x2101201f);
5530		snd_hda_codec_set_pincfg(codec, 0xf, 0x2181205e);
5531	}
5532
5533	codec->no_trigger_sense = 1;
5534	codec->spec = spec;
5535
5536	stac92hd8x_fill_auto_spec(codec);
 
 
 
 
 
5537
5538	spec->linear_tone_beep = 0;
5539	codec->slave_dig_outs = stac92hd83xxx_slave_dig_outs;
5540	spec->digbeep_nid = 0x21;
5541	spec->pwr_nids = stac92hd83xxx_pwr_nids;
5542	spec->num_pwrs = ARRAY_SIZE(stac92hd83xxx_pwr_nids);
5543	spec->multiout.dac_nids = spec->dac_nids;
5544	spec->init = stac92hd83xxx_core_init;
5545
5546	spec->board_config = snd_hda_check_board_config(codec,
5547							STAC_92HD83XXX_MODELS,
5548							stac92hd83xxx_models,
5549							stac92hd83xxx_cfg_tbl);
5550	/* check codec subsystem id if not found */
5551	if (spec->board_config < 0)
5552		spec->board_config =
5553			snd_hda_check_board_codec_sid_config(codec,
5554				STAC_92HD83XXX_MODELS, stac92hd83xxx_models,
5555				stac92hd83xxx_codec_id_cfg_tbl);
5556again:
5557	if (spec->board_config < 0)
5558		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5559			    codec->chip_name);
5560	else
5561		stac92xx_set_config_regs(codec,
5562				stac92hd83xxx_brd_tbl[spec->board_config]);
5563
5564	codec->patch_ops = stac92xx_patch_ops;
 
 
5565
5566	switch (spec->board_config) {
5567	case STAC_HP_ZEPHYR:
5568		spec->init = stac92hd83xxx_hp_zephyr_init;
5569		break;
5570	case STAC_92HD83XXX_HP_LED:
5571		default_polarity = 0;
5572		break;
5573	case STAC_92HD83XXX_HP_INV_LED:
5574		default_polarity = 1;
5575		break;
5576	}
5577
5578	if (find_mute_led_cfg(codec, default_polarity))
5579		snd_printd("mute LED gpio %d polarity %d\n",
5580				spec->gpio_led,
5581				spec->gpio_led_polarity);
5582
5583	if (spec->gpio_led) {
5584		if (!spec->vref_mute_led_nid) {
5585			spec->gpio_mask |= spec->gpio_led;
5586			spec->gpio_dir |= spec->gpio_led;
5587			spec->gpio_data |= spec->gpio_led;
5588		} else {
5589			codec->patch_ops.set_power_state =
5590					stac92xx_set_power_state;
5591		}
5592	}
5593
5594	err = stac92xx_parse_auto_config(codec);
5595	if (!err) {
5596		if (spec->board_config < 0) {
5597			printk(KERN_WARNING "hda_codec: No auto-config is "
5598			       "available, default to model=ref\n");
5599			spec->board_config = STAC_92HD83XXX_REF;
5600			goto again;
5601		}
5602		err = -EINVAL;
5603	}
5604
 
5605	if (err < 0) {
5606		stac92xx_free(codec);
5607		return err;
5608	}
5609
5610	codec->proc_widget_hook = stac92hd_proc_hook;
5611
 
 
5612	return 0;
5613}
5614
5615static int stac92hd71bxx_connected_smuxes(struct hda_codec *codec,
5616					  hda_nid_t dig0pin)
 
 
 
5617{
5618	struct sigmatel_spec *spec = codec->spec;
5619	int idx;
 
 
 
 
5620
5621	for (idx = 0; idx < spec->num_pins; idx++)
5622		if (spec->pin_nids[idx] == dig0pin)
5623			break;
5624	if ((idx + 2) >= spec->num_pins)
5625		return 0;
5626
5627	/* dig1pin case */
5628	if (stac_get_defcfg_connect(codec, idx + 1) != AC_JACK_PORT_NONE)
5629		return 2;
5630
5631	/* dig0pin + dig2pin case */
5632	if (stac_get_defcfg_connect(codec, idx + 2) != AC_JACK_PORT_NONE)
5633		return 2;
5634	if (stac_get_defcfg_connect(codec, idx) != AC_JACK_PORT_NONE)
5635		return 1;
5636	else
5637		return 0;
5638}
5639
5640/* HP dv7 bass switch - GPIO5 */
5641#define stac_hp_bass_gpio_info	snd_ctl_boolean_mono_info
5642static int stac_hp_bass_gpio_get(struct snd_kcontrol *kcontrol,
5643				 struct snd_ctl_elem_value *ucontrol)
5644{
5645	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
5646	struct sigmatel_spec *spec = codec->spec;
5647	ucontrol->value.integer.value[0] = !!(spec->gpio_data & 0x20);
5648	return 0;
5649}
5650
5651static int stac_hp_bass_gpio_put(struct snd_kcontrol *kcontrol,
5652				 struct snd_ctl_elem_value *ucontrol)
5653{
5654	struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
5655	struct sigmatel_spec *spec = codec->spec;
5656	unsigned int gpio_data;
5657
5658	gpio_data = (spec->gpio_data & ~0x20) |
5659		(ucontrol->value.integer.value[0] ? 0x20 : 0);
5660	if (gpio_data == spec->gpio_data)
5661		return 0;
5662	spec->gpio_data = gpio_data;
5663	stac_gpio_set(codec, spec->gpio_mask, spec->gpio_dir, spec->gpio_data);
5664	return 1;
5665}
5666
5667static const struct snd_kcontrol_new stac_hp_bass_sw_ctrl = {
5668	.iface = SNDRV_CTL_ELEM_IFACE_MIXER,
5669	.info = stac_hp_bass_gpio_info,
5670	.get = stac_hp_bass_gpio_get,
5671	.put = stac_hp_bass_gpio_put,
5672};
5673
5674static int stac_add_hp_bass_switch(struct hda_codec *codec)
5675{
5676	struct sigmatel_spec *spec = codec->spec;
5677
5678	if (!stac_control_new(spec, &stac_hp_bass_sw_ctrl,
5679			      "Bass Speaker Playback Switch", 0))
5680		return -ENOMEM;
5681
5682	spec->gpio_mask |= 0x20;
5683	spec->gpio_dir |= 0x20;
5684	spec->gpio_data |= 0x20;
5685	return 0;
5686}
5687
5688static int patch_stac92hd71bxx(struct hda_codec *codec)
5689{
5690	struct sigmatel_spec *spec;
5691	const struct hda_verb *unmute_init = stac92hd71bxx_unmute_core_init;
5692	unsigned int pin_cfg;
5693	int err = 0;
5694
5695	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5696	if (spec == NULL)
5697		return -ENOMEM;
5698
5699	codec->no_trigger_sense = 1;
5700	codec->spec = spec;
 
5701	spec->linear_tone_beep = 0;
5702	codec->patch_ops = stac92xx_patch_ops;
5703	spec->num_pins = STAC92HD71BXX_NUM_PINS;
5704	switch (codec->vendor_id) {
5705	case 0x111d76b6:
5706	case 0x111d76b7:
5707		spec->pin_nids = stac92hd71bxx_pin_nids_4port;
5708		break;
5709	case 0x111d7603:
5710	case 0x111d7608:
5711		/* On 92HD75Bx 0x27 isn't a pin nid */
5712		spec->num_pins--;
5713		/* fallthrough */
5714	default:
5715		spec->pin_nids = stac92hd71bxx_pin_nids_6port;
5716	}
5717	spec->num_pwrs = ARRAY_SIZE(stac92hd71bxx_pwr_nids);
5718	spec->board_config = snd_hda_check_board_config(codec,
5719							STAC_92HD71BXX_MODELS,
5720							stac92hd71bxx_models,
5721							stac92hd71bxx_cfg_tbl);
5722again:
5723	if (spec->board_config < 0)
5724		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5725			    codec->chip_name);
5726	else
5727		stac92xx_set_config_regs(codec,
5728				stac92hd71bxx_brd_tbl[spec->board_config]);
5729
5730	if (spec->board_config != STAC_92HD71BXX_REF) {
5731		/* GPIO0 = EAPD */
5732		spec->gpio_mask = 0x01;
5733		spec->gpio_dir = 0x01;
5734		spec->gpio_data = 0x01;
5735	}
5736
5737	spec->dmic_nids = stac92hd71bxx_dmic_nids;
5738	spec->dmux_nids = stac92hd71bxx_dmux_nids;
5739
5740	spec->num_caps = STAC92HD71BXX_NUM_CAPS;
5741	spec->capvols = stac92hd71bxx_capvols;
5742	spec->capsws = stac92hd71bxx_capsws;
5743
5744	switch (codec->vendor_id) {
5745	case 0x111d76b6: /* 4 Port without Analog Mixer */
5746	case 0x111d76b7:
5747		unmute_init++;
5748		/* fallthru */
5749	case 0x111d76b4: /* 6 Port without Analog Mixer */
5750	case 0x111d76b5:
5751		spec->init = stac92hd71bxx_core_init;
5752		codec->slave_dig_outs = stac92hd71bxx_slave_dig_outs;
5753		spec->num_dmics = stac92xx_connected_ports(codec,
5754					stac92hd71bxx_dmic_nids,
5755					STAC92HD71BXX_NUM_DMICS);
5756		break;
5757	case 0x111d7608: /* 5 Port with Analog Mixer */
5758		switch (spec->board_config) {
5759		case STAC_HP_M4:
5760			/* Enable VREF power saving on GPIO1 detect */
5761			err = stac_add_event(codec, codec->afg,
5762					     STAC_VREF_EVENT, 0x02);
5763			if (err < 0)
5764				return err;
5765			snd_hda_codec_write_cache(codec, codec->afg, 0,
5766				AC_VERB_SET_GPIO_UNSOLICITED_RSP_MASK, 0x02);
5767			snd_hda_jack_detect_enable(codec, codec->afg, 0);
5768			spec->gpio_mask |= 0x02;
5769			break;
5770		}
5771		if ((codec->revision_id & 0xf) == 0 ||
5772		    (codec->revision_id & 0xf) == 1)
5773			spec->stream_delay = 40; /* 40 milliseconds */
5774
5775		/* disable VSW */
5776		spec->init = stac92hd71bxx_core_init;
5777		unmute_init++;
5778		snd_hda_codec_set_pincfg(codec, 0x0f, 0x40f000f0);
5779		snd_hda_codec_set_pincfg(codec, 0x19, 0x40f000f3);
5780		spec->dmic_nids = stac92hd71bxx_dmic_5port_nids;
5781		spec->num_dmics = stac92xx_connected_ports(codec,
5782					stac92hd71bxx_dmic_5port_nids,
5783					STAC92HD71BXX_NUM_DMICS - 1);
5784		break;
5785	case 0x111d7603: /* 6 Port with Analog Mixer */
5786		if ((codec->revision_id & 0xf) == 1)
5787			spec->stream_delay = 40; /* 40 milliseconds */
5788
5789		/* fallthru */
5790	default:
5791		spec->init = stac92hd71bxx_core_init;
5792		codec->slave_dig_outs = stac92hd71bxx_slave_dig_outs;
5793		spec->num_dmics = stac92xx_connected_ports(codec,
5794					stac92hd71bxx_dmic_nids,
5795					STAC92HD71BXX_NUM_DMICS);
5796		break;
5797	}
5798
5799	if (get_wcaps(codec, 0xa) & AC_WCAP_IN_AMP)
5800		snd_hda_sequence_write_cache(codec, unmute_init);
5801
5802	spec->aloopback_ctl = stac92hd71bxx_loopback;
 
 
 
 
 
 
 
5803	spec->aloopback_mask = 0x50;
5804	spec->aloopback_shift = 0;
5805
5806	spec->powerdown_adcs = 1;
5807	spec->digbeep_nid = 0x26;
5808	spec->mux_nids = stac92hd71bxx_mux_nids;
5809	spec->adc_nids = stac92hd71bxx_adc_nids;
5810	spec->smux_nids = stac92hd71bxx_smux_nids;
5811	spec->pwr_nids = stac92hd71bxx_pwr_nids;
5812
5813	spec->num_muxes = ARRAY_SIZE(stac92hd71bxx_mux_nids);
5814	spec->num_adcs = ARRAY_SIZE(stac92hd71bxx_adc_nids);
5815	spec->num_dmuxes = ARRAY_SIZE(stac92hd71bxx_dmux_nids);
5816	spec->num_smuxes = stac92hd71bxx_connected_smuxes(codec, 0x1e);
5817
5818	snd_printdd("Found board config: %d\n", spec->board_config);
5819
5820	switch (spec->board_config) {
5821	case STAC_HP_M4:
5822		/* enable internal microphone */
5823		snd_hda_codec_set_pincfg(codec, 0x0e, 0x01813040);
5824		stac92xx_auto_set_pinctl(codec, 0x0e,
5825			AC_PINCTL_IN_EN | AC_PINCTL_VREF_80);
5826		/* fallthru */
5827	case STAC_DELL_M4_2:
5828		spec->num_dmics = 0;
5829		spec->num_smuxes = 0;
5830		spec->num_dmuxes = 0;
5831		break;
5832	case STAC_DELL_M4_1:
5833	case STAC_DELL_M4_3:
5834		spec->num_dmics = 1;
5835		spec->num_smuxes = 0;
5836		spec->num_dmuxes = 1;
5837		break;
5838	case STAC_HP_DV4_1222NR:
5839		spec->num_dmics = 1;
5840		/* I don't know if it needs 1 or 2 smuxes - will wait for
5841		 * bug reports to fix if needed
5842		 */
5843		spec->num_smuxes = 1;
5844		spec->num_dmuxes = 1;
5845		/* fallthrough */
5846	case STAC_HP_DV4:
5847		spec->gpio_led = 0x01;
5848		/* fallthrough */
5849	case STAC_HP_DV5:
5850		snd_hda_codec_set_pincfg(codec, 0x0d, 0x90170010);
5851		stac92xx_auto_set_pinctl(codec, 0x0d, AC_PINCTL_OUT_EN);
5852		/* HP dv6 gives the headphone pin as a line-out.  Thus we
5853		 * need to set hp_detect flag here to force to enable HP
5854		 * detection.
5855		 */
5856		spec->hp_detect = 1;
5857		break;
5858	case STAC_HP_HDX:
5859		spec->num_dmics = 1;
5860		spec->num_dmuxes = 1;
5861		spec->num_smuxes = 1;
5862		spec->gpio_led = 0x08;
5863		break;
5864	}
5865
5866	if (hp_blike_system(codec->subsystem_id)) {
5867		pin_cfg = snd_hda_codec_get_pincfg(codec, 0x0f);
5868		if (get_defcfg_device(pin_cfg) == AC_JACK_LINE_OUT ||
5869			get_defcfg_device(pin_cfg) == AC_JACK_SPEAKER  ||
5870			get_defcfg_device(pin_cfg) == AC_JACK_HP_OUT) {
5871			/* It was changed in the BIOS to just satisfy MS DTM.
5872			 * Lets turn it back into slaved HP
5873			 */
5874			pin_cfg = (pin_cfg & (~AC_DEFCFG_DEVICE))
5875					| (AC_JACK_HP_OUT <<
5876						AC_DEFCFG_DEVICE_SHIFT);
5877			pin_cfg = (pin_cfg & (~(AC_DEFCFG_DEF_ASSOC
5878							| AC_DEFCFG_SEQUENCE)))
5879								| 0x1f;
5880			snd_hda_codec_set_pincfg(codec, 0x0f, pin_cfg);
5881		}
5882	}
5883
5884	if (find_mute_led_cfg(codec, 1))
5885		snd_printd("mute LED gpio %d polarity %d\n",
5886				spec->gpio_led,
5887				spec->gpio_led_polarity);
5888
5889	if (spec->gpio_led) {
5890		if (!spec->vref_mute_led_nid) {
5891			spec->gpio_mask |= spec->gpio_led;
5892			spec->gpio_dir |= spec->gpio_led;
5893			spec->gpio_data |= spec->gpio_led;
5894		} else {
5895			codec->patch_ops.set_power_state =
5896					stac92xx_set_power_state;
5897		}
5898	}
5899
5900	spec->multiout.dac_nids = spec->dac_nids;
5901
5902	err = stac92xx_parse_auto_config(codec);
5903	if (!err) {
5904		if (spec->board_config < 0) {
5905			printk(KERN_WARNING "hda_codec: No auto-config is "
5906			       "available, default to model=ref\n");
5907			spec->board_config = STAC_92HD71BXX_REF;
5908			goto again;
5909		}
5910		err = -EINVAL;
5911	}
5912
 
5913	if (err < 0) {
5914		stac92xx_free(codec);
5915		return err;
5916	}
5917
5918	/* enable bass on HP dv7 */
5919	if (spec->board_config == STAC_HP_DV4 ||
5920	    spec->board_config == STAC_HP_DV5) {
5921		unsigned int cap;
5922		cap = snd_hda_param_read(codec, 0x1, AC_PAR_GPIO_CAP);
5923		cap &= AC_GPIO_IO_COUNT;
5924		if (cap >= 6)
5925			stac_add_hp_bass_switch(codec);
5926	}
5927
5928	codec->proc_widget_hook = stac92hd7x_proc_hook;
5929
5930	return 0;
5931}
5932
5933static int patch_stac922x(struct hda_codec *codec)
5934{
5935	struct sigmatel_spec *spec;
5936	int err;
5937
5938	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
5939	if (spec == NULL)
5940		return -ENOMEM;
5941
5942	codec->no_trigger_sense = 1;
5943	codec->spec = spec;
5944	spec->linear_tone_beep = 1;
5945	spec->num_pins = ARRAY_SIZE(stac922x_pin_nids);
5946	spec->pin_nids = stac922x_pin_nids;
5947	spec->board_config = snd_hda_check_board_config(codec, STAC_922X_MODELS,
5948							stac922x_models,
5949							stac922x_cfg_tbl);
5950	if (spec->board_config == STAC_INTEL_MAC_AUTO) {
5951		spec->gpio_mask = spec->gpio_dir = 0x03;
5952		spec->gpio_data = 0x03;
5953		/* Intel Macs have all same PCI SSID, so we need to check
5954		 * codec SSID to distinguish the exact models
5955		 */
5956		printk(KERN_INFO "hda_codec: STAC922x, Apple subsys_id=%x\n", codec->subsystem_id);
5957		switch (codec->subsystem_id) {
5958
5959		case 0x106b0800:
5960			spec->board_config = STAC_INTEL_MAC_V1;
5961			break;
5962		case 0x106b0600:
5963		case 0x106b0700:
5964			spec->board_config = STAC_INTEL_MAC_V2;
5965			break;
5966		case 0x106b0e00:
5967		case 0x106b0f00:
5968		case 0x106b1600:
5969		case 0x106b1700:
5970		case 0x106b0200:
5971		case 0x106b1e00:
5972			spec->board_config = STAC_INTEL_MAC_V3;
5973			break;
5974		case 0x106b1a00:
5975		case 0x00000100:
5976			spec->board_config = STAC_INTEL_MAC_V4;
5977			break;
5978		case 0x106b0a00:
5979		case 0x106b2200:
5980			spec->board_config = STAC_INTEL_MAC_V5;
5981			break;
5982		default:
5983			spec->board_config = STAC_INTEL_MAC_V3;
5984			break;
5985		}
5986	}
5987
5988 again:
5989	if (spec->board_config < 0)
5990		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
5991			    codec->chip_name);
5992	else
5993		stac92xx_set_config_regs(codec,
5994				stac922x_brd_tbl[spec->board_config]);
5995
5996	spec->adc_nids = stac922x_adc_nids;
5997	spec->mux_nids = stac922x_mux_nids;
5998	spec->num_muxes = ARRAY_SIZE(stac922x_mux_nids);
5999	spec->num_adcs = ARRAY_SIZE(stac922x_adc_nids);
6000	spec->num_dmics = 0;
6001	spec->num_pwrs = 0;
6002
6003	spec->init = stac922x_core_init;
6004
6005	spec->num_caps = STAC922X_NUM_CAPS;
6006	spec->capvols = stac922x_capvols;
6007	spec->capsws = stac922x_capsws;
6008
6009	spec->multiout.dac_nids = spec->dac_nids;
6010	
6011	err = stac92xx_parse_auto_config(codec);
6012	if (!err) {
6013		if (spec->board_config < 0) {
6014			printk(KERN_WARNING "hda_codec: No auto-config is "
6015			       "available, default to model=ref\n");
6016			spec->board_config = STAC_D945_REF;
6017			goto again;
6018		}
6019		err = -EINVAL;
6020	}
6021	if (err < 0) {
6022		stac92xx_free(codec);
6023		return err;
6024	}
6025
6026	codec->patch_ops = stac92xx_patch_ops;
6027
6028	/* Fix Mux capture level; max to 2 */
6029	snd_hda_override_amp_caps(codec, 0x12, HDA_OUTPUT,
6030				  (0 << AC_AMPCAP_OFFSET_SHIFT) |
6031				  (2 << AC_AMPCAP_NUM_STEPS_SHIFT) |
6032				  (0x27 << AC_AMPCAP_STEP_SIZE_SHIFT) |
6033				  (0 << AC_AMPCAP_MUTE_SHIFT));
6034
6035	return 0;
6036}
6037
 
 
 
 
 
6038static int patch_stac927x(struct hda_codec *codec)
6039{
6040	struct sigmatel_spec *spec;
6041	int err;
6042
6043	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
6044	if (spec == NULL)
6045		return -ENOMEM;
6046
6047	codec->no_trigger_sense = 1;
6048	codec->spec = spec;
6049	spec->linear_tone_beep = 1;
6050	codec->slave_dig_outs = stac927x_slave_dig_outs;
6051	spec->num_pins = ARRAY_SIZE(stac927x_pin_nids);
6052	spec->pin_nids = stac927x_pin_nids;
6053	spec->board_config = snd_hda_check_board_config(codec, STAC_927X_MODELS,
6054							stac927x_models,
6055							stac927x_cfg_tbl);
6056 again:
6057	if (spec->board_config < 0)
6058		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
6059			    codec->chip_name);
6060	else
6061		stac92xx_set_config_regs(codec,
6062				stac927x_brd_tbl[spec->board_config]);
6063
6064	spec->digbeep_nid = 0x23;
6065	spec->adc_nids = stac927x_adc_nids;
6066	spec->num_adcs = ARRAY_SIZE(stac927x_adc_nids);
6067	spec->mux_nids = stac927x_mux_nids;
6068	spec->num_muxes = ARRAY_SIZE(stac927x_mux_nids);
6069	spec->smux_nids = stac927x_smux_nids;
6070	spec->num_smuxes = ARRAY_SIZE(stac927x_smux_nids);
6071	spec->spdif_labels = stac927x_spdif_labels;
6072	spec->dac_list = stac927x_dac_nids;
6073	spec->multiout.dac_nids = spec->dac_nids;
6074
6075	if (spec->board_config != STAC_D965_REF) {
6076		/* GPIO0 High = Enable EAPD */
6077		spec->eapd_mask = spec->gpio_mask = 0x01;
6078		spec->gpio_dir = spec->gpio_data = 0x01;
6079	}
6080
6081	switch (spec->board_config) {
6082	case STAC_D965_3ST:
6083	case STAC_D965_5ST:
6084		/* GPIO0 High = Enable EAPD */
6085		spec->num_dmics = 0;
6086		spec->init = d965_core_init;
6087		break;
6088	case STAC_DELL_BIOS:
6089		switch (codec->subsystem_id) {
6090		case 0x10280209:
6091		case 0x1028022e:
6092			/* correct the device field to SPDIF out */
6093			snd_hda_codec_set_pincfg(codec, 0x21, 0x01442070);
6094			break;
6095		}
6096		/* configure the analog microphone on some laptops */
6097		snd_hda_codec_set_pincfg(codec, 0x0c, 0x90a79130);
6098		/* correct the front output jack as a hp out */
6099		snd_hda_codec_set_pincfg(codec, 0x0f, 0x0227011f);
6100		/* correct the front input jack as a mic */
6101		snd_hda_codec_set_pincfg(codec, 0x0e, 0x02a79130);
6102		/* fallthru */
6103	case STAC_DELL_3ST:
6104		if (codec->subsystem_id != 0x1028022f) {
6105			/* GPIO2 High = Enable EAPD */
6106			spec->eapd_mask = spec->gpio_mask = 0x04;
6107			spec->gpio_dir = spec->gpio_data = 0x04;
6108		}
6109		spec->dmic_nids = stac927x_dmic_nids;
6110		spec->num_dmics = STAC927X_NUM_DMICS;
6111
6112		spec->init = dell_3st_core_init;
6113		spec->dmux_nids = stac927x_dmux_nids;
6114		spec->num_dmuxes = ARRAY_SIZE(stac927x_dmux_nids);
6115		break;
6116	case STAC_927X_VOLKNOB:
6117		spec->num_dmics = 0;
6118		spec->init = stac927x_volknob_core_init;
6119		break;
6120	default:
6121		spec->num_dmics = 0;
6122		spec->init = stac927x_core_init;
6123		break;
6124	}
6125
6126	spec->num_caps = STAC927X_NUM_CAPS;
6127	spec->capvols = stac927x_capvols;
6128	spec->capsws = stac927x_capsws;
6129
6130	spec->num_pwrs = 0;
6131	spec->aloopback_ctl = stac927x_loopback;
6132	spec->aloopback_mask = 0x40;
6133	spec->aloopback_shift = 0;
6134	spec->eapd_switch = 1;
6135
6136	err = stac92xx_parse_auto_config(codec);
6137	if (!err) {
6138		if (spec->board_config < 0) {
6139			printk(KERN_WARNING "hda_codec: No auto-config is "
6140			       "available, default to model=ref\n");
6141			spec->board_config = STAC_D965_REF;
6142			goto again;
6143		}
6144		err = -EINVAL;
6145	}
6146	if (err < 0) {
6147		stac92xx_free(codec);
6148		return err;
6149	}
6150
6151	codec->patch_ops = stac92xx_patch_ops;
6152
6153	codec->proc_widget_hook = stac927x_proc_hook;
6154
6155	/*
6156	 * !!FIXME!!
6157	 * The STAC927x seem to require fairly long delays for certain
6158	 * command sequences.  With too short delays (even if the answer
6159	 * is set to RIRB properly), it results in the silence output
6160	 * on some hardwares like Dell.
6161	 *
6162	 * The below flag enables the longer delay (see get_response
6163	 * in hda_intel.c).
6164	 */
6165	codec->bus->needs_damn_long_delay = 1;
6166
6167	/* no jack detecion for ref-no-jd model */
6168	if (spec->board_config == STAC_D965_REF_NO_JD)
6169		spec->hp_detect = 0;
6170
6171	return 0;
6172}
6173
6174static int patch_stac9205(struct hda_codec *codec)
6175{
6176	struct sigmatel_spec *spec;
6177	int err;
6178
6179	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
6180	if (spec == NULL)
6181		return -ENOMEM;
6182
6183	codec->no_trigger_sense = 1;
6184	codec->spec = spec;
6185	spec->linear_tone_beep = 1;
6186	spec->num_pins = ARRAY_SIZE(stac9205_pin_nids);
6187	spec->pin_nids = stac9205_pin_nids;
6188	spec->board_config = snd_hda_check_board_config(codec, STAC_9205_MODELS,
6189							stac9205_models,
6190							stac9205_cfg_tbl);
6191 again:
6192	if (spec->board_config < 0)
6193		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
6194			    codec->chip_name);
6195	else
6196		stac92xx_set_config_regs(codec,
6197					 stac9205_brd_tbl[spec->board_config]);
6198
6199	spec->digbeep_nid = 0x23;
6200	spec->adc_nids = stac9205_adc_nids;
6201	spec->num_adcs = ARRAY_SIZE(stac9205_adc_nids);
6202	spec->mux_nids = stac9205_mux_nids;
6203	spec->num_muxes = ARRAY_SIZE(stac9205_mux_nids);
6204	spec->smux_nids = stac9205_smux_nids;
6205	spec->num_smuxes = ARRAY_SIZE(stac9205_smux_nids);
6206	spec->dmic_nids = stac9205_dmic_nids;
6207	spec->num_dmics = STAC9205_NUM_DMICS;
6208	spec->dmux_nids = stac9205_dmux_nids;
6209	spec->num_dmuxes = ARRAY_SIZE(stac9205_dmux_nids);
6210	spec->num_pwrs = 0;
6211
6212	spec->init = stac9205_core_init;
6213	spec->aloopback_ctl = stac9205_loopback;
6214
6215	spec->num_caps = STAC9205_NUM_CAPS;
6216	spec->capvols = stac9205_capvols;
6217	spec->capsws = stac9205_capsws;
6218
6219	spec->aloopback_mask = 0x40;
6220	spec->aloopback_shift = 0;
6221	/* Turn on/off EAPD per HP plugging */
6222	if (spec->board_config != STAC_9205_EAPD)
6223		spec->eapd_switch = 1;
6224	spec->multiout.dac_nids = spec->dac_nids;
6225	
6226	switch (spec->board_config){
6227	case STAC_9205_DELL_M43:
6228		/* Enable SPDIF in/out */
6229		snd_hda_codec_set_pincfg(codec, 0x1f, 0x01441030);
6230		snd_hda_codec_set_pincfg(codec, 0x20, 0x1c410030);
6231
6232		/* Enable unsol response for GPIO4/Dock HP connection */
6233		err = stac_add_event(codec, codec->afg, STAC_VREF_EVENT, 0x01);
6234		if (err < 0)
6235			return err;
6236		snd_hda_codec_write_cache(codec, codec->afg, 0,
6237			AC_VERB_SET_GPIO_UNSOLICITED_RSP_MASK, 0x10);
6238		snd_hda_jack_detect_enable(codec, codec->afg, 0);
6239
6240		spec->gpio_dir = 0x0b;
6241		spec->eapd_mask = 0x01;
6242		spec->gpio_mask = 0x1b;
6243		spec->gpio_mute = 0x10;
6244		/* GPIO0 High = EAPD, GPIO1 Low = Headphone Mute,
6245		 * GPIO3 Low = DRM
6246		 */
6247		spec->gpio_data = 0x01;
6248		break;
6249	case STAC_9205_REF:
6250		/* SPDIF-In enabled */
6251		break;
6252	default:
6253		/* GPIO0 High = EAPD */
6254		spec->eapd_mask = spec->gpio_mask = spec->gpio_dir = 0x1;
6255		spec->gpio_data = 0x01;
6256		break;
6257	}
6258
6259	err = stac92xx_parse_auto_config(codec);
6260	if (!err) {
6261		if (spec->board_config < 0) {
6262			printk(KERN_WARNING "hda_codec: No auto-config is "
6263			       "available, default to model=ref\n");
6264			spec->board_config = STAC_9205_REF;
6265			goto again;
6266		}
6267		err = -EINVAL;
6268	}
6269	if (err < 0) {
6270		stac92xx_free(codec);
6271		return err;
6272	}
6273
6274	codec->patch_ops = stac92xx_patch_ops;
6275
6276	codec->proc_widget_hook = stac9205_proc_hook;
6277
6278	return 0;
6279}
6280
6281/*
6282 * STAC9872 hack
6283 */
6284
6285static const struct hda_verb stac9872_core_init[] = {
6286	{0x15, AC_VERB_SET_CONNECT_SEL, 0x1}, /* mic-sel: 0a,0d,14,02 */
6287	{0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, /* Mic-in -> 0x9 */
6288	{}
6289};
6290
6291static const hda_nid_t stac9872_pin_nids[] = {
6292	0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f,
6293	0x11, 0x13, 0x14,
 
 
 
 
 
 
 
 
6294};
6295
6296static const hda_nid_t stac9872_adc_nids[] = {
6297	0x8 /*,0x6*/
 
6298};
6299
6300static const hda_nid_t stac9872_mux_nids[] = {
6301	0x15
6302};
6303
6304static const unsigned long stac9872_capvols[] = {
6305	HDA_COMPOSE_AMP_VAL(0x09, 3, 0, HDA_INPUT),
6306};
6307#define stac9872_capsws		stac9872_capvols
6308
6309static const unsigned int stac9872_vaio_pin_configs[9] = {
6310	0x03211020, 0x411111f0, 0x411111f0, 0x03a15030,
6311	0x411111f0, 0x90170110, 0x411111f0, 0x411111f0,
6312	0x90a7013e
6313};
6314
6315static const char * const stac9872_models[STAC_9872_MODELS] = {
6316	[STAC_9872_AUTO] = "auto",
6317	[STAC_9872_VAIO] = "vaio",
6318};
6319
6320static const unsigned int *stac9872_brd_tbl[STAC_9872_MODELS] = {
6321	[STAC_9872_VAIO] = stac9872_vaio_pin_configs,
6322};
6323
6324static const struct snd_pci_quirk stac9872_cfg_tbl[] = {
6325	SND_PCI_QUIRK_MASK(0x104d, 0xfff0, 0x81e0,
6326			   "Sony VAIO F/S", STAC_9872_VAIO),
6327	{} /* terminator */
6328};
6329
6330static int patch_stac9872(struct hda_codec *codec)
6331{
6332	struct sigmatel_spec *spec;
6333	int err;
6334
6335	spec  = kzalloc(sizeof(*spec), GFP_KERNEL);
6336	if (spec == NULL)
6337		return -ENOMEM;
6338	codec->no_trigger_sense = 1;
6339	codec->spec = spec;
6340	spec->linear_tone_beep = 1;
6341	spec->num_pins = ARRAY_SIZE(stac9872_pin_nids);
6342	spec->pin_nids = stac9872_pin_nids;
6343
6344	spec->board_config = snd_hda_check_board_config(codec, STAC_9872_MODELS,
6345							stac9872_models,
6346							stac9872_cfg_tbl);
6347	if (spec->board_config < 0)
6348		snd_printdd(KERN_INFO "hda_codec: %s: BIOS auto-probing.\n",
6349			    codec->chip_name);
6350	else
6351		stac92xx_set_config_regs(codec,
6352					 stac9872_brd_tbl[spec->board_config]);
6353
6354	spec->multiout.dac_nids = spec->dac_nids;
6355	spec->num_adcs = ARRAY_SIZE(stac9872_adc_nids);
6356	spec->adc_nids = stac9872_adc_nids;
6357	spec->num_muxes = ARRAY_SIZE(stac9872_mux_nids);
6358	spec->mux_nids = stac9872_mux_nids;
6359	spec->init = stac9872_core_init;
6360	spec->num_caps = 1;
6361	spec->capvols = stac9872_capvols;
6362	spec->capsws = stac9872_capsws;
6363
6364	err = stac92xx_parse_auto_config(codec);
6365	if (err < 0) {
6366		stac92xx_free(codec);
6367		return -EINVAL;
6368	}
6369	spec->input_mux = &spec->private_imux;
6370	codec->patch_ops = stac92xx_patch_ops;
 
6371	return 0;
6372}
6373
6374
6375/*
6376 * patch entries
6377 */
6378static const struct hda_codec_preset snd_hda_preset_sigmatel[] = {
6379 	{ .id = 0x83847690, .name = "STAC9200", .patch = patch_stac9200 },
6380 	{ .id = 0x83847882, .name = "STAC9220 A1", .patch = patch_stac922x },
6381 	{ .id = 0x83847680, .name = "STAC9221 A1", .patch = patch_stac922x },
6382 	{ .id = 0x83847880, .name = "STAC9220 A2", .patch = patch_stac922x },
6383 	{ .id = 0x83847681, .name = "STAC9220D/9223D A2", .patch = patch_stac922x },
6384 	{ .id = 0x83847682, .name = "STAC9221 A2", .patch = patch_stac922x },
6385 	{ .id = 0x83847683, .name = "STAC9221D A2", .patch = patch_stac922x },
6386 	{ .id = 0x83847618, .name = "STAC9227", .patch = patch_stac927x },
6387 	{ .id = 0x83847619, .name = "STAC9227", .patch = patch_stac927x },
6388 	{ .id = 0x83847616, .name = "STAC9228", .patch = patch_stac927x },
6389 	{ .id = 0x83847617, .name = "STAC9228", .patch = patch_stac927x },
6390 	{ .id = 0x83847614, .name = "STAC9229", .patch = patch_stac927x },
6391 	{ .id = 0x83847615, .name = "STAC9229", .patch = patch_stac927x },
6392 	{ .id = 0x83847620, .name = "STAC9274", .patch = patch_stac927x },
6393 	{ .id = 0x83847621, .name = "STAC9274D", .patch = patch_stac927x },
6394 	{ .id = 0x83847622, .name = "STAC9273X", .patch = patch_stac927x },
6395 	{ .id = 0x83847623, .name = "STAC9273D", .patch = patch_stac927x },
6396 	{ .id = 0x83847624, .name = "STAC9272X", .patch = patch_stac927x },
6397 	{ .id = 0x83847625, .name = "STAC9272D", .patch = patch_stac927x },
6398 	{ .id = 0x83847626, .name = "STAC9271X", .patch = patch_stac927x },
6399 	{ .id = 0x83847627, .name = "STAC9271D", .patch = patch_stac927x },
6400 	{ .id = 0x83847628, .name = "STAC9274X5NH", .patch = patch_stac927x },
6401 	{ .id = 0x83847629, .name = "STAC9274D5NH", .patch = patch_stac927x },
6402	{ .id = 0x83847632, .name = "STAC9202",  .patch = patch_stac925x },
6403	{ .id = 0x83847633, .name = "STAC9202D", .patch = patch_stac925x },
6404	{ .id = 0x83847634, .name = "STAC9250", .patch = patch_stac925x },
6405	{ .id = 0x83847635, .name = "STAC9250D", .patch = patch_stac925x },
6406	{ .id = 0x83847636, .name = "STAC9251", .patch = patch_stac925x },
6407	{ .id = 0x83847637, .name = "STAC9250D", .patch = patch_stac925x },
6408	{ .id = 0x83847645, .name = "92HD206X", .patch = patch_stac927x },
6409	{ .id = 0x83847646, .name = "92HD206D", .patch = patch_stac927x },
6410 	/* The following does not take into account .id=0x83847661 when subsys =
6411 	 * 104D0C00 which is STAC9225s. Because of this, some SZ Notebooks are
6412 	 * currently not fully supported.
6413 	 */
6414 	{ .id = 0x83847661, .name = "CXD9872RD/K", .patch = patch_stac9872 },
6415 	{ .id = 0x83847662, .name = "STAC9872AK", .patch = patch_stac9872 },
6416 	{ .id = 0x83847664, .name = "CXD9872AKD", .patch = patch_stac9872 },
6417	{ .id = 0x83847698, .name = "STAC9205", .patch = patch_stac9205 },
6418 	{ .id = 0x838476a0, .name = "STAC9205", .patch = patch_stac9205 },
6419 	{ .id = 0x838476a1, .name = "STAC9205D", .patch = patch_stac9205 },
6420 	{ .id = 0x838476a2, .name = "STAC9204", .patch = patch_stac9205 },
6421 	{ .id = 0x838476a3, .name = "STAC9204D", .patch = patch_stac9205 },
6422 	{ .id = 0x838476a4, .name = "STAC9255", .patch = patch_stac9205 },
6423 	{ .id = 0x838476a5, .name = "STAC9255D", .patch = patch_stac9205 },
6424 	{ .id = 0x838476a6, .name = "STAC9254", .patch = patch_stac9205 },
6425 	{ .id = 0x838476a7, .name = "STAC9254D", .patch = patch_stac9205 },
6426	{ .id = 0x111d7603, .name = "92HD75B3X5", .patch = patch_stac92hd71bxx},
6427	{ .id = 0x111d7604, .name = "92HD83C1X5", .patch = patch_stac92hd83xxx},
6428	{ .id = 0x111d76d4, .name = "92HD83C1C5", .patch = patch_stac92hd83xxx},
6429	{ .id = 0x111d7605, .name = "92HD81B1X5", .patch = patch_stac92hd83xxx},
6430	{ .id = 0x111d76d5, .name = "92HD81B1C5", .patch = patch_stac92hd83xxx},
6431	{ .id = 0x111d76d1, .name = "92HD87B1/3", .patch = patch_stac92hd83xxx},
6432	{ .id = 0x111d76d9, .name = "92HD87B2/4", .patch = patch_stac92hd83xxx},
6433	{ .id = 0x111d7666, .name = "92HD88B3", .patch = patch_stac92hd83xxx},
6434	{ .id = 0x111d7667, .name = "92HD88B1", .patch = patch_stac92hd83xxx},
6435	{ .id = 0x111d7668, .name = "92HD88B2", .patch = patch_stac92hd83xxx},
6436	{ .id = 0x111d7669, .name = "92HD88B4", .patch = patch_stac92hd83xxx},
6437	{ .id = 0x111d7608, .name = "92HD75B2X5", .patch = patch_stac92hd71bxx},
6438	{ .id = 0x111d7674, .name = "92HD73D1X5", .patch = patch_stac92hd73xx },
6439	{ .id = 0x111d7675, .name = "92HD73C1X5", .patch = patch_stac92hd73xx },
6440	{ .id = 0x111d7676, .name = "92HD73E1X5", .patch = patch_stac92hd73xx },
6441	{ .id = 0x111d76b0, .name = "92HD71B8X", .patch = patch_stac92hd71bxx },
6442	{ .id = 0x111d76b1, .name = "92HD71B8X", .patch = patch_stac92hd71bxx },
6443	{ .id = 0x111d76b2, .name = "92HD71B7X", .patch = patch_stac92hd71bxx },
6444	{ .id = 0x111d76b3, .name = "92HD71B7X", .patch = patch_stac92hd71bxx },
6445	{ .id = 0x111d76b4, .name = "92HD71B6X", .patch = patch_stac92hd71bxx },
6446	{ .id = 0x111d76b5, .name = "92HD71B6X", .patch = patch_stac92hd71bxx },
6447	{ .id = 0x111d76b6, .name = "92HD71B5X", .patch = patch_stac92hd71bxx },
6448	{ .id = 0x111d76b7, .name = "92HD71B5X", .patch = patch_stac92hd71bxx },
6449	{ .id = 0x111d76c0, .name = "92HD89C3", .patch = patch_stac92hd73xx },
6450	{ .id = 0x111d76c1, .name = "92HD89C2", .patch = patch_stac92hd73xx },
6451	{ .id = 0x111d76c2, .name = "92HD89C1", .patch = patch_stac92hd73xx },
6452	{ .id = 0x111d76c3, .name = "92HD89B3", .patch = patch_stac92hd73xx },
6453	{ .id = 0x111d76c4, .name = "92HD89B2", .patch = patch_stac92hd73xx },
6454	{ .id = 0x111d76c5, .name = "92HD89B1", .patch = patch_stac92hd73xx },
6455	{ .id = 0x111d76c6, .name = "92HD89E3", .patch = patch_stac92hd73xx },
6456	{ .id = 0x111d76c7, .name = "92HD89E2", .patch = patch_stac92hd73xx },
6457	{ .id = 0x111d76c8, .name = "92HD89E1", .patch = patch_stac92hd73xx },
6458	{ .id = 0x111d76c9, .name = "92HD89D3", .patch = patch_stac92hd73xx },
6459	{ .id = 0x111d76ca, .name = "92HD89D2", .patch = patch_stac92hd73xx },
6460	{ .id = 0x111d76cb, .name = "92HD89D1", .patch = patch_stac92hd73xx },
6461	{ .id = 0x111d76cc, .name = "92HD89F3", .patch = patch_stac92hd73xx },
6462	{ .id = 0x111d76cd, .name = "92HD89F2", .patch = patch_stac92hd73xx },
6463	{ .id = 0x111d76ce, .name = "92HD89F1", .patch = patch_stac92hd73xx },
6464	{ .id = 0x111d76df, .name = "92HD93BXX", .patch = patch_stac92hd83xxx},
6465	{ .id = 0x111d76e0, .name = "92HD91BXX", .patch = patch_stac92hd83xxx},
6466	{ .id = 0x111d76e3, .name = "92HD98BXX", .patch = patch_stac92hd83xxx},
6467	{ .id = 0x111d76e5, .name = "92HD99BXX", .patch = patch_stac92hd83xxx},
6468	{ .id = 0x111d76e7, .name = "92HD90BXX", .patch = patch_stac92hd83xxx},
6469	{ .id = 0x111d76e8, .name = "92HD66B1X5", .patch = patch_stac92hd83xxx},
6470	{ .id = 0x111d76e9, .name = "92HD66B2X5", .patch = patch_stac92hd83xxx},
6471	{ .id = 0x111d76ea, .name = "92HD66B3X5", .patch = patch_stac92hd83xxx},
6472	{ .id = 0x111d76eb, .name = "92HD66C1X5", .patch = patch_stac92hd83xxx},
6473	{ .id = 0x111d76ec, .name = "92HD66C2X5", .patch = patch_stac92hd83xxx},
6474	{ .id = 0x111d76ed, .name = "92HD66C3X5", .patch = patch_stac92hd83xxx},
6475	{ .id = 0x111d76ee, .name = "92HD66B1X3", .patch = patch_stac92hd83xxx},
6476	{ .id = 0x111d76ef, .name = "92HD66B2X3", .patch = patch_stac92hd83xxx},
6477	{ .id = 0x111d76f0, .name = "92HD66B3X3", .patch = patch_stac92hd83xxx},
6478	{ .id = 0x111d76f1, .name = "92HD66C1X3", .patch = patch_stac92hd83xxx},
6479	{ .id = 0x111d76f2, .name = "92HD66C2X3", .patch = patch_stac92hd83xxx},
6480	{ .id = 0x111d76f3, .name = "92HD66C3/65", .patch = patch_stac92hd83xxx},
 
 
6481	{} /* terminator */
6482};
6483
6484MODULE_ALIAS("snd-hda-codec-id:8384*");
6485MODULE_ALIAS("snd-hda-codec-id:111d*");
6486
6487MODULE_LICENSE("GPL");
6488MODULE_DESCRIPTION("IDT/Sigmatel HD-audio codec");
6489
6490static struct hda_codec_preset_list sigmatel_list = {
6491	.preset = snd_hda_preset_sigmatel,
6492	.owner = THIS_MODULE,
6493};
6494
6495static int __init patch_sigmatel_init(void)
6496{
6497	return snd_hda_add_codec_preset(&sigmatel_list);
6498}
6499
6500static void __exit patch_sigmatel_exit(void)
6501{
6502	snd_hda_delete_codec_preset(&sigmatel_list);
6503}
6504
6505module_init(patch_sigmatel_init)
6506module_exit(patch_sigmatel_exit)