Re: PATCH swsusp: page rellocation speed up

From: hugang
Date: Wed Jan 12 2005 - 08:50:29 EST


On Wed, Jan 12, 2005 at 08:49:49PM +0800, hugang@xxxxxxxxxxxx wrote:
> On Tue, Jan 11, 2005 at 02:01:23AM +0100, Lukas Hejtmanek wrote:
> > Hello,
> >
> > attached patch should speed up page rellocation at time of resume. Please test.
> > The diff is against 2.6.10-bk8
> >
> ....
>
> really cool, Passed in my x86 and ppc.
>
> Here is a patch to make pagedir using non-continuity page,
> 2.6.10 -> mm1 -> this patch -> my patch
>
...

After more deep test, I found A bug, Here is a patch to fix it.

--- 2.6.10-mm1-one-pbe-hg/kernel/power/pbe.h~mail 2005-01-12 21:10:39.000000000 +0800
+++ 2.6.10-mm1-one-pbe-hg/kernel/power/pbe.h 2005-01-12 21:21:41.000000000 +0800
@@ -267,7 +267,7 @@ static int __init check_pagedir(void)
{
void **c, *f;
struct pbe *next, *pos;
- int error, index, i;
+ int error, index;
suspend_pagedir_t *addr = NULL;
struct zone *zone;
unsigned long zone_pfn;
@@ -280,8 +280,9 @@ static int __init check_pagedir(void)
}

/* Clear orig address */
- pbe_for_each(pos, next, i, nr_copy_pages, pagedir_nosave) {
- pr_debug("clear <%p>\n", (void*)pos->orig_address);
+ pbe_for_each(pos, next, index, nr_copy_pages, pagedir_nosave) {
+ pr_debug("clear <%p>, <%p>, %d\n",
+ pos, (void*)pos->orig_address, index);
ClearPageNosaveFree(virt_to_page(pos->orig_address));
}

--- 2.6.10-mm1-one-pbe-hg/kernel/power/swsusp.c~mail 2005-01-12 21:10:43.000000000 +0800
+++ 2.6.10-mm1-one-pbe-hg/kernel/power/swsusp.c 2005-01-12 21:43:41.000000000 +0800
@@ -380,6 +380,8 @@ static int write_pagedir(void)

pgdir_for_each(pgdir, next, pagedir_nosave) {
error = write_page((unsigned long)pgdir, &swsusp_info.pagedir[n]);
+ pr_debug("write_pagedir: <%p>, %lu\n",
+ pgdir, swp_offset(swsusp_info.pagedir[n]));
if (error) break;
n ++;
}
@@ -1008,6 +1010,7 @@ static int __init read_pagedir(void)
pgdir_for_each(pgdir, next, pagedir_nosave) {
error = read_one_pagedir(pgdir, i);
if (error) break;
+ pgdir[ONE_PAGE_PBE_NUM-1].dummy.val = next ? next->dummy.val : 0;
i++;
}
BUG_ON(i != n);

--
Hu Gang .-.
/v\
// \\
Linux User /( )\ [204016]
GPG Key ID ^^-^^ http://soulinfo.com/~hugang/hugang.asc
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/