From: "Rafael J. Wysocki" <rjw@rjwysocki.net>
To: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Cc: "Rafael J. Wysocki" <rafael@kernel.org>,
Hans de Goede <hdegoede@redhat.com>,
ACPI Devel Mailing List <linux-acpi@vger.kernel.org>,
Mika Westerberg <mika.westerberg@linux.intel.com>,
"Rafael J. Wysocki" <rafael.j.wysocki@intel.com>,
Andy Shevchenko <andriy.shevchenko@linux.intel.com>,
"Bossart, Pierre-louis" <pierre-louis.bossart@intel.com>
Subject: Re: ACPI scan regression -> Boot fail on Cherrytrail w/ 5.11-rc3
Date: Fri, 15 Jan 2021 20:01:19 +0100 [thread overview]
Message-ID: <2803525.PQFCXvBIof@kreacher> (raw)
In-Reply-To: <8b316bf8-6a5c-c6d4-c0db-304ec529c805@linux.intel.com>
On Friday, January 15, 2021 5:41:57 PM CET Pierre-Louis Bossart wrote:
>
> >>> [ 0.516336] ACPI: \_SB_.PCI0.BRCM: Dependencies found
> >>
> >> Ah, that is enlightening, that is not supposed to happen, that device
> >> has both an _ADR and an _HID method which is not allowed according
> >> to the spec.
>
> it's not an uncommon issue for audio codecs, here's three examples:
>
> Device (RTK1)
> {
> Name (_ADR, Zero) // _ADR: Address
> Name (_HID, "10EC5670") // _HID: Hardware ID
> Name (_CID, "10EC5670") // _CID: Compatible ID
> Name (_DDN, "ALC5642") // _DDN: DOS Device Name
>
> Device (MAXM)
> {
> Name (_ADR, Zero) // _ADR: Address
> Name (_HID, "193C9890") // _HID: Hardware ID
> Name (_CID, "193C9890") // _CID: Compatible ID
> Name (_DDN, "Maxim 98090 Codec ") // _DDN: DOS Device Name
>
> Device (TISW)
> {
> Name (_ADR, Zero) // _ADR: Address
> Name (_HID, "104C227E") // _HID: Hardware ID
> Name (_CID, "104C227E") // _CID: Compatible ID
>
> It's been that way for years...
>
> >> Can you try a clean 5.11 kernel (so none of the previous
> >> debug patches) with the following change added:
> >>
> >> diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c
> >> index 1f27f74cc83c..93954ac3bfcc 100644
> >> --- a/drivers/acpi/scan.c
> >> +++ b/drivers/acpi/scan.c
> >> @@ -1854,7 +1854,8 @@ static u32 acpi_scan_check_dep(acpi_handle handle)
> >> * 2. ACPI nodes describing USB ports.
> >> * Still, checking for _HID catches more then just these cases ...
> >> */
> >> - if (!acpi_has_method(handle, "_DEP") || !acpi_has_method(handle, "_HID"))
> >> + if (!acpi_has_method(handle, "_DEP") || !acpi_has_method(handle, "_HID") ||
> >> + acpi_has_method(handle, "_ADR"))
> >> return 0;
> >>
> >> status = acpi_evaluate_reference(handle, "_DEP", NULL, &dep_devices);
> >>
> >>
> >>> [ 0.517490] ACPI: \_SB_.PCI0.LNPW: Dependencies found
> >>
> >> And idem. for this one.
> >>
> >> That might very well fix this.
>
> Nope, no luck with this patch. boot still stuck.
OK, thanks!
Now, there is a theory to test and some more debug work to do.
First, the kernel should not crash outright if some ACPI device objects are
missing which evidently happens here. There may be some problems resulting
from that, but the crash indicates a code bug in the kernel.
Apparently, something expects the device objects to be there so badly, that it
crashes right away when they aren't there. One of the issues that may cause
that to happen are mistakes around the acpi_bus_get_device() usage and I found
two of them, so below is a patch to test.
Please apply to plain 5.11-rc3 (or -rc4 when it is out) and see if that makes
any difference.
---
drivers/acpi/scan.c | 3 +--
drivers/usb/core/usb-acpi.c | 3 +--
2 files changed, 2 insertions(+), 4 deletions(-)
Index: linux-pm/drivers/acpi/scan.c
===================================================================
--- linux-pm.orig/drivers/acpi/scan.c
+++ linux-pm/drivers/acpi/scan.c
@@ -2120,8 +2120,7 @@ void acpi_walk_dep_device_list(acpi_hand
mutex_lock(&acpi_dep_list_lock);
list_for_each_entry_safe(dep, tmp, &acpi_dep_list, node) {
if (dep->supplier == handle) {
- acpi_bus_get_device(dep->consumer, &adev);
- if (!adev)
+ if (acpi_bus_get_device(dep->consumer, &adev))
continue;
adev->dep_unmet--;
Index: linux-pm/drivers/usb/core/usb-acpi.c
===================================================================
--- linux-pm.orig/drivers/usb/core/usb-acpi.c
+++ linux-pm/drivers/usb/core/usb-acpi.c
@@ -163,10 +163,9 @@ usb_acpi_get_companion_for_port(struct u
} else {
parent_handle = usb_get_hub_port_acpi_handle(udev->parent,
udev->portnum);
- if (!parent_handle)
+ if (!parent_handle || acpi_bus_get_device(parent_handle, &adev))
return NULL;
- acpi_bus_get_device(parent_handle, &adev);
port1 = port_dev->portnum;
}
next prev parent reply other threads:[~2021-01-15 19:02 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-01-14 21:55 ACPI scan regression -> Boot fail on Cherrytrail w/ 5.11-rc3 Pierre-Louis Bossart
2021-01-14 23:34 ` Hans de Goede
2021-01-15 0:49 ` Pierre-Louis Bossart
2021-01-15 8:54 ` Hans de Goede
2021-01-15 13:38 ` Rafael J. Wysocki
2021-01-15 13:54 ` Rafael J. Wysocki
2021-01-15 14:52 ` Pierre-Louis Bossart
2021-01-15 14:55 ` Rafael J. Wysocki
2021-01-15 15:09 ` Pierre-Louis Bossart
2021-01-15 15:22 ` Rafael J. Wysocki
2021-01-15 15:38 ` Pierre-Louis Bossart
2021-01-15 16:05 ` Hans de Goede
2021-01-15 16:22 ` Rafael J. Wysocki
2021-01-15 16:41 ` Pierre-Louis Bossart
2021-01-15 19:01 ` Rafael J. Wysocki [this message]
2021-01-15 19:06 ` Rafael J. Wysocki
2021-01-15 20:48 ` Hans de Goede
2021-01-15 21:57 ` Hans de Goede
[not found] ` <56b732f4-9a24-688e-7cc7-6c2522d173c9@linux.intel.com>
2021-01-16 11:18 ` Hans de Goede
2021-01-16 12:26 ` Hans de Goede
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=2803525.PQFCXvBIof@kreacher \
--to=rjw@rjwysocki.net \
--cc=andriy.shevchenko@linux.intel.com \
--cc=hdegoede@redhat.com \
--cc=linux-acpi@vger.kernel.org \
--cc=mika.westerberg@linux.intel.com \
--cc=pierre-louis.bossart@intel.com \
--cc=pierre-louis.bossart@linux.intel.com \
--cc=rafael.j.wysocki@intel.com \
--cc=rafael@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox