aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/acpi/bus.c32
1 files changed, 11 insertions, 21 deletions
diff --git a/drivers/acpi/bus.c b/drivers/acpi/bus.c
index 19e78fb0a8d1..2b08c3dc79da 100644
--- a/drivers/acpi/bus.c
+++ b/drivers/acpi/bus.c
@@ -450,14 +450,13 @@ int acpi_bus_receive_event(struct acpi_bus_event *event)
450 Notification Handling 450 Notification Handling
451 -------------------------------------------------------------------------- */ 451 -------------------------------------------------------------------------- */
452 452
453static int acpi_bus_check_device(struct acpi_device *device) 453static void acpi_bus_check_device(struct acpi_device *device)
454{ 454{
455 acpi_status status = 0; 455 acpi_status status;
456 struct acpi_device_status old_status; 456 struct acpi_device_status old_status;
457 457
458
459 if (!device) 458 if (!device)
460 return -EINVAL; 459 return;
461 460
462 old_status = device->status; 461 old_status = device->status;
463 462
@@ -467,15 +466,15 @@ static int acpi_bus_check_device(struct acpi_device *device)
467 */ 466 */
468 if (device->parent && !device->parent->status.present) { 467 if (device->parent && !device->parent->status.present) {
469 device->status = device->parent->status; 468 device->status = device->parent->status;
470 return 0; 469 return;
471 } 470 }
472 471
473 status = acpi_bus_get_status(device); 472 status = acpi_bus_get_status(device);
474 if (ACPI_FAILURE(status)) 473 if (ACPI_FAILURE(status))
475 return -ENODEV; 474 return;
476 475
477 if (STRUCT_TO_INT(old_status) == STRUCT_TO_INT(device->status)) 476 if (STRUCT_TO_INT(old_status) == STRUCT_TO_INT(device->status))
478 return 0; 477 return;
479 478
480 /* 479 /*
481 * Device Insertion/Removal 480 * Device Insertion/Removal
@@ -487,28 +486,20 @@ static int acpi_bus_check_device(struct acpi_device *device)
487 ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Device removal detected\n")); 486 ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Device removal detected\n"));
488 /* TBD: Handle device removal */ 487 /* TBD: Handle device removal */
489 } 488 }
490
491 return 0;
492} 489}
493 490
494static int acpi_bus_check_scope(struct acpi_device *device) 491static void acpi_bus_check_scope(struct acpi_device *device)
495{ 492{
496 int result = 0;
497
498 if (!device) 493 if (!device)
499 return -EINVAL; 494 return;
500 495
501 /* Status Change? */ 496 /* Status Change? */
502 result = acpi_bus_check_device(device); 497 acpi_bus_check_device(device);
503 if (result)
504 return result;
505 498
506 /* 499 /*
507 * TBD: Enumerate child devices within this device's scope and 500 * TBD: Enumerate child devices within this device's scope and
508 * run acpi_bus_check_device()'s on them. 501 * run acpi_bus_check_device()'s on them.
509 */ 502 */
510
511 return 0;
512} 503}
513 504
514static BLOCKING_NOTIFIER_HEAD(acpi_bus_notify_list); 505static BLOCKING_NOTIFIER_HEAD(acpi_bus_notify_list);
@@ -531,7 +522,6 @@ EXPORT_SYMBOL_GPL(unregister_acpi_bus_notifier);
531 */ 522 */
532static void acpi_bus_notify(acpi_handle handle, u32 type, void *data) 523static void acpi_bus_notify(acpi_handle handle, u32 type, void *data)
533{ 524{
534 int result = 0;
535 struct acpi_device *device = NULL; 525 struct acpi_device *device = NULL;
536 struct acpi_driver *driver; 526 struct acpi_driver *driver;
537 527
@@ -547,7 +537,7 @@ static void acpi_bus_notify(acpi_handle handle, u32 type, void *data)
547 switch (type) { 537 switch (type) {
548 538
549 case ACPI_NOTIFY_BUS_CHECK: 539 case ACPI_NOTIFY_BUS_CHECK:
550 result = acpi_bus_check_scope(device); 540 acpi_bus_check_scope(device);
551 /* 541 /*
552 * TBD: We'll need to outsource certain events to non-ACPI 542 * TBD: We'll need to outsource certain events to non-ACPI
553 * drivers via the device manager (device.c). 543 * drivers via the device manager (device.c).
@@ -555,7 +545,7 @@ static void acpi_bus_notify(acpi_handle handle, u32 type, void *data)
555 break; 545 break;
556 546
557 case ACPI_NOTIFY_DEVICE_CHECK: 547 case ACPI_NOTIFY_DEVICE_CHECK:
558 result = acpi_bus_check_device(device); 548 acpi_bus_check_device(device);
559 /* 549 /*
560 * TBD: We'll need to outsource certain events to non-ACPI 550 * TBD: We'll need to outsource certain events to non-ACPI
561 * drivers via the device manager (device.c). 551 * drivers via the device manager (device.c).