summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-04-17 01:20:48 +0200
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-04-19 22:57:04 +0200
commitc381fc3a1bbfc9d780048a0b94afd162e4c3815b (patch)
treef4499d7a1cf594caed95fc43dea3b5d634e5788b
parentf5beabfe61794d9a9d9549d387cda2bffd81e504 (diff)
downloadtalos-obmc-linux-c381fc3a1bbfc9d780048a0b94afd162e4c3815b.tar.gz
talos-obmc-linux-c381fc3a1bbfc9d780048a0b94afd162e4c3815b.zip
ACPI / scan: Avoid enumerating devices more than once
acpi_bus_attach() does not check the visited flag for devices that have been enumerated already and some of them may be enumerated for multiple times as a result, because some callers of acpi_bus_scan() don't check the visited flag either. For this reason, modify acpi_bus_attach() to check the visited flag and avoid enumerating devices that have already been enumerated. Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com> Reviewed-by: Joey Lee <jlee@suse.com>
-rw-r--r--drivers/acpi/scan.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c
index f74bc0d28692..c26931067415 100644
--- a/drivers/acpi/scan.c
+++ b/drivers/acpi/scan.c
@@ -1840,6 +1840,8 @@ static void acpi_bus_attach(struct acpi_device *device)
device->flags.power_manageable = 0;
device->flags.initialized = true;
+ } else if (device->flags.visited) {
+ goto ok;
}
ret = acpi_scan_attach_handler(device);
OpenPOWER on IntegriCloud