aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci/hda/patch_sigmatel.c
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2007-09-03 03:43:38 -0400
committerJaroslav Kysela <perex@perex.cz>2007-10-16 09:59:41 -0400
commitc480f79bdca58923e605ff5e4698cfe1779bae70 (patch)
tree775e8cfd0d087c1ee7c5f11c016f2e89167c70c1 /sound/pci/hda/patch_sigmatel.c
parentdc81bed127a93e20d2100624273a27369738ffc7 (diff)
[ALSA] hda-codec - Avoid zero NID in line_out_pins[] of STAC codecs
The STAC codes adds line_out_pins[] for shared mic/line-inputs accordingly. But, the current code may give a hole with NID=0 in some setting, which results in an error at probe. This patch fixes the problem. Signed-off-by: Takashi Iwai <tiwai@suse.de> Signed-off-by: Jaroslav Kysela <perex@suse.cz>
Diffstat (limited to 'sound/pci/hda/patch_sigmatel.c')
-rw-r--r--sound/pci/hda/patch_sigmatel.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/sound/pci/hda/patch_sigmatel.c b/sound/pci/hda/patch_sigmatel.c
index 39187828503d..b4a1d73b5721 100644
--- a/sound/pci/hda/patch_sigmatel.c
+++ b/sound/pci/hda/patch_sigmatel.c
@@ -1479,7 +1479,8 @@ static int stac92xx_add_dyn_out_pins(struct hda_codec *codec, struct auto_pin_cf
1479 case 3: 1479 case 3:
1480 /* add line-in as side */ 1480 /* add line-in as side */
1481 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 3) { 1481 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 3) {
1482 cfg->line_out_pins[3] = cfg->input_pins[AUTO_PIN_LINE]; 1482 cfg->line_out_pins[cfg->line_outs] =
1483 cfg->input_pins[AUTO_PIN_LINE];
1483 spec->line_switch = 1; 1484 spec->line_switch = 1;
1484 cfg->line_outs++; 1485 cfg->line_outs++;
1485 } 1486 }
@@ -1487,12 +1488,14 @@ static int stac92xx_add_dyn_out_pins(struct hda_codec *codec, struct auto_pin_cf
1487 case 2: 1488 case 2:
1488 /* add line-in as clfe and mic as side */ 1489 /* add line-in as clfe and mic as side */
1489 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 2) { 1490 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 2) {
1490 cfg->line_out_pins[2] = cfg->input_pins[AUTO_PIN_LINE]; 1491 cfg->line_out_pins[cfg->line_outs] =
1492 cfg->input_pins[AUTO_PIN_LINE];
1491 spec->line_switch = 1; 1493 spec->line_switch = 1;
1492 cfg->line_outs++; 1494 cfg->line_outs++;
1493 } 1495 }
1494 if (cfg->input_pins[AUTO_PIN_MIC] && num_dacs > 3) { 1496 if (cfg->input_pins[AUTO_PIN_MIC] && num_dacs > 3) {
1495 cfg->line_out_pins[3] = cfg->input_pins[AUTO_PIN_MIC]; 1497 cfg->line_out_pins[cfg->line_outs] =
1498 cfg->input_pins[AUTO_PIN_MIC];
1496 spec->mic_switch = 1; 1499 spec->mic_switch = 1;
1497 cfg->line_outs++; 1500 cfg->line_outs++;
1498 } 1501 }
@@ -1500,12 +1503,14 @@ static int stac92xx_add_dyn_out_pins(struct hda_codec *codec, struct auto_pin_cf
1500 case 1: 1503 case 1:
1501 /* add line-in as surr and mic as clfe */ 1504 /* add line-in as surr and mic as clfe */
1502 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 1) { 1505 if (cfg->input_pins[AUTO_PIN_LINE] && num_dacs > 1) {
1503 cfg->line_out_pins[1] = cfg->input_pins[AUTO_PIN_LINE]; 1506 cfg->line_out_pins[cfg->line_outs] =
1507 cfg->input_pins[AUTO_PIN_LINE];
1504 spec->line_switch = 1; 1508 spec->line_switch = 1;
1505 cfg->line_outs++; 1509 cfg->line_outs++;
1506 } 1510 }
1507 if (cfg->input_pins[AUTO_PIN_MIC] && num_dacs > 2) { 1511 if (cfg->input_pins[AUTO_PIN_MIC] && num_dacs > 2) {
1508 cfg->line_out_pins[2] = cfg->input_pins[AUTO_PIN_MIC]; 1512 cfg->line_out_pins[cfg->line_outs] =
1513 cfg->input_pins[AUTO_PIN_MIC];
1509 spec->mic_switch = 1; 1514 spec->mic_switch = 1;
1510 cfg->line_outs++; 1515 cfg->line_outs++;
1511 } 1516 }