Commit c9b57130 authored by Len Brown's avatar Len Brown Committed by Len Brown

[ACPI] acpi_bus_register_driver() now return a count

consistent with pnp_register_driver() and pci_register_driver()

All existing callers of acpi_bus_register_driver() either ignore the
return value or check only for negative (error) return values.
Signed-off-by: default avatarBjorn Helgaas <bjorn.helgaas@hp.com>
parent a2653f64
...@@ -370,6 +370,7 @@ acpi_bus_driver_init ( ...@@ -370,6 +370,7 @@ acpi_bus_driver_init (
static int acpi_driver_attach(struct acpi_driver * drv) static int acpi_driver_attach(struct acpi_driver * drv)
{ {
struct list_head * node, * next; struct list_head * node, * next;
int count = 0;
ACPI_FUNCTION_TRACE("acpi_driver_attach"); ACPI_FUNCTION_TRACE("acpi_driver_attach");
...@@ -384,6 +385,7 @@ static int acpi_driver_attach(struct acpi_driver * drv) ...@@ -384,6 +385,7 @@ static int acpi_driver_attach(struct acpi_driver * drv)
if (!acpi_bus_match(dev, drv)) { if (!acpi_bus_match(dev, drv)) {
if (!acpi_bus_driver_init(dev, drv)) { if (!acpi_bus_driver_init(dev, drv)) {
atomic_inc(&drv->references); atomic_inc(&drv->references);
count++;
ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Found driver [%s] for device [%s]\n", ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Found driver [%s] for device [%s]\n",
drv->name, dev->pnp.bus_id)); drv->name, dev->pnp.bus_id));
} }
...@@ -391,7 +393,7 @@ static int acpi_driver_attach(struct acpi_driver * drv) ...@@ -391,7 +393,7 @@ static int acpi_driver_attach(struct acpi_driver * drv)
spin_lock(&acpi_device_lock); spin_lock(&acpi_device_lock);
} }
spin_unlock(&acpi_device_lock); spin_unlock(&acpi_device_lock);
return_VALUE(0); return_VALUE(count);
} }
static int acpi_driver_detach(struct acpi_driver * drv) static int acpi_driver_detach(struct acpi_driver * drv)
...@@ -422,28 +424,30 @@ static int acpi_driver_detach(struct acpi_driver * drv) ...@@ -422,28 +424,30 @@ static int acpi_driver_detach(struct acpi_driver * drv)
* acpi_bus_register_driver * acpi_bus_register_driver
* ------------------------ * ------------------------
* Registers a driver with the ACPI bus. Searches the namespace for all * Registers a driver with the ACPI bus. Searches the namespace for all
* devices that match the driver's criteria and binds. * devices that match the driver's criteria and binds. Returns the
* number of devices that were claimed by the driver, or a negative
* error status for failure.
*/ */
int int
acpi_bus_register_driver ( acpi_bus_register_driver (
struct acpi_driver *driver) struct acpi_driver *driver)
{ {
int error = 0; int count;
ACPI_FUNCTION_TRACE("acpi_bus_register_driver"); ACPI_FUNCTION_TRACE("acpi_bus_register_driver");
if (acpi_disabled) if (acpi_disabled)
return_VALUE(-ENODEV); return_VALUE(-ENODEV);
if (driver) { if (!driver)
return_VALUE(-EINVAL);
spin_lock(&acpi_device_lock); spin_lock(&acpi_device_lock);
list_add_tail(&driver->node, &acpi_bus_drivers); list_add_tail(&driver->node, &acpi_bus_drivers);
spin_unlock(&acpi_device_lock); spin_unlock(&acpi_device_lock);
acpi_driver_attach(driver); count = acpi_driver_attach(driver);
} else
error = -EINVAL;
return_VALUE(error); return_VALUE(count);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment