All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] Wait for all codecs to be ready if doing a cold reset
@ 2008-07-06 17:15 Thadeu Lima de Souza Cascardo
  2008-07-07 16:39 ` Takashi Iwai
  0 siblings, 1 reply; 12+ messages in thread
From: Thadeu Lima de Souza Cascardo @ 2008-07-06 17:15 UTC (permalink / raw)
  To: linux-kernel; +Cc: tiwai

If AC97_POWER_SAVE is enabled, intel8x0 does a cold reset when
initializing the codecs. While resuming, it does not wait for all codecs
to be active. Sound card does not work after a resume without it,
however. This patch fixes it.
---
 sound/pci/intel8x0.c |   24 ++++++++++++++----------
 1 files changed, 14 insertions(+), 10 deletions(-)

diff --git a/sound/pci/intel8x0.c b/sound/pci/intel8x0.c
index 048d99e..7228a0a 100644
--- a/sound/pci/intel8x0.c
+++ b/sound/pci/intel8x0.c
@@ -2335,16 +2335,6 @@ static int snd_intel8x0_ich_chip_init(struct intel8x0 *chip, int probing)
 				   igetdword(chip, ICHREG(GLOB_STA)));
 			return -EIO;
 		}
-
-		/* wait for other codecs ready status. */
-		end_time = jiffies + HZ / 4;
-		while (status != chip->codec_isr_bits &&
-		       time_after_eq(end_time, jiffies)) {
-			schedule_timeout_uninterruptible(1);
-			status |= igetdword(chip, ICHREG(GLOB_STA)) &
-				chip->codec_isr_bits;
-		}
-
 	} else {
 		/* resume phase */
 		int i;
@@ -2363,6 +2353,20 @@ static int snd_intel8x0_ich_chip_init(struct intel8x0 *chip, int probing)
 		} while (time_after_eq(end_time, jiffies));
 	}
 
+#ifndef CONFIG_SND_AC97_POWER_SAVE
+	if (probing)
+#endif
+	{
+		/* wait for other codecs ready status. */
+		end_time = jiffies + HZ / 4;
+		while (status != chip->codec_isr_bits &&
+		       time_after_eq(end_time, jiffies)) {
+			schedule_timeout_uninterruptible(1);
+			status |= igetdword(chip, ICHREG(GLOB_STA)) &
+				chip->codec_isr_bits;
+		}
+	}
+
 	if (chip->device_type == DEVICE_SIS) {
 		/* unmute the output on SIS7012 */
 		iputword(chip, 0x4c, igetword(chip, 0x4c) | 1);
-- 
1.5.6

^ permalink raw reply related	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2008-12-18  7:18 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-07-06 17:15 [PATCH] Wait for all codecs to be ready if doing a cold reset Thadeu Lima de Souza Cascardo
2008-07-07 16:39 ` Takashi Iwai
2008-07-07 17:36   ` Thadeu Lima de Souza Cascardo
2008-07-08 10:16     ` Takashi Iwai
2008-07-08 16:59       ` Thadeu Lima de Souza Cascardo
2008-07-09 15:07         ` Takashi Iwai
2008-07-08 17:31           ` Thadeu Lima de Souza Cascardo
     [not found]             ` <s5h63rezzlb.wl%tiwai@suse.de>
2008-07-09 17:26               ` Thadeu Lima de Souza Cascardo
2008-07-15 23:47                 ` Takashi Iwai
2008-07-15  0:10                   ` Thadeu Lima de Souza Cascardo
2008-12-17 22:08                     ` Thadeu Lima de Souza Cascardo
2008-12-18  7:18                       ` Takashi Iwai

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.