diff options
author | Takashi Iwai <tiwai@suse.de> | 2009-02-13 05:19:09 -0500 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2009-02-13 05:59:33 -0500 |
commit | 6a05ac4afa90ac9c38fedd3f6940fe8da5d1fcf6 (patch) | |
tree | 056f6c1e27b751035af769b83f6def4086df9ef1 | |
parent | 9b5f12e5a4029c1cd03784754687faef6d9e54fa (diff) |
ALSA: hda - Support multiple digital outs with auto-probing
Added the support of multiple digital outputs via auto-probing for
Realtek ALC88x codecs. The multiple outputs are handled as slave
streams, so only one PCM stream (and the corresponding IEC958*
elements) is provided to control both digital outputs.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 22 |
1 files changed, 19 insertions, 3 deletions
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index ef9b7ee34100..244de597c5be 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -279,6 +279,7 @@ struct alc_spec { | |||
279 | * dig_out_nid and hp_nid are optional | 279 | * dig_out_nid and hp_nid are optional |
280 | */ | 280 | */ |
281 | hda_nid_t alt_dac_nid; | 281 | hda_nid_t alt_dac_nid; |
282 | hda_nid_t slave_dig_outs[3]; /* optional - for auto-parsing */ | ||
282 | int dig_out_type; | 283 | int dig_out_type; |
283 | 284 | ||
284 | /* capture */ | 285 | /* capture */ |
@@ -4269,7 +4270,7 @@ static void alc880_auto_init_analog_input(struct hda_codec *codec) | |||
4269 | static int alc880_parse_auto_config(struct hda_codec *codec) | 4270 | static int alc880_parse_auto_config(struct hda_codec *codec) |
4270 | { | 4271 | { |
4271 | struct alc_spec *spec = codec->spec; | 4272 | struct alc_spec *spec = codec->spec; |
4272 | int err; | 4273 | int i, err; |
4273 | static hda_nid_t alc880_ignore[] = { 0x1d, 0 }; | 4274 | static hda_nid_t alc880_ignore[] = { 0x1d, 0 }; |
4274 | 4275 | ||
4275 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, | 4276 | err = snd_hda_parse_pin_def_config(codec, &spec->autocfg, |
@@ -4300,8 +4301,23 @@ static int alc880_parse_auto_config(struct hda_codec *codec) | |||
4300 | 4301 | ||
4301 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; | 4302 | spec->multiout.max_channels = spec->multiout.num_dacs * 2; |
4302 | 4303 | ||
4303 | if (spec->autocfg.dig_outs) | 4304 | /* check multiple SPDIF-out (for recent codecs) */ |
4304 | spec->multiout.dig_out_nid = ALC880_DIGOUT_NID; | 4305 | for (i = 0; i < spec->autocfg.dig_outs; i++) { |
4306 | hda_nid_t dig_nid; | ||
4307 | err = snd_hda_get_connections(codec, | ||
4308 | spec->autocfg.dig_out_pins[i], | ||
4309 | &dig_nid, 1); | ||
4310 | if (err < 0) | ||
4311 | continue; | ||
4312 | if (!i) | ||
4313 | spec->multiout.dig_out_nid = dig_nid; | ||
4314 | else { | ||
4315 | spec->multiout.slave_dig_outs = spec->slave_dig_outs; | ||
4316 | spec->slave_dig_outs[i - 1] = dig_nid; | ||
4317 | if (i == ARRAY_SIZE(spec->slave_dig_outs) - 1) | ||
4318 | break; | ||
4319 | } | ||
4320 | } | ||
4305 | if (spec->autocfg.dig_in_pin) | 4321 | if (spec->autocfg.dig_in_pin) |
4306 | spec->dig_in_nid = ALC880_DIGIN_NID; | 4322 | spec->dig_in_nid = ALC880_DIGIN_NID; |
4307 | 4323 | ||