Module Name: src Committed By: jmcneill Date: Mon Dec 30 11:44:16 UTC 2024
Modified Files: src/sys/dev/acpi: acpi.c acpi_i2c.c Log Message: acpi: Ensure that non-child I2C HID devices are properly claimed. To generate a diff of this commit: cvs rdiff -u -r1.301 -r1.302 src/sys/dev/acpi/acpi.c cvs rdiff -u -r1.17 -r1.18 src/sys/dev/acpi/acpi_i2c.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/acpi/acpi.c diff -u src/sys/dev/acpi/acpi.c:1.301 src/sys/dev/acpi/acpi.c:1.302 --- src/sys/dev/acpi/acpi.c:1.301 Thu Dec 19 14:19:53 2024 +++ src/sys/dev/acpi/acpi.c Mon Dec 30 11:44:16 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: acpi.c,v 1.301 2024/12/19 14:19:53 riastradh Exp $ */ +/* $NetBSD: acpi.c,v 1.302 2024/12/30 11:44:16 jmcneill Exp $ */ /*- * Copyright (c) 2003, 2007 The NetBSD Foundation, Inc. @@ -100,7 +100,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.301 2024/12/19 14:19:53 riastradh Exp $"); +__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.302 2024/12/30 11:44:16 jmcneill Exp $"); #include "pci.h" #include "opt_acpi.h" @@ -1058,6 +1058,11 @@ acpi_rescan_node(struct acpi_softc *sc, } } + /* Dependency scanning may have claimed this device. */ + if (ad->ad_device != NULL) { + return; + } + aa.aa_node = ad; aa.aa_iot = sc->sc_iot; aa.aa_memt = sc->sc_memt; Index: src/sys/dev/acpi/acpi_i2c.c diff -u src/sys/dev/acpi/acpi_i2c.c:1.17 src/sys/dev/acpi/acpi_i2c.c:1.18 --- src/sys/dev/acpi/acpi_i2c.c:1.17 Sat Dec 14 12:52:39 2024 +++ src/sys/dev/acpi/acpi_i2c.c Mon Dec 30 11:44:16 2024 @@ -1,4 +1,4 @@ -/* $NetBSD: acpi_i2c.c,v 1.17 2024/12/14 12:52:39 jmcneill Exp $ */ +/* $NetBSD: acpi_i2c.c,v 1.18 2024/12/30 11:44:16 jmcneill Exp $ */ /*- * Copyright (c) 2017, 2021 The NetBSD Foundation, Inc. @@ -32,7 +32,7 @@ #include "iic.h" #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: acpi_i2c.c,v 1.17 2024/12/14 12:52:39 jmcneill Exp $"); +__KERNEL_RCSID(0, "$NetBSD: acpi_i2c.c,v 1.18 2024/12/30 11:44:16 jmcneill Exp $"); #include <sys/device.h> @@ -189,6 +189,8 @@ acpi_enter_i2chid_devs(device_t dev, str i2cc.i2c_addr != 0 && i2cc.res_src == devnode) { aprint_debug_dev(dev, "claiming %s\n", ad->ad_name); + ad->ad_device = dev; + acpi_claim_childdevs(dev, ad); acpi_enter_i2c_device(ad, array); } }