diff options
author | Takashi Iwai <tiwai@suse.de> | 2012-12-20 09:27:24 -0500 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2013-01-12 02:34:16 -0500 |
commit | db23fd193d20e222449bdca71c4cc95dfadd6eaf (patch) | |
tree | bcc71ae438b6ee791a84ea5b65d1ed1d3e7dcfb3 /sound/pci/hda/hda_generic.c | |
parent | 973e4972f9f0fe8f854451f7559c847a8cdc8bc7 (diff) |
ALSA: hda - Refactor init_extra_out() in hda_generic.c
Just a small clean up by splitting a function.
No functional changes at all.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/hda/hda_generic.c')
-rw-r--r-- | sound/pci/hda/hda_generic.c | 49 |
1 files changed, 24 insertions, 25 deletions
diff --git a/sound/pci/hda/hda_generic.c b/sound/pci/hda/hda_generic.c index b7b8d7eee7c6..96c779b6ca25 100644 --- a/sound/pci/hda/hda_generic.c +++ b/sound/pci/hda/hda_generic.c | |||
@@ -3389,45 +3389,44 @@ static void init_multi_out(struct hda_codec *codec) | |||
3389 | } | 3389 | } |
3390 | } | 3390 | } |
3391 | 3391 | ||
3392 | /* initialize hp and speaker paths */ | 3392 | |
3393 | static void init_extra_out(struct hda_codec *codec) | 3393 | static void __init_extra_out(struct hda_codec *codec, int num_outs, |
3394 | hda_nid_t *pins, hda_nid_t *dacs, int type) | ||
3394 | { | 3395 | { |
3395 | struct hda_gen_spec *spec = codec->spec; | 3396 | struct hda_gen_spec *spec = codec->spec; |
3396 | int i; | 3397 | int i; |
3397 | hda_nid_t pin, dac; | 3398 | hda_nid_t pin, dac; |
3398 | 3399 | ||
3399 | for (i = 0; i < spec->autocfg.hp_outs; i++) { | 3400 | for (i = 0; i < num_outs; i++) { |
3400 | if (spec->autocfg.line_out_type == AUTO_PIN_HP_OUT) | 3401 | pin = pins[i]; |
3401 | break; | ||
3402 | pin = spec->autocfg.hp_pins[i]; | ||
3403 | if (!pin) | ||
3404 | break; | ||
3405 | dac = spec->multiout.hp_out_nid[i]; | ||
3406 | if (!dac) { | ||
3407 | if (i > 0 && spec->multiout.hp_out_nid[0]) | ||
3408 | dac = spec->multiout.hp_out_nid[0]; | ||
3409 | else | ||
3410 | dac = spec->multiout.dac_nids[0]; | ||
3411 | } | ||
3412 | set_output_and_unmute(codec, pin, PIN_HP, dac); | ||
3413 | } | ||
3414 | for (i = 0; i < spec->autocfg.speaker_outs; i++) { | ||
3415 | if (spec->autocfg.line_out_type == AUTO_PIN_SPEAKER_OUT) | ||
3416 | break; | ||
3417 | pin = spec->autocfg.speaker_pins[i]; | ||
3418 | if (!pin) | 3402 | if (!pin) |
3419 | break; | 3403 | break; |
3420 | dac = spec->multiout.extra_out_nid[i]; | 3404 | dac = dacs[i]; |
3421 | if (!dac) { | 3405 | if (!dac) { |
3422 | if (i > 0 && spec->multiout.extra_out_nid[0]) | 3406 | if (i > 0 && dacs[0]) |
3423 | dac = spec->multiout.extra_out_nid[0]; | 3407 | dac = dacs[0]; |
3424 | else | 3408 | else |
3425 | dac = spec->multiout.dac_nids[0]; | 3409 | dac = spec->multiout.dac_nids[0]; |
3426 | } | 3410 | } |
3427 | set_output_and_unmute(codec, pin, PIN_OUT, dac); | 3411 | set_output_and_unmute(codec, pin, type, dac); |
3428 | } | 3412 | } |
3429 | } | 3413 | } |
3430 | 3414 | ||
3415 | /* initialize hp and speaker paths */ | ||
3416 | static void init_extra_out(struct hda_codec *codec) | ||
3417 | { | ||
3418 | struct hda_gen_spec *spec = codec->spec; | ||
3419 | |||
3420 | if (spec->autocfg.line_out_type != AUTO_PIN_HP_OUT) | ||
3421 | __init_extra_out(codec, spec->autocfg.hp_outs, | ||
3422 | spec->autocfg.hp_pins, | ||
3423 | spec->multiout.hp_out_nid, PIN_HP); | ||
3424 | if (spec->autocfg.line_out_type != AUTO_PIN_SPEAKER_OUT) | ||
3425 | __init_extra_out(codec, spec->autocfg.speaker_outs, | ||
3426 | spec->autocfg.speaker_pins, | ||
3427 | spec->multiout.extra_out_nid, PIN_OUT); | ||
3428 | } | ||
3429 | |||
3431 | /* initialize multi-io paths */ | 3430 | /* initialize multi-io paths */ |
3432 | static void init_multi_io(struct hda_codec *codec) | 3431 | static void init_multi_io(struct hda_codec *codec) |
3433 | { | 3432 | { |