suspend.c 14.1 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
/*
 * kernel/power/suspend.c - Suspend to RAM and standby functionality.
 *
 * Copyright (c) 2003 Patrick Mochel
 * Copyright (c) 2003 Open Source Development Lab
 * Copyright (c) 2009 Rafael J. Wysocki <rjw@sisk.pl>, Novell Inc.
 *
 * This file is released under the GPLv2.
 */

#include <linux/string.h>
#include <linux/delay.h>
#include <linux/errno.h>
#include <linux/init.h>
#include <linux/console.h>
#include <linux/cpu.h>
17
#include <linux/cpuidle.h>
18
#include <linux/syscalls.h>
19
#include <linux/gfp.h>
20 21 22 23 24
#include <linux/io.h>
#include <linux/kernel.h>
#include <linux/list.h>
#include <linux/mm.h>
#include <linux/slab.h>
25
#include <linux/export.h>
26
#include <linux/suspend.h>
27
#include <linux/syscore_ops.h>
28
#include <linux/ftrace.h>
29
#include <trace/events/power.h>
30
#include <linux/compiler.h>
31
#include <linux/moduleparam.h>
32 33 34

#include "power.h"

35 36 37 38 39
const char * const pm_labels[] = {
	[PM_SUSPEND_FREEZE] = "freeze",
	[PM_SUSPEND_STANDBY] = "standby",
	[PM_SUSPEND_MEM] = "mem",
};
40
const char *pm_states[PM_SUSPEND_MAX];
41 42 43 44 45 46 47 48
static const char * const mem_sleep_labels[] = {
	[PM_SUSPEND_FREEZE] = "s2idle",
	[PM_SUSPEND_STANDBY] = "shallow",
	[PM_SUSPEND_MEM] = "deep",
};
const char *mem_sleep_states[PM_SUSPEND_MAX];

suspend_state_t mem_sleep_current = PM_SUSPEND_FREEZE;
49
static suspend_state_t mem_sleep_default = PM_SUSPEND_MEM;
50

51 52 53
unsigned int pm_suspend_global_flags;
EXPORT_SYMBOL_GPL(pm_suspend_global_flags);

54
static const struct platform_suspend_ops *suspend_ops;
55
static const struct platform_freeze_ops *freeze_ops;
56
static DECLARE_WAIT_QUEUE_HEAD(suspend_freeze_wait_head);
57 58 59

enum freeze_state __read_mostly suspend_freeze_state;
static DEFINE_SPINLOCK(suspend_freeze_lock);
60

61 62 63 64 65 66 67
void freeze_set_ops(const struct platform_freeze_ops *ops)
{
	lock_system_sleep();
	freeze_ops = ops;
	unlock_system_sleep();
}

68 69
static void freeze_begin(void)
{
70
	suspend_freeze_state = FREEZE_STATE_NONE;
71 72 73 74
}

static void freeze_enter(void)
{
75 76 77 78 79 80 81 82
	spin_lock_irq(&suspend_freeze_lock);
	if (pm_wakeup_pending())
		goto out;

	suspend_freeze_state = FREEZE_STATE_ENTER;
	spin_unlock_irq(&suspend_freeze_lock);

	get_online_cpus();
83
	cpuidle_resume();
84 85 86 87 88 89 90 91 92

	/* Push all the CPUs into the idle loop. */
	wake_up_all_idle_cpus();
	pr_debug("PM: suspend-to-idle\n");
	/* Make the current CPU wait so it can enter the idle loop too. */
	wait_event(suspend_freeze_wait_head,
		   suspend_freeze_state == FREEZE_STATE_WAKE);
	pr_debug("PM: resume from suspend-to-idle\n");

93
	cpuidle_pause();
94 95 96 97 98 99 100
	put_online_cpus();

	spin_lock_irq(&suspend_freeze_lock);

 out:
	suspend_freeze_state = FREEZE_STATE_NONE;
	spin_unlock_irq(&suspend_freeze_lock);
101 102 103 104
}

