ALSA: hda - Fix uninitialized HDMI controllers with VGA-switcheroo
authorTakashi Iwai <tiwai@suse.de>
Thu, 7 Jun 2012 10:15:16 +0000 (12:15 +0200)
committerTakashi Iwai <tiwai@suse.de>
Fri, 8 Jun 2012 09:24:19 +0000 (11:24 +0200)
When VGA-switcheroo is built in but unused on systems with multiple
graphics cards, the initializations of non-default graphics cards are
skipped and never enabled (because the switcheroo is activated only
when the controller supports).  The current behavior is for avoiding
the system lockup by accessing the disabled GPU, but due to the recent
change in VGA-switcheroo, it determines the state simply by checking
with the default VGA device.  This is the culprit.

Now with the new vga_switcheroo_get_client_state(), we can know the
initial state of the bound GPU, thus can determine the initial audio
client state more correctly.

Signed-off-by: Takashi Iwai <tiwai@suse.de>
sound/pci/hda/hda_intel.c

index 2b6392be451c688830cf9d42e346d0eee61ac1dc..5f0375fefc89ec740dca9f35947ccb6a89de480d 100644 (file)
@@ -2670,7 +2670,7 @@ static bool __devinit check_hdmi_disabled(struct pci_dev *pci)
        struct pci_dev *p = get_bound_vga(pci);
 
        if (p) {
-               if (vga_default_device() && p != vga_default_device())
+               if (vga_switcheroo_get_client_state(p) == VGA_SWITCHEROO_OFF)
                        vga_inactive = true;
                pci_dev_put(p);
        }