aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/acpi/scan.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/drivers/acpi/scan.c b/drivers/acpi/scan.c
index 954bd01f295a..2c4cac576a7e 100644
--- a/drivers/acpi/scan.c
+++ b/drivers/acpi/scan.c
@@ -1400,10 +1400,10 @@ static acpi_status acpi_bus_check_add(acpi_handle handle, u32 lvl,
1400 void *context, void **return_value) 1400 void *context, void **return_value)
1401{ 1401{
1402 struct acpi_bus_ops *ops = context; 1402 struct acpi_bus_ops *ops = context;
1403 struct acpi_device *device = NULL;
1404 acpi_status status;
1405 int type; 1403 int type;
1406 unsigned long long sta; 1404 unsigned long long sta;
1405 struct acpi_device *device;
1406 acpi_status status;
1407 int result; 1407 int result;
1408 1408
1409 result = acpi_bus_type_and_status(handle, &type, &sta); 1409 result = acpi_bus_type_and_status(handle, &type, &sta);
@@ -1414,13 +1414,16 @@ static acpi_status acpi_bus_check_add(acpi_handle handle, u32 lvl,
1414 !(sta & ACPI_STA_DEVICE_FUNCTIONING)) 1414 !(sta & ACPI_STA_DEVICE_FUNCTIONING))
1415 return AE_CTRL_DEPTH; 1415 return AE_CTRL_DEPTH;
1416 1416
1417 if (ops->acpi_op_add) 1417 /*
1418 status = acpi_add_single_object(&device, handle, type, sta, 1418 * We may already have an acpi_device from a previous enumeration. If
1419 ops); 1419 * so, we needn't add it again, but we may still have to start it.
1420 else 1420 */
1421 status = acpi_bus_get_device(handle, &device); 1421 device = NULL;
1422 acpi_bus_get_device(handle, &device);
1423 if (ops->acpi_op_add && !device)
1424 acpi_add_single_object(&device, handle, type, sta, ops);
1422 1425
1423 if (ACPI_FAILURE(status)) 1426 if (!device)
1424 return AE_CTRL_DEPTH; 1427 return AE_CTRL_DEPTH;
1425 1428
1426 if (ops->acpi_op_start && !(ops->acpi_op_add)) { 1429 if (ops->acpi_op_start && !(ops->acpi_op_add)) {