Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 350921
b: refs/heads/master
c: ef85bdb
h: refs/heads/master
i:
  350919: 5aab871
v: v3
  • Loading branch information
Rafael J. Wysocki committed Jan 17, 2013
1 parent 261c7c9 commit 65a42a5
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 33 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 8bc5053bcdff09a6d1c6a61a79a9014884aa0a14
refs/heads/master: ef85bdbec444b42775a18580c6bfe1307a63ef0f
4 changes: 3 additions & 1 deletion trunk/drivers/acpi/internal.h
Original file line number Diff line number Diff line change
Expand Up @@ -50,8 +50,10 @@ void acpi_free_ids(struct acpi_device *device);
Power Resource
-------------------------------------------------------------------------- */
int acpi_power_init(void);
void acpi_power_resources_list_add(acpi_handle handle, struct list_head *list);
void acpi_power_resources_list_free(struct list_head *list);
acpi_status acpi_extract_power_resources(union acpi_object *package,
unsigned int start,
struct list_head *list);
void acpi_add_power_resource(acpi_handle handle);
void acpi_power_add_remove_device(struct acpi_device *adev, bool add);
int acpi_device_sleep_wake(struct acpi_device *dev,
Expand Down
32 changes: 31 additions & 1 deletion trunk/drivers/acpi/power.c
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,8 @@ static struct acpi_power_resource *acpi_power_get_context(acpi_handle handle)
return container_of(device, struct acpi_power_resource, device);
}

void acpi_power_resources_list_add(acpi_handle handle, struct list_head *list)
static void acpi_power_resources_list_add(acpi_handle handle,
struct list_head *list)
{
struct acpi_power_resource *resource = acpi_power_get_context(handle);
struct acpi_power_resource_entry *entry;
Expand Down Expand Up @@ -132,6 +133,35 @@ void acpi_power_resources_list_free(struct list_head *list)
}
}

acpi_status acpi_extract_power_resources(union acpi_object *package,
unsigned int start,
struct list_head *list)
{
acpi_status status = AE_OK;
unsigned int i;

for (i = start; i < package->package.count; i++) {
union acpi_object *element = &package->package.elements[i];
acpi_handle rhandle;

if (element->type != ACPI_TYPE_LOCAL_REFERENCE) {
status = AE_BAD_DATA;
break;
}
rhandle = element->reference.handle;
if (!rhandle) {
status = AE_NULL_ENTRY;
break;
}
acpi_add_power_resource(rhandle);
acpi_power_resources_list_add(rhandle, list);
}
if (ACPI_FAILURE(status))
acpi_power_resources_list_free(list);

return status;
}

static int acpi_power_get_state(acpi_handle handle, int *state)
{
acpi_status status = AE_OK;
Expand Down
51 changes: 21 additions & 30 deletions trunk/drivers/acpi/scan.c
Original file line number Diff line number Diff line change
Expand Up @@ -900,7 +900,6 @@ acpi_bus_extract_wakeup_device_power_package(acpi_handle handle,
union acpi_object *package = NULL;
union acpi_object *element = NULL;
acpi_status status;
int i = 0;

if (!wakeup)
return AE_BAD_PARAMETER;
Expand Down Expand Up @@ -953,18 +952,9 @@ acpi_bus_extract_wakeup_device_power_package(acpi_handle handle,
}
wakeup->sleep_state = element->integer.value;

for (i = 2; i < package->package.count; i++) {
acpi_handle rhandle;

element = &(package->package.elements[i]);
if (element->type != ACPI_TYPE_LOCAL_REFERENCE) {
status = AE_BAD_DATA;
goto out;
}
rhandle = element->reference.handle;
acpi_add_power_resource(rhandle);
acpi_power_resources_list_add(rhandle, &wakeup->resources);
}
status = acpi_extract_power_resources(package, 2, &wakeup->resources);
if (ACPI_FAILURE(status))
goto out;

acpi_setup_gpe_for_wake(handle, wakeup->gpe_device, wakeup->gpe_number);

Expand Down Expand Up @@ -1021,7 +1011,6 @@ static void acpi_bus_get_wakeup_device_flags(struct acpi_device *device)
status = acpi_bus_extract_wakeup_device_power_package(device->handle,
&device->wakeup);
if (ACPI_FAILURE(status)) {
acpi_power_resources_list_free(&device->wakeup.resources);
ACPI_EXCEPTION((AE_INFO, status, "Extracting _PRW package"));
return;
}
Expand All @@ -1044,38 +1033,40 @@ static void acpi_bus_get_wakeup_device_flags(struct acpi_device *device)
static void acpi_bus_init_power_state(struct acpi_device *device, int state)
{
struct acpi_device_power_state *ps = &device->power.states[state];
char object_name[5] = { '_', 'P', 'R', '0' + state, '\0' };
struct acpi_handle_list resources;
char pathname[5] = { '_', 'P', 'R', '0' + state, '\0' };
struct acpi_buffer buffer = { ACPI_ALLOCATE_BUFFER, NULL };
acpi_handle handle;
acpi_status status;

INIT_LIST_HEAD(&ps->resources);

/* Evaluate "_PRx" to se if power resources are referenced */
acpi_evaluate_reference(device->handle, object_name, NULL, &resources);
if (resources.count) {
int j;

device->power.flags.power_resources = 1;
for (j = 0; j < resources.count; j++) {
acpi_handle rhandle = resources.handles[j];

acpi_add_power_resource(rhandle);
acpi_power_resources_list_add(rhandle, &ps->resources);
/* Evaluate "_PRx" to get referenced power resources */
status = acpi_evaluate_object(device->handle, pathname, NULL, &buffer);
if (ACPI_SUCCESS(status)) {
union acpi_object *package = buffer.pointer;

if (buffer.length && package
&& package->type == ACPI_TYPE_PACKAGE
&& package->package.count) {
status = acpi_extract_power_resources(package, 0,
&ps->resources);
if (ACPI_SUCCESS(status))
device->power.flags.power_resources = 1;
}
ACPI_FREE(buffer.pointer);
}

/* Evaluate "_PSx" to see if we can do explicit sets */
object_name[2] = 'S';
status = acpi_get_handle(device->handle, object_name, &handle);
pathname[2] = 'S';
status = acpi_get_handle(device->handle, pathname, &handle);
if (ACPI_SUCCESS(status))
ps->flags.explicit_set = 1;

/*
* State is valid if there are means to put the device into it.
* D3hot is only valid if _PR3 present.
*/
if (resources.count
if (!list_empty(&ps->resources)
|| (ps->flags.explicit_set && state < ACPI_STATE_D3_HOT)) {
ps->flags.valid = 1;
ps->flags.os_accessible = 1;
Expand Down

0 comments on commit 65a42a5

Please sign in to comment.