[alsa-devel] Hung task with trace after resume on kernel v3.7-rc6

Julian Wollrath jwollrath at web.de
Mon Nov 19 20:25:13 CET 2012


> > Could you clear the patch and check whether power_save_controller=0
> > option also solves the issue?
> 
> If it works, the patch below should help.  Give it a try.
The patch below does help, the spurious responses do not show up
anymore.

Thank you very much for your help and your quick response, with best
regards,
Julian

> ---
> From: Takashi Iwai <tiwai at suse.de>
> Subject: [PATCH] ALSA: hda - Limit runtime PM support only to known
> Intel chips
> 
> We've got a report that the runtime PM may make the codec the
> unresponsive on AMD platforms.  Since the feature has been tested only
> on the recent Intel platforms, it's safer to limit the support to such
> devices for now.
> 
> This patch adds a new DCAPS bit flag indicating the runtime PM
> support, and mark it for Intel controllers.
> 
> Reported-by: Julian Wollrath <jwollrath at web.de>
> Signed-off-by: Takashi Iwai <tiwai at suse.de>
Tested-by: Julian Wollrath <jwollrath at web.de>
> ---
>  sound/pci/hda/hda_intel.c | 39
> ++++++++++++++++++++------------------- 1 file changed, 20
> insertions(+), 19 deletions(-)
> 
> diff --git a/sound/pci/hda/hda_intel.c b/sound/pci/hda/hda_intel.c
> index cd2dbaf..f9d870e 100644
> --- a/sound/pci/hda/hda_intel.c
> +++ b/sound/pci/hda/hda_intel.c
> @@ -556,6 +556,12 @@ enum {
>  #define AZX_DCAPS_ALIGN_BUFSIZE	(1 << 22)	/* buffer
> size alignment */ #define AZX_DCAPS_4K_BDLE_BOUNDARY (1 <<
> 23)	/* BDLE in 4k boundary */ #define
> AZX_DCAPS_COUNT_LPIB_DELAY  (1 << 25)	/* Take LPIB as delay */
> +#define AZX_DCAPS_PM_RUNTIME	(1 << 26)	/* runtime PM
> support */ + +/* quirks for Intel PCH */
> +#define AZX_DCAPS_INTEL_PCH \
> +	(AZX_DCAPS_SCH_SNOOP | AZX_DCAPS_BUFSIZE | \
> +	 AZX_DCAPS_COUNT_LPIB_DELAY | AZX_DCAPS_PM_RUNTIME)
>  
>  /* quirks for ATI SB / AMD Hudson */
>  #define AZX_DCAPS_PRESET_ATI_SB \
> @@ -2433,6 +2439,9 @@ static void azx_power_notify(struct hda_bus
> *bus, bool power_up) {
>  	struct azx *chip = bus->private_data;
>  
> +	if (!(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
> +		return;
> +
>  	if (power_up)
>  		pm_runtime_get_sync(&chip->pci->dev);
>  	else
> @@ -2548,7 +2557,8 @@ static int azx_runtime_suspend(struct device
> *dev) struct snd_card *card = dev_get_drvdata(dev);
>  	struct azx *chip = card->private_data;
>  
> -	if (!power_save_controller)
> +	if (!power_save_controller ||
> +	    !(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
>  		return -EAGAIN;
>  
>  	azx_stop_chip(chip);
> @@ -3429,39 +3439,30 @@ static void __devexit azx_remove(struct
> pci_dev *pci) static DEFINE_PCI_DEVICE_TABLE(azx_ids) = {
>  	/* CPT */
>  	{ PCI_DEVICE(0x8086, 0x1c20),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* PBG */
>  	{ PCI_DEVICE(0x8086, 0x1d20),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE},
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* Panther Point */
>  	{ PCI_DEVICE(0x8086, 0x1e20),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* Lynx Point */
>  	{ PCI_DEVICE(0x8086, 0x8c20),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* Lynx Point-LP */
>  	{ PCI_DEVICE(0x8086, 0x9c20),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* Lynx Point-LP */
>  	{ PCI_DEVICE(0x8086, 0x9c21),
> -	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_PCH | AZX_DCAPS_INTEL_PCH },
>  	/* Haswell */
>  	{ PCI_DEVICE(0x8086, 0x0c0c),
> -	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH },
>  	{ PCI_DEVICE(0x8086, 0x0d0c),
> -	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH },
>  	/* 5 Series/3400 */
>  	{ PCI_DEVICE(0x8086, 0x3b56),
> -	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |
> -	  AZX_DCAPS_BUFSIZE | AZX_DCAPS_COUNT_LPIB_DELAY },
> +	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH },
>  	/* SCH */
>  	{ PCI_DEVICE(0x8086, 0x811b),
>  	  .driver_data = AZX_DRIVER_SCH | AZX_DCAPS_SCH_SNOOP |



More information about the Alsa-devel mailing list