diff options
Diffstat (limited to 'kernel/power/swsusp.c')
| -rw-r--r-- | kernel/power/swsusp.c | 14 |
1 files changed, 10 insertions, 4 deletions
diff --git a/kernel/power/swsusp.c b/kernel/power/swsusp.c index 17f669c83012..0b66659dc516 100644 --- a/kernel/power/swsusp.c +++ b/kernel/power/swsusp.c | |||
| @@ -193,14 +193,13 @@ int swsusp_shrink_memory(void) | |||
| 193 | printk("Shrinking memory... "); | 193 | printk("Shrinking memory... "); |
| 194 | do { | 194 | do { |
| 195 | size = 2 * count_highmem_pages(); | 195 | size = 2 * count_highmem_pages(); |
| 196 | size += size / 50 + count_data_pages(); | 196 | size += size / 50 + count_data_pages() + PAGES_FOR_IO; |
| 197 | size += (size + PBES_PER_PAGE - 1) / PBES_PER_PAGE + | ||
| 198 | PAGES_FOR_IO; | ||
| 199 | tmp = size; | 197 | tmp = size; |
| 200 | for_each_zone (zone) | 198 | for_each_zone (zone) |
| 201 | if (!is_highmem(zone) && populated_zone(zone)) { | 199 | if (!is_highmem(zone) && populated_zone(zone)) { |
| 202 | tmp -= zone->free_pages; | 200 | tmp -= zone->free_pages; |
| 203 | tmp += zone->lowmem_reserve[ZONE_NORMAL]; | 201 | tmp += zone->lowmem_reserve[ZONE_NORMAL]; |
| 202 | tmp += snapshot_additional_pages(zone); | ||
| 204 | } | 203 | } |
| 205 | if (tmp > 0) { | 204 | if (tmp > 0) { |
| 206 | tmp = __shrink_memory(tmp); | 205 | tmp = __shrink_memory(tmp); |
| @@ -248,6 +247,9 @@ int swsusp_suspend(void) | |||
| 248 | restore_processor_state(); | 247 | restore_processor_state(); |
| 249 | Restore_highmem: | 248 | Restore_highmem: |
| 250 | restore_highmem(); | 249 | restore_highmem(); |
| 250 | /* NOTE: device_power_up() is just a resume() for devices | ||
| 251 | * that suspended with irqs off ... no overall powerup. | ||
| 252 | */ | ||
| 251 | device_power_up(); | 253 | device_power_up(); |
| 252 | Enable_irqs: | 254 | Enable_irqs: |
| 253 | local_irq_enable(); | 255 | local_irq_enable(); |
| @@ -257,8 +259,12 @@ Enable_irqs: | |||
| 257 | int swsusp_resume(void) | 259 | int swsusp_resume(void) |
| 258 | { | 260 | { |
| 259 | int error; | 261 | int error; |
| 262 | |||
| 260 | local_irq_disable(); | 263 | local_irq_disable(); |
| 261 | if (device_power_down(PMSG_FREEZE)) | 264 | /* NOTE: device_power_down() is just a suspend() with irqs off; |
| 265 | * it has no special "power things down" semantics | ||
| 266 | */ | ||
| 267 | if (device_power_down(PMSG_PRETHAW)) | ||
| 262 | printk(KERN_ERR "Some devices failed to power down, very bad\n"); | 268 | printk(KERN_ERR "Some devices failed to power down, very bad\n"); |
| 263 | /* We'll ignore saved state, but this gets preempt count (etc) right */ | 269 | /* We'll ignore saved state, but this gets preempt count (etc) right */ |
| 264 | save_processor_state(); | 270 | save_processor_state(); |
