acpi_button: Fix several issues with multiple devices.

- On some hardware, both the fixed function FADT as well as the
  device-based power interfaces are present. In such a case we
  would fail to publish one or the other, depending on which was
  enumerated first, since we'd always attempt to publish the same
  name regardless. Now we differentiate the device name for fixed vs
  device.
- Only enable fixed function for actual fixed devices.
- Improve tracing.
This commit is contained in:
Rene Gollent 2014-08-24 10:12:19 -04:00
parent 79c1d45cee
commit 74f7623716

View File

@ -106,6 +106,7 @@ acpi_button_init_device(void *_cookie, void **cookie)
sDeviceManager->put_node(parent); sDeviceManager->put_node(parent);
device->fixed = strcmp(hid, "PNP0C0C") != 0 && strcmp(hid, "PNP0C0E") != 0; device->fixed = strcmp(hid, "PNP0C0C") != 0 && strcmp(hid, "PNP0C0E") != 0;
TRACE("Device found, hid: %s, fixed: %d\n", hid, device->fixed);
if (strcmp(hid, "PNP0C0C") == 0 || strcmp(hid, "ACPI_FPB") == 0) if (strcmp(hid, "PNP0C0C") == 0 || strcmp(hid, "ACPI_FPB") == 0)
device->type = ACPI_EVENT_POWER_BUTTON; device->type = ACPI_EVENT_POWER_BUTTON;
else if (strcmp(hid, "PNP0C0E") == 0 || strcmp(hid, "ACPI_FSB") == 0) else if (strcmp(hid, "PNP0C0E") == 0 || strcmp(hid, "ACPI_FSB") == 0)
@ -117,11 +118,15 @@ acpi_button_init_device(void *_cookie, void **cookie)
if (device->fixed) { if (device->fixed) {
sAcpi->reset_fixed_event(device->type); sAcpi->reset_fixed_event(device->type);
TRACE("Installing fixed handler for type %" B_PRIu32 "\n",
device->type);
if (sAcpi->install_fixed_event_handler(device->type, if (sAcpi->install_fixed_event_handler(device->type,
acpi_button_fixed_handler, device) != B_OK) { acpi_button_fixed_handler, device) != B_OK) {
ERROR("can't install notify handler\n"); ERROR("can't install fixed handler\n");
} }
} else { } else {
TRACE("Installing notify handler for type %" B_PRIu32 "\n",
device->type);
if (device->acpi->install_notify_handler(device->acpi_cookie, if (device->acpi->install_notify_handler(device->acpi_cookie,
ACPI_DEVICE_NOTIFY, acpi_button_notify_handler, device) != B_OK) { ACPI_DEVICE_NOTIFY, acpi_button_notify_handler, device) != B_OK) {
ERROR("can't install notify handler\n"); ERROR("can't install notify handler\n");
@ -154,6 +159,7 @@ acpi_button_open(void *_cookie, const char *path, int flags, void** cookie)
{ {
acpi_button_device_info *device = (acpi_button_device_info *)_cookie; acpi_button_device_info *device = (acpi_button_device_info *)_cookie;
if (device->fixed)
sAcpi->enable_fixed_event(device->type); sAcpi->enable_fixed_event(device->type);
*cookie = device; *cookie = device;
@ -271,7 +277,7 @@ acpi_button_support(device_node *parent)
return 0.0; return 0.0;
} }
TRACE("acpi_button_support button device found\n"); TRACE("acpi_button_support button device found: %s\n", hid);
return 0.6; return 0.6;
} }
@ -319,12 +325,18 @@ acpi_button_register_child_devices(void *_cookie)
sDeviceManager->put_node(parent); sDeviceManager->put_node(parent);
status_t status = B_ERROR; status_t status = B_ERROR;
if (strcmp(hid, "PNP0C0C") == 0 || strcmp(hid, "ACPI_FPB") == 0) { if (strcmp(hid, "PNP0C0C") == 0) {
status = sDeviceManager->publish_device(node, status = sDeviceManager->publish_device(node,
"power/button/power", ACPI_BUTTON_DEVICE_MODULE_NAME); "power/button/power", ACPI_BUTTON_DEVICE_MODULE_NAME);
} else if (strcmp(hid, "PNP0C0E") == 0 || strcmp(hid, "ACPI_FSB") == 0) { } else if (strcmp(hid, "ACPI_FPB") == 0) {
status = sDeviceManager->publish_device(node,
"power/button/power_fixed", ACPI_BUTTON_DEVICE_MODULE_NAME);
} else if (strcmp(hid, "PNP0C0E") == 0) {
status = sDeviceManager->publish_device(node, "power/button/sleep", status = sDeviceManager->publish_device(node, "power/button/sleep",
ACPI_BUTTON_DEVICE_MODULE_NAME); ACPI_BUTTON_DEVICE_MODULE_NAME);
} else if ( strcmp(hid, "ACPI_FSB") == 0) {
status = sDeviceManager->publish_device(node,
"power/button/sleep_fixed", ACPI_BUTTON_DEVICE_MODULE_NAME);
} }
return status; return status;