Page Menu
Home
FreeBSD
Search
Configure Global Search
Log In
Files
F146686353
D18311.id.diff
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Mute Notifications
Flag For Later
Award Token
Size
1 KB
Referenced Files
None
Subscribers
None
D18311.id.diff
View Options
Index: head/sys/dev/acpica/acpi_ec.c
===================================================================
--- head/sys/dev/acpica/acpi_ec.c
+++ head/sys/dev/acpica/acpi_ec.c
@@ -362,7 +362,8 @@
ret = 0;
goto out;
- }
+ } else
+ ecdt = 0;
ret = ACPI_ID_PROBE(device_get_parent(dev), dev, ec_ids, NULL);
if (ret > 0)
@@ -382,6 +383,22 @@
if (ACPI_FAILURE(status))
params->uid = 0;
+ /*
+ * Check for a duplicate probe. This can happen when a probe via ECDT
+ * succeeded already. If this is a duplicate, disable this device.
+ *
+ * NB: It would seem device_disable would be sufficient to not get
+ * duplicated devices, and ENXIO isn't needed, however, device_probe() only
+ * checks DF_ENABLED at the start and so disabling it here is too late to
+ * prevent device_attach() from being called.
+ */
+ peer = devclass_get_device(acpi_ec_devclass, params->uid);
+ if (peer != NULL && device_is_alive(peer)) {
+ device_disable(dev);
+ ret = ENXIO;
+ goto out;
+ }
+
status = acpi_GetInteger(h, "_GLK", ¶ms->glk);
if (ACPI_FAILURE(status))
params->glk = 0;
@@ -421,16 +438,6 @@
/* Store the values we got from the namespace for attach. */
acpi_set_private(dev, params);
-
- /*
- * Check for a duplicate probe. This can happen when a probe via ECDT
- * succeeded already. If this is a duplicate, disable this device.
- */
- peer = devclass_get_device(acpi_ec_devclass, params->uid);
- if (peer == NULL || !device_is_alive(peer))
- ret = 0;
- else
- device_disable(dev);
if (buf.Pointer)
AcpiOsFree(buf.Pointer);
File Metadata
Details
Attached
Mime Type
text/plain
Expires
Thu, Mar 5, 5:31 PM (2 h, 40 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
29265931
Default Alt Text
D18311.id.diff (1 KB)
Attached To
Mode
D18311: Summary: acpi/ec: Fix regression caused by r340644
Attached
Detach File
Event Timeline
Log In to Comment