diff options
Diffstat (limited to 'kernel/power/user.c')
| -rw-r--r-- | kernel/power/user.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/kernel/power/user.c b/kernel/power/user.c index c36c3b9e8a84..7d02d33be699 100644 --- a/kernel/power/user.c +++ b/kernel/power/user.c | |||
| @@ -135,8 +135,10 @@ static int snapshot_release(struct inode *inode, struct file *filp) | |||
| 135 | free_basic_memory_bitmaps(); | 135 | free_basic_memory_bitmaps(); |
| 136 | data = filp->private_data; | 136 | data = filp->private_data; |
| 137 | free_all_swap_pages(data->swap); | 137 | free_all_swap_pages(data->swap); |
| 138 | if (data->frozen) | 138 | if (data->frozen) { |
| 139 | pm_restore_gfp_mask(); | ||
| 139 | thaw_processes(); | 140 | thaw_processes(); |
| 141 | } | ||
| 140 | pm_notifier_call_chain(data->mode == O_RDONLY ? | 142 | pm_notifier_call_chain(data->mode == O_RDONLY ? |
| 141 | PM_POST_HIBERNATION : PM_POST_RESTORE); | 143 | PM_POST_HIBERNATION : PM_POST_RESTORE); |
| 142 | atomic_inc(&snapshot_device_available); | 144 | atomic_inc(&snapshot_device_available); |
| @@ -379,6 +381,7 @@ static long snapshot_ioctl(struct file *filp, unsigned int cmd, | |||
| 379 | * PM_HIBERNATION_PREPARE | 381 | * PM_HIBERNATION_PREPARE |
| 380 | */ | 382 | */ |
| 381 | error = suspend_devices_and_enter(PM_SUSPEND_MEM); | 383 | error = suspend_devices_and_enter(PM_SUSPEND_MEM); |
| 384 | data->ready = 0; | ||
| 382 | break; | 385 | break; |
| 383 | 386 | ||
| 384 | case SNAPSHOT_PLATFORM_SUPPORT: | 387 | case SNAPSHOT_PLATFORM_SUPPORT: |