void freeze_wake(void)
{
105 106 107 108 109 110 111 112
	unsigned long flags;

	spin_lock_irqsave(&suspend_freeze_lock, flags);
	if (suspend_freeze_state > FREEZE_STATE_NONE) {
		suspend_freeze_state = FREEZE_STATE_WAKE;
		wake_up(&suspend_freeze_wait_head);
	}
	spin_unlock_irqrestore(&suspend_freeze_lock, flags);
113 114 115
}
EXPORT_SYMBOL_GPL(freeze_wake);

116 117 118 119 120 121 122 123 124 125
static bool valid_state(suspend_state_t state)
{
	/*
	 * PM_SUSPEND_STANDBY and PM_SUSPEND_MEM states need low level
	 * support and need to be valid to the low level
	 * implementation, no valid callback implies that none are valid.
	 */
	return suspend_ops && suspend_ops->valid && suspend_ops->valid(state);
}

126 127
void __init pm_states_init(void)
{
128 129 130
	/* "mem" and "freeze" are always present in /sys/power/state. */
	pm_states[PM_SUSPEND_MEM] = pm_labels[PM_SUSPEND_MEM];
	pm_states[PM_SUSPEND_FREEZE] = pm_labels[PM_SUSPEND_FREEZE];
131
	/*
132 133
	 * Suspend-to-idle should be supported even without any suspend_ops,
	 * initialize mem_sleep_states[] accordingly here.
134
	 */
135
	mem_sleep_states[PM_SUSPEND_FREEZE] = mem_sleep_labels[PM_SUSPEND_FREEZE];
136 137
}

138
static int __init mem_sleep_default_setup(char *str)
139
{
140 141 142 143 144 145 146 147 148
	suspend_state_t state;

	for (state = PM_SUSPEND_FREEZE; state <= PM_SUSPEND_MEM; state++)
		if (mem_sleep_labels[state] &&
		    !strcmp(str, mem_sleep_labels[state])) {
			mem_sleep_default = state;
			break;
		}

149 150
	return 1;
}
151
__setup("mem_sleep_default=", mem_sleep_default_setup);
152

153
/**
154 155
 * suspend_set_ops - Set the global suspend method table.
 * @ops: Suspend operations to use.
156
 */
157
void suspend_set_ops(const struct platform_suspend_ops *ops)
158
{
159
	lock_system_sleep();
160

161
	suspend_ops = ops;
162

163 164 165 166 167 168 169 170
	if (valid_state(PM_SUSPEND_STANDBY)) {
		mem_sleep_states[PM_SUSPEND_STANDBY] = mem_sleep_labels[PM_SUSPEND_STANDBY];
		pm_states[PM_SUSPEND_STANDBY] = pm_labels[PM_SUSPEND_STANDBY];
		if (mem_sleep_default == PM_SUSPEND_STANDBY)
			mem_sleep_current = PM_SUSPEND_STANDBY;
	}
	if (valid_state(PM_SUSPEND_MEM)) {
		mem_sleep_states[PM_SUSPEND_MEM] = mem_sleep_labels[PM_SUSPEND_MEM];
171
		if (mem_sleep_default == PM_SUSPEND_MEM)
172 173
			mem_sleep_current = PM_SUSPEND_MEM;
	}
174

175
	unlock_system_sleep();
176
}
177
EXPORT_SYMBOL_GPL(suspend_set_ops);
178 179

/**
180
 * suspend_valid_only_mem - Generic memory-only valid callback.
181
 *
182 183 184
 * Platform drivers that implement mem suspend only and only need to check for
 * that in their .valid() callback can use this instead of rolling their own
 * .valid() callback.
185 186 187 188 189
 */
int suspend_valid_only_mem(suspend_state_t state)
{
	return state == PM_SUSPEND_MEM;
}
190
EXPORT_SYMBOL_GPL(suspend_valid_only_mem);
191

192 193 194 195 196 197 198 199 200 201 202
static bool sleep_state_supported(suspend_state_t state)
{
	return state == PM_SUSPEND_FREEZE || (suspend_ops && suspend_ops->enter);
}

static int platform_suspend_prepare(suspend_state_t state)
{
	return state != PM_SUSPEND_FREEZE && suspend_ops->prepare ?
		suspend_ops->prepare() : 0;
}

203 204
static int platform_suspend_prepare_late(suspend_state_t state)
{
205
	return state == PM_SUSPEND_FREEZE && freeze_ops && freeze_ops->prepare ?
206 207 208
		freeze_ops->prepare() : 0;
}

