Commit 1f585447 authored by Andrew Morton's avatar Andrew Morton Committed by Patrick Mochel

[PATCH] swsusp: do not oops after allocation failure

From: Pavel Machek <pavel@ucw.cz>

This checks error return from swsusp_alloc, preventing oops when memory can
not be allocated.
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
parent 19318566
...@@ -677,9 +677,9 @@ static int alloc_pagedir(void) ...@@ -677,9 +677,9 @@ static int alloc_pagedir(void)
calc_order(); calc_order();
pagedir_save = (suspend_pagedir_t *)__get_free_pages(GFP_ATOMIC | __GFP_COLD, pagedir_save = (suspend_pagedir_t *)__get_free_pages(GFP_ATOMIC | __GFP_COLD,
pagedir_order); pagedir_order);
if(!pagedir_save) if (!pagedir_save)
return -ENOMEM; return -ENOMEM;
memset(pagedir_save,0,(1 << pagedir_order) * PAGE_SIZE); memset(pagedir_save, 0, (1 << pagedir_order) * PAGE_SIZE);
pagedir_nosave = pagedir_save; pagedir_nosave = pagedir_save;
return 0; return 0;
} }
...@@ -784,6 +784,7 @@ static int swsusp_alloc(void) ...@@ -784,6 +784,7 @@ static int swsusp_alloc(void)
int suspend_prepare_image(void) int suspend_prepare_image(void)
{ {
unsigned int nr_needed_pages = 0; unsigned int nr_needed_pages = 0;
int error;
pr_debug("swsusp: critical section: \n"); pr_debug("swsusp: critical section: \n");
if (save_highmem()) { if (save_highmem()) {
...@@ -796,7 +797,9 @@ int suspend_prepare_image(void) ...@@ -796,7 +797,9 @@ int suspend_prepare_image(void)
printk("swsusp: Need to copy %u pages\n",nr_copy_pages); printk("swsusp: Need to copy %u pages\n",nr_copy_pages);
nr_needed_pages = nr_copy_pages + PAGES_FOR_IO; nr_needed_pages = nr_copy_pages + PAGES_FOR_IO;
swsusp_alloc(); error = swsusp_alloc();
if (error)
return error;
/* During allocating of suspend pagedir, new cold pages may appear. /* During allocating of suspend pagedir, new cold pages may appear.
* Kill them. * Kill them.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment