Daniel Drake
2019-Jun-13 06:35 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
From: Lukas Wunner <lukas at wunner.de> The integrated HDA controller on Nvidia GPUs can be hidden with a bit in the GPU's config space. Information about this scheme was provided by NVIDIA on their forums. Many laptops now ship with this device hidden, meaning that Linux users of affected platforms (where the HDMI connector comes off the NVIDIA GPU) cannot use HDMI audio functionality. Avoid this issue by exposing the HDMI audio device on device enumeration and resume. The GPU and HDA controller are two functions of the same PCI device (VGA class device on function 0 and audio device on function 1). The multifunction flag in the GPU's Header Type register is cleared when the HDA controller is hidden and set if it's exposed, so reread the flag after exposing the HDA. According to Ilia Mirkin, the HDA controller is only present from MCP89 onward, so do not touch config space on older GPUs. This quirk is limited to NVIDIA PCI devices with the VGA Controller device class. This is expected to correspond to product configurations where the NVIDIA GPU has connectors attached. Other products where the device class is 3D Controller are expected to correspond to configurations where the NVIDIA GPU is dedicated (dGPU) and has no connectors. It's sensible to avoid exposing the HDA controller on dGPU setups, especially because we've seen cases where the PCI BARs are not set up correctly by the platform in this case, causing Linux to log errors if the device is visible. This assumption of device class accurately corresponding to product configuration is true for 6 of 6 laptops recently checked at the Endless lab, and there are also signs of agreement checking the data from 74 previously tested products, however Ilia Mirkin comments that he's seen cases where it is not true. Anyway, it looks like this quirk should fix audio support for the majority of affected users. This commit takes inspiration from an earlier patch by Daniel Drake. Link: https://devtalk.nvidia.com/default/topic/1024022 Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=75985 Cc: Aaron Plattner <aplattner at nvidia.com> Cc: Peter Wu <peter at lekensteyn.nl> Cc: Ilia Mirkin <imirkin at alum.mit.edu> Cc: Karol Herbst <kherbst at redhat.com> Cc: Maik Freudenberg <hhfeuer at gmx.de> Signed-off-by: Lukas Wunner <lukas at wunner.de> Tested-by: Daniel Drake <drake at endlessm.com> --- drivers/pci/quirks.c | 28 ++++++++++++++++++++++++++++ include/linux/pci_ids.h | 1 + 2 files changed, 29 insertions(+) Submitting Lukas's patch from over a year ago. It got held up before on patch dependencies (which are now all merged) and also the concern around the device class assumption not being true in all cases. However, there hasn't been any progress towards finding a better approach, and we don't have any logs to hand from the cases where this isn't true, so I think we should go with this approach which will work in the (vast?) majority of cases. diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 0f16acc323c6..52046b517e2e 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -4971,6 +4971,34 @@ DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_AMD, PCI_ANY_ID, DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, PCI_CLASS_MULTIMEDIA_HD_AUDIO, 8, quirk_gpu_hda); +/* + * Many laptop BIOSes hide the integrated HDA controller on NVIDIA GPUs + * via a special bit. This prevents Linux from seeing and using it. + * Unhide it here. + * https://devtalk.nvidia.com/default/topic/1024022 + */ +static void quirk_nvidia_hda(struct pci_dev *gpu) +{ + u8 hdr_type; + u32 val; + + /* there was no integrated HDA controller before MCP89 */ + if (gpu->device < PCI_DEVICE_ID_NVIDIA_GEFORCE_320M) + return; + + /* bit 25 at offset 0x488 hides or exposes the HDA controller */ + pci_read_config_dword(gpu, 0x488, &val); + pci_write_config_dword(gpu, 0x488, val | BIT(25)); + + /* the GPU becomes a multifunction device when the HDA is exposed */ + pci_read_config_byte(gpu, PCI_HEADER_TYPE, &hdr_type); + gpu->multifunction = !!(hdr_type & BIT(7)); +} +DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); +DECLARE_PCI_FIXUP_CLASS_RESUME_EARLY(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); + /* * Some IDT switches incorrectly flag an ACS Source Validation error on * completions for config read requests even though PCIe r4.0, sec diff --git a/include/linux/pci_ids.h b/include/linux/pci_ids.h index 70e86148cb1e..66898463b81f 100644 --- a/include/linux/pci_ids.h +++ b/include/linux/pci_ids.h @@ -1336,6 +1336,7 @@ #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP78S_SMBUS 0x0752 #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE 0x0759 #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_SMBUS 0x07D8 +#define PCI_DEVICE_ID_NVIDIA_GEFORCE_320M 0x08A0 #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP79_SMBUS 0x0AA2 #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP89_SATA 0x0D85 -- 2.20.1
Ilia Mirkin
2019-Jun-13 13:15 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
On Thu, Jun 13, 2019 at 2:35 AM Daniel Drake <drake at endlessm.com> wrote:> > From: Lukas Wunner <lukas at wunner.de> > > The integrated HDA controller on Nvidia GPUs can be hidden with a bit in > the GPU's config space. Information about this scheme was provided by > NVIDIA on their forums. > > Many laptops now ship with this device hidden, meaning that Linux users > of affected platforms (where the HDMI connector comes off the NVIDIA GPU) > cannot use HDMI audio functionality. > > Avoid this issue by exposing the HDMI audio device on device enumeration > and resume. > > The GPU and HDA controller are two functions of the same PCI device > (VGA class device on function 0 and audio device on function 1). > The multifunction flag in the GPU's Header Type register is cleared when > the HDA controller is hidden and set if it's exposed, so reread the flag > after exposing the HDA. > > According to Ilia Mirkin, the HDA controller is only present from MCP89 > onward, so do not touch config space on older GPUs.Actually GF100 also has it, and has a lower PCI ID than MCP89. But I don't think it really matters - I can't imagine anyone played HDA hiding tricks on that power-hungry monster. I'd appreciate it if you could reword this sentence to imply that it's on PCI IDs >= MCP89's rather than GPUs newer than MCP89. GT215 was released before MCP89, I'm fairly sure, but its PCI ID comes later, for example. [Wikipedia says November 17, 2009 for GT215 vs some point in 2010 for MCP89.] Maybe like "..., the HDA controller is only present on GPUs with PCI IDs values from MCP89's and onward, so ..."> > This quirk is limited to NVIDIA PCI devices with the VGA Controller > device class. This is expected to correspond to product configurations > where the NVIDIA GPU has connectors attached. Other products where the > device class is 3D Controller are expected to correspond to configurations > where the NVIDIA GPU is dedicated (dGPU) and has no connectors. > > It's sensible to avoid exposing the HDA controller on dGPU setups, > especially because we've seen cases where the PCI BARs are not set > up correctly by the platform in this case, causing Linux to log > errors if the device is visible. This assumption of device class > accurately corresponding to product configuration is true for 6 of 6 > laptops recently checked at the Endless lab, and there are also signs of > agreement checking the data from 74 previously tested products, however > Ilia Mirkin comments that he's seen cases where it is not true. Anyway, it > looks like this quirk should fix audio support for the majority of > affected users.Yeah, this is fine. We used to have code which prevented enabling the display portion when 3d class != VGA. We had to change it :) So I'm definitely not making things up... However whether any of those people *also* had HDA hiding issues -- unknown. And it wouldn't make things any worse for them. Not sure if mapping a BAR is an option at this super-early stage in the kernel, but if it were, you could have logic which checked whether the DISPLAY unit is fused off or not. Probably not worth the complication though.> > This commit takes inspiration from an earlier patch by Daniel Drake. > > Link: https://devtalk.nvidia.com/default/topic/1024022 > Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=75985 > Cc: Aaron Plattner <aplattner at nvidia.com> > Cc: Peter Wu <peter at lekensteyn.nl> > Cc: Ilia Mirkin <imirkin at alum.mit.edu> > Cc: Karol Herbst <kherbst at redhat.com> > Cc: Maik Freudenberg <hhfeuer at gmx.de> > Signed-off-by: Lukas Wunner <lukas at wunner.de> > Tested-by: Daniel Drake <drake at endlessm.com> > --- > drivers/pci/quirks.c | 28 ++++++++++++++++++++++++++++ > include/linux/pci_ids.h | 1 + > 2 files changed, 29 insertions(+) > > Submitting Lukas's patch from over a year ago. > > It got held up before on patch dependencies (which are now all merged) > and also the concern around the device class assumption not being true > in all cases. However, there hasn't been any progress towards finding a > better approach, and we don't have any logs to hand from the cases where > this isn't true, so I think we should go with this approach which will > work in the (vast?) majority of cases. > > diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c > index 0f16acc323c6..52046b517e2e 100644 > --- a/drivers/pci/quirks.c > +++ b/drivers/pci/quirks.c > @@ -4971,6 +4971,34 @@ DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_AMD, PCI_ANY_ID, > DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > PCI_CLASS_MULTIMEDIA_HD_AUDIO, 8, quirk_gpu_hda); > > +/* > + * Many laptop BIOSes hide the integrated HDA controller on NVIDIA GPUs > + * via a special bit. This prevents Linux from seeing and using it. > + * Unhide it here. > + * https://devtalk.nvidia.com/default/topic/1024022 > + */ > +static void quirk_nvidia_hda(struct pci_dev *gpu) > +{ > + u8 hdr_type; > + u32 val; > + > + /* there was no integrated HDA controller before MCP89 */ > + if (gpu->device < PCI_DEVICE_ID_NVIDIA_GEFORCE_320M) > + return; > + > + /* bit 25 at offset 0x488 hides or exposes the HDA controller */ > + pci_read_config_dword(gpu, 0x488, &val); > + pci_write_config_dword(gpu, 0x488, val | BIT(25)); > + > + /* the GPU becomes a multifunction device when the HDA is exposed */ > + pci_read_config_byte(gpu, PCI_HEADER_TYPE, &hdr_type); > + gpu->multifunction = !!(hdr_type & BIT(7)); > +} > +DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); > +DECLARE_PCI_FIXUP_CLASS_RESUME_EARLY(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); > + > /* > * Some IDT switches incorrectly flag an ACS Source Validation error on > * completions for config read requests even though PCIe r4.0, sec > diff --git a/include/linux/pci_ids.h b/include/linux/pci_ids.h > index 70e86148cb1e..66898463b81f 100644 > --- a/include/linux/pci_ids.h > +++ b/include/linux/pci_ids.h > @@ -1336,6 +1336,7 @@ > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP78S_SMBUS 0x0752 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE 0x0759 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_SMBUS 0x07D8 > +#define PCI_DEVICE_ID_NVIDIA_GEFORCE_320M 0x08A0 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP79_SMBUS 0x0AA2 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP89_SATA 0x0D85 > > -- > 2.20.1 >
Lukas Wunner
2019-Jun-13 19:25 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
On Thu, Jun 13, 2019 at 09:15:31AM -0400, Ilia Mirkin wrote:> On Thu, Jun 13, 2019 at 2:35 AM Daniel Drake <drake at endlessm.com> wrote: > > Link: https://devtalk.nvidia.com/default/topic/1024022 > > Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=75985 > > Cc: Aaron Plattner <aplattner at nvidia.com> > > Cc: Peter Wu <peter at lekensteyn.nl> > > Cc: Ilia Mirkin <imirkin at alum.mit.edu> > > Cc: Karol Herbst <kherbst at redhat.com> > > Cc: Maik Freudenberg <hhfeuer at gmx.de> > > Signed-off-by: Lukas Wunner <lukas at wunner.de> > > Tested-by: Daniel Drake <drake at endlessm.com>Daniel, if you submit a v2 to address Ilia's comments, please be sure to add your Signed-off-by. Thanks for taking care of mainlining this. Kind regards, Lukas
Ilia Mirkin
2019-Jun-13 19:44 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
On Thu, Jun 13, 2019 at 9:15 AM Ilia Mirkin <imirkin at alum.mit.edu> wrote:> > On Thu, Jun 13, 2019 at 2:35 AM Daniel Drake <drake at endlessm.com> wrote: > > > > From: Lukas Wunner <lukas at wunner.de> > > > > The integrated HDA controller on Nvidia GPUs can be hidden with a bit in > > the GPU's config space. Information about this scheme was provided by > > NVIDIA on their forums. > > > > Many laptops now ship with this device hidden, meaning that Linux users > > of affected platforms (where the HDMI connector comes off the NVIDIA GPU) > > cannot use HDMI audio functionality. > > > > Avoid this issue by exposing the HDMI audio device on device enumeration > > and resume. > > > > The GPU and HDA controller are two functions of the same PCI device > > (VGA class device on function 0 and audio device on function 1). > > The multifunction flag in the GPU's Header Type register is cleared when > > the HDA controller is hidden and set if it's exposed, so reread the flag > > after exposing the HDA. > > > > According to Ilia Mirkin, the HDA controller is only present from MCP89 > > onward, so do not touch config space on older GPUs. > > Actually GF100 also has it, and has a lower PCI ID than MCP89. But I > don't think it really matters - I can't imagine anyone played HDA > hiding tricks on that power-hungry monster. I'd appreciate it if you > could reword this sentence to imply that it's on PCI IDs >= MCP89's > rather than GPUs newer than MCP89. GT215 was released before MCP89, > I'm fairly sure, but its PCI ID comes later, for example. [Wikipedia > says November 17, 2009 for GT215 vs some point in 2010 for MCP89.] > Maybe like > > "..., the HDA controller is only present on GPUs with PCI IDs values > from MCP89's and onward, so ..." > > > > > This quirk is limited to NVIDIA PCI devices with the VGA Controller > > device class. This is expected to correspond to product configurations > > where the NVIDIA GPU has connectors attached. Other products where the > > device class is 3D Controller are expected to correspond to configurations > > where the NVIDIA GPU is dedicated (dGPU) and has no connectors. > > > > It's sensible to avoid exposing the HDA controller on dGPU setups, > > especially because we've seen cases where the PCI BARs are not set > > up correctly by the platform in this case, causing Linux to log > > errors if the device is visible. This assumption of device class > > accurately corresponding to product configuration is true for 6 of 6 > > laptops recently checked at the Endless lab, and there are also signs of > > agreement checking the data from 74 previously tested products, however > > Ilia Mirkin comments that he's seen cases where it is not true. Anyway, it > > looks like this quirk should fix audio support for the majority of > > affected users. > > Yeah, this is fine. We used to have code which prevented enabling the > display portion when 3d class != VGA. We had to change it :) So I'm > definitely not making things up... However whether any of those people > *also* had HDA hiding issues -- unknown. And it wouldn't make things > any worse for them.FTR, this is where it was enabled: commit fc1620883af8cbc10bfb1a4ef2eb4e8113243012 Author: Ben Skeggs <bskeggs at redhat.com> Date: Tue Sep 10 13:20:34 2013 +1000 drm/nouveau/kms: enable for non-vga pci classes Signed-off-by: Ben Skeggs <bskeggs at redhat.com> Unfortunately no bug id included.
Bjorn Helgaas
2019-Jun-13 20:03 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
[+cc Rafael, Martin, zigarrre] On Thu, Jun 13, 2019 at 02:35:14PM +0800, Daniel Drake wrote:> From: Lukas Wunner <lukas at wunner.de> > > The integrated HDA controller on Nvidia GPUs can be hidden with a bit in > the GPU's config space. Information about this scheme was provided by > NVIDIA on their forums. > > Many laptops now ship with this device hidden, meaning that Linux users > of affected platforms (where the HDMI connector comes off the NVIDIA GPU) > cannot use HDMI audio functionality. > > Avoid this issue by exposing the HDMI audio device on device enumeration > and resume. > > The GPU and HDA controller are two functions of the same PCI device > (VGA class device on function 0 and audio device on function 1). > The multifunction flag in the GPU's Header Type register is cleared when > the HDA controller is hidden and set if it's exposed, so reread the flag > after exposing the HDA.Is it possible that this works on Windows but not Linux because they handle ACPI hotplug slightly differently? Martin did some nice debug [1] and found that _DSM, _PS0, and _PS3 functions write the config bit at 0x488. The dmesg log [2] from zigarrre seems to show that _OSC failed (which I *think* means we won't use pciehp) and that there's a slot registered by acpiphp. Maybe this works on Windows via an ACPI hotplug event that runs AML to flip the 0x488 bit and rescans the bus? That would make more sense to me than the idea that the Nvidia driver does it. I could imagine the driver flipping the bit, but the bus rescan seems like it would be out of the driver's purview. The dmesg log also shows some _DSM warnings; are these correlated with cable plug/unplug? Is there some acpiphp debug we can turn on to get more visibility into hotplug events and how we handle them? [1] https://bugs.freedesktop.org/show_bug.cgi?id=75985#c32 [2] https://bugs.freedesktop.org/attachment.cgi?id=128640> According to Ilia Mirkin, the HDA controller is only present from MCP89 > onward, so do not touch config space on older GPUs. > > This quirk is limited to NVIDIA PCI devices with the VGA Controller > device class. This is expected to correspond to product configurations > where the NVIDIA GPU has connectors attached. Other products where the > device class is 3D Controller are expected to correspond to configurations > where the NVIDIA GPU is dedicated (dGPU) and has no connectors. > > It's sensible to avoid exposing the HDA controller on dGPU setups, > especially because we've seen cases where the PCI BARs are not set > up correctly by the platform in this case, causing Linux to log > errors if the device is visible. This assumption of device class > accurately corresponding to product configuration is true for 6 of 6 > laptops recently checked at the Endless lab, and there are also signs of > agreement checking the data from 74 previously tested products, however > Ilia Mirkin comments that he's seen cases where it is not true. Anyway, it > looks like this quirk should fix audio support for the majority of > affected users. > > This commit takes inspiration from an earlier patch by Daniel Drake. > > Link: https://devtalk.nvidia.com/default/topic/1024022 > Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=75985 > Cc: Aaron Plattner <aplattner at nvidia.com> > Cc: Peter Wu <peter at lekensteyn.nl> > Cc: Ilia Mirkin <imirkin at alum.mit.edu> > Cc: Karol Herbst <kherbst at redhat.com> > Cc: Maik Freudenberg <hhfeuer at gmx.de> > Signed-off-by: Lukas Wunner <lukas at wunner.de> > Tested-by: Daniel Drake <drake at endlessm.com> > --- > drivers/pci/quirks.c | 28 ++++++++++++++++++++++++++++ > include/linux/pci_ids.h | 1 + > 2 files changed, 29 insertions(+) > > Submitting Lukas's patch from over a year ago. > > It got held up before on patch dependencies (which are now all merged) > and also the concern around the device class assumption not being true > in all cases. However, there hasn't been any progress towards finding a > better approach, and we don't have any logs to hand from the cases where > this isn't true, so I think we should go with this approach which will > work in the (vast?) majority of cases. > > diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c > index 0f16acc323c6..52046b517e2e 100644 > --- a/drivers/pci/quirks.c > +++ b/drivers/pci/quirks.c > @@ -4971,6 +4971,34 @@ DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_AMD, PCI_ANY_ID, > DECLARE_PCI_FIXUP_CLASS_FINAL(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > PCI_CLASS_MULTIMEDIA_HD_AUDIO, 8, quirk_gpu_hda); > > +/* > + * Many laptop BIOSes hide the integrated HDA controller on NVIDIA GPUs > + * via a special bit. This prevents Linux from seeing and using it. > + * Unhide it here. > + * https://devtalk.nvidia.com/default/topic/1024022 > + */ > +static void quirk_nvidia_hda(struct pci_dev *gpu) > +{ > + u8 hdr_type; > + u32 val; > + > + /* there was no integrated HDA controller before MCP89 */ > + if (gpu->device < PCI_DEVICE_ID_NVIDIA_GEFORCE_320M) > + return; > + > + /* bit 25 at offset 0x488 hides or exposes the HDA controller */ > + pci_read_config_dword(gpu, 0x488, &val); > + pci_write_config_dword(gpu, 0x488, val | BIT(25)); > + > + /* the GPU becomes a multifunction device when the HDA is exposed */ > + pci_read_config_byte(gpu, PCI_HEADER_TYPE, &hdr_type); > + gpu->multifunction = !!(hdr_type & BIT(7)); > +} > +DECLARE_PCI_FIXUP_CLASS_HEADER(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); > +DECLARE_PCI_FIXUP_CLASS_RESUME_EARLY(PCI_VENDOR_ID_NVIDIA, PCI_ANY_ID, > + PCI_BASE_CLASS_DISPLAY, 16, quirk_nvidia_hda); > + > /* > * Some IDT switches incorrectly flag an ACS Source Validation error on > * completions for config read requests even though PCIe r4.0, sec > diff --git a/include/linux/pci_ids.h b/include/linux/pci_ids.h > index 70e86148cb1e..66898463b81f 100644 > --- a/include/linux/pci_ids.h > +++ b/include/linux/pci_ids.h > @@ -1336,6 +1336,7 @@ > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP78S_SMBUS 0x0752 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP77_IDE 0x0759 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP73_SMBUS 0x07D8 > +#define PCI_DEVICE_ID_NVIDIA_GEFORCE_320M 0x08A0 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP79_SMBUS 0x0AA2 > #define PCI_DEVICE_ID_NVIDIA_NFORCE_MCP89_SATA 0x0D85 > > -- > 2.20.1 >
Daniel Drake
2019-Jun-25 05:57 UTC
[Nouveau] [PATCH] PCI: Expose hidden NVIDIA HDA controllers
On Fri, Jun 14, 2019 at 4:03 AM Bjorn Helgaas <helgaas at kernel.org> wrote:> Is it possible that this works on Windows but not Linux because they > handle ACPI hotplug slightly differently? > > Martin did some nice debug [1] and found that _DSM, _PS0, and _PS3 > functions write the config bit at 0x488. The dmesg log [2] from > zigarrre seems to show that _OSC failed (which I *think* means we > won't use pciehp) and that there's a slot registered by acpiphp. > > Maybe this works on Windows via an ACPI hotplug event that runs AML to > flip the 0x488 bit and rescans the bus? That would make more sense to > me than the idea that the Nvidia driver does it. I could imagine the > driver flipping the bit, but the bus rescan seems like it would be out > of the driver's purview.Oh, I had missed that part of the conversation. I checked on the Acer Predator G3-572 and I was able to find ACPI code to manipulate the magic bit, however I can't see any linkage to _DSM methods, and the code looks like it would only be run on power-up. I modified the DSDT to avoid the codepaths that tweak the bit, booted Windows and confirmed that change had taken effect. Then I installed the nvidia driver and observed that the magic bit was being manipulated according to HDMI cable status. So I believe the nvidia Windows driver does not rely on ACPI for this to work. It presumably does it directly and causes rescans, as evil as that sounds. I added more details to the bug report.> The dmesg log also shows some _DSM warnings; are these correlated with > cable plug/unplug? Is there some acpiphp debug we can turn on to get > more visibility into hotplug events and how we handle them?I scattered a load of debug messages around the ACPI & PCIe hotplug code but nothing gets hit. I don't think this is architected to be handled by existing PCI hotplug mechanisms. I don't have any _DSM warnings on this product, even after connecting and disconnecting the HDMI cable. Thanks Daniel