Commit 614d7426 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

Merge branch 'acpi-hotplug'

* acpi-hotplug:
  ACPI / scan: Set flags.match_driver in acpi_bus_scan_fixed()
  ACPI / PCI root: Clear driver_data before failing enumeration
  ACPI / hotplug: Fix PCI host bridge hot removal
  ACPI / hotplug: Fix acpi_bus_get_device() return value check
parents f86e7bc9 88346167
...@@ -575,6 +575,7 @@ static int acpi_pci_root_add(struct acpi_device *device, ...@@ -575,6 +575,7 @@ static int acpi_pci_root_add(struct acpi_device *device,
dev_err(&device->dev, dev_err(&device->dev,
"Bus %04x:%02x not present in PCI namespace\n", "Bus %04x:%02x not present in PCI namespace\n",
root->segment, (unsigned int)root->secondary.start); root->segment, (unsigned int)root->secondary.start);
device->driver_data = NULL;
result = -ENODEV; result = -ENODEV;
goto end; goto end;
} }
......
...@@ -289,24 +289,17 @@ void acpi_bus_device_eject(void *data, u32 ost_src) ...@@ -289,24 +289,17 @@ void acpi_bus_device_eject(void *data, u32 ost_src)
{ {
struct acpi_device *device = data; struct acpi_device *device = data;
acpi_handle handle = device->handle; acpi_handle handle = device->handle;
struct acpi_scan_handler *handler;
u32 ost_code = ACPI_OST_SC_NON_SPECIFIC_FAILURE; u32 ost_code = ACPI_OST_SC_NON_SPECIFIC_FAILURE;
int error; int error;
lock_device_hotplug(); lock_device_hotplug();
mutex_lock(&acpi_scan_lock); mutex_lock(&acpi_scan_lock);
handler = device->handler;
if (!handler || !handler->hotplug.enabled) {
put_device(&device->dev);
goto err_support;
}
if (ost_src == ACPI_NOTIFY_EJECT_REQUEST) if (ost_src == ACPI_NOTIFY_EJECT_REQUEST)
acpi_evaluate_hotplug_ost(handle, ACPI_NOTIFY_EJECT_REQUEST, acpi_evaluate_hotplug_ost(handle, ACPI_NOTIFY_EJECT_REQUEST,
ACPI_OST_SC_EJECT_IN_PROGRESS, NULL); ACPI_OST_SC_EJECT_IN_PROGRESS, NULL);
if (handler->hotplug.mode == AHM_CONTAINER) if (device->handler && device->handler->hotplug.mode == AHM_CONTAINER)
kobject_uevent(&device->dev.kobj, KOBJ_OFFLINE); kobject_uevent(&device->dev.kobj, KOBJ_OFFLINE);
error = acpi_scan_hot_remove(device); error = acpi_scan_hot_remove(device);
...@@ -411,8 +404,7 @@ static void acpi_hotplug_notify_cb(acpi_handle handle, u32 type, void *data) ...@@ -411,8 +404,7 @@ static void acpi_hotplug_notify_cb(acpi_handle handle, u32 type, void *data)
break; break;
case ACPI_NOTIFY_EJECT_REQUEST: case ACPI_NOTIFY_EJECT_REQUEST:
acpi_handle_debug(handle, "ACPI_NOTIFY_EJECT_REQUEST event\n"); acpi_handle_debug(handle, "ACPI_NOTIFY_EJECT_REQUEST event\n");
status = acpi_bus_get_device(handle, &adev); if (acpi_bus_get_device(handle, &adev))
if (ACPI_FAILURE(status))
goto err_out; goto err_out;
get_device(&adev->dev); get_device(&adev->dev);
...@@ -1997,6 +1989,7 @@ static int acpi_bus_scan_fixed(void) ...@@ -1997,6 +1989,7 @@ static int acpi_bus_scan_fixed(void)
if (result) if (result)
return result; return result;
device->flags.match_driver = true;
result = device_attach(&device->dev); result = device_attach(&device->dev);
if (result < 0) if (result < 0)
return result; return result;
...@@ -2013,6 +2006,7 @@ static int acpi_bus_scan_fixed(void) ...@@ -2013,6 +2006,7 @@ static int acpi_bus_scan_fixed(void)
if (result) if (result)
return result; return result;
device->flags.match_driver = true;
result = device_attach(&device->dev); result = device_attach(&device->dev);
} }
......
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