diff options
author | Clemens Ladisch <clemens@ladisch.de> | 2007-08-22 03:45:03 -0400 |
---|---|---|
committer | Jaroslav Kysela <perex@perex.cz> | 2007-10-16 09:59:22 -0400 |
commit | 45c41b4868c9dbec5d43a4023e77994afa94470f (patch) | |
tree | cdf019b41ae2462d5dc63dcf65d879890c9208b5 /sound/pci | |
parent | c2b1239a9f22f19c53543b460b24507d0e21ea0c (diff) |
[ALSA] cmipci: fix handling of FM/MIDI port addresses
Make sure that the MPU-401 MIDI and OPL-3 FM devices are used only on
those chips where they are supported, and that the correct port
addresses are used.
Signed-off-by: Clemens Ladisch <clemens@ladisch.de>
Signed-off-by: Jaroslav Kysela <perex@suse.cz>
Diffstat (limited to 'sound/pci')
-rw-r--r-- | sound/pci/Kconfig | 6 | ||||
-rw-r--r-- | sound/pci/cmipci.c | 22 |
2 files changed, 18 insertions, 10 deletions
diff --git a/sound/pci/Kconfig b/sound/pci/Kconfig index 9554140f0b04..5d0732c09f2e 100644 --- a/sound/pci/Kconfig +++ b/sound/pci/Kconfig | |||
@@ -170,14 +170,14 @@ config SND_CA0106 | |||
170 | will be called snd-ca0106. | 170 | will be called snd-ca0106. |
171 | 171 | ||
172 | config SND_CMIPCI | 172 | config SND_CMIPCI |
173 | tristate "C-Media 8738, 8338" | 173 | tristate "C-Media 8338, 8738, 8768, 8770" |
174 | depends on SND | 174 | depends on SND |
175 | select SND_OPL3_LIB | 175 | select SND_OPL3_LIB |
176 | select SND_MPU401_UART | 176 | select SND_MPU401_UART |
177 | select SND_PCM | 177 | select SND_PCM |
178 | help | 178 | help |
179 | If you want to use soundcards based on C-Media CMI8338 or CMI8738 | 179 | If you want to use soundcards based on C-Media CMI8338, CMI8738, |
180 | chips, say Y here and read | 180 | CMI8768 or CMI8770 chips, say Y here and read |
181 | <file:Documentation/sound/alsa/CMIPCI.txt>. | 181 | <file:Documentation/sound/alsa/CMIPCI.txt>. |
182 | 182 | ||
183 | To compile this driver as a module, choose M here: the module | 183 | To compile this driver as a module, choose M here: the module |
diff --git a/sound/pci/cmipci.c b/sound/pci/cmipci.c index c42c51647df7..9d394c7c221d 100644 --- a/sound/pci/cmipci.c +++ b/sound/pci/cmipci.c | |||
@@ -2774,10 +2774,14 @@ static int __devinit snd_cmipci_create_fm(struct cmipci *cm, long fm_port) | |||
2774 | if (!fm_port) | 2774 | if (!fm_port) |
2775 | goto disable_fm; | 2775 | goto disable_fm; |
2776 | 2776 | ||
2777 | /* first try FM regs in PCI port range */ | 2777 | if (cm->chip_version > 33) { |
2778 | iosynth = cm->iobase + CM_REG_FM_PCI; | 2778 | /* first try FM regs in PCI port range */ |
2779 | err = snd_opl3_create(cm->card, iosynth, iosynth + 2, | 2779 | iosynth = cm->iobase + CM_REG_FM_PCI; |
2780 | OPL3_HW_OPL3, 1, &opl3); | 2780 | err = snd_opl3_create(cm->card, iosynth, iosynth + 2, |
2781 | OPL3_HW_OPL3, 1, &opl3); | ||
2782 | } else { | ||
2783 | err = -EIO; | ||
2784 | } | ||
2781 | if (err < 0) { | 2785 | if (err < 0) { |
2782 | /* then try legacy ports */ | 2786 | /* then try legacy ports */ |
2783 | val = snd_cmipci_read(cm, CM_REG_LEGACY_CTRL) & ~CM_FMSEL_MASK; | 2787 | val = snd_cmipci_read(cm, CM_REG_LEGACY_CTRL) & ~CM_FMSEL_MASK; |
@@ -2935,7 +2939,8 @@ static int __devinit snd_cmipci_create(struct snd_card *card, struct pci_dev *pc | |||
2935 | return err; | 2939 | return err; |
2936 | } | 2940 | } |
2937 | 2941 | ||
2938 | integrated_midi = snd_cmipci_read_b(cm, CM_REG_MPU_PCI) != 0xff; | 2942 | integrated_midi = cm->chip_version > 33 && |
2943 | snd_cmipci_read_b(cm, CM_REG_MPU_PCI + 1) != 0xff; | ||
2939 | if (integrated_midi && mpu_port[dev] == 1) | 2944 | if (integrated_midi && mpu_port[dev] == 1) |
2940 | iomidi = cm->iobase + CM_REG_MPU_PCI; | 2945 | iomidi = cm->iobase + CM_REG_MPU_PCI; |
2941 | else { | 2946 | else { |
@@ -2955,8 +2960,11 @@ static int __devinit snd_cmipci_create(struct snd_card *card, struct pci_dev *pc | |||
2955 | } | 2960 | } |
2956 | } | 2961 | } |
2957 | 2962 | ||
2958 | if ((err = snd_cmipci_create_fm(cm, fm_port[dev])) < 0) | 2963 | if (cm->chip_version < 68) { |
2959 | return err; | 2964 | err = snd_cmipci_create_fm(cm, fm_port[dev]); |
2965 | if (err < 0) | ||
2966 | return err; | ||
2967 | } | ||
2960 | 2968 | ||
2961 | /* reset mixer */ | 2969 | /* reset mixer */ |
2962 | snd_cmipci_mixer_write(cm, 0, 0); | 2970 | snd_cmipci_mixer_write(cm, 0, 0); |