aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLuotao Fu <l.fu@pengutronix.de>2009-03-26 08:18:03 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2009-04-02 11:34:15 -0400
commit057de50c0d34b4ef7e15b7a8442a36a396d99c00 (patch)
tree48a361a37c29b656ac0fcb4308a23c562e63f3cd
parenta4d11fe50c238a7da5225d1399314c3505cbd792 (diff)
pxa2xx-ac97: fix displaying GSR after reset timeout
the variable gsr_bit is set in isr. It is however set to 0 and interrupts are disabled prior to reset. Hence it doesn't make a lot of sense to show the content of gsr_bit in case of a reset timeout. Signed-off-by: Luotao Fu <l.fu@pengutronix.de> Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r--sound/arm/pxa2xx-ac97-lib.c15
1 files changed, 10 insertions, 5 deletions
diff --git a/sound/arm/pxa2xx-ac97-lib.c b/sound/arm/pxa2xx-ac97-lib.c
index 2e6355f4cbb..71bef45e9d3 100644
--- a/sound/arm/pxa2xx-ac97-lib.c
+++ b/sound/arm/pxa2xx-ac97-lib.c
@@ -239,6 +239,8 @@ static inline void pxa_ac97_cold_pxa3xx(void)
239 239
240bool pxa2xx_ac97_try_warm_reset(struct snd_ac97 *ac97) 240bool pxa2xx_ac97_try_warm_reset(struct snd_ac97 *ac97)
241{ 241{
242 unsigned long gsr;
243
242#ifdef CONFIG_PXA25x 244#ifdef CONFIG_PXA25x
243 if (cpu_is_pxa25x()) 245 if (cpu_is_pxa25x())
244 pxa_ac97_warm_pxa25x(); 246 pxa_ac97_warm_pxa25x();
@@ -255,10 +257,10 @@ bool pxa2xx_ac97_try_warm_reset(struct snd_ac97 *ac97)
255 else 257 else
256#endif 258#endif
257 BUG(); 259 BUG();
258 260 gsr = GSR | gsr_bits;
259 if (!((GSR | gsr_bits) & (GSR_PCR | GSR_SCR))) { 261 if (!(gsr & (GSR_PCR | GSR_SCR))) {
260 printk(KERN_INFO "%s: warm reset timeout (GSR=%#lx)\n", 262 printk(KERN_INFO "%s: warm reset timeout (GSR=%#lx)\n",
261 __func__, gsr_bits); 263 __func__, gsr);
262 264
263 return false; 265 return false;
264 } 266 }
@@ -269,6 +271,8 @@ EXPORT_SYMBOL_GPL(pxa2xx_ac97_try_warm_reset);
269 271
270bool pxa2xx_ac97_try_cold_reset(struct snd_ac97 *ac97) 272bool pxa2xx_ac97_try_cold_reset(struct snd_ac97 *ac97)
271{ 273{
274 unsigned long gsr;
275
272#ifdef CONFIG_PXA25x 276#ifdef CONFIG_PXA25x
273 if (cpu_is_pxa25x()) 277 if (cpu_is_pxa25x())
274 pxa_ac97_cold_pxa25x(); 278 pxa_ac97_cold_pxa25x();
@@ -286,9 +290,10 @@ bool pxa2xx_ac97_try_cold_reset(struct snd_ac97 *ac97)
286#endif 290#endif
287 BUG(); 291 BUG();
288 292
289 if (!((GSR | gsr_bits) & (GSR_PCR | GSR_SCR))) { 293 gsr = GSR | gsr_bits;
294 if (!(gsr & (GSR_PCR | GSR_SCR))) {
290 printk(KERN_INFO "%s: cold reset timeout (GSR=%#lx)\n", 295 printk(KERN_INFO "%s: cold reset timeout (GSR=%#lx)\n",
291 __func__, gsr_bits); 296 __func__, gsr);
292 297
293 return false; 298 return false;
294 } 299 }