diff options
| author | Srivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com> | 2012-02-04 16:26:38 -0500 |
|---|---|---|
| committer | Rafael J. Wysocki <rjw@sisk.pl> | 2012-02-09 17:55:54 -0500 |
| commit | 51d6ff7acd920379f54d0be4dbe844a46178a65f (patch) | |
| tree | b016233eaf9dd4f1698ca6e8e649d1df905a48ec /kernel/power | |
| parent | 9045a05044268b075c13bb0284601b24959dc3c6 (diff) | |
PM / Hibernate: Thaw kernel threads in hibernation_snapshot() in error/test path
In the hibernation call path, the kernel threads are frozen inside
hibernation_snapshot(). If we happen to encounter an error further down
the road or if we are exiting early due to a successful freezer test,
then thaw kernel threads before returning to the caller.
Signed-off-by: Srivatsa S. Bhat <srivatsa.bhat@linux.vnet.ibm.com>
Acked-by: Tejun Heo <tj@kernel.org>
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Diffstat (limited to 'kernel/power')
| -rw-r--r-- | kernel/power/hibernate.c | 6 | ||||
| -rw-r--r-- | kernel/power/user.c | 8 |
2 files changed, 6 insertions, 8 deletions
diff --git a/kernel/power/hibernate.c b/kernel/power/hibernate.c index a5d4cf0aa03e..c6dee739080c 100644 --- a/kernel/power/hibernate.c +++ b/kernel/power/hibernate.c | |||
| @@ -343,13 +343,13 @@ int hibernation_snapshot(int platform_mode) | |||
| 343 | * successful freezer test. | 343 | * successful freezer test. |
| 344 | */ | 344 | */ |
| 345 | freezer_test_done = true; | 345 | freezer_test_done = true; |
| 346 | goto Cleanup; | 346 | goto Thaw; |
| 347 | } | 347 | } |
| 348 | 348 | ||
| 349 | error = dpm_prepare(PMSG_FREEZE); | 349 | error = dpm_prepare(PMSG_FREEZE); |
| 350 | if (error) { | 350 | if (error) { |
| 351 | dpm_complete(PMSG_RECOVER); | 351 | dpm_complete(PMSG_RECOVER); |
| 352 | goto Cleanup; | 352 | goto Thaw; |
| 353 | } | 353 | } |
| 354 | 354 | ||
| 355 | suspend_console(); | 355 | suspend_console(); |
| @@ -385,6 +385,8 @@ int hibernation_snapshot(int platform_mode) | |||
| 385 | platform_end(platform_mode); | 385 | platform_end(platform_mode); |
| 386 | return error; | 386 | return error; |
| 387 | 387 | ||
| 388 | Thaw: | ||
| 389 | thaw_kernel_threads(); | ||
| 388 | Cleanup: | 390 | Cleanup: |
| 389 | swsusp_free(); | 391 | swsusp_free(); |
| 390 | goto Close; | 392 | goto Close; |
diff --git a/kernel/power/user.c b/kernel/power/user.c index 3e100075b13c..7bee91f9af51 100644 --- a/kernel/power/user.c +++ b/kernel/power/user.c | |||
| @@ -249,16 +249,12 @@ static long snapshot_ioctl(struct file *filp, unsigned int cmd, | |||
| 249 | } | 249 | } |
| 250 | pm_restore_gfp_mask(); | 250 | pm_restore_gfp_mask(); |
| 251 | error = hibernation_snapshot(data->platform_support); | 251 | error = hibernation_snapshot(data->platform_support); |
| 252 | if (error) { | 252 | if (!error) { |
| 253 | thaw_kernel_threads(); | ||
| 254 | } else { | ||
| 255 | error = put_user(in_suspend, (int __user *)arg); | 253 | error = put_user(in_suspend, (int __user *)arg); |
| 256 | if (!error && !freezer_test_done) | 254 | if (!error && !freezer_test_done) |
| 257 | data->ready = 1; | 255 | data->ready = 1; |
| 258 | if (freezer_test_done) { | 256 | if (freezer_test_done) |
| 259 | freezer_test_done = false; | 257 | freezer_test_done = false; |
| 260 | thaw_kernel_threads(); | ||
| 261 | } | ||
| 262 | } | 258 | } |
| 263 | break; | 259 | break; |
| 264 | 260 | ||
