Linux Kernel  3.7.1
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
hda_generic.c
Go to the documentation of this file.
1 /*
2  * Universal Interface for Intel High Definition Audio Codec
3  *
4  * Generic widget tree parser
5  *
6  * Copyright (c) 2004 Takashi Iwai <[email protected]>
7  *
8  * This driver is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This driver is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21  */
22 
23 #include <linux/init.h>
24 #include <linux/slab.h>
25 #include <linux/export.h>
26 #include <sound/core.h>
27 #include "hda_codec.h"
28 #include "hda_local.h"
29 
30 /* widget node for parsing */
31 struct hda_gnode {
32  hda_nid_t nid; /* NID of this widget */
33  unsigned short nconns; /* number of input connections */
35  hda_nid_t slist[2]; /* temporay list */
36  unsigned int wid_caps; /* widget capabilities */
37  unsigned char type; /* widget type */
38  unsigned char pin_ctl; /* pin controls */
39  unsigned char checked; /* the flag indicates that the node is already parsed */
40  unsigned int pin_caps; /* pin widget capabilities */
41  unsigned int def_cfg; /* default configuration */
42  unsigned int amp_out_caps; /* AMP out capabilities */
43  unsigned int amp_in_caps; /* AMP in capabilities */
44  struct list_head list;
45 };
46 
47 /* patch-specific record */
48 
49 #define MAX_PCM_VOLS 2
50 struct pcm_vol {
51  struct hda_gnode *node; /* Node for PCM volume */
52  unsigned int index; /* connection of PCM volume */
53 };
54 
55 struct hda_gspec {
56  struct hda_gnode *dac_node[2]; /* DAC node */
57  struct hda_gnode *out_pin_node[2]; /* Output pin (Line-Out) node */
58  struct pcm_vol pcm_vol[MAX_PCM_VOLS]; /* PCM volumes */
59  unsigned int pcm_vol_nodes; /* number of PCM volumes */
60 
61  struct hda_gnode *adc_node; /* ADC node */
62  struct hda_gnode *cap_vol_node; /* Node for capture volume */
63  unsigned int cur_cap_src; /* current capture source */
65 
66  unsigned int def_amp_in_caps;
67  unsigned int def_amp_out_caps;
68 
69  struct hda_pcm pcm_rec; /* PCM information */
70 
71  struct list_head nid_list; /* list of widgets */
72 
73 #ifdef CONFIG_PM
74 #define MAX_LOOPBACK_AMPS 7
76  int num_loopbacks;
77  struct hda_amp_list loopback_list[MAX_LOOPBACK_AMPS + 1];
78 #endif
79 };
80 
81 /*
82  * retrieve the default device type from the default config value
83  */
84 #define defcfg_type(node) (((node)->def_cfg & AC_DEFCFG_DEVICE) >> \
85  AC_DEFCFG_DEVICE_SHIFT)
86 #define defcfg_location(node) (((node)->def_cfg & AC_DEFCFG_LOCATION) >> \
87  AC_DEFCFG_LOCATION_SHIFT)
88 #define defcfg_port_conn(node) (((node)->def_cfg & AC_DEFCFG_PORT_CONN) >> \
89  AC_DEFCFG_PORT_CONN_SHIFT)
90 
91 /*
92  * destructor
93  */
94 static void snd_hda_generic_free(struct hda_codec *codec)
95 {
96  struct hda_gspec *spec = codec->spec;
97  struct hda_gnode *node, *n;
98 
99  if (! spec)
100  return;
101  /* free all widgets */
102  list_for_each_entry_safe(node, n, &spec->nid_list, list) {
103  if (node->conn_list != node->slist)
104  kfree(node->conn_list);
105  kfree(node);
106  }
107  kfree(spec);
108 }
109 
110 
111 /*
112  * add a new widget node and read its attributes
113  */
114 static int add_new_node(struct hda_codec *codec, struct hda_gspec *spec, hda_nid_t nid)
115 {
116  struct hda_gnode *node;
117  int nconns;
119 
120  node = kzalloc(sizeof(*node), GFP_KERNEL);
121  if (node == NULL)
122  return -ENOMEM;
123  node->nid = nid;
124  node->wid_caps = get_wcaps(codec, nid);
125  node->type = get_wcaps_type(node->wid_caps);
126  if (node->wid_caps & AC_WCAP_CONN_LIST) {
127  nconns = snd_hda_get_connections(codec, nid, conn_list,
129  if (nconns < 0) {
130  kfree(node);
131  return nconns;
132  }
133  } else {
134  nconns = 0;
135  }
136  if (nconns <= ARRAY_SIZE(node->slist))
137  node->conn_list = node->slist;
138  else {
139  node->conn_list = kmalloc(sizeof(hda_nid_t) * nconns,
140  GFP_KERNEL);
141  if (! node->conn_list) {
142  snd_printk(KERN_ERR "hda-generic: cannot malloc\n");
143  kfree(node);
144  return -ENOMEM;
145  }
146  }
147  memcpy(node->conn_list, conn_list, nconns * sizeof(hda_nid_t));
148  node->nconns = nconns;
149 
150  if (node->type == AC_WID_PIN) {
151  node->pin_caps = snd_hda_query_pin_caps(codec, node->nid);
152  node->pin_ctl = snd_hda_codec_read(codec, node->nid, 0, AC_VERB_GET_PIN_WIDGET_CONTROL, 0);
153  node->def_cfg = snd_hda_codec_get_pincfg(codec, node->nid);
154  }
155 
156  if (node->wid_caps & AC_WCAP_OUT_AMP) {
157  if (node->wid_caps & AC_WCAP_AMP_OVRD)
158  node->amp_out_caps = snd_hda_param_read(codec, node->nid, AC_PAR_AMP_OUT_CAP);
159  if (! node->amp_out_caps)
160  node->amp_out_caps = spec->def_amp_out_caps;
161  }
162  if (node->wid_caps & AC_WCAP_IN_AMP) {
163  if (node->wid_caps & AC_WCAP_AMP_OVRD)
164  node->amp_in_caps = snd_hda_param_read(codec, node->nid, AC_PAR_AMP_IN_CAP);
165  if (! node->amp_in_caps)
166  node->amp_in_caps = spec->def_amp_in_caps;
167  }
168  list_add_tail(&node->list, &spec->nid_list);
169  return 0;
170 }
171 
172 /*
173  * build the AFG subtree
174  */
175 static int build_afg_tree(struct hda_codec *codec)
176 {
177  struct hda_gspec *spec = codec->spec;
178  int i, nodes, err;
179  hda_nid_t nid;
180 
181  if (snd_BUG_ON(!spec))
182  return -EINVAL;
183 
186 
187  nodes = snd_hda_get_sub_nodes(codec, codec->afg, &nid);
188  if (! nid || nodes < 0) {
189  printk(KERN_ERR "Invalid AFG subtree\n");
190  return -EINVAL;
191  }
192 
193  /* parse all nodes belonging to the AFG */
194  for (i = 0; i < nodes; i++, nid++) {
195  if ((err = add_new_node(codec, spec, nid)) < 0)
196  return err;
197  }
198 
199  return 0;
200 }
201 
202 
203 /*
204  * look for the node record for the given NID
205  */
206 /* FIXME: should avoid the braindead linear search */
207 static struct hda_gnode *hda_get_node(struct hda_gspec *spec, hda_nid_t nid)
208 {
209  struct hda_gnode *node;
210 
211  list_for_each_entry(node, &spec->nid_list, list) {
212  if (node->nid == nid)
213  return node;
214  }
215  return NULL;
216 }
217 
218 /*
219  * unmute (and set max vol) the output amplifier
220  */
221 static int unmute_output(struct hda_codec *codec, struct hda_gnode *node)
222 {
223  unsigned int val, ofs;
224  snd_printdd("UNMUTE OUT: NID=0x%x\n", node->nid);
227  if (val >= ofs)
228  val -= ofs;
229  snd_hda_codec_amp_stereo(codec, node->nid, HDA_OUTPUT, 0, 0xff, val);
230  return 0;
231 }
232 
233 /*
234  * unmute (and set max vol) the input amplifier
235  */
236 static int unmute_input(struct hda_codec *codec, struct hda_gnode *node, unsigned int index)
237 {
238  unsigned int val, ofs;
239  snd_printdd("UNMUTE IN: NID=0x%x IDX=0x%x\n", node->nid, index);
242  if (val >= ofs)
243  val -= ofs;
244  snd_hda_codec_amp_stereo(codec, node->nid, HDA_INPUT, index, 0xff, val);
245  return 0;
246 }
247 
248 /*
249  * select the input connection of the given node.
250  */
251 static int select_input_connection(struct hda_codec *codec, struct hda_gnode *node,
252  unsigned int index)
253 {
254  snd_printdd("CONNECT: NID=0x%x IDX=0x%x\n", node->nid, index);
255  return snd_hda_codec_write_cache(codec, node->nid, 0,
256  AC_VERB_SET_CONNECT_SEL, index);
257 }
258 
259 /*
260  * clear checked flag of each node in the node list
261  */
262 static void clear_check_flags(struct hda_gspec *spec)
263 {
264  struct hda_gnode *node;
265 
266  list_for_each_entry(node, &spec->nid_list, list) {
267  node->checked = 0;
268  }
269 }
270 
271 /*
272  * parse the output path recursively until reach to an audio output widget
273  *
274  * returns 0 if not found, 1 if found, or a negative error code.
275  */
276 static int parse_output_path(struct hda_codec *codec, struct hda_gspec *spec,
277  struct hda_gnode *node, int dac_idx)
278 {
279  int i, err;
280  struct hda_gnode *child;
281 
282  if (node->checked)
283  return 0;
284 
285  node->checked = 1;
286  if (node->type == AC_WID_AUD_OUT) {
287  if (node->wid_caps & AC_WCAP_DIGITAL) {
288  snd_printdd("Skip Digital OUT node %x\n", node->nid);
289  return 0;
290  }
291  snd_printdd("AUD_OUT found %x\n", node->nid);
292  if (spec->dac_node[dac_idx]) {
293  /* already DAC node is assigned, just unmute & connect */
294  return node == spec->dac_node[dac_idx];
295  }
296  spec->dac_node[dac_idx] = node;
297  if ((node->wid_caps & AC_WCAP_OUT_AMP) &&
298  spec->pcm_vol_nodes < MAX_PCM_VOLS) {
299  spec->pcm_vol[spec->pcm_vol_nodes].node = node;
300  spec->pcm_vol[spec->pcm_vol_nodes].index = 0;
301  spec->pcm_vol_nodes++;
302  }
303  return 1; /* found */
304  }
305 
306  for (i = 0; i < node->nconns; i++) {
307  child = hda_get_node(spec, node->conn_list[i]);
308  if (! child)
309  continue;
310  err = parse_output_path(codec, spec, child, dac_idx);
311  if (err < 0)
312  return err;
313  else if (err > 0) {
314  /* found one,
315  * select the path, unmute both input and output
316  */
317  if (node->nconns > 1)
318  select_input_connection(codec, node, i);
319  unmute_input(codec, node, i);
320  unmute_output(codec, node);
321  if (spec->dac_node[dac_idx] &&
322  spec->pcm_vol_nodes < MAX_PCM_VOLS &&
323  !(spec->dac_node[dac_idx]->wid_caps &
324  AC_WCAP_OUT_AMP)) {
325  if ((node->wid_caps & AC_WCAP_IN_AMP) ||
326  (node->wid_caps & AC_WCAP_OUT_AMP)) {
327  int n = spec->pcm_vol_nodes;
328  spec->pcm_vol[n].node = node;
329  spec->pcm_vol[n].index = i;
330  spec->pcm_vol_nodes++;
331  }
332  }
333  return 1;
334  }
335  }
336  return 0;
337 }
338 
339 /*
340  * Look for the output PIN widget with the given jack type
341  * and parse the output path to that PIN.
342  *
343  * Returns the PIN node when the path to DAC is established.
344  */
345 static struct hda_gnode *parse_output_jack(struct hda_codec *codec,
346  struct hda_gspec *spec,
347  int jack_type)
348 {
349  struct hda_gnode *node;
350  int err;
351 
352  list_for_each_entry(node, &spec->nid_list, list) {
353  if (node->type != AC_WID_PIN)
354  continue;
355  /* output capable? */
356  if (! (node->pin_caps & AC_PINCAP_OUT))
357  continue;
358  if (defcfg_port_conn(node) == AC_JACK_PORT_NONE)
359  continue; /* unconnected */
360  if (jack_type >= 0) {
361  if (jack_type != defcfg_type(node))
362  continue;
363  if (node->wid_caps & AC_WCAP_DIGITAL)
364  continue; /* skip SPDIF */
365  } else {
366  /* output as default? */
367  if (! (node->pin_ctl & AC_PINCTL_OUT_EN))
368  continue;
369  }
370  clear_check_flags(spec);
371  err = parse_output_path(codec, spec, node, 0);
372  if (err < 0)
373  return NULL;
374  if (! err && spec->out_pin_node[0]) {
375  err = parse_output_path(codec, spec, node, 1);
376  if (err < 0)
377  return NULL;
378  }
379  if (err > 0) {
380  /* unmute the PIN output */
381  unmute_output(codec, node);
382  /* set PIN-Out enable */
383  snd_hda_codec_write_cache(codec, node->nid, 0,
386  ((node->pin_caps & AC_PINCAP_HP_DRV) ?
387  AC_PINCTL_HP_EN : 0));
388  return node;
389  }
390  }
391  return NULL;
392 }
393 
394 
395 /*
396  * parse outputs
397  */
398 static int parse_output(struct hda_codec *codec)
399 {
400  struct hda_gspec *spec = codec->spec;
401  struct hda_gnode *node;
402 
403  /*
404  * Look for the output PIN widget
405  */
406  /* first, look for the line-out pin */
407  node = parse_output_jack(codec, spec, AC_JACK_LINE_OUT);
408  if (node) /* found, remember the PIN node */
409  spec->out_pin_node[0] = node;
410  else {
411  /* if no line-out is found, try speaker out */
412  node = parse_output_jack(codec, spec, AC_JACK_SPEAKER);
413  if (node)
414  spec->out_pin_node[0] = node;
415  }
416  /* look for the HP-out pin */
417  node = parse_output_jack(codec, spec, AC_JACK_HP_OUT);
418  if (node) {
419  if (! spec->out_pin_node[0])
420  spec->out_pin_node[0] = node;
421  else
422  spec->out_pin_node[1] = node;
423  }
424 
425  if (! spec->out_pin_node[0]) {
426  /* no line-out or HP pins found,
427  * then choose for the first output pin
428  */
429  spec->out_pin_node[0] = parse_output_jack(codec, spec, -1);
430  if (! spec->out_pin_node[0])
431  snd_printd("hda_generic: no proper output path found\n");
432  }
433 
434  return 0;
435 }
436 
437 /*
438  * input MUX
439  */
440 
441 /* control callbacks */
442 static int capture_source_info(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_info *uinfo)
443 {
444  struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
445  struct hda_gspec *spec = codec->spec;
446  return snd_hda_input_mux_info(&spec->input_mux, uinfo);
447 }
448 
449 static int capture_source_get(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
450 {
451  struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
452  struct hda_gspec *spec = codec->spec;
453 
454  ucontrol->value.enumerated.item[0] = spec->cur_cap_src;
455  return 0;
456 }
457 
458 static int capture_source_put(struct snd_kcontrol *kcontrol, struct snd_ctl_elem_value *ucontrol)
459 {
460  struct hda_codec *codec = snd_kcontrol_chip(kcontrol);
461  struct hda_gspec *spec = codec->spec;
462  return snd_hda_input_mux_put(codec, &spec->input_mux, ucontrol,
463  spec->adc_node->nid, &spec->cur_cap_src);
464 }
465 
466 /*
467  * return the string name of the given input PIN widget
468  */
469 static const char *get_input_type(struct hda_gnode *node, unsigned int *pinctl)
470 {
471  unsigned int location = defcfg_location(node);
472  switch (defcfg_type(node)) {
473  case AC_JACK_LINE_IN:
474  if ((location & 0x0f) == AC_JACK_LOC_FRONT)
475  return "Front Line";
476  return "Line";
477  case AC_JACK_CD:
478 #if 0
479  if (pinctl)
480  *pinctl |= AC_PINCTL_VREF_GRD;
481 #endif
482  return "CD";
483  case AC_JACK_AUX:
484  if ((location & 0x0f) == AC_JACK_LOC_FRONT)
485  return "Front Aux";
486  return "Aux";
487  case AC_JACK_MIC_IN:
488  if (pinctl &&
489  (node->pin_caps &
491  *pinctl |= AC_PINCTL_VREF_80;
492  if ((location & 0x0f) == AC_JACK_LOC_FRONT)
493  return "Front Mic";
494  return "Mic";
495  case AC_JACK_SPDIF_IN:
496  return "SPDIF";
498  return "Digital";
499  }
500  return NULL;
501 }
502 
503 /*
504  * parse the nodes recursively until reach to the input PIN
505  *
506  * returns 0 if not found, 1 if found, or a negative error code.
507  */
508 static int parse_adc_sub_nodes(struct hda_codec *codec, struct hda_gspec *spec,
509  struct hda_gnode *node, int idx)
510 {
511  int i, err;
512  unsigned int pinctl;
513  const char *type;
514 
515  if (node->checked)
516  return 0;
517 
518  node->checked = 1;
519  if (node->type != AC_WID_PIN) {
520  for (i = 0; i < node->nconns; i++) {
521  struct hda_gnode *child;
522  child = hda_get_node(spec, node->conn_list[i]);
523  if (! child)
524  continue;
525  err = parse_adc_sub_nodes(codec, spec, child, idx);
526  if (err < 0)
527  return err;
528  if (err > 0) {
529  /* found one,
530  * select the path, unmute both input and output
531  */
532  if (node->nconns > 1)
533  select_input_connection(codec, node, i);
534  unmute_input(codec, node, i);
535  unmute_output(codec, node);
536  return err;
537  }
538  }
539  return 0;
540  }
541 
542  /* input capable? */
543  if (! (node->pin_caps & AC_PINCAP_IN))
544  return 0;
545 
546  if (defcfg_port_conn(node) == AC_JACK_PORT_NONE)
547  return 0; /* unconnected */
548 
549  if (node->wid_caps & AC_WCAP_DIGITAL)
550  return 0; /* skip SPDIF */
551 
552  if (spec->input_mux.num_items >= HDA_MAX_NUM_INPUTS) {
553  snd_printk(KERN_ERR "hda_generic: Too many items for capture\n");
554  return -EINVAL;
555  }
556 
557  pinctl = AC_PINCTL_IN_EN;
558  /* create a proper capture source label */
559  type = get_input_type(node, &pinctl);
560  if (! type) {
561  /* input as default? */
562  if (! (node->pin_ctl & AC_PINCTL_IN_EN))
563  return 0;
564  type = "Input";
565  }
566  snd_hda_add_imux_item(&spec->input_mux, type, idx, NULL);
567 
568  /* unmute the PIN external input */
569  unmute_input(codec, node, 0); /* index = 0? */
570  /* set PIN-In enable */
571  snd_hda_codec_write_cache(codec, node->nid, 0,
573 
574  return 1; /* found */
575 }
576 
577 /*
578  * parse input
579  */
580 static int parse_input_path(struct hda_codec *codec, struct hda_gnode *adc_node)
581 {
582  struct hda_gspec *spec = codec->spec;
583  struct hda_gnode *node;
584  int i, err;
585 
586  snd_printdd("AUD_IN = %x\n", adc_node->nid);
587  clear_check_flags(spec);
588 
589  // awk added - fixed no recording due to muted widget
590  unmute_input(codec, adc_node, 0);
591 
592  /*
593  * check each connection of the ADC
594  * if it reaches to a proper input PIN, add the path as the
595  * input path.
596  */
597  /* first, check the direct connections to PIN widgets */
598  for (i = 0; i < adc_node->nconns; i++) {
599  node = hda_get_node(spec, adc_node->conn_list[i]);
600  if (node && node->type == AC_WID_PIN) {
601  err = parse_adc_sub_nodes(codec, spec, node, i);
602  if (err < 0)
603  return err;
604  }
605  }
606  /* ... then check the rests, more complicated connections */
607  for (i = 0; i < adc_node->nconns; i++) {
608  node = hda_get_node(spec, adc_node->conn_list[i]);
609  if (node && node->type != AC_WID_PIN) {
610  err = parse_adc_sub_nodes(codec, spec, node, i);
611  if (err < 0)
612  return err;
613  }
614  }
615 
616  if (! spec->input_mux.num_items)
617  return 0; /* no input path found... */
618 
619  snd_printdd("[Capture Source] NID=0x%x, #SRC=%d\n", adc_node->nid, spec->input_mux.num_items);
620  for (i = 0; i < spec->input_mux.num_items; i++)
621  snd_printdd(" [%s] IDX=0x%x\n", spec->input_mux.items[i].label,
622  spec->input_mux.items[i].index);
623 
624  spec->adc_node = adc_node;
625  return 1;
626 }
627 
628 /*
629  * parse input
630  */
631 static int parse_input(struct hda_codec *codec)
632 {
633  struct hda_gspec *spec = codec->spec;
634  struct hda_gnode *node;
635  int err;
636 
637  /*
638  * At first we look for an audio input widget.
639  * If it reaches to certain input PINs, we take it as the
640  * input path.
641  */
642  list_for_each_entry(node, &spec->nid_list, list) {
643  if (node->wid_caps & AC_WCAP_DIGITAL)
644  continue; /* skip SPDIF */
645  if (node->type == AC_WID_AUD_IN) {
646  err = parse_input_path(codec, node);
647  if (err < 0)
648  return err;
649  else if (err > 0)
650  return 0;
651  }
652  }
653  snd_printd("hda_generic: no proper input path found\n");
654  return 0;
655 }
656 
657 #ifdef CONFIG_PM
658 static void add_input_loopback(struct hda_codec *codec, hda_nid_t nid,
659  int dir, int idx)
660 {
661  struct hda_gspec *spec = codec->spec;
662  struct hda_amp_list *p;
663 
664  if (spec->num_loopbacks >= MAX_LOOPBACK_AMPS) {
665  snd_printk(KERN_ERR "hda_generic: Too many loopback ctls\n");
666  return;
667  }
668  p = &spec->loopback_list[spec->num_loopbacks++];
669  p->nid = nid;
670  p->dir = dir;
671  p->idx = idx;
672  spec->loopback.amplist = spec->loopback_list;
673 }
674 #else
675 #define add_input_loopback(codec,nid,dir,idx)
676 #endif
677 
678 /*
679  * create mixer controls if possible
680  */
681 static int create_mixer(struct hda_codec *codec, struct hda_gnode *node,
682  unsigned int index, const char *type,
683  const char *dir_sfx, int is_loopback)
684 {
685  char name[32];
686  int err;
687  int created = 0;
688  struct snd_kcontrol_new knew;
689 
690  if (type)
691  sprintf(name, "%s %s Switch", type, dir_sfx);
692  else
693  sprintf(name, "%s Switch", dir_sfx);
694  if ((node->wid_caps & AC_WCAP_IN_AMP) &&
695  (node->amp_in_caps & AC_AMPCAP_MUTE)) {
696  knew = (struct snd_kcontrol_new)HDA_CODEC_MUTE(name, node->nid, index, HDA_INPUT);
697  if (is_loopback)
698  add_input_loopback(codec, node->nid, HDA_INPUT, index);
699  snd_printdd("[%s] NID=0x%x, DIR=IN, IDX=0x%x\n", name, node->nid, index);
700  err = snd_hda_ctl_add(codec, node->nid,
701  snd_ctl_new1(&knew, codec));
702  if (err < 0)
703  return err;
704  created = 1;
705  } else if ((node->wid_caps & AC_WCAP_OUT_AMP) &&
706  (node->amp_out_caps & AC_AMPCAP_MUTE)) {
707  knew = (struct snd_kcontrol_new)HDA_CODEC_MUTE(name, node->nid, 0, HDA_OUTPUT);
708  if (is_loopback)
709  add_input_loopback(codec, node->nid, HDA_OUTPUT, 0);
710  snd_printdd("[%s] NID=0x%x, DIR=OUT\n", name, node->nid);
711  err = snd_hda_ctl_add(codec, node->nid,
712  snd_ctl_new1(&knew, codec));
713  if (err < 0)
714  return err;
715  created = 1;
716  }
717 
718  if (type)
719  sprintf(name, "%s %s Volume", type, dir_sfx);
720  else
721  sprintf(name, "%s Volume", dir_sfx);
722  if ((node->wid_caps & AC_WCAP_IN_AMP) &&
723  (node->amp_in_caps & AC_AMPCAP_NUM_STEPS)) {
724  knew = (struct snd_kcontrol_new)HDA_CODEC_VOLUME(name, node->nid, index, HDA_INPUT);
725  snd_printdd("[%s] NID=0x%x, DIR=IN, IDX=0x%x\n", name, node->nid, index);
726  err = snd_hda_ctl_add(codec, node->nid,
727  snd_ctl_new1(&knew, codec));
728  if (err < 0)
729  return err;
730  created = 1;
731  } else if ((node->wid_caps & AC_WCAP_OUT_AMP) &&
732  (node->amp_out_caps & AC_AMPCAP_NUM_STEPS)) {
733  knew = (struct snd_kcontrol_new)HDA_CODEC_VOLUME(name, node->nid, 0, HDA_OUTPUT);
734  snd_printdd("[%s] NID=0x%x, DIR=OUT\n", name, node->nid);
735  err = snd_hda_ctl_add(codec, node->nid,
736  snd_ctl_new1(&knew, codec));
737  if (err < 0)
738  return err;
739  created = 1;
740  }
741 
742  return created;
743 }
744 
745 /*
746  * check whether the controls with the given name and direction suffix already exist
747  */
748 static int check_existing_control(struct hda_codec *codec, const char *type, const char *dir)
749 {
750  struct snd_ctl_elem_id id;
751  memset(&id, 0, sizeof(id));
752  sprintf(id.name, "%s %s Volume", type, dir);
753  id.iface = SNDRV_CTL_ELEM_IFACE_MIXER;
754  if (snd_ctl_find_id(codec->bus->card, &id))
755  return 1;
756  sprintf(id.name, "%s %s Switch", type, dir);
757  id.iface = SNDRV_CTL_ELEM_IFACE_MIXER;
758  if (snd_ctl_find_id(codec->bus->card, &id))
759  return 1;
760  return 0;
761 }
762 
763 /*
764  * build output mixer controls
765  */
766 static int create_output_mixers(struct hda_codec *codec,
767  const char * const *names)
768 {
769  struct hda_gspec *spec = codec->spec;
770  int i, err;
771 
772  for (i = 0; i < spec->pcm_vol_nodes; i++) {
773  err = create_mixer(codec, spec->pcm_vol[i].node,
774  spec->pcm_vol[i].index,
775  names[i], "Playback", 0);
776  if (err < 0)
777  return err;
778  }
779  return 0;
780 }
781 
782 static int build_output_controls(struct hda_codec *codec)
783 {
784  struct hda_gspec *spec = codec->spec;
785  static const char * const types_speaker[] = { "Speaker", "Headphone" };
786  static const char * const types_line[] = { "Front", "Headphone" };
787 
788  switch (spec->pcm_vol_nodes) {
789  case 1:
790  return create_mixer(codec, spec->pcm_vol[0].node,
791  spec->pcm_vol[0].index,
792  "Master", "Playback", 0);
793  case 2:
794  if (defcfg_type(spec->out_pin_node[0]) == AC_JACK_SPEAKER)
795  return create_output_mixers(codec, types_speaker);
796  else
797  return create_output_mixers(codec, types_line);
798  }
799  return 0;
800 }
801 
802 /* create capture volume/switch */
803 static int build_input_controls(struct hda_codec *codec)
804 {
805  struct hda_gspec *spec = codec->spec;
806  struct hda_gnode *adc_node = spec->adc_node;
807  int i, err;
808  static struct snd_kcontrol_new cap_sel = {
810  .name = "Capture Source",
811  .info = capture_source_info,
812  .get = capture_source_get,
813  .put = capture_source_put,
814  };
815 
816  if (! adc_node || ! spec->input_mux.num_items)
817  return 0; /* not found */
818 
819  spec->cur_cap_src = 0;
820  select_input_connection(codec, adc_node,
821  spec->input_mux.items[0].index);
822 
823  /* create capture volume and switch controls if the ADC has an amp */
824  /* do we have only a single item? */
825  if (spec->input_mux.num_items == 1) {
826  err = create_mixer(codec, adc_node,
827  spec->input_mux.items[0].index,
828  NULL, "Capture", 0);
829  if (err < 0)
830  return err;
831  return 0;
832  }
833 
834  /* create input MUX if multiple sources are available */
835  err = snd_hda_ctl_add(codec, spec->adc_node->nid,
836  snd_ctl_new1(&cap_sel, codec));
837  if (err < 0)
838  return err;
839 
840  /* no volume control? */
841  if (! (adc_node->wid_caps & AC_WCAP_IN_AMP) ||
842  ! (adc_node->amp_in_caps & AC_AMPCAP_NUM_STEPS))
843  return 0;
844 
845  for (i = 0; i < spec->input_mux.num_items; i++) {
846  struct snd_kcontrol_new knew;
847  char name[32];
848  sprintf(name, "%s Capture Volume",
849  spec->input_mux.items[i].label);
850  knew = (struct snd_kcontrol_new)
851  HDA_CODEC_VOLUME(name, adc_node->nid,
852  spec->input_mux.items[i].index,
853  HDA_INPUT);
854  err = snd_hda_ctl_add(codec, adc_node->nid,
855  snd_ctl_new1(&knew, codec));
856  if (err < 0)
857  return err;
858  }
859 
860  return 0;
861 }
862 
863 
864 /*
865  * parse the nodes recursively until reach to the output PIN.
866  *
867  * returns 0 - if not found,
868  * 1 - if found, but no mixer is created
869  * 2 - if found and mixer was already created, (just skip)
870  * a negative error code
871  */
872 static int parse_loopback_path(struct hda_codec *codec, struct hda_gspec *spec,
873  struct hda_gnode *node, struct hda_gnode *dest_node,
874  const char *type)
875 {
876  int i, err;
877 
878  if (node->checked)
879  return 0;
880 
881  node->checked = 1;
882  if (node == dest_node) {
883  /* loopback connection found */
884  return 1;
885  }
886 
887  for (i = 0; i < node->nconns; i++) {
888  struct hda_gnode *child = hda_get_node(spec, node->conn_list[i]);
889  if (! child)
890  continue;
891  err = parse_loopback_path(codec, spec, child, dest_node, type);
892  if (err < 0)
893  return err;
894  else if (err >= 1) {
895  if (err == 1) {
896  err = create_mixer(codec, node, i, type,
897  "Playback", 1);
898  if (err < 0)
899  return err;
900  if (err > 0)
901  return 2; /* ok, created */
902  /* not created, maybe in the lower path */
903  err = 1;
904  }
905  /* connect and unmute */
906  if (node->nconns > 1)
907  select_input_connection(codec, node, i);
908  unmute_input(codec, node, i);
909  unmute_output(codec, node);
910  return err;
911  }
912  }
913  return 0;
914 }
915 
916 /*
917  * parse the tree and build the loopback controls
918  */
919 static int build_loopback_controls(struct hda_codec *codec)
920 {
921  struct hda_gspec *spec = codec->spec;
922  struct hda_gnode *node;
923  int err;
924  const char *type;
925 
926  if (! spec->out_pin_node[0])
927  return 0;
928 
929  list_for_each_entry(node, &spec->nid_list, list) {
930  if (node->type != AC_WID_PIN)
931  continue;
932  /* input capable? */
933  if (! (node->pin_caps & AC_PINCAP_IN))
934  return 0;
935  type = get_input_type(node, NULL);
936  if (type) {
937  if (check_existing_control(codec, type, "Playback"))
938  continue;
939  clear_check_flags(spec);
940  err = parse_loopback_path(codec, spec,
941  spec->out_pin_node[0],
942  node, type);
943  if (err < 0)
944  return err;
945  if (! err)
946  continue;
947  }
948  }
949  return 0;
950 }
951 
952 /*
953  * build mixer controls
954  */
955 static int build_generic_controls(struct hda_codec *codec)
956 {
957  int err;
958 
959  if ((err = build_input_controls(codec)) < 0 ||
960  (err = build_output_controls(codec)) < 0 ||
961  (err = build_loopback_controls(codec)) < 0)
962  return err;
963 
964  return 0;
965 }
966 
967 /*
968  * PCM
969  */
970 static struct hda_pcm_stream generic_pcm_playback = {
971  .substreams = 1,
972  .channels_min = 2,
973  .channels_max = 2,
974 };
975 
976 static int generic_pcm2_prepare(struct hda_pcm_stream *hinfo,
977  struct hda_codec *codec,
978  unsigned int stream_tag,
979  unsigned int format,
980  struct snd_pcm_substream *substream)
981 {
982  struct hda_gspec *spec = codec->spec;
983 
984  snd_hda_codec_setup_stream(codec, hinfo->nid, stream_tag, 0, format);
985  snd_hda_codec_setup_stream(codec, spec->dac_node[1]->nid,
986  stream_tag, 0, format);
987  return 0;
988 }
989 
990 static int generic_pcm2_cleanup(struct hda_pcm_stream *hinfo,
991  struct hda_codec *codec,
992  struct snd_pcm_substream *substream)
993 {
994  struct hda_gspec *spec = codec->spec;
995 
996  snd_hda_codec_cleanup_stream(codec, hinfo->nid);
997  snd_hda_codec_cleanup_stream(codec, spec->dac_node[1]->nid);
998  return 0;
999 }
1000 
1001 static int build_generic_pcms(struct hda_codec *codec)
1002 {
1003  struct hda_gspec *spec = codec->spec;
1004  struct hda_pcm *info = &spec->pcm_rec;
1005 
1006  if (! spec->dac_node[0] && ! spec->adc_node) {
1007  snd_printd("hda_generic: no PCM found\n");
1008  return 0;
1009  }
1010 
1011  codec->num_pcms = 1;
1012  codec->pcm_info = info;
1013 
1014  info->name = "HDA Generic";
1015  if (spec->dac_node[0]) {
1016  info->stream[0] = generic_pcm_playback;
1017  info->stream[0].nid = spec->dac_node[0]->nid;
1018  if (spec->dac_node[1]) {
1019  info->stream[0].ops.prepare = generic_pcm2_prepare;
1020  info->stream[0].ops.cleanup = generic_pcm2_cleanup;
1021  }
1022  }
1023  if (spec->adc_node) {
1024  info->stream[1] = generic_pcm_playback;
1025  info->stream[1].nid = spec->adc_node->nid;
1026  }
1027 
1028  return 0;
1029 }
1030 
1031 #ifdef CONFIG_PM
1032 static int generic_check_power_status(struct hda_codec *codec, hda_nid_t nid)
1033 {
1034  struct hda_gspec *spec = codec->spec;
1035  return snd_hda_check_amp_list_power(codec, &spec->loopback, nid);
1036 }
1037 #endif
1038 
1039 
1040 /*
1041  */
1042 static struct hda_codec_ops generic_patch_ops = {
1043  .build_controls = build_generic_controls,
1044  .build_pcms = build_generic_pcms,
1045  .free = snd_hda_generic_free,
1046 #ifdef CONFIG_PM
1047  .check_power_status = generic_check_power_status,
1048 #endif
1049 };
1050 
1051 /*
1052  * the generic parser
1053  */
1055 {
1056  struct hda_gspec *spec;
1057  int err;
1058 
1059  if(!codec->afg)
1060  return 0;
1061 
1062  spec = kzalloc(sizeof(*spec), GFP_KERNEL);
1063  if (spec == NULL) {
1064  printk(KERN_ERR "hda_generic: can't allocate spec\n");
1065  return -ENOMEM;
1066  }
1067  codec->spec = spec;
1068  INIT_LIST_HEAD(&spec->nid_list);
1069 
1070  if ((err = build_afg_tree(codec)) < 0)
1071  goto error;
1072 
1073  if ((err = parse_input(codec)) < 0 ||
1074  (err = parse_output(codec)) < 0)
1075  goto error;
1076 
1077  codec->patch_ops = generic_patch_ops;
1078 
1079  return 0;
1080 
1081  error:
1082  snd_hda_generic_free(codec);
1083  return err;
1084 }