|
@@ -272,7 +272,7 @@ enum {
|
|
|
/* quirks for Intel PCH */
|
|
|
#define AZX_DCAPS_INTEL_PCH_NOPM \
|
|
|
(AZX_DCAPS_SCH_SNOOP | AZX_DCAPS_BUFSIZE | \
|
|
|
- AZX_DCAPS_COUNT_LPIB_DELAY)
|
|
|
+ AZX_DCAPS_COUNT_LPIB_DELAY | AZX_DCAPS_REVERSE_ASSIGN)
|
|
|
|
|
|
#define AZX_DCAPS_INTEL_PCH \
|
|
|
(AZX_DCAPS_INTEL_PCH_NOPM | AZX_DCAPS_PM_RUNTIME)
|
|
@@ -773,9 +773,10 @@ static int azx_suspend(struct device *dev)
|
|
|
struct pci_dev *pci = to_pci_dev(dev);
|
|
|
struct snd_card *card = dev_get_drvdata(dev);
|
|
|
struct azx *chip = card->private_data;
|
|
|
+ struct hda_intel *hda = container_of(chip, struct hda_intel, chip);
|
|
|
struct azx_pcm *p;
|
|
|
|
|
|
- if (chip->disabled)
|
|
|
+ if (chip->disabled || hda->init_failed)
|
|
|
return 0;
|
|
|
|
|
|
snd_power_change_state(card, SNDRV_CTL_POWER_D3hot);
|
|
@@ -806,8 +807,9 @@ static int azx_resume(struct device *dev)
|
|
|
struct pci_dev *pci = to_pci_dev(dev);
|
|
|
struct snd_card *card = dev_get_drvdata(dev);
|
|
|
struct azx *chip = card->private_data;
|
|
|
+ struct hda_intel *hda = container_of(chip, struct hda_intel, chip);
|
|
|
|
|
|
- if (chip->disabled)
|
|
|
+ if (chip->disabled || hda->init_failed)
|
|
|
return 0;
|
|
|
|
|
|
if (chip->driver_caps & AZX_DCAPS_I915_POWERWELL) {
|
|
@@ -843,8 +845,9 @@ static int azx_runtime_suspend(struct device *dev)
|
|
|
{
|
|
|
struct snd_card *card = dev_get_drvdata(dev);
|
|
|
struct azx *chip = card->private_data;
|
|
|
+ struct hda_intel *hda = container_of(chip, struct hda_intel, chip);
|
|
|
|
|
|
- if (chip->disabled)
|
|
|
+ if (chip->disabled || hda->init_failed)
|
|
|
return 0;
|
|
|
|
|
|
if (!(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
|
|
@@ -867,11 +870,12 @@ static int azx_runtime_resume(struct device *dev)
|
|
|
{
|
|
|
struct snd_card *card = dev_get_drvdata(dev);
|
|
|
struct azx *chip = card->private_data;
|
|
|
+ struct hda_intel *hda = container_of(chip, struct hda_intel, chip);
|
|
|
struct hda_bus *bus;
|
|
|
struct hda_codec *codec;
|
|
|
int status;
|
|
|
|
|
|
- if (chip->disabled)
|
|
|
+ if (chip->disabled || hda->init_failed)
|
|
|
return 0;
|
|
|
|
|
|
if (!(chip->driver_caps & AZX_DCAPS_PM_RUNTIME))
|
|
@@ -907,8 +911,9 @@ static int azx_runtime_idle(struct device *dev)
|
|
|
{
|
|
|
struct snd_card *card = dev_get_drvdata(dev);
|
|
|
struct azx *chip = card->private_data;
|
|
|
+ struct hda_intel *hda = container_of(chip, struct hda_intel, chip);
|
|
|
|
|
|
- if (chip->disabled)
|
|
|
+ if (chip->disabled || hda->init_failed)
|
|
|
return 0;
|
|
|
|
|
|
if (!power_save_controller ||
|