aboutsummaryrefslogtreecommitdiffstats
path: root/sound/pci/intel8x0.c
diff options
context:
space:
mode:
authorTakashi Iwai <tiwai@suse.de>2005-06-30 07:47:06 -0400
committerJaroslav Kysela <perex@suse.cz>2005-07-28 06:10:04 -0400
commit52b723888c1a55d34551f9b0b9d9296e0e3e8d3c (patch)
tree57df026da13319fa608c38674e411f2d18c0de8c /sound/pci/intel8x0.c
parent2eff7ec81eb586076974cb0918dffc5f4ad763d5 (diff)
[ALSA] Fix resume of intel8x0
Intel8x0 driver,AC97 Codec Fix resume of intel8x0 driver. The ac97 codec didn't restore some registers properly, and the restore of ICH4 SPDIF and SDIN settings was missing. Signed-off-by: Takashi Iwai <tiwai@suse.de>
Diffstat (limited to 'sound/pci/intel8x0.c')
-rw-r--r--sound/pci/intel8x0.c13
1 files changed, 13 insertions, 0 deletions
diff --git a/sound/pci/intel8x0.c b/sound/pci/intel8x0.c
index cc16f95f9cef..c3c3b68b4540 100644
--- a/sound/pci/intel8x0.c
+++ b/sound/pci/intel8x0.c
@@ -424,6 +424,7 @@ struct _snd_intel8x0 {
424 unsigned xbox: 1; /* workaround for Xbox AC'97 detection */ 424 unsigned xbox: 1; /* workaround for Xbox AC'97 detection */
425 425
426 int spdif_idx; /* SPDIF BAR index; *_SPBAR or -1 if use PCMOUT */ 426 int spdif_idx; /* SPDIF BAR index; *_SPBAR or -1 if use PCMOUT */
427 unsigned int sdm_saved; /* SDM reg value */
427 428
428 ac97_bus_t *ac97_bus; 429 ac97_bus_t *ac97_bus;
429 ac97_t *ac97[3]; 430 ac97_t *ac97[3];
@@ -2373,6 +2374,8 @@ static int intel8x0_suspend(snd_card_t *card, pm_message_t state)
2373 for (i = 0; i < 3; i++) 2374 for (i = 0; i < 3; i++)
2374 if (chip->ac97[i]) 2375 if (chip->ac97[i])
2375 snd_ac97_suspend(chip->ac97[i]); 2376 snd_ac97_suspend(chip->ac97[i]);
2377 if (chip->device_type == DEVICE_INTEL_ICH4)
2378 chip->sdm_saved = igetbyte(chip, ICHREG(SDM));
2376 pci_disable_device(chip->pci); 2379 pci_disable_device(chip->pci);
2377 return 0; 2380 return 0;
2378} 2381}
@@ -2386,6 +2389,16 @@ static int intel8x0_resume(snd_card_t *card)
2386 pci_set_master(chip->pci); 2389 pci_set_master(chip->pci);
2387 snd_intel8x0_chip_init(chip, 0); 2390 snd_intel8x0_chip_init(chip, 0);
2388 2391
2392 /* re-initialize mixer stuff */
2393 if (chip->device_type == DEVICE_INTEL_ICH4) {
2394 /* enable separate SDINs for ICH4 */
2395 iputbyte(chip, ICHREG(SDM), chip->sdm_saved);
2396 /* use slot 10/11 for SPDIF */
2397 iputdword(chip, ICHREG(GLOB_CNT),
2398 (igetdword(chip, ICHREG(GLOB_CNT)) & ~ICH_PCM_SPDIF_MASK) |
2399 ICH_PCM_SPDIF_1011);
2400 }
2401
2389 /* refill nocache */ 2402 /* refill nocache */
2390 if (chip->fix_nocache) 2403 if (chip->fix_nocache)
2391 fill_nocache(chip->bdbars.area, chip->bdbars.bytes, 1); 2404 fill_nocache(chip->bdbars.area, chip->bdbars.bytes, 1);