209
static int platform_suspend_prepare_noirq(suspend_state_t state)
210 211 212 213 214
{
	return state != PM_SUSPEND_FREEZE && suspend_ops->prepare_late ?
		suspend_ops->prepare_late() : 0;
}

215
static void platform_resume_noirq(suspend_state_t state)
216 217 218 219 220
{
	if (state != PM_SUSPEND_FREEZE && suspend_ops->wake)
		suspend_ops->wake();
}

221 222
static void platform_resume_early(suspend_state_t state)
{
223
	if (state == PM_SUSPEND_FREEZE && freeze_ops && freeze_ops->restore)
224 225 226
		freeze_ops->restore();
}

227
static void platform_resume_finish(suspend_state_t state)
228 229 230 231 232 233 234 235 236
{
	if (state != PM_SUSPEND_FREEZE && suspend_ops->finish)
		suspend_ops->finish();
}

static int platform_suspend_begin(suspend_state_t state)
{
	if (state == PM_SUSPEND_FREEZE && freeze_ops && freeze_ops->begin)
		return freeze_ops->begin();
237
	else if (suspend_ops && suspend_ops->begin)
238 239 240 241 242
		return suspend_ops->begin(state);
	else
		return 0;
}

243
static void platform_resume_end(suspend_state_t state)
244 245 246
{
	if (state == PM_SUSPEND_FREEZE && freeze_ops && freeze_ops->end)
		freeze_ops->end();
247
	else if (suspend_ops && suspend_ops->end)
248 249 250
		suspend_ops->end();
}

251
static void platform_recover(suspend_state_t state)
252 253 254 255 256 257 258 259 260 261 262
{
	if (state != PM_SUSPEND_FREEZE && suspend_ops->recover)
		suspend_ops->recover();
}

static bool platform_suspend_again(suspend_state_t state)
{
	return state != PM_SUSPEND_FREEZE && suspend_ops->suspend_again ?
		suspend_ops->suspend_again() : false;
}

263 264 265 266 267 268 269
#ifdef CONFIG_PM_DEBUG
static unsigned int pm_test_delay = 5;
module_param(pm_test_delay, uint, 0644);
MODULE_PARM_DESC(pm_test_delay,
		 "Number of seconds to wait before resuming from suspend test");
#endif

270 271 272 273
static int suspend_test(int level)
{
#ifdef CONFIG_PM_DEBUG
	if (pm_test_level == level) {
S
saurabh 已提交
274
		pr_info("suspend debug: Waiting for %d second(s).\n",
275 276
				pm_test_delay);
		mdelay(pm_test_delay * 1000);
277 278 279 280 281 282 283
		return 1;
	}
#endif /* !CONFIG_PM_DEBUG */
	return 0;
}

/**
284
 * suspend_prepare - Prepare for entering system sleep state.
285
 *
286 287 288
 * Common code run for every system sleep state that can be entered (except for
 * hibernation).  Run suspend notifiers, allocate the "suspend" console and
 * freeze processes.
289
 */
290
static int suspend_prepare(suspend_state_t state)
291
{
292
	int error, nr_calls = 0;
293

294
	if (!sleep_state_supported(state))
295 296 297 298
		return -EPERM;

	pm_prepare_console();

299 300 301
	error = __pm_notifier_call_chain(PM_SUSPEND_PREPARE, -1, &nr_calls);
	if (error) {
		nr_calls--;
302
		goto Finish;
303
	}
304

305
	trace_suspend_resume(TPS("freeze_processes"), 0, true);
306
	error = suspend_freeze_processes();
307
	trace_suspend_resume(TPS("freeze_processes"), 0, false);
308
	if (!error)
309 310
		return 0;

311 312
	suspend_stats.failed_freeze++;
	dpm_save_failed_step(SUSPEND_FREEZE);
313
 Finish:
314
	__pm_notifier_call_chain(PM_POST_SUSPEND, nr_calls, NULL);
315 316 317 318 319
	pm_restore_console();
	return error;
}

/* default implementation */
320
void __weak arch_suspend_disable_irqs(void)
321 322 323 324 325
{
	local_irq_disable();
}

