| /* |
| * ALC267/ALC268 quirk models |
| * included by patch_realtek.c |
| */ |
| |
| /* ALC268 models */ |
| enum { |
| ALC268_AUTO, |
| ALC267_QUANTA_IL1, |
| ALC268_3ST, |
| ALC268_TOSHIBA, |
| ALC268_ACER, |
| ALC268_ACER_DMIC, |
| ALC268_ACER_ASPIRE_ONE, |
| ALC268_DELL, |
| ALC268_ZEPTO, |
| #ifdef CONFIG_SND_DEBUG |
| ALC268_TEST, |
| #endif |
| ALC268_MODEL_LAST /* last tag */ |
| }; |
| |
| /* |
| * ALC268 channel source setting (2 channel) |
| */ |
| #define ALC268_DIGOUT_NID ALC880_DIGOUT_NID |
| #define alc268_modes alc260_modes |
| |
| static const hda_nid_t alc268_dac_nids[2] = { |
| /* front, hp */ |
| 0x02, 0x03 |
| }; |
| |
| static const hda_nid_t alc268_adc_nids[2] = { |
| /* ADC0-1 */ |
| 0x08, 0x07 |
| }; |
| |
| static const hda_nid_t alc268_adc_nids_alt[1] = { |
| /* ADC0 */ |
| 0x08 |
| }; |
| |
| static const hda_nid_t alc268_capsrc_nids[2] = { 0x23, 0x24 }; |
| |
| static const struct snd_kcontrol_new alc268_base_mixer[] = { |
| /* output mixer control */ |
| HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Line In Boost Volume", 0x1a, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct snd_kcontrol_new alc268_toshiba_mixer[] = { |
| /* output mixer control */ |
| HDA_CODEC_VOLUME("Front Playback Volume", 0x2, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT), |
| ALC262_HIPPO_MASTER_SWITCH, |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Line In Boost Volume", 0x1a, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct hda_verb alc268_eapd_verbs[] = { |
| {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2}, |
| {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2}, |
| { } |
| }; |
| |
| /* Toshiba specific */ |
| static const struct hda_verb alc268_toshiba_verbs[] = { |
| {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_HP_EVENT | AC_USRSP_EN}, |
| { } /* end */ |
| }; |
| |
| /* Acer specific */ |
| /* bind volumes of both NID 0x02 and 0x03 */ |
| static const struct hda_bind_ctls alc268_acer_bind_master_vol = { |
| .ops = &snd_hda_bind_vol, |
| .values = { |
| HDA_COMPOSE_AMP_VAL(0x02, 3, 0, HDA_OUTPUT), |
| HDA_COMPOSE_AMP_VAL(0x03, 3, 0, HDA_OUTPUT), |
| 0 |
| }, |
| }; |
| |
| static void alc268_acer_setup(struct hda_codec *codec) |
| { |
| struct alc_spec *spec = codec->spec; |
| |
| spec->autocfg.hp_pins[0] = 0x14; |
| spec->autocfg.speaker_pins[0] = 0x15; |
| spec->automute = 1; |
| spec->automute_mode = ALC_AUTOMUTE_AMP; |
| } |
| |
| #define alc268_acer_master_sw_get alc262_hp_master_sw_get |
| #define alc268_acer_master_sw_put alc262_hp_master_sw_put |
| |
| static const struct snd_kcontrol_new alc268_acer_aspire_one_mixer[] = { |
| /* output mixer control */ |
| HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol), |
| { |
| .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
| .name = "Master Playback Switch", |
| .subdevice = HDA_SUBDEV_NID_FLAG | 0x15, |
| .info = snd_ctl_boolean_mono_info, |
| .get = alc268_acer_master_sw_get, |
| .put = alc268_acer_master_sw_put, |
| }, |
| HDA_CODEC_VOLUME("Mic Boost Capture Volume", 0x18, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct snd_kcontrol_new alc268_acer_mixer[] = { |
| /* output mixer control */ |
| HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol), |
| { |
| .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
| .name = "Master Playback Switch", |
| .subdevice = HDA_SUBDEV_NID_FLAG | 0x14, |
| .info = snd_ctl_boolean_mono_info, |
| .get = alc268_acer_master_sw_get, |
| .put = alc268_acer_master_sw_put, |
| }, |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Line In Boost Volume", 0x1a, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct snd_kcontrol_new alc268_acer_dmic_mixer[] = { |
| /* output mixer control */ |
| HDA_BIND_VOL("Master Playback Volume", &alc268_acer_bind_master_vol), |
| { |
| .iface = SNDRV_CTL_ELEM_IFACE_MIXER, |
| .name = "Master Playback Switch", |
| .subdevice = HDA_SUBDEV_NID_FLAG | 0x14, |
| .info = snd_ctl_boolean_mono_info, |
| .get = alc268_acer_master_sw_get, |
| .put = alc268_acer_master_sw_put, |
| }, |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Line In Boost Volume", 0x1a, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct hda_verb alc268_acer_aspire_one_verbs[] = { |
| {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, |
| {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, |
| {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_HP_EVENT | AC_USRSP_EN}, |
| {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT}, |
| {0x23, AC_VERB_SET_CONNECT_SEL, 0x06}, |
| {0x23, AC_VERB_SET_AMP_GAIN_MUTE, 0xa017}, |
| { } |
| }; |
| |
| static const struct hda_verb alc268_acer_verbs[] = { |
| {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, /* internal dmic? */ |
| {0x13, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN}, |
| {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, |
| {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT}, |
| {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, |
| {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80}, |
| {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_HP_EVENT | AC_USRSP_EN}, |
| { } |
| }; |
| |
| /* unsolicited event for HP jack sensing */ |
| #define alc268_toshiba_setup alc262_hippo_setup |
| |
| static void alc268_acer_lc_setup(struct hda_codec *codec) |
| { |
| struct alc_spec *spec = codec->spec; |
| spec->autocfg.hp_pins[0] = 0x15; |
| spec->autocfg.speaker_pins[0] = 0x14; |
| spec->automute = 1; |
| spec->automute_mode = ALC_AUTOMUTE_AMP; |
| spec->ext_mic_pin = 0x18; |
| spec->int_mic_pin = 0x12; |
| spec->auto_mic = 1; |
| } |
| |
| static const struct snd_kcontrol_new alc268_dell_mixer[] = { |
| /* output mixer control */ |
| HDA_CODEC_VOLUME("Speaker Playback Volume", 0x02, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Headphone Playback Volume", 0x03, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct hda_verb alc268_dell_verbs[] = { |
| {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, |
| {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP}, |
| {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_HP_EVENT | AC_USRSP_EN}, |
| {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_MIC_EVENT | AC_USRSP_EN}, |
| { } |
| }; |
| |
| /* mute/unmute internal speaker according to the hp jack and mute state */ |
| static void alc268_dell_setup(struct hda_codec *codec) |
| { |
| struct alc_spec *spec = codec->spec; |
| |
| spec->autocfg.hp_pins[0] = 0x15; |
| spec->autocfg.speaker_pins[0] = 0x14; |
| spec->ext_mic_pin = 0x18; |
| spec->int_mic_pin = 0x19; |
| spec->auto_mic = 1; |
| spec->automute = 1; |
| spec->automute_mode = ALC_AUTOMUTE_PIN; |
| } |
| |
| static const struct snd_kcontrol_new alc267_quanta_il1_mixer[] = { |
| HDA_CODEC_VOLUME("Speaker Playback Volume", 0x2, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Headphone Playback Volume", 0x3, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Mic Capture Volume", 0x23, 0x0, HDA_OUTPUT), |
| HDA_BIND_MUTE("Mic Capture Switch", 0x23, 2, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT), |
| HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT), |
| { } |
| }; |
| |
| static const struct hda_verb alc267_quanta_il1_verbs[] = { |
| {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_HP_EVENT | AC_USRSP_EN}, |
| {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, ALC_MIC_EVENT | AC_USRSP_EN}, |
| { } |
| }; |
| |
| static void alc267_quanta_il1_setup(struct hda_codec *codec) |
| { |
| struct alc_spec *spec = codec->spec; |
| spec->autocfg.hp_pins[0] = 0x15; |
| spec->autocfg.speaker_pins[0] = 0x14; |
| spec->ext_mic_pin = 0x18; |
| spec->int_mic_pin = 0x19; |
| spec->auto_mic = 1; |
| spec->automute = 1; |
| spec->automute_mode = ALC_AUTOMUTE_PIN; |
| } |
| |
| /* |
| * generic initialization of ADC, input mixers and output mixers |
| */ |
| static const struct hda_verb alc268_base_init_verbs[] = { |
| /* Unmute DAC0-1 and set vol = 0 */ |
| {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, |
| {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, |
| |
| /* |
| * Set up output mixers (0x0c - 0x0e) |
| */ |
| /* set vol=0 to output mixers */ |
| {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| {0x0e, AC_VERB_SET_CONNECT_SEL, 0x00}, |
| |
| {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| |
| {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40}, |
| {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0}, |
| {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40}, |
| {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, |
| {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, |
| {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| |
| {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| |
| /* set PCBEEP vol = 0, mute connections */ |
| {0x1d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, |
| {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)}, |
| |
| /* Unmute Selector 23h,24h and set the default input to mic-in */ |
| |
| {0x23, AC_VERB_SET_CONNECT_SEL, 0x00}, |
| {0x23, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
| {0x24, AC_VERB_SET_CONNECT_SEL, 0x00}, |
| {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE}, |
| |
| { } |
| }; |
| |
| /* only for model=test */ |
| #ifdef CONFIG_SND_DEBUG |
| /* |
| * generic initialization of ADC, input mixers and output mixers |
| */ |
| static const struct hda_verb alc268_volume_init_verbs[] = { |
| /* set output DAC */ |
| {0x02, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, |
| {0x03, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO}, |
| |
| {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, |
| {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, |
| {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| {0x1d, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20}, |
| |
| {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| {0x0f, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| {0x10, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)}, |
| |
| {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE}, |
| { } |
| }; |
| #endif /* CONFIG_SND_DEBUG */ |
| |
| static const struct snd_kcontrol_new alc268_capture_nosrc_mixer[] = { |
| HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT), |
| { } /* end */ |
| }; |
| |
| static const struct snd_kcontrol_new alc268_capture_alt_mixer[] = { |
| HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT), |
| _DEFINE_CAPSRC(1), |
| { } /* end */ |
| }; |
| |
| static const struct snd_kcontrol_new alc268_capture_mixer[] = { |
| HDA_CODEC_VOLUME("Capture Volume", 0x23, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE("Capture Switch", 0x23, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME_IDX("Capture Volume", 1, 0x24, 0x0, HDA_OUTPUT), |
| HDA_CODEC_MUTE_IDX("Capture Switch", 1, 0x24, 0x0, HDA_OUTPUT), |
| _DEFINE_CAPSRC(2), |
| { } /* end */ |
| }; |
| |
| static const struct hda_input_mux alc268_capture_source = { |
| .num_items = 4, |
| .items = { |
| { "Mic", 0x0 }, |
| { "Front Mic", 0x1 }, |
| { "Line", 0x2 }, |
| { "CD", 0x3 }, |
| }, |
| }; |
| |
| static const struct hda_input_mux alc268_acer_capture_source = { |
| .num_items = 3, |
| .items = { |
| { "Mic", 0x0 }, |
| { "Internal Mic", 0x1 }, |
| { "Line", 0x2 }, |
| }, |
| }; |
| |
| static const struct hda_input_mux alc268_acer_dmic_capture_source = { |
| .num_items = 3, |
| .items = { |
| { "Mic", 0x0 }, |
| { "Internal Mic", 0x6 }, |
| { "Line", 0x2 }, |
| }, |
| }; |
| |
| #ifdef CONFIG_SND_DEBUG |
| static const struct snd_kcontrol_new alc268_test_mixer[] = { |
| /* Volume widgets */ |
| HDA_CODEC_VOLUME("LOUT1 Playback Volume", 0x02, 0x0, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("LOUT2 Playback Volume", 0x03, 0x0, HDA_OUTPUT), |
| HDA_BIND_MUTE_MONO("Mono sum Playback Switch", 0x0e, 1, 2, HDA_INPUT), |
| HDA_BIND_MUTE("LINE-OUT sum Playback Switch", 0x0f, 2, HDA_INPUT), |
| HDA_BIND_MUTE("HP-OUT sum Playback Switch", 0x10, 2, HDA_INPUT), |
| HDA_BIND_MUTE("LINE-OUT Playback Switch", 0x14, 2, HDA_OUTPUT), |
| HDA_BIND_MUTE("HP-OUT Playback Switch", 0x15, 2, HDA_OUTPUT), |
| HDA_BIND_MUTE("Mono Playback Switch", 0x16, 2, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("MIC1 Capture Volume", 0x18, 0x0, HDA_INPUT), |
| HDA_BIND_MUTE("MIC1 Capture Switch", 0x18, 2, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("MIC2 Capture Volume", 0x19, 0x0, HDA_INPUT), |
| HDA_CODEC_VOLUME("LINE1 Capture Volume", 0x1a, 0x0, HDA_INPUT), |
| HDA_BIND_MUTE("LINE1 Capture Switch", 0x1a, 2, HDA_OUTPUT), |
| /* The below appears problematic on some hardwares */ |
| /*HDA_CODEC_VOLUME("PCBEEP Playback Volume", 0x1d, 0x0, HDA_INPUT),*/ |
| HDA_CODEC_VOLUME("PCM-IN1 Capture Volume", 0x23, 0x0, HDA_OUTPUT), |
| HDA_BIND_MUTE("PCM-IN1 Capture Switch", 0x23, 2, HDA_OUTPUT), |
| HDA_CODEC_VOLUME("PCM-IN2 Capture Volume", 0x24, 0x0, HDA_OUTPUT), |
| HDA_BIND_MUTE("PCM-IN2 Capture Switch", 0x24, 2, HDA_OUTPUT), |
| |
| /* Modes for retasking pin widgets */ |
| ALC_PIN_MODE("LINE-OUT pin mode", 0x14, ALC_PIN_DIR_INOUT), |
| ALC_PIN_MODE("HP-OUT pin mode", 0x15, ALC_PIN_DIR_INOUT), |
| ALC_PIN_MODE("MIC1 pin mode", 0x18, ALC_PIN_DIR_INOUT), |
| ALC_PIN_MODE("LINE1 pin mode", 0x1a, ALC_PIN_DIR_INOUT), |
| |
| /* Controls for GPIO pins, assuming they are configured as outputs */ |
| ALC_GPIO_DATA_SWITCH("GPIO pin 0", 0x01, 0x01), |
| ALC_GPIO_DATA_SWITCH("GPIO pin 1", 0x01, 0x02), |
| ALC_GPIO_DATA_SWITCH("GPIO pin 2", 0x01, 0x04), |
| ALC_GPIO_DATA_SWITCH("GPIO pin 3", 0x01, 0x08), |
| |
| /* Switches to allow the digital SPDIF output pin to be enabled. |
| * The ALC268 does not have an SPDIF input. |
| */ |
| ALC_SPDIF_CTRL_SWITCH("SPDIF Playback Switch", 0x06, 0x01), |
| |
| /* A switch allowing EAPD to be enabled. Some laptops seem to use |
| * this output to turn on an external amplifier. |
| */ |
| ALC_EAPD_CTRL_SWITCH("LINE-OUT EAPD Enable Switch", 0x0f, 0x02), |
| ALC_EAPD_CTRL_SWITCH("HP-OUT EAPD Enable Switch", 0x10, 0x02), |
| |
| { } /* end */ |
| }; |
| #endif |
| |
| /* |
| * configuration and preset |
| */ |
| static const char * const alc268_models[ALC268_MODEL_LAST] = { |
| [ALC267_QUANTA_IL1] = "quanta-il1", |
| [ALC268_3ST] = "3stack", |
| [ALC268_TOSHIBA] = "toshiba", |
| [ALC268_ACER] = "acer", |
| [ALC268_ACER_DMIC] = "acer-dmic", |
| [ALC268_ACER_ASPIRE_ONE] = "acer-aspire", |
| [ALC268_DELL] = "dell", |
| [ALC268_ZEPTO] = "zepto", |
| #ifdef CONFIG_SND_DEBUG |
| [ALC268_TEST] = "test", |
| #endif |
| [ALC268_AUTO] = "auto", |
| }; |
| |
| static const struct snd_pci_quirk alc268_cfg_tbl[] = { |
| SND_PCI_QUIRK(0x1025, 0x011e, "Acer Aspire 5720z", ALC268_ACER), |
| SND_PCI_QUIRK(0x1025, 0x0126, "Acer", ALC268_ACER), |
| SND_PCI_QUIRK(0x1025, 0x012e, "Acer Aspire 5310", ALC268_ACER), |
| SND_PCI_QUIRK(0x1025, 0x0130, "Acer Extensa 5210", ALC268_ACER), |
| SND_PCI_QUIRK(0x1025, 0x0136, "Acer Aspire 5315", ALC268_ACER), |
| SND_PCI_QUIRK(0x1025, 0x015b, "Acer Aspire One", |
| ALC268_ACER_ASPIRE_ONE), |
| SND_PCI_QUIRK(0x1028, 0x0253, "Dell OEM", ALC268_DELL), |
| SND_PCI_QUIRK(0x1028, 0x02b0, "Dell Inspiron 910", ALC268_AUTO), |
| SND_PCI_QUIRK_MASK(0x1028, 0xfff0, 0x02b0, |
| "Dell Inspiron Mini9/Vostro A90", ALC268_DELL), |
| /* almost compatible with toshiba but with optional digital outs; |
| * auto-probing seems working fine |
| */ |
| SND_PCI_QUIRK_MASK(0x103c, 0xff00, 0x3000, "HP TX25xx series", |
| ALC268_AUTO), |
| SND_PCI_QUIRK(0x1043, 0x1205, "ASUS W7J", ALC268_3ST), |
| SND_PCI_QUIRK(0x1170, 0x0040, "ZEPTO", ALC268_ZEPTO), |
| SND_PCI_QUIRK(0x14c0, 0x0025, "COMPAL IFL90/JFL-92", ALC268_TOSHIBA), |
| SND_PCI_QUIRK(0x152d, 0x0771, "Quanta IL1", ALC267_QUANTA_IL1), |
| {} |
| }; |
| |
| /* Toshiba laptops have no unique PCI SSID but only codec SSID */ |
| static const struct snd_pci_quirk alc268_ssid_cfg_tbl[] = { |
| SND_PCI_QUIRK(0x1179, 0xff0a, "TOSHIBA X-200", ALC268_AUTO), |
| SND_PCI_QUIRK(0x1179, 0xff0e, "TOSHIBA X-200 HDMI", ALC268_AUTO), |
| SND_PCI_QUIRK_MASK(0x1179, 0xff00, 0xff00, "TOSHIBA A/Lx05", |
| ALC268_TOSHIBA), |
| {} |
| }; |
| |
| static const struct alc_config_preset alc268_presets[] = { |
| [ALC267_QUANTA_IL1] = { |
| .mixers = { alc267_quanta_il1_mixer, alc268_beep_mixer, |
| alc268_capture_nosrc_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc267_quanta_il1_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .hp_nid = 0x03, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc267_quanta_il1_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_3ST] = { |
| .mixers = { alc268_base_mixer, alc268_capture_alt_mixer, |
| alc268_beep_mixer }, |
| .init_verbs = { alc268_base_init_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x03, |
| .dig_out_nid = ALC268_DIGOUT_NID, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_capture_source, |
| }, |
| [ALC268_TOSHIBA] = { |
| .mixers = { alc268_toshiba_mixer, alc268_capture_alt_mixer, |
| alc268_beep_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_toshiba_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x03, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_capture_source, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_toshiba_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_ACER] = { |
| .mixers = { alc268_acer_mixer, alc268_capture_alt_mixer, |
| alc268_beep_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_acer_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x02, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_acer_capture_source, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_acer_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_ACER_DMIC] = { |
| .mixers = { alc268_acer_dmic_mixer, alc268_capture_alt_mixer, |
| alc268_beep_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_acer_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x02, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_acer_dmic_capture_source, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_acer_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_ACER_ASPIRE_ONE] = { |
| .mixers = { alc268_acer_aspire_one_mixer, |
| alc268_beep_mixer, |
| alc268_capture_nosrc_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_acer_aspire_one_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x03, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_acer_lc_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_DELL] = { |
| .mixers = { alc268_dell_mixer, alc268_beep_mixer, |
| alc268_capture_nosrc_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_dell_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x02, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_dell_setup, |
| .init_hook = alc_inithook, |
| }, |
| [ALC268_ZEPTO] = { |
| .mixers = { alc268_base_mixer, alc268_capture_alt_mixer, |
| alc268_beep_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_toshiba_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x03, |
| .dig_out_nid = ALC268_DIGOUT_NID, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_capture_source, |
| .unsol_event = alc_sku_unsol_event, |
| .setup = alc268_toshiba_setup, |
| .init_hook = alc_inithook, |
| }, |
| #ifdef CONFIG_SND_DEBUG |
| [ALC268_TEST] = { |
| .mixers = { alc268_test_mixer, alc268_capture_mixer }, |
| .init_verbs = { alc268_base_init_verbs, alc268_eapd_verbs, |
| alc268_volume_init_verbs, |
| alc268_beep_init_verbs }, |
| .num_dacs = ARRAY_SIZE(alc268_dac_nids), |
| .dac_nids = alc268_dac_nids, |
| .num_adc_nids = ARRAY_SIZE(alc268_adc_nids_alt), |
| .adc_nids = alc268_adc_nids_alt, |
| .capsrc_nids = alc268_capsrc_nids, |
| .hp_nid = 0x03, |
| .dig_out_nid = ALC268_DIGOUT_NID, |
| .num_channel_mode = ARRAY_SIZE(alc268_modes), |
| .channel_mode = alc268_modes, |
| .input_mux = &alc268_capture_source, |
| }, |
| #endif |
| }; |
| |