diff options
author | Takashi Iwai <tiwai@suse.de> | 2005-11-17 10:13:41 -0500 |
---|---|---|
committer | Jaroslav Kysela <perex@suse.cz> | 2006-01-03 06:27:56 -0500 |
commit | fe8be10786c040bce53c18048d75b1b23aec64ae (patch) | |
tree | 5f96e9b242637dd5c654cf9d9e5baeaf680407e1 | |
parent | 11d3824ad7d6240d7ce44bdf1d9e81e62a903f72 (diff) |
[ALSA] ens137x - Fix and ADD PM support
Modules: ENS1370/1+ driver
Fix PM support on ens1371 driver.
Add PM support on ens1370 (together with AK4531), too.
Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r-- | sound/pci/ens1370.c | 43 |
1 files changed, 25 insertions, 18 deletions
diff --git a/sound/pci/ens1370.c b/sound/pci/ens1370.c index 2cc0f83a0fde..ff86fabc98c3 100644 --- a/sound/pci/ens1370.c +++ b/sound/pci/ens1370.c | |||
@@ -2034,40 +2034,45 @@ static void snd_ensoniq_chip_init(struct ensoniq *ensoniq) | |||
2034 | } | 2034 | } |
2035 | 2035 | ||
2036 | #ifdef CONFIG_PM | 2036 | #ifdef CONFIG_PM |
2037 | static int snd_ensoniq_suspend(struct snd_card *card, pm_message_t state) | 2037 | static int snd_ensoniq_suspend(struct pci_dev *pci, pm_message_t state) |
2038 | { | 2038 | { |
2039 | struct ensoniq *ensoniq = card->pm_private_data; | 2039 | struct snd_card *card = pci_get_drvdata(pci); |
2040 | struct ensoniq *ensoniq = card->private_data; | ||
2040 | 2041 | ||
2042 | snd_power_change_state(card, SNDRV_CTL_POWER_D3hot); | ||
2043 | |||
2041 | snd_pcm_suspend_all(ensoniq->pcm1); | 2044 | snd_pcm_suspend_all(ensoniq->pcm1); |
2042 | snd_pcm_suspend_all(ensoniq->pcm2); | 2045 | snd_pcm_suspend_all(ensoniq->pcm2); |
2043 | 2046 | ||
2044 | #ifdef CHIP1371 | 2047 | #ifdef CHIP1371 |
2045 | if (ensoniq->u.es1371.ac97) | 2048 | snd_ac97_suspend(ensoniq->u.es1371.ac97); |
2046 | snd_ac97_suspend(ensoniq->u.es1371.ac97); | ||
2047 | #else | 2049 | #else |
2048 | /* FIXME */ | 2050 | snd_ak4531_suspend(ensoniq->u.es1370.ak4531); |
2049 | #endif | 2051 | #endif |
2050 | pci_set_power_state(ensoniq->pci, 3); | 2052 | pci_set_power_state(pci, PCI_D3hot); |
2051 | pci_disable_device(ensoniq->pci); | 2053 | pci_disable_device(pci); |
2054 | pci_save_state(pci); | ||
2052 | return 0; | 2055 | return 0; |
2053 | } | 2056 | } |
2054 | 2057 | ||
2055 | static int snd_ensoniq_resume(struct snd_card *card) | 2058 | static int snd_ensoniq_resume(struct pci_dev *pci) |
2056 | { | 2059 | { |
2057 | struct ensoniq *ensoniq = card->pm_private_data; | 2060 | struct snd_card *card = pci_get_drvdata(pci); |
2061 | struct ensoniq *ensoniq = card->private_data; | ||
2058 | 2062 | ||
2059 | pci_enable_device(ensoniq->pci); | 2063 | pci_restore_state(pci); |
2060 | pci_set_power_state(ensoniq->pci, 0); | 2064 | pci_enable_device(pci); |
2061 | pci_set_master(ensoniq->pci); | 2065 | pci_set_power_state(pci, PCI_D0); |
2066 | pci_set_master(pci); | ||
2062 | 2067 | ||
2063 | snd_ensoniq_chip_init(ensoniq); | 2068 | snd_ensoniq_chip_init(ensoniq); |
2064 | 2069 | ||
2065 | #ifdef CHIP1371 | 2070 | #ifdef CHIP1371 |
2066 | if (ensoniq->u.es1371.ac97) | 2071 | snd_ac97_resume(ensoniq->u.es1371.ac97); |
2067 | snd_ac97_resume(ensoniq->u.es1371.ac97); | ||
2068 | #else | 2072 | #else |
2069 | /* FIXME */ | 2073 | snd_ak4531_resume(ensoniq->u.es1370.ak4531); |
2070 | #endif | 2074 | #endif |
2075 | snd_power_change_state(card, SNDRV_CTL_POWER_D0); | ||
2071 | return 0; | 2076 | return 0; |
2072 | } | 2077 | } |
2073 | #endif /* CONFIG_PM */ | 2078 | #endif /* CONFIG_PM */ |
@@ -2165,8 +2170,6 @@ static int __devinit snd_ensoniq_create(struct snd_card *card, | |||
2165 | 2170 | ||
2166 | snd_ensoniq_proc_init(ensoniq); | 2171 | snd_ensoniq_proc_init(ensoniq); |
2167 | 2172 | ||
2168 | snd_card_set_pm_callback(card, snd_ensoniq_suspend, snd_ensoniq_resume, ensoniq); | ||
2169 | |||
2170 | snd_card_set_dev(card, &pci->dev); | 2173 | snd_card_set_dev(card, &pci->dev); |
2171 | 2174 | ||
2172 | *rensoniq = ensoniq; | 2175 | *rensoniq = ensoniq; |
@@ -2436,6 +2439,7 @@ static int __devinit snd_audiopci_probe(struct pci_dev *pci, | |||
2436 | snd_card_free(card); | 2439 | snd_card_free(card); |
2437 | return err; | 2440 | return err; |
2438 | } | 2441 | } |
2442 | card->private_data = ensoniq; | ||
2439 | 2443 | ||
2440 | pcm_devs[0] = 0; pcm_devs[1] = 1; | 2444 | pcm_devs[0] = 0; pcm_devs[1] = 1; |
2441 | #ifdef CHIP1370 | 2445 | #ifdef CHIP1370 |
@@ -2495,7 +2499,10 @@ static struct pci_driver driver = { | |||
2495 | .id_table = snd_audiopci_ids, | 2499 | .id_table = snd_audiopci_ids, |
2496 | .probe = snd_audiopci_probe, | 2500 | .probe = snd_audiopci_probe, |
2497 | .remove = __devexit_p(snd_audiopci_remove), | 2501 | .remove = __devexit_p(snd_audiopci_remove), |
2498 | SND_PCI_PM_CALLBACKS | 2502 | #ifdef CONFIG_PM |
2503 | .suspend = snd_ensoniq_suspend, | ||
2504 | .resume = snd_ensoniq_resume, | ||
2505 | #endif | ||
2499 | }; | 2506 | }; |
2500 | 2507 | ||
2501 | static int __init alsa_card_ens137x_init(void) | 2508 | static int __init alsa_card_ens137x_init(void) |