diff options
-rw-r--r-- | sound/pci/ca0106/ca0106_mixer.c | 33 |
1 files changed, 15 insertions, 18 deletions
diff --git a/sound/pci/ca0106/ca0106_mixer.c b/sound/pci/ca0106/ca0106_mixer.c index 7fbfe17438b4..18a0525a6b5c 100644 --- a/sound/pci/ca0106/ca0106_mixer.c +++ b/sound/pci/ca0106/ca0106_mixer.c | |||
@@ -643,9 +643,19 @@ static int __devinit rename_ctl(struct snd_card *card, const char *src, const ch | |||
643 | return -ENOENT; | 643 | return -ENOENT; |
644 | } | 644 | } |
645 | 645 | ||
646 | #define ADD_CTLS(emu, ctls) \ | ||
647 | do { \ | ||
648 | int i, err; \ | ||
649 | for (i = 0; i < ARRAY_SIZE(ctls); i++) { \ | ||
650 | err = snd_ctl_add(card, snd_ctl_new1(&ctls[i], emu)); \ | ||
651 | if (err < 0) \ | ||
652 | return err; \ | ||
653 | } \ | ||
654 | } while (0) | ||
655 | |||
646 | int __devinit snd_ca0106_mixer(struct snd_ca0106 *emu) | 656 | int __devinit snd_ca0106_mixer(struct snd_ca0106 *emu) |
647 | { | 657 | { |
648 | int i, err; | 658 | int err; |
649 | struct snd_card *card = emu->card; | 659 | struct snd_card *card = emu->card; |
650 | char **c; | 660 | char **c; |
651 | static char *ca0106_remove_ctls[] = { | 661 | static char *ca0106_remove_ctls[] = { |
@@ -692,17 +702,9 @@ int __devinit snd_ca0106_mixer(struct snd_ca0106 *emu) | |||
692 | rename_ctl(card, c[0], c[1]); | 702 | rename_ctl(card, c[0], c[1]); |
693 | #endif | 703 | #endif |
694 | 704 | ||
695 | for (i = 0; i < ARRAY_SIZE(snd_ca0106_volume_ctls); i++) { | 705 | ADD_CTLS(emu, snd_ca0106_volume_ctls); |
696 | err = snd_ctl_add(card, snd_ctl_new1(&snd_ca0106_volume_ctls[i], emu)); | ||
697 | if (err < 0) | ||
698 | return err; | ||
699 | } | ||
700 | if (emu->details->i2c_adc == 1) { | 706 | if (emu->details->i2c_adc == 1) { |
701 | for (i = 0; i < ARRAY_SIZE(snd_ca0106_volume_i2c_adc_ctls); i++) { | 707 | ADD_CTLS(emu, snd_ca0106_volume_i2c_adc_ctls); |
702 | err = snd_ctl_add(card, snd_ctl_new1(&snd_ca0106_volume_i2c_adc_ctls[i], emu)); | ||
703 | if (err < 0) | ||
704 | return err; | ||
705 | } | ||
706 | if (emu->details->gpio_type == 1) | 708 | if (emu->details->gpio_type == 1) |
707 | err = snd_ctl_add(card, snd_ctl_new1(&snd_ca0106_capture_mic_line_in, emu)); | 709 | err = snd_ctl_add(card, snd_ctl_new1(&snd_ca0106_capture_mic_line_in, emu)); |
708 | else /* gpio_type == 2 */ | 710 | else /* gpio_type == 2 */ |
@@ -710,13 +712,8 @@ int __devinit snd_ca0106_mixer(struct snd_ca0106 *emu) | |||
710 | if (err < 0) | 712 | if (err < 0) |
711 | return err; | 713 | return err; |
712 | } | 714 | } |
713 | if (emu->details->spi_dac == 1) { | 715 | if (emu->details->spi_dac == 1) |
714 | for (i = 0; i < ARRAY_SIZE(snd_ca0106_volume_spi_dac_ctls); i++) { | 716 | ADD_CTLS(emu, snd_ca0106_volume_spi_dac_ctls); |
715 | err = snd_ctl_add(card, snd_ctl_new1(&snd_ca0106_volume_spi_dac_ctls[i], emu)); | ||
716 | if (err < 0) | ||
717 | return err; | ||
718 | } | ||
719 | } | ||
720 | return 0; | 717 | return 0; |
721 | } | 718 | } |
722 | 719 | ||