Branch data Line data Source code
1 : : // SPDX-License-Identifier: GPL-2.0-only
2 : : /*
3 : : * drivers/acpi/device_pm.c - ACPI device power management routines.
4 : : *
5 : : * Copyright (C) 2012, Intel Corp.
6 : : * Author: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
7 : : *
8 : : * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
9 : : *
10 : : * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
11 : : */
12 : :
13 : : #include <linux/acpi.h>
14 : : #include <linux/export.h>
15 : : #include <linux/mutex.h>
16 : : #include <linux/pm_qos.h>
17 : : #include <linux/pm_domain.h>
18 : : #include <linux/pm_runtime.h>
19 : : #include <linux/suspend.h>
20 : :
21 : : #include "internal.h"
22 : :
23 : : #define _COMPONENT ACPI_POWER_COMPONENT
24 : : ACPI_MODULE_NAME("device_pm");
25 : :
26 : : /**
27 : : * acpi_power_state_string - String representation of ACPI device power state.
28 : : * @state: ACPI device power state to return the string representation of.
29 : : */
30 : 0 : const char *acpi_power_state_string(int state)
31 : : {
32 [ # # ]: 0 : switch (state) {
33 : : case ACPI_STATE_D0:
34 : : return "D0";
35 : : case ACPI_STATE_D1:
36 : : return "D1";
37 : : case ACPI_STATE_D2:
38 : : return "D2";
39 : : case ACPI_STATE_D3_HOT:
40 : : return "D3hot";
41 : : case ACPI_STATE_D3_COLD:
42 : : return "D3cold";
43 : : default:
44 : : return "(unknown)";
45 : : }
46 : : }
47 : :
48 : 0 : static int acpi_dev_pm_explicit_get(struct acpi_device *device, int *state)
49 : : {
50 : 0 : unsigned long long psc;
51 : 0 : acpi_status status;
52 : :
53 : 0 : status = acpi_evaluate_integer(device->handle, "_PSC", NULL, &psc);
54 [ # # # # ]: 0 : if (ACPI_FAILURE(status))
55 : : return -ENODEV;
56 : :
57 : 0 : *state = psc;
58 : 0 : return 0;
59 : : }
60 : :
61 : : /**
62 : : * acpi_device_get_power - Get power state of an ACPI device.
63 : : * @device: Device to get the power state of.
64 : : * @state: Place to store the power state of the device.
65 : : *
66 : : * This function does not update the device's power.state field, but it may
67 : : * update its parent's power.state field (when the parent's power state is
68 : : * unknown and the device's power state turns out to be D0).
69 : : *
70 : : * Also, it does not update power resource reference counters to ensure that
71 : : * the power state returned by it will be persistent and it may return a power
72 : : * state shallower than previously set by acpi_device_set_power() for @device
73 : : * (if that power state depends on any power resources).
74 : : */
75 : 0 : int acpi_device_get_power(struct acpi_device *device, int *state)
76 : : {
77 : 0 : int result = ACPI_STATE_UNKNOWN;
78 : 0 : int error;
79 : :
80 [ # # ]: 0 : if (!device || !state)
81 : : return -EINVAL;
82 : :
83 [ # # ]: 0 : if (!device->flags.power_manageable) {
84 : : /* TBD: Non-recursive algorithm for walking up hierarchy. */
85 : 0 : *state = device->parent ?
86 [ # # ]: 0 : device->parent->power.state : ACPI_STATE_D0;
87 : 0 : goto out;
88 : : }
89 : :
90 : : /*
91 : : * Get the device's power state from power resources settings and _PSC,
92 : : * if available.
93 : : */
94 [ # # ]: 0 : if (device->power.flags.power_resources) {
95 : 0 : error = acpi_power_get_inferred_state(device, &result);
96 [ # # ]: 0 : if (error)
97 : : return error;
98 : : }
99 [ # # ]: 0 : if (device->power.flags.explicit_get) {
100 : 0 : int psc;
101 : :
102 : 0 : error = acpi_dev_pm_explicit_get(device, &psc);
103 : 0 : if (error)
104 : 0 : return error;
105 : :
106 : : /*
107 : : * The power resources settings may indicate a power state
108 : : * shallower than the actual power state of the device, because
109 : : * the same power resources may be referenced by other devices.
110 : : *
111 : : * For systems predating ACPI 4.0 we assume that D3hot is the
112 : : * deepest state that can be supported.
113 : : */
114 [ # # # # ]: 0 : if (psc > result && psc < ACPI_STATE_D3_COLD)
115 : 0 : result = psc;
116 [ # # ]: 0 : else if (result == ACPI_STATE_UNKNOWN)
117 : 0 : result = psc > ACPI_STATE_D2 ? ACPI_STATE_D3_HOT : psc;
118 : : }
119 : :
120 : : /*
121 : : * If we were unsure about the device parent's power state up to this
122 : : * point, the fact that the device is in D0 implies that the parent has
123 : : * to be in D0 too, except if ignore_parent is set.
124 : : */
125 [ # # # # ]: 0 : if (!device->power.flags.ignore_parent && device->parent
126 [ # # ]: 0 : && device->parent->power.state == ACPI_STATE_UNKNOWN
127 [ # # ]: 0 : && result == ACPI_STATE_D0)
128 : 0 : device->parent->power.state = ACPI_STATE_D0;
129 : :
130 : 0 : *state = result;
131 : :
132 : : out:
133 : : ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Device [%s] power state is %s\n",
134 : : device->pnp.bus_id, acpi_power_state_string(*state)));
135 : :
136 : : return 0;
137 : : }
138 : :
139 : 0 : static int acpi_dev_pm_explicit_set(struct acpi_device *adev, int state)
140 : : {
141 [ # # ]: 0 : if (adev->power.states[state].flags.explicit_set) {
142 : 0 : char method[5] = { '_', 'P', 'S', '0' + state, '\0' };
143 : 0 : acpi_status status;
144 : :
145 : 0 : status = acpi_evaluate_object(adev->handle, method, NULL, NULL);
146 [ # # ]: 0 : if (ACPI_FAILURE(status))
147 : 0 : return -ENODEV;
148 : : }
149 : : return 0;
150 : : }
151 : :
152 : : /**
153 : : * acpi_device_set_power - Set power state of an ACPI device.
154 : : * @device: Device to set the power state of.
155 : : * @state: New power state to set.
156 : : *
157 : : * Callers must ensure that the device is power manageable before using this
158 : : * function.
159 : : */
160 : 0 : int acpi_device_set_power(struct acpi_device *device, int state)
161 : : {
162 : 0 : int target_state = state;
163 : 0 : int result = 0;
164 : :
165 [ # # # # ]: 0 : if (!device || !device->flags.power_manageable
166 [ # # ]: 0 : || (state < ACPI_STATE_D0) || (state > ACPI_STATE_D3_COLD))
167 : : return -EINVAL;
168 : :
169 : 0 : acpi_handle_debug(device->handle, "Power state change: %s -> %s\n",
170 : : acpi_power_state_string(device->power.state),
171 : : acpi_power_state_string(state));
172 : :
173 : : /* Make sure this is a valid target state */
174 : :
175 : : /* There is a special case for D0 addressed below. */
176 [ # # # # ]: 0 : if (state > ACPI_STATE_D0 && state == device->power.state) {
177 : : ACPI_DEBUG_PRINT((ACPI_DB_INFO, "Device [%s] already in %s\n",
178 : : device->pnp.bus_id,
179 : : acpi_power_state_string(state)));
180 : : return 0;
181 : : }
182 : :
183 [ # # ]: 0 : if (state == ACPI_STATE_D3_COLD) {
184 : : /*
185 : : * For transitions to D3cold we need to execute _PS3 and then
186 : : * possibly drop references to the power resources in use.
187 : : */
188 : 0 : state = ACPI_STATE_D3_HOT;
189 : : /* If _PR3 is not available, use D3hot as the target state. */
190 : 0 : if (!device->power.states[ACPI_STATE_D3_COLD].flags.valid)
191 : : target_state = state;
192 [ # # ]: 0 : } else if (!device->power.states[state].flags.valid) {
193 : 0 : dev_warn(&device->dev, "Power state %s not supported\n",
194 : : acpi_power_state_string(state));
195 : 0 : return -ENODEV;
196 : : }
197 : :
198 [ # # ]: 0 : if (!device->power.flags.ignore_parent &&
199 [ # # # # ]: 0 : device->parent && (state < device->parent->power.state)) {
200 [ # # ]: 0 : dev_warn(&device->dev,
201 : : "Cannot transition to power state %s for parent in %s\n",
202 : : acpi_power_state_string(state),
203 : : acpi_power_state_string(device->parent->power.state));
204 : 0 : return -ENODEV;
205 : : }
206 : :
207 : : /*
208 : : * Transition Power
209 : : * ----------------
210 : : * In accordance with ACPI 6, _PSx is executed before manipulating power
211 : : * resources, unless the target state is D0, in which case _PS0 is
212 : : * supposed to be executed after turning the power resources on.
213 : : */
214 [ # # ]: 0 : if (state > ACPI_STATE_D0) {
215 : : /*
216 : : * According to ACPI 6, devices cannot go from lower-power
217 : : * (deeper) states to higher-power (shallower) states.
218 : : */
219 [ # # ]: 0 : if (state < device->power.state) {
220 [ # # ]: 0 : dev_warn(&device->dev, "Cannot transition from %s to %s\n",
221 : : acpi_power_state_string(device->power.state),
222 : : acpi_power_state_string(state));
223 : 0 : return -ENODEV;
224 : : }
225 : :
226 : : /*
227 : : * If the device goes from D3hot to D3cold, _PS3 has been
228 : : * evaluated for it already, so skip it in that case.
229 : : */
230 [ # # ]: 0 : if (device->power.state < ACPI_STATE_D3_HOT) {
231 : 0 : result = acpi_dev_pm_explicit_set(device, state);
232 [ # # ]: 0 : if (result)
233 : 0 : goto end;
234 : : }
235 : :
236 [ # # ]: 0 : if (device->power.flags.power_resources)
237 : 0 : result = acpi_power_transition(device, target_state);
238 : : } else {
239 : 0 : int cur_state = device->power.state;
240 : :
241 [ # # ]: 0 : if (device->power.flags.power_resources) {
242 : 0 : result = acpi_power_transition(device, ACPI_STATE_D0);
243 [ # # ]: 0 : if (result)
244 : 0 : goto end;
245 : : }
246 : :
247 [ # # ]: 0 : if (cur_state == ACPI_STATE_D0) {
248 : 0 : int psc;
249 : :
250 : : /* Nothing to do here if _PSC is not present. */
251 [ # # ]: 0 : if (!device->power.flags.explicit_get)
252 : : return 0;
253 : :
254 : : /*
255 : : * The power state of the device was set to D0 last
256 : : * time, but that might have happened before a
257 : : * system-wide transition involving the platform
258 : : * firmware, so it may be necessary to evaluate _PS0
259 : : * for the device here. However, use extra care here
260 : : * and evaluate _PSC to check the device's current power
261 : : * state, and only invoke _PS0 if the evaluation of _PSC
262 : : * is successful and it returns a power state different
263 : : * from D0.
264 : : */
265 : 0 : result = acpi_dev_pm_explicit_get(device, &psc);
266 [ # # ]: 0 : if (result || psc == ACPI_STATE_D0)
267 : 0 : return 0;
268 : : }
269 : :
270 : 0 : result = acpi_dev_pm_explicit_set(device, ACPI_STATE_D0);
271 : : }
272 : :
273 : 0 : end:
274 [ # # ]: 0 : if (result) {
275 : 0 : dev_warn(&device->dev, "Failed to change power state to %s\n",
276 : : acpi_power_state_string(state));
277 : : } else {
278 : 0 : device->power.state = target_state;
279 : : ACPI_DEBUG_PRINT((ACPI_DB_INFO,
280 : : "Device [%s] transitioned to %s\n",
281 : : device->pnp.bus_id,
282 : : acpi_power_state_string(state)));
283 : : }
284 : :
285 : : return result;
286 : : }
287 : : EXPORT_SYMBOL(acpi_device_set_power);
288 : :
289 : 0 : int acpi_bus_set_power(acpi_handle handle, int state)
290 : : {
291 : 0 : struct acpi_device *device;
292 : 0 : int result;
293 : :
294 : 0 : result = acpi_bus_get_device(handle, &device);
295 [ # # ]: 0 : if (result)
296 : : return result;
297 : :
298 : 0 : return acpi_device_set_power(device, state);
299 : : }
300 : : EXPORT_SYMBOL(acpi_bus_set_power);
301 : :
302 : 0 : int acpi_bus_init_power(struct acpi_device *device)
303 : : {
304 : 0 : int state;
305 : 0 : int result;
306 : :
307 [ # # ]: 0 : if (!device)
308 : : return -EINVAL;
309 : :
310 : 0 : device->power.state = ACPI_STATE_UNKNOWN;
311 [ # # ]: 0 : if (!acpi_device_is_present(device)) {
312 : 0 : device->flags.initialized = false;
313 : 0 : return -ENXIO;
314 : : }
315 : :
316 : 0 : result = acpi_device_get_power(device, &state);
317 [ # # ]: 0 : if (result)
318 : : return result;
319 : :
320 [ # # # # ]: 0 : if (state < ACPI_STATE_D3_COLD && device->power.flags.power_resources) {
321 : : /* Reference count the power resources. */
322 : 0 : result = acpi_power_on_resources(device, state);
323 [ # # ]: 0 : if (result)
324 : : return result;
325 : :
326 [ # # ]: 0 : if (state == ACPI_STATE_D0) {
327 : : /*
328 : : * If _PSC is not present and the state inferred from
329 : : * power resources appears to be D0, it still may be
330 : : * necessary to execute _PS0 at this point, because
331 : : * another device using the same power resources may
332 : : * have been put into D0 previously and that's why we
333 : : * see D0 here.
334 : : */
335 : 0 : result = acpi_dev_pm_explicit_set(device, state);
336 [ # # ]: 0 : if (result)
337 : : return result;
338 : : }
339 [ # # ]: 0 : } else if (state == ACPI_STATE_UNKNOWN) {
340 : : /*
341 : : * No power resources and missing _PSC? Cross fingers and make
342 : : * it D0 in hope that this is what the BIOS put the device into.
343 : : * [We tried to force D0 here by executing _PS0, but that broke
344 : : * Toshiba P870-303 in a nasty way.]
345 : : */
346 : 0 : state = ACPI_STATE_D0;
347 : : }
348 : 0 : device->power.state = state;
349 : 0 : return 0;
350 : : }
351 : :
352 : : /**
353 : : * acpi_device_fix_up_power - Force device with missing _PSC into D0.
354 : : * @device: Device object whose power state is to be fixed up.
355 : : *
356 : : * Devices without power resources and _PSC, but having _PS0 and _PS3 defined,
357 : : * are assumed to be put into D0 by the BIOS. However, in some cases that may
358 : : * not be the case and this function should be used then.
359 : : */
360 : 0 : int acpi_device_fix_up_power(struct acpi_device *device)
361 : : {
362 : 0 : int ret = 0;
363 : :
364 : 0 : if (!device->power.flags.power_resources
365 : : && !device->power.flags.explicit_get
366 [ # # ]: 0 : && device->power.state == ACPI_STATE_D0)
367 : 0 : ret = acpi_dev_pm_explicit_set(device, ACPI_STATE_D0);
368 : :
369 : 0 : return ret;
370 : : }
371 : : EXPORT_SYMBOL_GPL(acpi_device_fix_up_power);
372 : :
373 : 0 : int acpi_device_update_power(struct acpi_device *device, int *state_p)
374 : : {
375 : 0 : int state;
376 : 0 : int result;
377 : :
378 [ # # ]: 0 : if (device->power.state == ACPI_STATE_UNKNOWN) {
379 : 0 : result = acpi_bus_init_power(device);
380 [ # # ]: 0 : if (!result && state_p)
381 : 0 : *state_p = device->power.state;
382 : :
383 : 0 : return result;
384 : : }
385 : :
386 : 0 : result = acpi_device_get_power(device, &state);
387 [ # # ]: 0 : if (result)
388 : : return result;
389 : :
390 [ # # ]: 0 : if (state == ACPI_STATE_UNKNOWN) {
391 : 0 : state = ACPI_STATE_D0;
392 : 0 : result = acpi_device_set_power(device, state);
393 [ # # ]: 0 : if (result)
394 : : return result;
395 : : } else {
396 [ # # ]: 0 : if (device->power.flags.power_resources) {
397 : : /*
398 : : * We don't need to really switch the state, bu we need
399 : : * to update the power resources' reference counters.
400 : : */
401 : 0 : result = acpi_power_transition(device, state);
402 [ # # ]: 0 : if (result)
403 : : return result;
404 : : }
405 : 0 : device->power.state = state;
406 : : }
407 [ # # ]: 0 : if (state_p)
408 : 0 : *state_p = state;
409 : :
410 : : return 0;
411 : : }
412 : : EXPORT_SYMBOL_GPL(acpi_device_update_power);
413 : :
414 : 0 : int acpi_bus_update_power(acpi_handle handle, int *state_p)
415 : : {
416 : 0 : struct acpi_device *device;
417 : 0 : int result;
418 : :
419 : 0 : result = acpi_bus_get_device(handle, &device);
420 [ # # ]: 0 : return result ? result : acpi_device_update_power(device, state_p);
421 : : }
422 : : EXPORT_SYMBOL_GPL(acpi_bus_update_power);
423 : :
424 : 0 : bool acpi_bus_power_manageable(acpi_handle handle)
425 : : {
426 : 0 : struct acpi_device *device;
427 : 0 : int result;
428 : :
429 : 0 : result = acpi_bus_get_device(handle, &device);
430 [ # # # # ]: 0 : return result ? false : device->flags.power_manageable;
431 : : }
432 : : EXPORT_SYMBOL(acpi_bus_power_manageable);
433 : :
434 : : #ifdef CONFIG_PM
435 : : static DEFINE_MUTEX(acpi_pm_notifier_lock);
436 : : static DEFINE_MUTEX(acpi_pm_notifier_install_lock);
437 : :
438 : 0 : void acpi_pm_wakeup_event(struct device *dev)
439 : : {
440 : 0 : pm_wakeup_dev_event(dev, 0, acpi_s2idle_wakeup());
441 : 0 : }
442 : : EXPORT_SYMBOL_GPL(acpi_pm_wakeup_event);
443 : :
444 : 0 : static void acpi_pm_notify_handler(acpi_handle handle, u32 val, void *not_used)
445 : : {
446 : 0 : struct acpi_device *adev;
447 : :
448 [ # # ]: 0 : if (val != ACPI_NOTIFY_DEVICE_WAKE)
449 : : return;
450 : :
451 : 0 : acpi_handle_debug(handle, "Wake notify\n");
452 : :
453 : 0 : adev = acpi_bus_get_acpi_device(handle);
454 [ # # ]: 0 : if (!adev)
455 : : return;
456 : :
457 : 0 : mutex_lock(&acpi_pm_notifier_lock);
458 : :
459 [ # # ]: 0 : if (adev->wakeup.flags.notifier_present) {
460 : 0 : pm_wakeup_ws_event(adev->wakeup.ws, 0, acpi_s2idle_wakeup());
461 [ # # ]: 0 : if (adev->wakeup.context.func) {
462 : 0 : acpi_handle_debug(handle, "Running %pS for %s\n",
463 : : adev->wakeup.context.func,
464 : : dev_name(adev->wakeup.context.dev));
465 : 0 : adev->wakeup.context.func(&adev->wakeup.context);
466 : : }
467 : : }
468 : :
469 : 0 : mutex_unlock(&acpi_pm_notifier_lock);
470 : :
471 : 0 : acpi_bus_put_acpi_device(adev);
472 : : }
473 : :
474 : : /**
475 : : * acpi_add_pm_notifier - Register PM notify handler for given ACPI device.
476 : : * @adev: ACPI device to add the notify handler for.
477 : : * @dev: Device to generate a wakeup event for while handling the notification.
478 : : * @func: Work function to execute when handling the notification.
479 : : *
480 : : * NOTE: @adev need not be a run-wake or wakeup device to be a valid source of
481 : : * PM wakeup events. For example, wakeup events may be generated for bridges
482 : : * if one of the devices below the bridge is signaling wakeup, even if the
483 : : * bridge itself doesn't have a wakeup GPE associated with it.
484 : : */
485 : 91 : acpi_status acpi_add_pm_notifier(struct acpi_device *adev, struct device *dev,
486 : : void (*func)(struct acpi_device_wakeup_context *context))
487 : : {
488 : 91 : acpi_status status = AE_ALREADY_EXISTS;
489 : :
490 [ + - ]: 91 : if (!dev && !func)
491 : : return AE_BAD_PARAMETER;
492 : :
493 : 91 : mutex_lock(&acpi_pm_notifier_install_lock);
494 : :
495 [ - + ]: 91 : if (adev->wakeup.flags.notifier_present)
496 : 0 : goto out;
497 : :
498 : 91 : status = acpi_install_notify_handler(adev->handle, ACPI_SYSTEM_NOTIFY,
499 : : acpi_pm_notify_handler, NULL);
500 [ - + ]: 91 : if (ACPI_FAILURE(status))
501 : 0 : goto out;
502 : :
503 : 91 : mutex_lock(&acpi_pm_notifier_lock);
504 [ + - ]: 182 : adev->wakeup.ws = wakeup_source_register(&adev->dev,
505 : : dev_name(&adev->dev));
506 : 91 : adev->wakeup.context.dev = dev;
507 : 91 : adev->wakeup.context.func = func;
508 : 91 : adev->wakeup.flags.notifier_present = true;
509 : 91 : mutex_unlock(&acpi_pm_notifier_lock);
510 : :
511 : 91 : out:
512 : 91 : mutex_unlock(&acpi_pm_notifier_install_lock);
513 : 91 : return status;
514 : : }
515 : :
516 : : /**
517 : : * acpi_remove_pm_notifier - Unregister PM notifier from given ACPI device.
518 : : * @adev: ACPI device to remove the notifier from.
519 : : */
520 : 0 : acpi_status acpi_remove_pm_notifier(struct acpi_device *adev)
521 : : {
522 : 0 : acpi_status status = AE_BAD_PARAMETER;
523 : :
524 : 0 : mutex_lock(&acpi_pm_notifier_install_lock);
525 : :
526 [ # # ]: 0 : if (!adev->wakeup.flags.notifier_present)
527 : 0 : goto out;
528 : :
529 : 0 : status = acpi_remove_notify_handler(adev->handle,
530 : : ACPI_SYSTEM_NOTIFY,
531 : : acpi_pm_notify_handler);
532 [ # # ]: 0 : if (ACPI_FAILURE(status))
533 : 0 : goto out;
534 : :
535 : 0 : mutex_lock(&acpi_pm_notifier_lock);
536 : 0 : adev->wakeup.context.func = NULL;
537 : 0 : adev->wakeup.context.dev = NULL;
538 : 0 : wakeup_source_unregister(adev->wakeup.ws);
539 : 0 : adev->wakeup.flags.notifier_present = false;
540 : 0 : mutex_unlock(&acpi_pm_notifier_lock);
541 : :
542 : 0 : out:
543 : 0 : mutex_unlock(&acpi_pm_notifier_install_lock);
544 : 0 : return status;
545 : : }
546 : :
547 : 78 : bool acpi_bus_can_wakeup(acpi_handle handle)
548 : : {
549 : 78 : struct acpi_device *device;
550 : 78 : int result;
551 : :
552 : 78 : result = acpi_bus_get_device(handle, &device);
553 [ + - + - ]: 78 : return result ? false : device->wakeup.flags.valid;
554 : : }
555 : : EXPORT_SYMBOL(acpi_bus_can_wakeup);
556 : :
557 : 0 : bool acpi_pm_device_can_wakeup(struct device *dev)
558 : : {
559 [ # # ]: 0 : struct acpi_device *adev = ACPI_COMPANION(dev);
560 : :
561 [ # # # # ]: 0 : return adev ? acpi_device_can_wakeup(adev) : false;
562 : : }
563 : :
564 : : /**
565 : : * acpi_dev_pm_get_state - Get preferred power state of ACPI device.
566 : : * @dev: Device whose preferred target power state to return.
567 : : * @adev: ACPI device node corresponding to @dev.
568 : : * @target_state: System state to match the resultant device state.
569 : : * @d_min_p: Location to store the highest power state available to the device.
570 : : * @d_max_p: Location to store the lowest power state available to the device.
571 : : *
572 : : * Find the lowest power (highest number) and highest power (lowest number) ACPI
573 : : * device power states that the device can be in while the system is in the
574 : : * state represented by @target_state. Store the integer numbers representing
575 : : * those stats in the memory locations pointed to by @d_max_p and @d_min_p,
576 : : * respectively.
577 : : *
578 : : * Callers must ensure that @dev and @adev are valid pointers and that @adev
579 : : * actually corresponds to @dev before using this function.
580 : : *
581 : : * Returns 0 on success or -ENODATA when one of the ACPI methods fails or
582 : : * returns a value that doesn't make sense. The memory locations pointed to by
583 : : * @d_max_p and @d_min_p are only modified on success.
584 : : */
585 : 0 : static int acpi_dev_pm_get_state(struct device *dev, struct acpi_device *adev,
586 : : u32 target_state, int *d_min_p, int *d_max_p)
587 : : {
588 : 0 : char method[] = { '_', 'S', '0' + target_state, 'D', '\0' };
589 : 0 : acpi_handle handle = adev->handle;
590 : 0 : unsigned long long ret;
591 : 0 : int d_min, d_max;
592 : 0 : bool wakeup = false;
593 : 0 : bool has_sxd = false;
594 : 0 : acpi_status status;
595 : :
596 : : /*
597 : : * If the system state is S0, the lowest power state the device can be
598 : : * in is D3cold, unless the device has _S0W and is supposed to signal
599 : : * wakeup, in which case the return value of _S0W has to be used as the
600 : : * lowest power state available to the device.
601 : : */
602 : 0 : d_min = ACPI_STATE_D0;
603 : 0 : d_max = ACPI_STATE_D3_COLD;
604 : :
605 : : /*
606 : : * If present, _SxD methods return the minimum D-state (highest power
607 : : * state) we can use for the corresponding S-states. Otherwise, the
608 : : * minimum D-state is D0 (ACPI 3.x).
609 : : */
610 [ # # ]: 0 : if (target_state > ACPI_STATE_S0) {
611 : : /*
612 : : * We rely on acpi_evaluate_integer() not clobbering the integer
613 : : * provided if AE_NOT_FOUND is returned.
614 : : */
615 : 0 : ret = d_min;
616 : 0 : status = acpi_evaluate_integer(handle, method, NULL, &ret);
617 [ # # ]: 0 : if ((ACPI_FAILURE(status) && status != AE_NOT_FOUND)
618 [ # # ]: 0 : || ret > ACPI_STATE_D3_COLD)
619 : : return -ENODATA;
620 : :
621 : : /*
622 : : * We need to handle legacy systems where D3hot and D3cold are
623 : : * the same and 3 is returned in both cases, so fall back to
624 : : * D3cold if D3hot is not a valid state.
625 : : */
626 [ # # ]: 0 : if (!adev->power.states[ret].flags.valid) {
627 [ # # ]: 0 : if (ret == ACPI_STATE_D3_HOT)
628 : 0 : ret = ACPI_STATE_D3_COLD;
629 : : else
630 : : return -ENODATA;
631 : : }
632 : :
633 [ # # ]: 0 : if (status == AE_OK)
634 : 0 : has_sxd = true;
635 : :
636 : 0 : d_min = ret;
637 [ # # # # ]: 0 : wakeup = device_may_wakeup(dev) && adev->wakeup.flags.valid
638 [ # # # # ]: 0 : && adev->wakeup.sleep_state >= target_state;
639 : : } else {
640 : 0 : wakeup = adev->wakeup.flags.valid;
641 : : }
642 : :
643 : : /*
644 : : * If _PRW says we can wake up the system from the target sleep state,
645 : : * the D-state returned by _SxD is sufficient for that (we assume a
646 : : * wakeup-aware driver if wake is set). Still, if _SxW exists
647 : : * (ACPI 3.x), it should return the maximum (lowest power) D-state that
648 : : * can wake the system. _S0W may be valid, too.
649 : : */
650 [ # # ]: 0 : if (wakeup) {
651 : 0 : method[3] = 'W';
652 : 0 : status = acpi_evaluate_integer(handle, method, NULL, &ret);
653 [ # # ]: 0 : if (status == AE_NOT_FOUND) {
654 : : /* No _SxW. In this case, the ACPI spec says that we
655 : : * must not go into any power state deeper than the
656 : : * value returned from _SxD.
657 : : */
658 [ # # ]: 0 : if (has_sxd && target_state > ACPI_STATE_S0)
659 : 0 : d_max = d_min;
660 [ # # # # ]: 0 : } else if (ACPI_SUCCESS(status) && ret <= ACPI_STATE_D3_COLD) {
661 : : /* Fall back to D3cold if ret is not a valid state. */
662 [ # # ]: 0 : if (!adev->power.states[ret].flags.valid)
663 : 0 : ret = ACPI_STATE_D3_COLD;
664 : :
665 : 0 : d_max = ret > d_min ? ret : d_min;
666 : : } else {
667 : : return -ENODATA;
668 : : }
669 : : }
670 : :
671 [ # # ]: 0 : if (d_min_p)
672 : 0 : *d_min_p = d_min;
673 : :
674 [ # # ]: 0 : if (d_max_p)
675 : 0 : *d_max_p = d_max;
676 : :
677 : : return 0;
678 : : }
679 : :
680 : : /**
681 : : * acpi_pm_device_sleep_state - Get preferred power state of ACPI device.
682 : : * @dev: Device whose preferred target power state to return.
683 : : * @d_min_p: Location to store the upper limit of the allowed states range.
684 : : * @d_max_in: Deepest low-power state to take into consideration.
685 : : * Return value: Preferred power state of the device on success, -ENODEV
686 : : * if there's no 'struct acpi_device' for @dev, -EINVAL if @d_max_in is
687 : : * incorrect, or -ENODATA on ACPI method failure.
688 : : *
689 : : * The caller must ensure that @dev is valid before using this function.
690 : : */
691 : 0 : int acpi_pm_device_sleep_state(struct device *dev, int *d_min_p, int d_max_in)
692 : : {
693 : 0 : struct acpi_device *adev;
694 : 0 : int ret, d_min, d_max;
695 : :
696 [ # # ]: 0 : if (d_max_in < ACPI_STATE_D0 || d_max_in > ACPI_STATE_D3_COLD)
697 : : return -EINVAL;
698 : :
699 [ # # ]: 0 : if (d_max_in > ACPI_STATE_D2) {
700 : 0 : enum pm_qos_flags_status stat;
701 : :
702 : 0 : stat = dev_pm_qos_flags(dev, PM_QOS_FLAG_NO_POWER_OFF);
703 [ # # ]: 0 : if (stat == PM_QOS_FLAGS_ALL)
704 : 0 : d_max_in = ACPI_STATE_D2;
705 : : }
706 : :
707 [ # # ]: 0 : adev = ACPI_COMPANION(dev);
708 [ # # ]: 0 : if (!adev) {
709 : : dev_dbg(dev, "ACPI companion missing in %s!\n", __func__);
710 : : return -ENODEV;
711 : : }
712 : :
713 : 0 : ret = acpi_dev_pm_get_state(dev, adev, acpi_target_system_state(),
714 : : &d_min, &d_max);
715 [ # # ]: 0 : if (ret)
716 : : return ret;
717 : :
718 [ # # ]: 0 : if (d_max_in < d_min)
719 : : return -EINVAL;
720 : :
721 [ # # ]: 0 : if (d_max > d_max_in) {
722 [ # # ]: 0 : for (d_max = d_max_in; d_max > d_min; d_max--) {
723 [ # # ]: 0 : if (adev->power.states[d_max].flags.valid)
724 : : break;
725 : : }
726 : : }
727 : :
728 [ # # ]: 0 : if (d_min_p)
729 : 0 : *d_min_p = d_min;
730 : :
731 : 0 : return d_max;
732 : : }
733 : : EXPORT_SYMBOL(acpi_pm_device_sleep_state);
734 : :
735 : : /**
736 : : * acpi_pm_notify_work_func - ACPI devices wakeup notification work function.
737 : : * @context: Device wakeup context.
738 : : */
739 : 0 : static void acpi_pm_notify_work_func(struct acpi_device_wakeup_context *context)
740 : : {
741 : 0 : struct device *dev = context->dev;
742 : :
743 [ # # ]: 0 : if (dev) {
744 : 0 : pm_wakeup_event(dev, 0);
745 : 0 : pm_request_resume(dev);
746 : : }
747 : 0 : }
748 : :
749 : : static DEFINE_MUTEX(acpi_wakeup_lock);
750 : :
751 : 0 : static int __acpi_device_wakeup_enable(struct acpi_device *adev,
752 : : u32 target_state, int max_count)
753 : : {
754 : 0 : struct acpi_device_wakeup *wakeup = &adev->wakeup;
755 : 0 : acpi_status status;
756 : 0 : int error = 0;
757 : :
758 : 0 : mutex_lock(&acpi_wakeup_lock);
759 : :
760 [ # # ]: 0 : if (wakeup->enable_count >= max_count)
761 : 0 : goto out;
762 : :
763 [ # # ]: 0 : if (wakeup->enable_count > 0)
764 : 0 : goto inc;
765 : :
766 : 0 : error = acpi_enable_wakeup_device_power(adev, target_state);
767 [ # # ]: 0 : if (error)
768 : 0 : goto out;
769 : :
770 : 0 : status = acpi_enable_gpe(wakeup->gpe_device, wakeup->gpe_number);
771 [ # # ]: 0 : if (ACPI_FAILURE(status)) {
772 : 0 : acpi_disable_wakeup_device_power(adev);
773 : 0 : error = -EIO;
774 : 0 : goto out;
775 : : }
776 : :
777 : : acpi_handle_debug(adev->handle, "GPE%2X enabled for wakeup\n",
778 : : (unsigned int)wakeup->gpe_number);
779 : :
780 : 0 : inc:
781 : 0 : wakeup->enable_count++;
782 : :
783 : 0 : out:
784 : 0 : mutex_unlock(&acpi_wakeup_lock);
785 : 0 : return error;
786 : : }
787 : :
788 : : /**
789 : : * acpi_device_wakeup_enable - Enable wakeup functionality for device.
790 : : * @adev: ACPI device to enable wakeup functionality for.
791 : : * @target_state: State the system is transitioning into.
792 : : *
793 : : * Enable the GPE associated with @adev so that it can generate wakeup signals
794 : : * for the device in response to external (remote) events and enable wakeup
795 : : * power for it.
796 : : *
797 : : * Callers must ensure that @adev is a valid ACPI device node before executing
798 : : * this function.
799 : : */
800 : 0 : static int acpi_device_wakeup_enable(struct acpi_device *adev, u32 target_state)
801 : : {
802 : 0 : return __acpi_device_wakeup_enable(adev, target_state, 1);
803 : : }
804 : :
805 : : /**
806 : : * acpi_device_wakeup_disable - Disable wakeup functionality for device.
807 : : * @adev: ACPI device to disable wakeup functionality for.
808 : : *
809 : : * Disable the GPE associated with @adev and disable wakeup power for it.
810 : : *
811 : : * Callers must ensure that @adev is a valid ACPI device node before executing
812 : : * this function.
813 : : */
814 : 0 : static void acpi_device_wakeup_disable(struct acpi_device *adev)
815 : : {
816 : 0 : struct acpi_device_wakeup *wakeup = &adev->wakeup;
817 : :
818 : 0 : mutex_lock(&acpi_wakeup_lock);
819 : :
820 [ # # ]: 0 : if (!wakeup->enable_count)
821 : 0 : goto out;
822 : :
823 : 0 : acpi_disable_gpe(wakeup->gpe_device, wakeup->gpe_number);
824 : 0 : acpi_disable_wakeup_device_power(adev);
825 : :
826 : 0 : wakeup->enable_count--;
827 : :
828 : 0 : out:
829 : 0 : mutex_unlock(&acpi_wakeup_lock);
830 : 0 : }
831 : :
832 : 0 : static int __acpi_pm_set_device_wakeup(struct device *dev, bool enable,
833 : : int max_count)
834 : : {
835 : 0 : struct acpi_device *adev;
836 : 0 : int error;
837 : :
838 [ # # ]: 0 : adev = ACPI_COMPANION(dev);
839 [ # # ]: 0 : if (!adev) {
840 : : dev_dbg(dev, "ACPI companion missing in %s!\n", __func__);
841 : : return -ENODEV;
842 : : }
843 : :
844 [ # # ]: 0 : if (!acpi_device_can_wakeup(adev))
845 : : return -EINVAL;
846 : :
847 [ # # ]: 0 : if (!enable) {
848 : 0 : acpi_device_wakeup_disable(adev);
849 : 0 : dev_dbg(dev, "Wakeup disabled by ACPI\n");
850 : 0 : return 0;
851 : : }
852 : :
853 : 0 : error = __acpi_device_wakeup_enable(adev, acpi_target_system_state(),
854 : : max_count);
855 : 0 : if (!error)
856 : : dev_dbg(dev, "Wakeup enabled by ACPI\n");
857 : :
858 : 0 : return error;
859 : : }
860 : :
861 : : /**
862 : : * acpi_pm_set_device_wakeup - Enable/disable remote wakeup for given device.
863 : : * @dev: Device to enable/disable to generate wakeup events.
864 : : * @enable: Whether to enable or disable the wakeup functionality.
865 : : */
866 : 0 : int acpi_pm_set_device_wakeup(struct device *dev, bool enable)
867 : : {
868 : 0 : return __acpi_pm_set_device_wakeup(dev, enable, 1);
869 : : }
870 : : EXPORT_SYMBOL_GPL(acpi_pm_set_device_wakeup);
871 : :
872 : : /**
873 : : * acpi_pm_set_bridge_wakeup - Enable/disable remote wakeup for given bridge.
874 : : * @dev: Bridge device to enable/disable to generate wakeup events.
875 : : * @enable: Whether to enable or disable the wakeup functionality.
876 : : */
877 : 0 : int acpi_pm_set_bridge_wakeup(struct device *dev, bool enable)
878 : : {
879 : 0 : return __acpi_pm_set_device_wakeup(dev, enable, INT_MAX);
880 : : }
881 : : EXPORT_SYMBOL_GPL(acpi_pm_set_bridge_wakeup);
882 : :
883 : : /**
884 : : * acpi_dev_pm_low_power - Put ACPI device into a low-power state.
885 : : * @dev: Device to put into a low-power state.
886 : : * @adev: ACPI device node corresponding to @dev.
887 : : * @system_state: System state to choose the device state for.
888 : : */
889 : 0 : static int acpi_dev_pm_low_power(struct device *dev, struct acpi_device *adev,
890 : : u32 system_state)
891 : : {
892 : 0 : int ret, state;
893 : :
894 [ # # ]: 0 : if (!acpi_device_power_manageable(adev))
895 : : return 0;
896 : :
897 : 0 : ret = acpi_dev_pm_get_state(dev, adev, system_state, NULL, &state);
898 [ # # ]: 0 : return ret ? ret : acpi_device_set_power(adev, state);
899 : : }
900 : :
901 : : /**
902 : : * acpi_dev_pm_full_power - Put ACPI device into the full-power state.
903 : : * @adev: ACPI device node to put into the full-power state.
904 : : */
905 : 0 : static int acpi_dev_pm_full_power(struct acpi_device *adev)
906 : : {
907 : 0 : return acpi_device_power_manageable(adev) ?
908 [ # # # # ]: 0 : acpi_device_set_power(adev, ACPI_STATE_D0) : 0;
909 : : }
910 : :
911 : : /**
912 : : * acpi_dev_suspend - Put device into a low-power state using ACPI.
913 : : * @dev: Device to put into a low-power state.
914 : : * @wakeup: Whether or not to enable wakeup for the device.
915 : : *
916 : : * Put the given device into a low-power state using the standard ACPI
917 : : * mechanism. Set up remote wakeup if desired, choose the state to put the
918 : : * device into (this checks if remote wakeup is expected to work too), and set
919 : : * the power state of the device.
920 : : */
921 : 0 : int acpi_dev_suspend(struct device *dev, bool wakeup)
922 : : {
923 [ # # ]: 0 : struct acpi_device *adev = ACPI_COMPANION(dev);
924 : 0 : u32 target_state = acpi_target_system_state();
925 : 0 : int error;
926 : :
927 [ # # ]: 0 : if (!adev)
928 : : return 0;
929 : :
930 [ # # # # ]: 0 : if (wakeup && acpi_device_can_wakeup(adev)) {
931 : 0 : error = acpi_device_wakeup_enable(adev, target_state);
932 [ # # ]: 0 : if (error)
933 : : return -EAGAIN;
934 : : } else {
935 : : wakeup = false;
936 : : }
937 : :
938 : 0 : error = acpi_dev_pm_low_power(dev, adev, target_state);
939 [ # # ]: 0 : if (error && wakeup)
940 : 0 : acpi_device_wakeup_disable(adev);
941 : :
942 : : return error;
943 : : }
944 : : EXPORT_SYMBOL_GPL(acpi_dev_suspend);
945 : :
946 : : /**
947 : : * acpi_dev_resume - Put device into the full-power state using ACPI.
948 : : * @dev: Device to put into the full-power state.
949 : : *
950 : : * Put the given device into the full-power state using the standard ACPI
951 : : * mechanism. Set the power state of the device to ACPI D0 and disable wakeup.
952 : : */
953 : 0 : int acpi_dev_resume(struct device *dev)
954 : : {
955 [ # # ]: 0 : struct acpi_device *adev = ACPI_COMPANION(dev);
956 : 0 : int error;
957 : :
958 [ # # ]: 0 : if (!adev)
959 : : return 0;
960 : :
961 [ # # ]: 0 : error = acpi_dev_pm_full_power(adev);
962 : 0 : acpi_device_wakeup_disable(adev);
963 : 0 : return error;
964 : : }
965 : : EXPORT_SYMBOL_GPL(acpi_dev_resume);
966 : :
967 : : /**
968 : : * acpi_subsys_runtime_suspend - Suspend device using ACPI.
969 : : * @dev: Device to suspend.
970 : : *
971 : : * Carry out the generic runtime suspend procedure for @dev and use ACPI to put
972 : : * it into a runtime low-power state.
973 : : */
974 : 0 : int acpi_subsys_runtime_suspend(struct device *dev)
975 : : {
976 : 0 : int ret = pm_generic_runtime_suspend(dev);
977 [ # # ]: 0 : return ret ? ret : acpi_dev_suspend(dev, true);
978 : : }
979 : : EXPORT_SYMBOL_GPL(acpi_subsys_runtime_suspend);
980 : :
981 : : /**
982 : : * acpi_subsys_runtime_resume - Resume device using ACPI.
983 : : * @dev: Device to Resume.
984 : : *
985 : : * Use ACPI to put the given device into the full-power state and carry out the
986 : : * generic runtime resume procedure for it.
987 : : */
988 : 0 : int acpi_subsys_runtime_resume(struct device *dev)
989 : : {
990 : 0 : int ret = acpi_dev_resume(dev);
991 [ # # ]: 0 : return ret ? ret : pm_generic_runtime_resume(dev);
992 : : }
993 : : EXPORT_SYMBOL_GPL(acpi_subsys_runtime_resume);
994 : :
995 : : #ifdef CONFIG_PM_SLEEP
996 : 0 : static bool acpi_dev_needs_resume(struct device *dev, struct acpi_device *adev)
997 : : {
998 : 0 : u32 sys_target = acpi_target_system_state();
999 : 0 : int ret, state;
1000 : :
1001 [ # # # # : 0 : if (!pm_runtime_suspended(dev) || !adev || (adev->wakeup.flags.valid &&
# # # # ]
1002 [ # # ]: 0 : device_may_wakeup(dev) != !!adev->wakeup.prepare_count))
1003 : : return true;
1004 : :
1005 [ # # ]: 0 : if (sys_target == ACPI_STATE_S0)
1006 : : return false;
1007 : :
1008 [ # # ]: 0 : if (adev->power.flags.dsw_present)
1009 : : return true;
1010 : :
1011 : 0 : ret = acpi_dev_pm_get_state(dev, adev, sys_target, NULL, &state);
1012 [ # # ]: 0 : if (ret)
1013 : : return true;
1014 : :
1015 : 0 : return state != adev->power.state;
1016 : : }
1017 : :
1018 : : /**
1019 : : * acpi_subsys_prepare - Prepare device for system transition to a sleep state.
1020 : : * @dev: Device to prepare.
1021 : : */
1022 : 0 : int acpi_subsys_prepare(struct device *dev)
1023 : : {
1024 [ # # ]: 0 : struct acpi_device *adev = ACPI_COMPANION(dev);
1025 : :
1026 [ # # # # : 0 : if (dev->driver && dev->driver->pm && dev->driver->pm->prepare) {
# # ]
1027 : 0 : int ret = dev->driver->pm->prepare(dev);
1028 : :
1029 [ # # ]: 0 : if (ret < 0)
1030 : : return ret;
1031 : :
1032 [ # # # # ]: 0 : if (!ret && dev_pm_test_driver_flags(dev, DPM_FLAG_SMART_PREPARE))
1033 : : return 0;
1034 : : }
1035 : :
1036 : 0 : return !acpi_dev_needs_resume(dev, adev);
1037 : : }
1038 : : EXPORT_SYMBOL_GPL(acpi_subsys_prepare);
1039 : :
1040 : : /**
1041 : : * acpi_subsys_complete - Finalize device's resume during system resume.
1042 : : * @dev: Device to handle.
1043 : : */
1044 : 0 : void acpi_subsys_complete(struct device *dev)
1045 : : {
1046 : 0 : pm_generic_complete(dev);
1047 : : /*
1048 : : * If the device had been runtime-suspended before the system went into
1049 : : * the sleep state it is going out of and it has never been resumed till
1050 : : * now, resume it in case the firmware powered it up.
1051 : : */
1052 [ # # # # : 0 : if (pm_runtime_suspended(dev) && pm_resume_via_firmware())
# # ]
1053 : 0 : pm_request_resume(dev);
1054 : 0 : }
1055 : : EXPORT_SYMBOL_GPL(acpi_subsys_complete);
1056 : :
1057 : : /**
1058 : : * acpi_subsys_suspend - Run the device driver's suspend callback.
1059 : : * @dev: Device to handle.
1060 : : *
1061 : : * Follow PCI and resume devices from runtime suspend before running their
1062 : : * system suspend callbacks, unless the driver can cope with runtime-suspended
1063 : : * devices during system suspend and there are no ACPI-specific reasons for
1064 : : * resuming them.
1065 : : */
1066 : 0 : int acpi_subsys_suspend(struct device *dev)
1067 : : {
1068 [ # # # # ]: 0 : if (!dev_pm_test_driver_flags(dev, DPM_FLAG_SMART_SUSPEND) ||
1069 [ # # ]: 0 : acpi_dev_needs_resume(dev, ACPI_COMPANION(dev)))
1070 : 0 : pm_runtime_resume(dev);
1071 : :
1072 : 0 : return pm_generic_suspend(dev);
1073 : : }
1074 : : EXPORT_SYMBOL_GPL(acpi_subsys_suspend);
1075 : :
1076 : : /**
1077 : : * acpi_subsys_suspend_late - Suspend device using ACPI.
1078 : : * @dev: Device to suspend.
1079 : : *
1080 : : * Carry out the generic late suspend procedure for @dev and use ACPI to put
1081 : : * it into a low-power state during system transition into a sleep state.
1082 : : */
1083 : 0 : int acpi_subsys_suspend_late(struct device *dev)
1084 : : {
1085 : 0 : int ret;
1086 : :
1087 [ # # ]: 0 : if (dev_pm_smart_suspend_and_suspended(dev))
1088 : : return 0;
1089 : :
1090 : 0 : ret = pm_generic_suspend_late(dev);
1091 [ # # ]: 0 : return ret ? ret : acpi_dev_suspend(dev, device_may_wakeup(dev));
1092 : : }
1093 : : EXPORT_SYMBOL_GPL(acpi_subsys_suspend_late);
1094 : :
1095 : : /**
1096 : : * acpi_subsys_suspend_noirq - Run the device driver's "noirq" suspend callback.
1097 : : * @dev: Device to suspend.
1098 : : */
1099 : 0 : int acpi_subsys_suspend_noirq(struct device *dev)
1100 : : {
1101 : 0 : int ret;
1102 : :
1103 [ # # ]: 0 : if (dev_pm_smart_suspend_and_suspended(dev)) {
1104 : 0 : dev->power.may_skip_resume = true;
1105 : 0 : return 0;
1106 : : }
1107 : :
1108 : 0 : ret = pm_generic_suspend_noirq(dev);
1109 [ # # ]: 0 : if (ret)
1110 : : return ret;
1111 : :
1112 : : /*
1113 : : * If the target system sleep state is suspend-to-idle, it is sufficient
1114 : : * to check whether or not the device's wakeup settings are good for
1115 : : * runtime PM. Otherwise, the pm_resume_via_firmware() check will cause
1116 : : * acpi_subsys_complete() to take care of fixing up the device's state
1117 : : * anyway, if need be.
1118 : : */
1119 [ # # # # : 0 : dev->power.may_skip_resume = device_may_wakeup(dev) ||
# # ]
1120 : : !device_can_wakeup(dev);
1121 : :
1122 : 0 : return 0;
1123 : : }
1124 : : EXPORT_SYMBOL_GPL(acpi_subsys_suspend_noirq);
1125 : :
1126 : : /**
1127 : : * acpi_subsys_resume_noirq - Run the device driver's "noirq" resume callback.
1128 : : * @dev: Device to handle.
1129 : : */
1130 : 0 : static int acpi_subsys_resume_noirq(struct device *dev)
1131 : : {
1132 [ # # ]: 0 : if (dev_pm_may_skip_resume(dev))
1133 : : return 0;
1134 : :
1135 : : /*
1136 : : * Devices with DPM_FLAG_SMART_SUSPEND may be left in runtime suspend
1137 : : * during system suspend, so update their runtime PM status to "active"
1138 : : * as they will be put into D0 going forward.
1139 : : */
1140 [ # # ]: 0 : if (dev_pm_smart_suspend_and_suspended(dev))
1141 : 0 : pm_runtime_set_active(dev);
1142 : :
1143 : 0 : return pm_generic_resume_noirq(dev);
1144 : : }
1145 : :
1146 : : /**
1147 : : * acpi_subsys_resume_early - Resume device using ACPI.
1148 : : * @dev: Device to Resume.
1149 : : *
1150 : : * Use ACPI to put the given device into the full-power state and carry out the
1151 : : * generic early resume procedure for it during system transition into the
1152 : : * working state.
1153 : : */
1154 : 0 : static int acpi_subsys_resume_early(struct device *dev)
1155 : : {
1156 : 0 : int ret = acpi_dev_resume(dev);
1157 [ # # ]: 0 : return ret ? ret : pm_generic_resume_early(dev);
1158 : : }
1159 : :
1160 : : /**
1161 : : * acpi_subsys_freeze - Run the device driver's freeze callback.
1162 : : * @dev: Device to handle.
1163 : : */
1164 : 0 : int acpi_subsys_freeze(struct device *dev)
1165 : : {
1166 : : /*
1167 : : * Resume all runtime-suspended devices before creating a snapshot
1168 : : * image of system memory, because the restore kernel generally cannot
1169 : : * be expected to always handle them consistently and they need to be
1170 : : * put into the runtime-active metastate during system resume anyway,
1171 : : * so it is better to ensure that the state saved in the image will be
1172 : : * always consistent with that.
1173 : : */
1174 : 0 : pm_runtime_resume(dev);
1175 : :
1176 : 0 : return pm_generic_freeze(dev);
1177 : : }
1178 : : EXPORT_SYMBOL_GPL(acpi_subsys_freeze);
1179 : :
1180 : : /**
1181 : : * acpi_subsys_restore_early - Restore device using ACPI.
1182 : : * @dev: Device to restore.
1183 : : */
1184 : 0 : int acpi_subsys_restore_early(struct device *dev)
1185 : : {
1186 : 0 : int ret = acpi_dev_resume(dev);
1187 [ # # ]: 0 : return ret ? ret : pm_generic_restore_early(dev);
1188 : : }
1189 : : EXPORT_SYMBOL_GPL(acpi_subsys_restore_early);
1190 : :
1191 : : /**
1192 : : * acpi_subsys_poweroff - Run the device driver's poweroff callback.
1193 : : * @dev: Device to handle.
1194 : : *
1195 : : * Follow PCI and resume devices from runtime suspend before running their
1196 : : * system poweroff callbacks, unless the driver can cope with runtime-suspended
1197 : : * devices during system suspend and there are no ACPI-specific reasons for
1198 : : * resuming them.
1199 : : */
1200 : 0 : int acpi_subsys_poweroff(struct device *dev)
1201 : : {
1202 [ # # # # ]: 0 : if (!dev_pm_test_driver_flags(dev, DPM_FLAG_SMART_SUSPEND) ||
1203 [ # # ]: 0 : acpi_dev_needs_resume(dev, ACPI_COMPANION(dev)))
1204 : 0 : pm_runtime_resume(dev);
1205 : :
1206 : 0 : return pm_generic_poweroff(dev);
1207 : : }
1208 : : EXPORT_SYMBOL_GPL(acpi_subsys_poweroff);
1209 : :
1210 : : /**
1211 : : * acpi_subsys_poweroff_late - Run the device driver's poweroff callback.
1212 : : * @dev: Device to handle.
1213 : : *
1214 : : * Carry out the generic late poweroff procedure for @dev and use ACPI to put
1215 : : * it into a low-power state during system transition into a sleep state.
1216 : : */
1217 : 0 : static int acpi_subsys_poweroff_late(struct device *dev)
1218 : : {
1219 : 0 : int ret;
1220 : :
1221 [ # # ]: 0 : if (dev_pm_smart_suspend_and_suspended(dev))
1222 : : return 0;
1223 : :
1224 : 0 : ret = pm_generic_poweroff_late(dev);
1225 [ # # ]: 0 : if (ret)
1226 : : return ret;
1227 : :
1228 [ # # ]: 0 : return acpi_dev_suspend(dev, device_may_wakeup(dev));
1229 : : }
1230 : :
1231 : : /**
1232 : : * acpi_subsys_poweroff_noirq - Run the driver's "noirq" poweroff callback.
1233 : : * @dev: Device to suspend.
1234 : : */
1235 : 0 : static int acpi_subsys_poweroff_noirq(struct device *dev)
1236 : : {
1237 [ # # ]: 0 : if (dev_pm_smart_suspend_and_suspended(dev))
1238 : : return 0;
1239 : :
1240 : 0 : return pm_generic_poweroff_noirq(dev);
1241 : : }
1242 : : #endif /* CONFIG_PM_SLEEP */
1243 : :
1244 : : static struct dev_pm_domain acpi_general_pm_domain = {
1245 : : .ops = {
1246 : : .runtime_suspend = acpi_subsys_runtime_suspend,
1247 : : .runtime_resume = acpi_subsys_runtime_resume,
1248 : : #ifdef CONFIG_PM_SLEEP
1249 : : .prepare = acpi_subsys_prepare,
1250 : : .complete = acpi_subsys_complete,
1251 : : .suspend = acpi_subsys_suspend,
1252 : : .suspend_late = acpi_subsys_suspend_late,
1253 : : .suspend_noirq = acpi_subsys_suspend_noirq,
1254 : : .resume_noirq = acpi_subsys_resume_noirq,
1255 : : .resume_early = acpi_subsys_resume_early,
1256 : : .freeze = acpi_subsys_freeze,
1257 : : .poweroff = acpi_subsys_poweroff,
1258 : : .poweroff_late = acpi_subsys_poweroff_late,
1259 : : .poweroff_noirq = acpi_subsys_poweroff_noirq,
1260 : : .restore_early = acpi_subsys_restore_early,
1261 : : #endif
1262 : : },
1263 : : };
1264 : :
1265 : : /**
1266 : : * acpi_dev_pm_detach - Remove ACPI power management from the device.
1267 : : * @dev: Device to take care of.
1268 : : * @power_off: Whether or not to try to remove power from the device.
1269 : : *
1270 : : * Remove the device from the general ACPI PM domain and remove its wakeup
1271 : : * notifier. If @power_off is set, additionally remove power from the device if
1272 : : * possible.
1273 : : *
1274 : : * Callers must ensure proper synchronization of this function with power
1275 : : * management callbacks.
1276 : : */
1277 : 0 : static void acpi_dev_pm_detach(struct device *dev, bool power_off)
1278 : : {
1279 [ # # ]: 0 : struct acpi_device *adev = ACPI_COMPANION(dev);
1280 : :
1281 [ # # # # ]: 0 : if (adev && dev->pm_domain == &acpi_general_pm_domain) {
1282 : 0 : dev_pm_domain_set(dev, NULL);
1283 : 0 : acpi_remove_pm_notifier(adev);
1284 [ # # ]: 0 : if (power_off) {
1285 : : /*
1286 : : * If the device's PM QoS resume latency limit or flags
1287 : : * have been exposed to user space, they have to be
1288 : : * hidden at this point, so that they don't affect the
1289 : : * choice of the low-power state to put the device into.
1290 : : */
1291 : 0 : dev_pm_qos_hide_latency_limit(dev);
1292 : 0 : dev_pm_qos_hide_flags(dev);
1293 : 0 : acpi_device_wakeup_disable(adev);
1294 : 0 : acpi_dev_pm_low_power(dev, adev, ACPI_STATE_S0);
1295 : : }
1296 : : }
1297 : 0 : }
1298 : :
1299 : : /**
1300 : : * acpi_dev_pm_attach - Prepare device for ACPI power management.
1301 : : * @dev: Device to prepare.
1302 : : * @power_on: Whether or not to power on the device.
1303 : : *
1304 : : * If @dev has a valid ACPI handle that has a valid struct acpi_device object
1305 : : * attached to it, install a wakeup notification handler for the device and
1306 : : * add it to the general ACPI PM domain. If @power_on is set, the device will
1307 : : * be put into the ACPI D0 state before the function returns.
1308 : : *
1309 : : * This assumes that the @dev's bus type uses generic power management callbacks
1310 : : * (or doesn't use any power management callbacks at all).
1311 : : *
1312 : : * Callers must ensure proper synchronization of this function with power
1313 : : * management callbacks.
1314 : : */
1315 : 39 : int acpi_dev_pm_attach(struct device *dev, bool power_on)
1316 : : {
1317 : : /*
1318 : : * Skip devices whose ACPI companions match the device IDs below,
1319 : : * because they require special power management handling incompatible
1320 : : * with the generic ACPI PM domain.
1321 : : */
1322 : 39 : static const struct acpi_device_id special_pm_ids[] = {
1323 : : {"PNP0C0B", }, /* Generic ACPI fan */
1324 : : {"INT1044", }, /* Fan for Tiger Lake generation */
1325 : : {"INT3404", }, /* Fan */
1326 : : {}
1327 : : };
1328 [ - + ]: 39 : struct acpi_device *adev = ACPI_COMPANION(dev);
1329 : :
1330 [ # # # # ]: 0 : if (!adev || !acpi_match_device_ids(adev, special_pm_ids))
1331 : 39 : return 0;
1332 : :
1333 : : /*
1334 : : * Only attach the power domain to the first device if the
1335 : : * companion is shared by multiple. This is to prevent doing power
1336 : : * management twice.
1337 : : */
1338 [ # # ]: 0 : if (!acpi_device_is_first_physical_node(adev, dev))
1339 : : return 0;
1340 : :
1341 : 0 : acpi_add_pm_notifier(adev, dev, acpi_pm_notify_work_func);
1342 : 0 : dev_pm_domain_set(dev, &acpi_general_pm_domain);
1343 [ # # ]: 0 : if (power_on) {
1344 [ # # ]: 0 : acpi_dev_pm_full_power(adev);
1345 : 0 : acpi_device_wakeup_disable(adev);
1346 : : }
1347 : :
1348 : 0 : dev->pm_domain->detach = acpi_dev_pm_detach;
1349 : 0 : return 1;
1350 : : }
1351 : : EXPORT_SYMBOL_GPL(acpi_dev_pm_attach);
1352 : : #endif /* CONFIG_PM */
|