alc262_quirks.c 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875
  1. /*
  2. * ALC262 quirk models
  3. * included by patch_realtek.c
  4. */
  5. /* ALC262 models */
  6. enum {
  7. ALC262_AUTO,
  8. ALC262_BASIC,
  9. ALC262_HIPPO,
  10. ALC262_HIPPO_1,
  11. ALC262_FUJITSU,
  12. ALC262_BENQ_ED8,
  13. ALC262_BENQ_T31,
  14. ALC262_ULTRA,
  15. ALC262_LENOVO_3000,
  16. ALC262_NEC,
  17. ALC262_TOSHIBA_S06,
  18. ALC262_TOSHIBA_RX1,
  19. ALC262_TYAN,
  20. ALC262_MODEL_LAST /* last tag */
  21. };
  22. #define ALC262_DIGOUT_NID ALC880_DIGOUT_NID
  23. #define ALC262_DIGIN_NID ALC880_DIGIN_NID
  24. #define alc262_dac_nids alc260_dac_nids
  25. #define alc262_adc_nids alc882_adc_nids
  26. #define alc262_adc_nids_alt alc882_adc_nids_alt
  27. #define alc262_capsrc_nids alc882_capsrc_nids
  28. #define alc262_capsrc_nids_alt alc882_capsrc_nids_alt
  29. #define alc262_modes alc260_modes
  30. #define alc262_capture_source alc882_capture_source
  31. static const hda_nid_t alc262_dmic_adc_nids[1] = {
  32. /* ADC0 */
  33. 0x09
  34. };
  35. static const hda_nid_t alc262_dmic_capsrc_nids[1] = { 0x22 };
  36. static const struct snd_kcontrol_new alc262_base_mixer[] = {
  37. HDA_CODEC_VOLUME("Front Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  38. HDA_CODEC_MUTE("Front Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  39. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  40. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  41. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  42. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  43. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  44. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  45. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  46. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  47. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  48. HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
  49. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0D, 0x0, HDA_OUTPUT),
  50. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  51. HDA_CODEC_VOLUME_MONO("Mono Playback Volume", 0x0e, 2, 0x0, HDA_OUTPUT),
  52. HDA_CODEC_MUTE_MONO("Mono Playback Switch", 0x16, 2, 0x0, HDA_OUTPUT),
  53. { } /* end */
  54. };
  55. /* bind hp and internal speaker mute (with plug check) as master switch */
  56. static int alc262_hippo_master_sw_get(struct snd_kcontrol *kcontrol,
  57. struct snd_ctl_elem_value *ucontrol)
  58. {
  59. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  60. struct alc_spec *spec = codec->spec;
  61. *ucontrol->value.integer.value = !spec->master_mute;
  62. return 0;
  63. }
  64. static int alc262_hippo_master_sw_put(struct snd_kcontrol *kcontrol,
  65. struct snd_ctl_elem_value *ucontrol)
  66. {
  67. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  68. struct alc_spec *spec = codec->spec;
  69. int val = !*ucontrol->value.integer.value;
  70. if (val == spec->master_mute)
  71. return 0;
  72. spec->master_mute = val;
  73. update_outputs(codec);
  74. return 1;
  75. }
  76. #define ALC262_HIPPO_MASTER_SWITCH \
  77. { \
  78. .iface = SNDRV_CTL_ELEM_IFACE_MIXER, \
  79. .name = "Master Playback Switch", \
  80. .info = snd_ctl_boolean_mono_info, \
  81. .get = alc262_hippo_master_sw_get, \
  82. .put = alc262_hippo_master_sw_put, \
  83. }, \
  84. { \
  85. .iface = NID_MAPPING, \
  86. .name = "Master Playback Switch", \
  87. .subdevice = SUBDEV_HP(0) | (SUBDEV_LINE(0) << 8) | \
  88. (SUBDEV_SPEAKER(0) << 16), \
  89. }
  90. #define alc262_hp_master_sw_get alc262_hippo_master_sw_get
  91. #define alc262_hp_master_sw_put alc262_hippo_master_sw_put
  92. static const struct snd_kcontrol_new alc262_hippo_mixer[] = {
  93. ALC262_HIPPO_MASTER_SWITCH,
  94. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  95. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  96. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  97. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  98. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  99. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  100. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  101. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  102. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  103. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  104. HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
  105. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  106. { } /* end */
  107. };
  108. static const struct snd_kcontrol_new alc262_hippo1_mixer[] = {
  109. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  110. ALC262_HIPPO_MASTER_SWITCH,
  111. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  112. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  113. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  114. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  115. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  116. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  117. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  118. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  119. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  120. HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
  121. { } /* end */
  122. };
  123. /* mute/unmute internal speaker according to the hp jack and mute state */
  124. static void alc262_hippo_setup(struct hda_codec *codec)
  125. {
  126. struct alc_spec *spec = codec->spec;
  127. spec->autocfg.hp_pins[0] = 0x15;
  128. spec->autocfg.speaker_pins[0] = 0x14;
  129. alc_simple_setup_automute(spec, ALC_AUTOMUTE_AMP);
  130. }
  131. static void alc262_hippo1_setup(struct hda_codec *codec)
  132. {
  133. struct alc_spec *spec = codec->spec;
  134. spec->autocfg.hp_pins[0] = 0x1b;
  135. spec->autocfg.speaker_pins[0] = 0x14;
  136. alc_simple_setup_automute(spec, ALC_AUTOMUTE_AMP);
  137. }
  138. static const struct snd_kcontrol_new alc262_sony_mixer[] = {
  139. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  140. ALC262_HIPPO_MASTER_SWITCH,
  141. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  142. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  143. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  144. HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  145. { } /* end */
  146. };
  147. static const struct snd_kcontrol_new alc262_benq_t31_mixer[] = {
  148. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  149. ALC262_HIPPO_MASTER_SWITCH,
  150. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  151. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  152. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  153. HDA_CODEC_VOLUME("ATAPI Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  154. HDA_CODEC_MUTE("ATAPI Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  155. { } /* end */
  156. };
  157. static const struct snd_kcontrol_new alc262_tyan_mixer[] = {
  158. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  159. HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
  160. HDA_CODEC_VOLUME("Aux Playback Volume", 0x0b, 0x06, HDA_INPUT),
  161. HDA_CODEC_MUTE("Aux Playback Switch", 0x0b, 0x06, HDA_INPUT),
  162. HDA_CODEC_VOLUME("Line Playback Volume", 0x0b, 0x02, HDA_INPUT),
  163. HDA_CODEC_MUTE("Line Playback Switch", 0x0b, 0x02, HDA_INPUT),
  164. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  165. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  166. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  167. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  168. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  169. HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
  170. { } /* end */
  171. };
  172. static const struct hda_verb alc262_tyan_verbs[] = {
  173. /* Headphone automute */
  174. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  175. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  176. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  177. /* P11 AUX_IN, white 4-pin connector */
  178. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  179. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_1, 0xe1},
  180. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_2, 0x93},
  181. {0x14, AC_VERB_SET_CONFIG_DEFAULT_BYTES_3, 0x19},
  182. {}
  183. };
  184. /* unsolicited event for HP jack sensing */
  185. static void alc262_tyan_setup(struct hda_codec *codec)
  186. {
  187. struct alc_spec *spec = codec->spec;
  188. spec->autocfg.hp_pins[0] = 0x1b;
  189. spec->autocfg.speaker_pins[0] = 0x15;
  190. alc_simple_setup_automute(spec, ALC_AUTOMUTE_AMP);
  191. }
  192. #define alc262_capture_mixer alc882_capture_mixer
  193. #define alc262_capture_alt_mixer alc882_capture_alt_mixer
  194. /*
  195. * generic initialization of ADC, input mixers and output mixers
  196. */
  197. static const struct hda_verb alc262_init_verbs[] = {
  198. /*
  199. * Unmute ADC0-2 and set the default input to mic-in
  200. */
  201. {0x07, AC_VERB_SET_CONNECT_SEL, 0x00},
  202. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  203. {0x08, AC_VERB_SET_CONNECT_SEL, 0x00},
  204. {0x08, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  205. {0x09, AC_VERB_SET_CONNECT_SEL, 0x00},
  206. {0x09, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  207. /* Mute input amps (CD, Line In, Mic 1 & Mic 2) of the analog-loopback
  208. * mixer widget
  209. * Note: PASD motherboards uses the Line In 2 as the input for
  210. * front panel mic (mic 2)
  211. */
  212. /* Amp Indices: Mic1 = 0, Mic2 = 1, Line1 = 2, Line2 = 3, CD = 4 */
  213. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  214. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  215. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  216. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  217. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  218. /*
  219. * Set up output mixers (0x0c - 0x0e)
  220. */
  221. /* set vol=0 to output mixers */
  222. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  223. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  224. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  225. /* set up input amps for analog loopback */
  226. /* Amp Indices: DAC = 0, mixer = 1 */
  227. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  228. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  229. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  230. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  231. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  232. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  233. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  234. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  235. {0x16, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x40},
  236. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  237. {0x1a, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  238. {0x1c, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x20},
  239. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  240. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  241. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  242. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  243. {0x1a, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  244. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  245. {0x15, AC_VERB_SET_CONNECT_SEL, 0x01},
  246. /* FIXME: use matrix-type input source selection */
  247. /* Mixer elements: 0x18, 19, 1a, 1b, 1c, 1d, 14, 15, 16, 17, 0b */
  248. /* Input mixer1: unmute Mic, F-Mic, Line, CD inputs */
  249. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  250. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  251. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  252. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  253. /* Input mixer2 */
  254. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  255. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  256. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  257. {0x23, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  258. /* Input mixer3 */
  259. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7000 | (0x00 << 8))},
  260. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x03 << 8))},
  261. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x02 << 8))},
  262. {0x22, AC_VERB_SET_AMP_GAIN_MUTE, (0x7080 | (0x04 << 8))},
  263. { }
  264. };
  265. static const struct hda_verb alc262_eapd_verbs[] = {
  266. {0x14, AC_VERB_SET_EAPD_BTLENABLE, 2},
  267. {0x15, AC_VERB_SET_EAPD_BTLENABLE, 2},
  268. { }
  269. };
  270. static const struct hda_verb alc262_hippo1_unsol_verbs[] = {
  271. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  272. {0x1b, AC_VERB_SET_CONNECT_SEL, 0x00},
  273. {0x1b, AC_VERB_SET_AMP_GAIN_MUTE, 0x0000},
  274. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  275. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  276. {}
  277. };
  278. static const struct hda_verb alc262_sony_unsol_verbs[] = {
  279. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, 0xc0},
  280. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  281. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24}, // Front Mic
  282. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  283. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  284. {}
  285. };
  286. static const struct snd_kcontrol_new alc262_toshiba_s06_mixer[] = {
  287. HDA_CODEC_VOLUME("Speaker Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  288. HDA_CODEC_MUTE("Speaker Playback Switch", 0x14, 0x0, HDA_OUTPUT),
  289. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  290. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  291. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  292. { } /* end */
  293. };
  294. static const struct hda_verb alc262_toshiba_s06_verbs[] = {
  295. {0x12, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_IN},
  296. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  297. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  298. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  299. {0x22, AC_VERB_SET_CONNECT_SEL, 0x09},
  300. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  301. {0x18, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_MIC_EVENT},
  302. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  303. {}
  304. };
  305. static void alc262_toshiba_s06_setup(struct hda_codec *codec)
  306. {
  307. struct alc_spec *spec = codec->spec;
  308. spec->autocfg.hp_pins[0] = 0x15;
  309. spec->autocfg.speaker_pins[0] = 0x14;
  310. spec->ext_mic_pin = 0x18;
  311. spec->int_mic_pin = 0x12;
  312. spec->auto_mic = 1;
  313. alc_simple_setup_automute(spec, ALC_AUTOMUTE_PIN);
  314. }
  315. /*
  316. * nec model
  317. * 0x15 = headphone
  318. * 0x16 = internal speaker
  319. * 0x18 = external mic
  320. */
  321. static const struct snd_kcontrol_new alc262_nec_mixer[] = {
  322. HDA_CODEC_VOLUME_MONO("Speaker Playback Volume", 0x0e, 1, 0x0, HDA_OUTPUT),
  323. HDA_CODEC_MUTE_MONO("Speaker Playback Switch", 0x16, 0, 0x0, HDA_OUTPUT),
  324. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  325. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  326. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  327. HDA_CODEC_VOLUME("Headphone Playback Volume", 0x0d, 0x0, HDA_OUTPUT),
  328. HDA_CODEC_MUTE("Headphone Playback Switch", 0x15, 0x0, HDA_OUTPUT),
  329. { } /* end */
  330. };
  331. static const struct hda_verb alc262_nec_verbs[] = {
  332. /* Unmute Speaker */
  333. {0x16, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE},
  334. /* Headphone */
  335. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  336. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  337. /* External mic to headphone */
  338. {0x0d, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  339. /* External mic to speaker */
  340. {0x0e, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  341. {}
  342. };
  343. /*
  344. * fujitsu model
  345. * 0x14 = headphone/spdif-out, 0x15 = internal speaker,
  346. * 0x1b = port replicator headphone out
  347. */
  348. static const struct hda_verb alc262_fujitsu_unsol_verbs[] = {
  349. {0x14, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  350. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  351. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  352. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  353. {}
  354. };
  355. static const struct hda_verb alc262_lenovo_3000_unsol_verbs[] = {
  356. {0x1b, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  357. {0x1b, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  358. {}
  359. };
  360. static const struct hda_verb alc262_lenovo_3000_init_verbs[] = {
  361. /* Front Mic pin: input vref at 50% */
  362. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF50},
  363. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  364. {}
  365. };
  366. static const struct hda_input_mux alc262_fujitsu_capture_source = {
  367. .num_items = 3,
  368. .items = {
  369. { "Mic", 0x0 },
  370. { "Internal Mic", 0x1 },
  371. { "CD", 0x4 },
  372. },
  373. };
  374. static void alc262_fujitsu_setup(struct hda_codec *codec)
  375. {
  376. struct alc_spec *spec = codec->spec;
  377. spec->autocfg.hp_pins[0] = 0x14;
  378. spec->autocfg.hp_pins[1] = 0x1b;
  379. spec->autocfg.speaker_pins[0] = 0x15;
  380. alc_simple_setup_automute(spec, ALC_AUTOMUTE_AMP);
  381. }
  382. /* bind volumes of both NID 0x0c and 0x0d */
  383. static const struct hda_bind_ctls alc262_fujitsu_bind_master_vol = {
  384. .ops = &snd_hda_bind_vol,
  385. .values = {
  386. HDA_COMPOSE_AMP_VAL(0x0c, 3, 0, HDA_OUTPUT),
  387. HDA_COMPOSE_AMP_VAL(0x0d, 3, 0, HDA_OUTPUT),
  388. 0
  389. },
  390. };
  391. static const struct snd_kcontrol_new alc262_fujitsu_mixer[] = {
  392. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  393. {
  394. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  395. .name = "Master Playback Switch",
  396. .subdevice = HDA_SUBDEV_NID_FLAG | 0x14,
  397. .info = snd_ctl_boolean_mono_info,
  398. .get = alc262_hp_master_sw_get,
  399. .put = alc262_hp_master_sw_put,
  400. },
  401. {
  402. .iface = NID_MAPPING,
  403. .name = "Master Playback Switch",
  404. .private_value = 0x1b,
  405. },
  406. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  407. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  408. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  409. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  410. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  411. HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
  412. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  413. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  414. { } /* end */
  415. };
  416. static void alc262_lenovo_3000_setup(struct hda_codec *codec)
  417. {
  418. struct alc_spec *spec = codec->spec;
  419. spec->autocfg.hp_pins[0] = 0x1b;
  420. spec->autocfg.speaker_pins[0] = 0x14;
  421. spec->autocfg.speaker_pins[1] = 0x16;
  422. alc_simple_setup_automute(spec, ALC_AUTOMUTE_AMP);
  423. }
  424. static const struct snd_kcontrol_new alc262_lenovo_3000_mixer[] = {
  425. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  426. {
  427. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  428. .name = "Master Playback Switch",
  429. .subdevice = HDA_SUBDEV_NID_FLAG | 0x1b,
  430. .info = snd_ctl_boolean_mono_info,
  431. .get = alc262_hp_master_sw_get,
  432. .put = alc262_hp_master_sw_put,
  433. },
  434. HDA_CODEC_VOLUME("CD Playback Volume", 0x0b, 0x04, HDA_INPUT),
  435. HDA_CODEC_MUTE("CD Playback Switch", 0x0b, 0x04, HDA_INPUT),
  436. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  437. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  438. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  439. HDA_CODEC_VOLUME("Internal Mic Boost Volume", 0x19, 0, HDA_INPUT),
  440. HDA_CODEC_VOLUME("Internal Mic Playback Volume", 0x0b, 0x1, HDA_INPUT),
  441. HDA_CODEC_MUTE("Internal Mic Playback Switch", 0x0b, 0x1, HDA_INPUT),
  442. { } /* end */
  443. };
  444. static const struct snd_kcontrol_new alc262_toshiba_rx1_mixer[] = {
  445. HDA_BIND_VOL("Master Playback Volume", &alc262_fujitsu_bind_master_vol),
  446. ALC262_HIPPO_MASTER_SWITCH,
  447. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x0, HDA_INPUT),
  448. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x0, HDA_INPUT),
  449. HDA_CODEC_VOLUME("Mic Boost Volume", 0x18, 0, HDA_INPUT),
  450. HDA_CODEC_VOLUME("Front Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  451. HDA_CODEC_MUTE("Front Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  452. HDA_CODEC_VOLUME("Front Mic Boost Volume", 0x19, 0, HDA_INPUT),
  453. { } /* end */
  454. };
  455. /* additional init verbs for Benq laptops */
  456. static const struct hda_verb alc262_EAPD_verbs[] = {
  457. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  458. {0x20, AC_VERB_SET_PROC_COEF, 0x3070},
  459. {}
  460. };
  461. static const struct hda_verb alc262_benq_t31_EAPD_verbs[] = {
  462. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  463. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, 0x24},
  464. {0x20, AC_VERB_SET_COEF_INDEX, 0x07},
  465. {0x20, AC_VERB_SET_PROC_COEF, 0x3050},
  466. {}
  467. };
  468. /* Samsung Q1 Ultra Vista model setup */
  469. static const struct snd_kcontrol_new alc262_ultra_mixer[] = {
  470. HDA_CODEC_VOLUME("Master Playback Volume", 0x0c, 0x0, HDA_OUTPUT),
  471. HDA_BIND_MUTE("Master Playback Switch", 0x0c, 2, HDA_INPUT),
  472. HDA_CODEC_VOLUME("Mic Playback Volume", 0x0b, 0x01, HDA_INPUT),
  473. HDA_CODEC_MUTE("Mic Playback Switch", 0x0b, 0x01, HDA_INPUT),
  474. HDA_CODEC_VOLUME("Mic Boost Volume", 0x19, 0, HDA_INPUT),
  475. HDA_CODEC_VOLUME("Headphone Mic Boost Volume", 0x15, 0, HDA_INPUT),
  476. { } /* end */
  477. };
  478. static const struct hda_verb alc262_ultra_verbs[] = {
  479. /* output mixer */
  480. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  481. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  482. {0x0c, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_ZERO},
  483. /* speaker */
  484. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT},
  485. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  486. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  487. {0x14, AC_VERB_SET_CONNECT_SEL, 0x00},
  488. /* HP */
  489. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP},
  490. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_MUTE},
  491. {0x15, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0)},
  492. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  493. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  494. /* internal mic */
  495. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80},
  496. {0x0b, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(1)},
  497. /* ADC, choose mic */
  498. {0x07, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  499. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(0)},
  500. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(1)},
  501. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(2)},
  502. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(3)},
  503. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(4)},
  504. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(5)},
  505. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(6)},
  506. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(7)},
  507. {0x24, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_MUTE(8)},
  508. {}
  509. };
  510. /* mute/unmute internal speaker according to the hp jack and mute state */
  511. static void alc262_ultra_automute(struct hda_codec *codec)
  512. {
  513. struct alc_spec *spec = codec->spec;
  514. unsigned int mute;
  515. mute = 0;
  516. /* auto-mute only when HP is used as HP */
  517. if (!spec->cur_mux[0]) {
  518. spec->hp_jack_present = snd_hda_jack_detect(codec, 0x15);
  519. if (spec->hp_jack_present)
  520. mute = HDA_AMP_MUTE;
  521. }
  522. /* mute/unmute internal speaker */
  523. snd_hda_codec_amp_stereo(codec, 0x14, HDA_OUTPUT, 0,
  524. HDA_AMP_MUTE, mute);
  525. /* mute/unmute HP */
  526. snd_hda_codec_amp_stereo(codec, 0x15, HDA_OUTPUT, 0,
  527. HDA_AMP_MUTE, mute ? 0 : HDA_AMP_MUTE);
  528. }
  529. /* unsolicited event for HP jack sensing */
  530. static void alc262_ultra_unsol_event(struct hda_codec *codec,
  531. unsigned int res)
  532. {
  533. if ((res >> 26) != ALC_HP_EVENT)
  534. return;
  535. alc262_ultra_automute(codec);
  536. }
  537. static const struct hda_input_mux alc262_ultra_capture_source = {
  538. .num_items = 2,
  539. .items = {
  540. { "Mic", 0x1 },
  541. { "Headphone", 0x7 },
  542. },
  543. };
  544. static int alc262_ultra_mux_enum_put(struct snd_kcontrol *kcontrol,
  545. struct snd_ctl_elem_value *ucontrol)
  546. {
  547. struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
  548. struct alc_spec *spec = codec->spec;
  549. int ret;
  550. ret = alc_mux_enum_put(kcontrol, ucontrol);
  551. if (!ret)
  552. return 0;
  553. /* reprogram the HP pin as mic or HP according to the input source */
  554. snd_hda_codec_write_cache(codec, 0x15, 0,
  555. AC_VERB_SET_PIN_WIDGET_CONTROL,
  556. spec->cur_mux[0] ? PIN_VREF80 : PIN_HP);
  557. alc262_ultra_automute(codec); /* mute/unmute HP */
  558. return ret;
  559. }
  560. static const struct snd_kcontrol_new alc262_ultra_capture_mixer[] = {
  561. HDA_CODEC_VOLUME("Capture Volume", 0x07, 0x0, HDA_INPUT),
  562. HDA_CODEC_MUTE("Capture Switch", 0x07, 0x0, HDA_INPUT),
  563. {
  564. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  565. .name = "Capture Source",
  566. .info = alc_mux_enum_info,
  567. .get = alc_mux_enum_get,
  568. .put = alc262_ultra_mux_enum_put,
  569. },
  570. {
  571. .iface = NID_MAPPING,
  572. .name = "Capture Source",
  573. .private_value = 0x15,
  574. },
  575. { } /* end */
  576. };
  577. static const struct hda_verb alc262_toshiba_rx1_unsol_verbs[] = {
  578. {0x14, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_OUT }, /* Front Speaker */
  579. {0x14, AC_VERB_SET_AMP_GAIN_MUTE, AMP_OUT_UNMUTE },
  580. {0x14, AC_VERB_SET_CONNECT_SEL, 0x01},
  581. {0x18, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* MIC jack */
  582. {0x19, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_VREF80 }, /* Front MIC */
  583. {0x18, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
  584. {0x19, AC_VERB_SET_AMP_GAIN_MUTE, AMP_IN_UNMUTE(0) },
  585. {0x15, AC_VERB_SET_PIN_WIDGET_CONTROL, PIN_HP }, /* HP jack */
  586. {0x15, AC_VERB_SET_CONNECT_SEL, 0x00},
  587. {0x15, AC_VERB_SET_UNSOLICITED_ENABLE, AC_USRSP_EN | ALC_HP_EVENT},
  588. {}
  589. };
  590. /*
  591. * configuration and preset
  592. */
  593. static const char * const alc262_models[ALC262_MODEL_LAST] = {
  594. [ALC262_BASIC] = "basic",
  595. [ALC262_HIPPO] = "hippo",
  596. [ALC262_HIPPO_1] = "hippo_1",
  597. [ALC262_FUJITSU] = "fujitsu",
  598. [ALC262_BENQ_ED8] = "benq",
  599. [ALC262_BENQ_T31] = "benq-t31",
  600. [ALC262_TOSHIBA_S06] = "toshiba-s06",
  601. [ALC262_TOSHIBA_RX1] = "toshiba-rx1",
  602. [ALC262_ULTRA] = "ultra",
  603. [ALC262_LENOVO_3000] = "lenovo-3000",
  604. [ALC262_NEC] = "nec",
  605. [ALC262_TYAN] = "tyan",
  606. [ALC262_AUTO] = "auto",
  607. };
  608. static const struct snd_pci_quirk alc262_cfg_tbl[] = {
  609. SND_PCI_QUIRK(0x1002, 0x437b, "Hippo", ALC262_HIPPO),
  610. SND_PCI_QUIRK(0x1033, 0x8895, "NEC Versa S9100", ALC262_NEC),
  611. SND_PCI_QUIRK(0x1179, 0x0001, "Toshiba dynabook SS RX1",
  612. ALC262_TOSHIBA_RX1),
  613. SND_PCI_QUIRK(0x1179, 0xff7b, "Toshiba S06", ALC262_TOSHIBA_S06),
  614. SND_PCI_QUIRK(0x10cf, 0x1397, "Fujitsu", ALC262_FUJITSU),
  615. SND_PCI_QUIRK(0x10cf, 0x142d, "Fujitsu Lifebook E8410", ALC262_FUJITSU),
  616. SND_PCI_QUIRK(0x10f1, 0x2915, "Tyan Thunder n6650W", ALC262_TYAN),
  617. SND_PCI_QUIRK_MASK(0x144d, 0xff00, 0xc032, "Samsung Q1",
  618. ALC262_ULTRA),
  619. SND_PCI_QUIRK(0x144d, 0xc510, "Samsung Q45", ALC262_HIPPO),
  620. SND_PCI_QUIRK(0x17aa, 0x384e, "Lenovo 3000 y410", ALC262_LENOVO_3000),
  621. SND_PCI_QUIRK(0x17ff, 0x0560, "Benq ED8", ALC262_BENQ_ED8),
  622. SND_PCI_QUIRK(0x17ff, 0x058d, "Benq T31-16", ALC262_BENQ_T31),
  623. SND_PCI_QUIRK(0x17ff, 0x058f, "Benq Hippo", ALC262_HIPPO_1),
  624. {}
  625. };
  626. static const struct alc_config_preset alc262_presets[] = {
  627. [ALC262_BASIC] = {
  628. .mixers = { alc262_base_mixer },
  629. .init_verbs = { alc262_init_verbs },
  630. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  631. .dac_nids = alc262_dac_nids,
  632. .hp_nid = 0x03,
  633. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  634. .channel_mode = alc262_modes,
  635. .input_mux = &alc262_capture_source,
  636. },
  637. [ALC262_HIPPO] = {
  638. .mixers = { alc262_hippo_mixer },
  639. .init_verbs = { alc262_init_verbs, alc_hp15_unsol_verbs},
  640. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  641. .dac_nids = alc262_dac_nids,
  642. .hp_nid = 0x03,
  643. .dig_out_nid = ALC262_DIGOUT_NID,
  644. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  645. .channel_mode = alc262_modes,
  646. .input_mux = &alc262_capture_source,
  647. .unsol_event = alc_sku_unsol_event,
  648. .setup = alc262_hippo_setup,
  649. .init_hook = alc_inithook,
  650. },
  651. [ALC262_HIPPO_1] = {
  652. .mixers = { alc262_hippo1_mixer },
  653. .init_verbs = { alc262_init_verbs, alc262_hippo1_unsol_verbs},
  654. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  655. .dac_nids = alc262_dac_nids,
  656. .hp_nid = 0x02,
  657. .dig_out_nid = ALC262_DIGOUT_NID,
  658. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  659. .channel_mode = alc262_modes,
  660. .input_mux = &alc262_capture_source,
  661. .unsol_event = alc_sku_unsol_event,
  662. .setup = alc262_hippo1_setup,
  663. .init_hook = alc_inithook,
  664. },
  665. [ALC262_FUJITSU] = {
  666. .mixers = { alc262_fujitsu_mixer },
  667. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
  668. alc262_fujitsu_unsol_verbs },
  669. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  670. .dac_nids = alc262_dac_nids,
  671. .hp_nid = 0x03,
  672. .dig_out_nid = ALC262_DIGOUT_NID,
  673. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  674. .channel_mode = alc262_modes,
  675. .input_mux = &alc262_fujitsu_capture_source,
  676. .unsol_event = alc_sku_unsol_event,
  677. .setup = alc262_fujitsu_setup,
  678. .init_hook = alc_inithook,
  679. },
  680. [ALC262_BENQ_ED8] = {
  681. .mixers = { alc262_base_mixer },
  682. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs },
  683. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  684. .dac_nids = alc262_dac_nids,
  685. .hp_nid = 0x03,
  686. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  687. .channel_mode = alc262_modes,
  688. .input_mux = &alc262_capture_source,
  689. },
  690. [ALC262_BENQ_T31] = {
  691. .mixers = { alc262_benq_t31_mixer },
  692. .init_verbs = { alc262_init_verbs, alc262_benq_t31_EAPD_verbs,
  693. alc_hp15_unsol_verbs },
  694. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  695. .dac_nids = alc262_dac_nids,
  696. .hp_nid = 0x03,
  697. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  698. .channel_mode = alc262_modes,
  699. .input_mux = &alc262_capture_source,
  700. .unsol_event = alc_sku_unsol_event,
  701. .setup = alc262_hippo_setup,
  702. .init_hook = alc_inithook,
  703. },
  704. [ALC262_ULTRA] = {
  705. .mixers = { alc262_ultra_mixer },
  706. .cap_mixer = alc262_ultra_capture_mixer,
  707. .init_verbs = { alc262_ultra_verbs },
  708. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  709. .dac_nids = alc262_dac_nids,
  710. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  711. .channel_mode = alc262_modes,
  712. .input_mux = &alc262_ultra_capture_source,
  713. .adc_nids = alc262_adc_nids, /* ADC0 */
  714. .capsrc_nids = alc262_capsrc_nids,
  715. .num_adc_nids = 1, /* single ADC */
  716. .unsol_event = alc262_ultra_unsol_event,
  717. .init_hook = alc262_ultra_automute,
  718. },
  719. [ALC262_LENOVO_3000] = {
  720. .mixers = { alc262_lenovo_3000_mixer },
  721. .init_verbs = { alc262_init_verbs, alc262_EAPD_verbs,
  722. alc262_lenovo_3000_unsol_verbs,
  723. alc262_lenovo_3000_init_verbs },
  724. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  725. .dac_nids = alc262_dac_nids,
  726. .hp_nid = 0x03,
  727. .dig_out_nid = ALC262_DIGOUT_NID,
  728. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  729. .channel_mode = alc262_modes,
  730. .input_mux = &alc262_fujitsu_capture_source,
  731. .unsol_event = alc_sku_unsol_event,
  732. .setup = alc262_lenovo_3000_setup,
  733. .init_hook = alc_inithook,
  734. },
  735. [ALC262_NEC] = {
  736. .mixers = { alc262_nec_mixer },
  737. .init_verbs = { alc262_nec_verbs },
  738. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  739. .dac_nids = alc262_dac_nids,
  740. .hp_nid = 0x03,
  741. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  742. .channel_mode = alc262_modes,
  743. .input_mux = &alc262_capture_source,
  744. },
  745. [ALC262_TOSHIBA_S06] = {
  746. .mixers = { alc262_toshiba_s06_mixer },
  747. .init_verbs = { alc262_init_verbs, alc262_toshiba_s06_verbs,
  748. alc262_eapd_verbs },
  749. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  750. .capsrc_nids = alc262_dmic_capsrc_nids,
  751. .dac_nids = alc262_dac_nids,
  752. .adc_nids = alc262_dmic_adc_nids, /* ADC0 */
  753. .num_adc_nids = 1, /* single ADC */
  754. .dig_out_nid = ALC262_DIGOUT_NID,
  755. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  756. .channel_mode = alc262_modes,
  757. .unsol_event = alc_sku_unsol_event,
  758. .setup = alc262_toshiba_s06_setup,
  759. .init_hook = alc_inithook,
  760. },
  761. [ALC262_TOSHIBA_RX1] = {
  762. .mixers = { alc262_toshiba_rx1_mixer },
  763. .init_verbs = { alc262_init_verbs, alc262_toshiba_rx1_unsol_verbs },
  764. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  765. .dac_nids = alc262_dac_nids,
  766. .hp_nid = 0x03,
  767. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  768. .channel_mode = alc262_modes,
  769. .input_mux = &alc262_capture_source,
  770. .unsol_event = alc_sku_unsol_event,
  771. .setup = alc262_hippo_setup,
  772. .init_hook = alc_inithook,
  773. },
  774. [ALC262_TYAN] = {
  775. .mixers = { alc262_tyan_mixer },
  776. .init_verbs = { alc262_init_verbs, alc262_tyan_verbs},
  777. .num_dacs = ARRAY_SIZE(alc262_dac_nids),
  778. .dac_nids = alc262_dac_nids,
  779. .hp_nid = 0x02,
  780. .dig_out_nid = ALC262_DIGOUT_NID,
  781. .num_channel_mode = ARRAY_SIZE(alc262_modes),
  782. .channel_mode = alc262_modes,
  783. .input_mux = &alc262_capture_source,
  784. .unsol_event = alc_sku_unsol_event,
  785. .setup = alc262_tyan_setup,
  786. .init_hook = alc_hp_automute,
  787. },
  788. };