[BUG] ali5451 not resumed properly under 2.6.7 ( fine under 2.6.6 )

From: Fedor Karpelevitch
Date: Wed Jun 23 2004 - 12:09:05 EST


-----BEGIN PGP SIGNED MESSAGE-----
Hash: SHA1

Hi,

I upgraded to 2.6.7 recently and noticed that my ali5451 souncard
stopped behaving properly after resuming.

Basically after resume it produces no sound even though everything
pretends that the card is working properly (mixer "changes" volume
etc...).
I found that executing something like 'alsactl -F power A5451 D1'
makes it produce sound again although the volume is noticably lower
than it should be.

2.6.6 works just fine.

I looked at the diff for ali5451.c and noticed that in ali_suspend a
call to snd_pcm_suspend_all(chip->pcm) was added, but in ali_resume
no call to resume pcm was added. Could that be the cause of the
problem?

I will try adding that call and see if that fixes the problem.


here is that part of the diff:



+static int ali_suspend(snd_card_t *card, unsigned int state)
{
+ ali_t *chip = snd_magic_cast(ali_t, card->pm_private_data,
return -EINVAL);
ali_image_t *im;
int i, j;

im = chip->image;
if (! im)
- - return;
+ return 0;
+
+ snd_pcm_suspend_all(chip->pcm);
+ snd_ac97_suspend(chip->ac97);

spin_lock_irq(&chip->reg_lock);

@@ -1940,16 +1943,18 @@
outl(0xffffffff, ALI_REG(chip, ALI_STOP));

spin_unlock_irq(&chip->reg_lock);
+ return 0;
}

- -static void ali_resume(ali_t *chip)
+static int ali_resume(snd_card_t *card, unsigned int state)
{
+ ali_t *chip = snd_magic_cast(ali_t, card->pm_private_data,
return -EINVAL);
ali_image_t *im;
int i, j;

im = chip->image;
if (! im)
- - return;
+ return 0;

pci_enable_device(chip->pci);

@@ -1967,27 +1972,15 @@
-----BEGIN PGP SIGNATURE-----
Version: GnuPG v1.2.4 (GNU/Linux)

iD8DBQFA2bgYw4m50RG4juoRAqTqAJ4+oHXRvOjz6NZLUS82oxIh+d7SIACgl65l
hCtld2qftBglwS0V0gYNHAw=
=ZLy7
-----END PGP SIGNATURE-----
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/