Re: acpi_device_notify() binding devices that don't seem like they should be bound

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, Dec 10, 2020 at 11:46 PM Daniel Scally <djrscally@xxxxxxxxx> wrote:
>
>
> On 10/12/2020 16:59, Rafael J. Wysocki wrote:
> > On Thursday, December 10, 2020 5:07:56 PM CET Daniel Scally wrote:
> >> On 10/12/2020 16:05, Rafael J. Wysocki wrote:
> >>> All the adevs with matching _ADR also have both _STA and _HID
> >>> unfortunately. Sorry; let me stop half-arsing this and show you
> >>> something useful:
> >>>
> >>> [    0.219953] acpi_find_child_device(PNP0A08:00, 0x00, false)
> >>> [    0.220818] INT3472:00: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220821] INT3472:01: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220870] INT3472:02: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220892] INT3472:03: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220916] INT3472:04: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220941] INT3472:05: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220965] INT3472:06: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> [    0.220990] INT3472:07: _STA 0x00, _ADR=0x00000000, _HID=INT3472
> >>> These will be ignored with -ENODEV.
> >>>
> >>>> [    0.221038] INT3472:08: _STA 0x0f, _ADR=0x00000000, _HID=INT3472
> >>> For this acpi_find_child_device() will return FIND_CHILD_MIN_SCORE if
> >>> I'm not mistaken.
> >> It does - this is the one that binds, being the first.
> >>>> [    0.221051] OVTI5648:00: _STA 0x0f, _ADR=0x00000000, _HID=OVTI5648
> >>>> [    0.221061] INT3472:09: _STA 0x0f, _ADR=0x00000000, _HID=INT3472
> >>>> [    0.221070] OVTI2680:00: _STA 0x0f, _ADR=0x00000000, _HID=OVTI2680
> >>> As well as for the three above.
> >>>
> >>>> [    0.221079] INT3471:00: _STA 0x00, _ADR=0x00000000, _HID=INT3471
> >>>> [    0.221105] INT33BE:00: _STA 0x00, _ADR=0x00000000, _HID=INT33BE
> >>>> [    0.221130] INT3471:01: _STA 0x00, _ADR=0x00000000, _HID=INT3471
> >>>> [    0.221156] INT33BE:01: _STA 0x00, _ADR=0x00000000, _HID=INT33BE
> >>> And the rest will be ignored.
> >>>
> >>>> That's the debug output I included for each adev that's assessed as a
> >>>> child of PNP0A08:00. _STA, _ADR and _HID present for all, _ADR 0x00 for
> >>>> all, _STA 0x0f for the 2 sensors and their PMIC's and 0x00 for the rest.
> >>>> The same situation holds on both of my devices.
> >>> So in fact we don't want to have an ACPI companion for (PNP0A08:00,
> >>> 0x00, false).
> >> Yeah, I think that's right
> >>> This is a hostbridge special case and let me think about this for a while.
> >> Sure - thanks very much for your help.
> > I've come up with the following patch.
> >
> > Please let me know if it works for you.
> >
> > ---
> > Index: linux-pm/drivers/pci/pci-acpi.c
> > ===================================================================
> > --- linux-pm.orig/drivers/pci/pci-acpi.c
> > +++ linux-pm/drivers/pci/pci-acpi.c
> > @@ -1162,14 +1162,32 @@ void acpi_pci_remove_bus(struct pci_bus
> >  static struct acpi_device *acpi_pci_find_companion(struct device *dev)
> >  {
> >       struct pci_dev *pci_dev = to_pci_dev(dev);
> > +     struct acpi_device *adev;
> >       bool check_children;
> >       u64 addr;
> >
> >       check_children = pci_is_bridge(pci_dev);
> >       /* Please ref to ACPI spec for the syntax of _ADR */
> >       addr = (PCI_SLOT(pci_dev->devfn) << 16) | PCI_FUNC(pci_dev->devfn);
> > -     return acpi_find_child_device(ACPI_COMPANION(dev->parent), addr,
> > +     adev = acpi_find_child_device(ACPI_COMPANION(dev->parent), addr,
> >                                     check_children);
> > +     /*
> > +      * There may be ACPI device objects in the ACPI namesoace that are
> > +      * children of the device object representing the host bridge, but don't
> > +      * represent PCI devices.  Both _HID and _ADR may be present for them,
> > +      * even though that is against the specification (for example, see
> > +      * Section 6.1 of ACPI 6.3), but in many cases the _ADR returns 0 which
> > +      * appears to indicate that they should not be taken into consideration
> > +      * as potential companions of PCI devices on the root bus.
> > +      *
> > +      * To catch this special case, disregard the returned device object if
> > +      * it has a valid _HID, addr is 0 and the PCI device at hand is on the
> > +      * root bus.
> > +      */
> > +     if (adev->pnp.type.platform_id && !addr && !pci_dev->bus->parent)
> > +             return NULL;
> > +
> > +     return adev;
> >  }
> >
> >  /**
> >
> Thanks - this needs to check adev for NULL too; acpi_find_child_device()
> does return that sometimes.

Yes, it does, sorry for the mistake.

> When changed to:
>
> +       if (adev && adev->pnp.type.platform_id && !addr && !pci_dev->bus->parent)
> +               return NULL;
>
> Then it boots properly, and fixes the original problem.  Also;
> s/namesoace/namespace in the comment.

Right.

> Really appreciate the help - thank you!

YW

Let me fix the patch and post it "officially".



[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux