summaryrefslogtreecommitdiffstats
path: root/sound/pci/maestro3.c
diff options
context:
space:
mode:
authorCharles R. Anderson <cra@alum.wpi.edu>2005-10-18 18:04:36 +0200
committerJaroslav Kysela <perex@suse.cz>2005-11-04 13:19:06 +0100
commit051b51653309db976c9665f8d4b1774fa1f8124a (patch)
tree82b06edc315ae21e39cbcf2cc96cec37df6dfcde /sound/pci/maestro3.c
parentc829b052de189b3ca4fb76d2f61917b67e12b83d (diff)
downloadblackbird-op-linux-051b51653309db976c9665f8d4b1774fa1f8124a.tar.gz
blackbird-op-linux-051b51653309db976c9665f8d4b1774fa1f8124a.zip
[ALSA] Fix maestro3 hang after cold boot
Modules: Maestro3 driver This patch fixes the maestro3 driver to call the snd_m3_assp_init function to write the DSP firmware into the ASSP chip before sending the RUN_ASSP command, thereby solving the hang after a cold boot. Signed-off-by: Charles R. Anderson <cra@alum.wpi.edu> Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/maestro3.c')
-rw-r--r--sound/pci/maestro3.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sound/pci/maestro3.c b/sound/pci/maestro3.c
index 2693b6f731f3..7b1b82521cf4 100644
--- a/sound/pci/maestro3.c
+++ b/sound/pci/maestro3.c
@@ -2476,6 +2476,7 @@ snd_m3_chip_init(m3_t *chip)
t |= ASSP_0_WS_ENABLE;
outb(t, chip->iobase + ASSP_CONTROL_A);
+ snd_m3_assp_init(chip); /* download DSP code before starting ASSP below */
outb(RUN_ASSP, chip->iobase + ASSP_CONTROL_B);
outb(0x00, io + HARDWARE_VOL_CTRL);
@@ -2734,7 +2735,6 @@ snd_m3_create(snd_card_t *card, struct pci_dev *pci,
snd_m3_ac97_reset(chip);
- snd_m3_assp_init(chip);
snd_m3_amp_enable(chip, 1);
tasklet_init(&chip->hwvol_tq, snd_m3_update_hw_volume, (unsigned long)chip);
OpenPOWER on IntegriCloud