diff options
author | Glen Masgai <mimosius@gmx.de> | 2006-10-10 03:27:19 -0400 |
---|---|---|
committer | Jaroslav Kysela <perex@server.perex.cz> | 2006-12-20 02:55:38 -0500 |
commit | d9301263cce69ee4ef989de5bbe57515ef71a780 (patch) | |
tree | fea4b3477de82cc05121064732353898c66ffe8a /sound/pci/ymfpci/ymfpci_main.c | |
parent | 201efe3793b0faab3538a463ad6d63cf0ef4403c (diff) |
[ALSA] ymfpci: fix swap_rear for S/PDIF passthrough
This patch fixes incorrect assignment of swap_rear,
which was broken since patch 'ymfpci - make rear channel swap optional'
It removes module_param rear_swap.
Signed-off-by: Glen Masgai <mimosius@gmx.de>
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Jaroslav Kysela <perex@suse.cz>
Diffstat (limited to 'sound/pci/ymfpci/ymfpci_main.c')
-rw-r--r-- | sound/pci/ymfpci/ymfpci_main.c | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/sound/pci/ymfpci/ymfpci_main.c b/sound/pci/ymfpci/ymfpci_main.c index 79c58f3a6b7c..16be1f395484 100644 --- a/sound/pci/ymfpci/ymfpci_main.c +++ b/sound/pci/ymfpci/ymfpci_main.c | |||
@@ -910,7 +910,7 @@ static int snd_ymfpci_playback_open(struct snd_pcm_substream *substream) | |||
910 | ypcm = runtime->private_data; | 910 | ypcm = runtime->private_data; |
911 | ypcm->output_front = 1; | 911 | ypcm->output_front = 1; |
912 | ypcm->output_rear = chip->mode_dup4ch ? 1 : 0; | 912 | ypcm->output_rear = chip->mode_dup4ch ? 1 : 0; |
913 | ypcm->swap_rear = chip->rear_swap; | 913 | ypcm->swap_rear = 0; |
914 | spin_lock_irq(&chip->reg_lock); | 914 | spin_lock_irq(&chip->reg_lock); |
915 | if (ypcm->output_rear) { | 915 | if (ypcm->output_rear) { |
916 | ymfpci_open_extension(chip); | 916 | ymfpci_open_extension(chip); |
@@ -936,6 +936,7 @@ static int snd_ymfpci_playback_spdif_open(struct snd_pcm_substream *substream) | |||
936 | ypcm = runtime->private_data; | 936 | ypcm = runtime->private_data; |
937 | ypcm->output_front = 0; | 937 | ypcm->output_front = 0; |
938 | ypcm->output_rear = 1; | 938 | ypcm->output_rear = 1; |
939 | ypcm->swap_rear = 1; | ||
939 | spin_lock_irq(&chip->reg_lock); | 940 | spin_lock_irq(&chip->reg_lock); |
940 | snd_ymfpci_writew(chip, YDSXGR_SPDIFOUTCTRL, | 941 | snd_ymfpci_writew(chip, YDSXGR_SPDIFOUTCTRL, |
941 | snd_ymfpci_readw(chip, YDSXGR_SPDIFOUTCTRL) | 2); | 942 | snd_ymfpci_readw(chip, YDSXGR_SPDIFOUTCTRL) | 2); |
@@ -963,6 +964,7 @@ static int snd_ymfpci_playback_4ch_open(struct snd_pcm_substream *substream) | |||
963 | ypcm = runtime->private_data; | 964 | ypcm = runtime->private_data; |
964 | ypcm->output_front = 0; | 965 | ypcm->output_front = 0; |
965 | ypcm->output_rear = 1; | 966 | ypcm->output_rear = 1; |
967 | ypcm->swap_rear = 0; | ||
966 | spin_lock_irq(&chip->reg_lock); | 968 | spin_lock_irq(&chip->reg_lock); |
967 | ymfpci_open_extension(chip); | 969 | ymfpci_open_extension(chip); |
968 | chip->rear_opened++; | 970 | chip->rear_opened++; |
@@ -1755,7 +1757,7 @@ static void snd_ymfpci_mixer_free_ac97(struct snd_ac97 *ac97) | |||
1755 | chip->ac97 = NULL; | 1757 | chip->ac97 = NULL; |
1756 | } | 1758 | } |
1757 | 1759 | ||
1758 | int __devinit snd_ymfpci_mixer(struct snd_ymfpci *chip, int rear_switch, int rear_swap) | 1760 | int __devinit snd_ymfpci_mixer(struct snd_ymfpci *chip, int rear_switch) |
1759 | { | 1761 | { |
1760 | struct snd_ac97_template ac97; | 1762 | struct snd_ac97_template ac97; |
1761 | struct snd_kcontrol *kctl; | 1763 | struct snd_kcontrol *kctl; |
@@ -1767,7 +1769,6 @@ int __devinit snd_ymfpci_mixer(struct snd_ymfpci *chip, int rear_switch, int rea | |||
1767 | .read = snd_ymfpci_codec_read, | 1769 | .read = snd_ymfpci_codec_read, |
1768 | }; | 1770 | }; |
1769 | 1771 | ||
1770 | chip->rear_swap = rear_swap; | ||
1771 | if ((err = snd_ac97_bus(chip->card, 0, &ops, chip, &chip->ac97_bus)) < 0) | 1772 | if ((err = snd_ac97_bus(chip->card, 0, &ops, chip, &chip->ac97_bus)) < 0) |
1772 | return err; | 1773 | return err; |
1773 | chip->ac97_bus->private_free = snd_ymfpci_mixer_free_ac97_bus; | 1774 | chip->ac97_bus->private_free = snd_ymfpci_mixer_free_ac97_bus; |
@@ -2322,7 +2323,6 @@ int __devinit snd_ymfpci_create(struct snd_card *card, | |||
2322 | return -EIO; | 2323 | return -EIO; |
2323 | } | 2324 | } |
2324 | 2325 | ||
2325 | chip->rear_swap = 1; | ||
2326 | if ((err = snd_ymfpci_ac3_init(chip)) < 0) { | 2326 | if ((err = snd_ymfpci_ac3_init(chip)) < 0) { |
2327 | snd_ymfpci_free(chip); | 2327 | snd_ymfpci_free(chip); |
2328 | return err; | 2328 | return err; |