ALSA: ymfpci - Fix legacy registers on S3/S4 resume
authorTakashi Iwai <tiwai@suse.de>
Tue, 13 Mar 2012 07:07:41 +0000 (08:07 +0100)
committerTakashi Iwai <tiwai@suse.de>
Tue, 13 Mar 2012 07:12:33 +0000 (08:12 +0100)
We need to resume two legacy registers to recover MIDI/FM functionality
on S3/S4 resume, too.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
include/sound/ymfpci.h
sound/pci/ymfpci/ymfpci_main.c

index 444cd6ba0ba70645c8652089d39250e58d30f8cf..41199664666bb4a96d98b5336f6433b333ef12db 100644 (file)
@@ -366,6 +366,8 @@ struct snd_ymfpci {
 #ifdef CONFIG_PM
        u32 *saved_regs;
        u32 saved_ydsxgr_mode;
+       u16 saved_dsxg_legacy;
+       u16 saved_dsxg_elegacy;
 #endif
 };
 
index 03ee4e3653113820674ad6234fb0017c69dae91e..a3a2eababc01b51cd408dc5f49ae43bc51420be6 100644 (file)
@@ -2310,6 +2310,10 @@ int snd_ymfpci_suspend(struct pci_dev *pci, pm_message_t state)
        for (i = 0; i < YDSXGR_NUM_SAVED_REGS; i++)
                chip->saved_regs[i] = snd_ymfpci_readl(chip, saved_regs_index[i]);
        chip->saved_ydsxgr_mode = snd_ymfpci_readl(chip, YDSXGR_MODE);
+       pci_read_config_word(chip->pci, PCIR_DSXG_LEGACY,
+                            &chip->saved_dsxg_legacy);
+       pci_read_config_word(chip->pci, PCIR_DSXG_ELEGACY,
+                            &chip->saved_dsxg_elegacy);
        snd_ymfpci_writel(chip, YDSXGR_NATIVEDACOUTVOL, 0);
        snd_ymfpci_writel(chip, YDSXGR_BUF441OUTVOL, 0);
        snd_ymfpci_disable_dsp(chip);
@@ -2344,6 +2348,11 @@ int snd_ymfpci_resume(struct pci_dev *pci)
 
        snd_ac97_resume(chip->ac97);
 
+       pci_write_config_word(chip->pci, PCIR_DSXG_LEGACY,
+                             chip->saved_dsxg_legacy);
+       pci_write_config_word(chip->pci, PCIR_DSXG_ELEGACY,
+                             chip->saved_dsxg_elegacy);
+
        /* start hw again */
        if (chip->start_count > 0) {
                spin_lock_irq(&chip->reg_lock);