/* default implementation */
326
void __weak arch_suspend_enable_irqs(void)
327 328 329 330 331
{
	local_irq_enable();
}

/**
332 333 334
 * suspend_enter - Make the system enter the given sleep state.
 * @state: System sleep state to enter.
 * @wakeup: Returns information that the sleep state should not be re-entered.
335
 *
336
 * This function should be called after devices have been suspended.
337
 */
338
static int suspend_enter(suspend_state_t state, bool *wakeup)
339 340 341
{
	int error;

342 343 344
	error = platform_suspend_prepare(state);
	if (error)
		goto Platform_finish;
345

346
	error = dpm_suspend_late(PMSG_SUSPEND);
347
	if (error) {
S
saurabh 已提交
348
		pr_err("PM: late suspend of devices failed\n");
349
		goto Platform_finish;
350
	}
351 352 353 354
	error = platform_suspend_prepare_late(state);
	if (error)
		goto Devices_early_resume;

355 356
	error = dpm_suspend_noirq(PMSG_SUSPEND);
	if (error) {
S
saurabh 已提交
357
		pr_err("PM: noirq suspend of devices failed\n");
358
		goto Platform_early_resume;
359
	}
360
	error = platform_suspend_prepare_noirq(state);
361 362
	if (error)
		goto Platform_wake;
363

364 365 366
	if (suspend_test(TEST_PLATFORM))
		goto Platform_wake;

367 368 369 370 371 372 373
	/*
	 * PM_SUSPEND_FREEZE equals
	 * frozen processes + suspended devices + idle processors.
	 * Thus we should invoke freeze_enter() soon after
	 * all the devices are suspended.
	 */
	if (state == PM_SUSPEND_FREEZE) {
374 375 376 377
		trace_suspend_resume(TPS("machine_suspend"), state, true);
		freeze_enter();
		trace_suspend_resume(TPS("machine_suspend"), state, false);
		goto Platform_wake;
378 379
	}

380 381 382 383 384 385 386
	error = disable_nonboot_cpus();
	if (error || suspend_test(TEST_CPUS))
		goto Enable_cpus;

	arch_suspend_disable_irqs();
	BUG_ON(!irqs_disabled());

387
	error = syscore_suspend();
388
	if (!error) {
389 390
		*wakeup = pm_wakeup_pending();
		if (!(suspend_test(TEST_CORE) || *wakeup)) {
391 392
			trace_suspend_resume(TPS("machine_suspend"),
				state, true);
393
			error = suspend_ops->enter(state);
394 395
			trace_suspend_resume(TPS("machine_suspend"),
				state, false);
396
			events_check_enabled = false;
397 398
		} else if (*wakeup) {
			error = -EBUSY;
399
		}
400
		syscore_resume();
401 402 403 404 405 406 407 408 409
	}

	arch_suspend_enable_irqs();
	BUG_ON(irqs_disabled());

 Enable_cpus:
	enable_nonboot_cpus();

 Platform_wake:
410
	platform_resume_noirq(state);
411 412
	dpm_resume_noirq(PMSG_RESUME);

413 414 415
 Platform_early_resume:
	platform_resume_early(state);

416 417
 Devices_early_resume:
	dpm_resume_early(PMSG_RESUME);
418

419
 Platform_finish:
420
	platform_resume_finish(state);
421 422 423 424
	return error;
}

/**
425 426
 * suspend_devices_and_enter - Suspend devices and enter system sleep state.
 * @state: System sleep state to enter.
427 428 429 430
 */
int suspend_devices_and_enter(suspend_state_t state)
{
	int error;
431
	bool wakeup = false;
432

433
	if (!sleep_state_supported(state))
434 435
		return -ENOSYS;

436 437 438 439
	error = platform_suspend_begin(state);
	if (error)
		goto Close;

440 441 442 443
	suspend_console();
	suspend_test_start();
	error = dpm_suspend_start(PMSG_SUSPEND);
	if (error) {
444
		pr_err("PM: Some devices failed to suspend, or early wake event detected\n");
445 446 447 448 449 450
		goto Recover_platform;
	}
	suspend_test_finish("suspend devices");
	if (suspend_test(TEST_DEVICES))
		goto Recover_platform;

451 452
	do {
		error = suspend_enter(state, &wakeup);
453
	} while (!error && !wakeup && platform_suspend_again(state));
454 455 456 457 458

 Resume_devices:
	suspend_test_start();
	dpm_resume_end(PMSG_RESUME);
	suspend_test_finish("resume devices");
459
	trace_suspend_resume(TPS("resume_console"), state, true);
460
	resume_console();
461
	trace_suspend_resume(TPS("resume_console"), state, false);
462

463
 Close:
464
	platform_resume_end(state);
465 466 467
	return error;

 Recover_platform:
468
	platform_recover(state);
469 470 471 472
	goto Resume_devices;
}

