From 3bdbfa234e49b7a542c4948e32f73677bf2b6972 Mon Sep 17 00:00:00 2001 From: Takashi Iwai Date: Thu, 22 Nov 2012 17:18:49 +0100 Subject: [PATCH] --- yaml --- r: 342613 b: refs/heads/master c: 4f86f120d9d65b3a8f17e48dca1f991d861b5cd7 h: refs/heads/master i: 342611: 278caee7477bb6e97d1fd1a6164a30556b1c1c29 v: v3 --- [refs] | 2 +- trunk/include/sound/emu10k1.h | 1 + trunk/sound/pci/emu10k1/emu10k1.c | 4 ++++ trunk/sound/pci/emu10k1/emu10k1_main.c | 2 ++ 4 files changed, 8 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index fc8a27a28bb7..02da05d3d5a4 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: b209c4dfcd960ab176d4746ab7dc442a3edb4575 +refs/heads/master: 4f86f120d9d65b3a8f17e48dca1f991d861b5cd7 diff --git a/trunk/include/sound/emu10k1.h b/trunk/include/sound/emu10k1.h index 9dc94b559c7d..f841ba4bacb8 100644 --- a/trunk/include/sound/emu10k1.h +++ b/trunk/include/sound/emu10k1.h @@ -1796,6 +1796,7 @@ struct snd_emu10k1 { unsigned int *saved_icode; unsigned int *p16v_saved; unsigned int saved_a_iocfg, saved_hcfg; + bool suspend; #endif }; diff --git a/trunk/sound/pci/emu10k1/emu10k1.c b/trunk/sound/pci/emu10k1/emu10k1.c index b7c1875ba90e..a168138efc5e 100644 --- a/trunk/sound/pci/emu10k1/emu10k1.c +++ b/trunk/sound/pci/emu10k1/emu10k1.c @@ -215,6 +215,8 @@ static int snd_emu10k1_suspend(struct device *dev) snd_power_change_state(card, SNDRV_CTL_POWER_D3hot); + emu->suspend = 1; + snd_pcm_suspend_all(emu->pcm); snd_pcm_suspend_all(emu->pcm_mic); snd_pcm_suspend_all(emu->pcm_efx); @@ -260,6 +262,8 @@ static int snd_emu10k1_resume(struct device *dev) if (emu->card_capabilities->ca0151_chip) snd_p16v_resume(emu); + emu->suspend = 0; + snd_power_change_state(card, SNDRV_CTL_POWER_D0); return 0; } diff --git a/trunk/sound/pci/emu10k1/emu10k1_main.c b/trunk/sound/pci/emu10k1/emu10k1_main.c index 1dfb94d16b8b..cfd6cf952d44 100644 --- a/trunk/sound/pci/emu10k1/emu10k1_main.c +++ b/trunk/sound/pci/emu10k1/emu10k1_main.c @@ -714,6 +714,8 @@ static int emu1010_firmware_thread(void *data) msleep_interruptible(1000); if (kthread_should_stop()) break; + if (emu->suspend) + continue; snd_emu1010_fpga_read(emu, EMU_HANA_IRQ_STATUS, &tmp); /* IRQ Status */ snd_emu1010_fpga_read(emu, EMU_HANA_OPTION_CARDS, ®); /* OPTIONS: Which cards are attached to the EMU */ if (reg & EMU_HANA_OPTION_DOCK_OFFLINE) {