From 86f29f0a04dd369eb1cdb8c34cc1e9f7422adf33 Mon Sep 17 00:00:00 2001 From: Alexey Starikovskiy Date: Tue, 14 Aug 2007 01:03:42 -0400 Subject: [PATCH] --- yaml --- r: 63980 b: refs/heads/master c: c019b1933015ee31366eeaa085bad3ee9516991c h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/drivers/acpi/ec.c | 17 +++++++++++++++++ 2 files changed, 18 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index b456f99d1e85..051a9ac25a18 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 39d3520c92cf7a28c07229ca00cc35a1e8026c77 +refs/heads/master: c019b1933015ee31366eeaa085bad3ee9516991c diff --git a/trunk/drivers/acpi/ec.c b/trunk/drivers/acpi/ec.c index 2300d81bbc4e..56bee9e065cf 100644 --- a/trunk/drivers/acpi/ec.c +++ b/trunk/drivers/acpi/ec.c @@ -651,6 +651,19 @@ static struct acpi_ec *make_acpi_ec(void) return ec; } +static acpi_status +acpi_ec_register_query_methods(acpi_handle handle, u32 level, + void *context, void **return_value) +{ + struct acpi_namespace_node *node = handle; + struct acpi_ec *ec = context; + int value = 0; + if (sscanf(node->name.ascii, "_Q%x", &value) == 1) { + acpi_ec_add_query_handler(ec, value, handle, NULL, NULL); + } + return AE_OK; +} + static acpi_status ec_parse_device(acpi_handle handle, u32 Level, void *context, void **retval) { @@ -668,6 +681,10 @@ ec_parse_device(acpi_handle handle, u32 Level, void *context, void **retval) if (ACPI_FAILURE(status)) return status; + /* Find and register all query methods */ + acpi_walk_namespace(ACPI_TYPE_METHOD, handle, 1, + acpi_ec_register_query_methods, ec, NULL); + /* Use the global lock for all EC transactions? */ acpi_evaluate_integer(handle, "_GLK", NULL, &ec->global_lock);