/**
473
 * suspend_finish - Clean up before finishing the suspend sequence.
474
 *
475 476
 * Call platform code to clean up, restart processes, and free the console that
 * we've allocated. This routine is not called for hibernation.
477 478 479 480 481 482 483 484 485
 */
static void suspend_finish(void)
{
	suspend_thaw_processes();
	pm_notifier_call_chain(PM_POST_SUSPEND);
	pm_restore_console();
}

/**
486 487
 * enter_state - Do common work needed to enter system sleep state.
 * @state: System sleep state to enter.
488
 *
489 490 491
 * Make sure that no one else is trying to put the system into a sleep state.
 * Fail if that's not the case.  Otherwise, prepare for system suspend, make the
 * system enter the given sleep state and clean up after wakeup.
492
 */
493
static int enter_state(suspend_state_t state)
494 495 496
{
	int error;

497
	trace_suspend_resume(TPS("suspend_enter"), state, true);
498 499 500
	if (state == PM_SUSPEND_FREEZE) {
#ifdef CONFIG_PM_DEBUG
		if (pm_test_level != TEST_NONE && pm_test_level <= TEST_CPUS) {
501
			pr_warn("PM: Unsupported test mode for suspend to idle, please choose none/freezer/devices/platform.\n");
502 503 504 505 506 507
			return -EAGAIN;
		}
#endif
	} else if (!valid_state(state)) {
		return -EINVAL;
	}
508 509 510
	if (!mutex_trylock(&pm_mutex))
		return -EBUSY;

511 512 513
	if (state == PM_SUSPEND_FREEZE)
		freeze_begin();

514
#ifndef CONFIG_SUSPEND_SKIP_SYNC
515
	trace_suspend_resume(TPS("sync_filesystems"), 0, true);
516
	pr_info("PM: Syncing filesystems ... ");
517
	sys_sync();
518
	pr_cont("done.\n");
519
	trace_suspend_resume(TPS("sync_filesystems"), 0, false);
520
#endif
521

522
	pr_debug("PM: Preparing system for sleep (%s)\n", pm_states[state]);
523
	pm_suspend_clear_flags();
524
	error = suspend_prepare(state);
525 526 527 528 529 530
	if (error)
		goto Unlock;

	if (suspend_test(TEST_FREEZER))
		goto Finish;

531
	trace_suspend_resume(TPS("suspend_enter"), state, false);
532
	pr_debug("PM: Suspending system (%s)\n", pm_states[state]);
533
	pm_restrict_gfp_mask();
534
	error = suspend_devices_and_enter(state);
535
	pm_restore_gfp_mask();
536 537 538 539 540 541 542 543 544 545

 Finish:
	pr_debug("PM: Finishing wakeup.\n");
	suspend_finish();
 Unlock:
	mutex_unlock(&pm_mutex);
	return error;
}

/**
546 547
 * pm_suspend - Externally visible function for suspending the system.
 * @state: System sleep state to enter.
548
 *
549 550
 * Check if the value of @state represents one of the supported states,
 * execute enter_state() and update system suspend statistics.
551 552 553
 */
int pm_suspend(suspend_state_t state)
{
554 555 556 557 558 559 560 561 562 563 564
	int error;

	if (state <= PM_SUSPEND_ON || state >= PM_SUSPEND_MAX)
		return -EINVAL;

	error = enter_state(state);
	if (error) {
		suspend_stats.fail++;
		dpm_save_failed_errno(error);
	} else {
		suspend_stats.success++;
565
	}
566
	return error;
567 568
}
EXPORT_SYMBOL(pm_suspend);