diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2006-04-18 22:20:29 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-04-19 09:13:49 -0700 |
commit | 4a3b98a422a20dedf3a2a40c44892d6e7e665157 (patch) | |
tree | 24387ffda32d2d7a8582116cd39654bf1fac19fe /mm/slob.c | |
parent | 8db08de4f6ae24e90aedf5125b5ddd52ffff15f4 (diff) | |
download | lwn-4a3b98a422a20dedf3a2a40c44892d6e7e665157.tar.gz lwn-4a3b98a422a20dedf3a2a40c44892d6e7e665157.zip |
[PATCH] swsusp: prevent possible image corruption on resume
The function free_pagedir() used by swsusp for freeing its internal data
structures clears the PG_nosave and PG_nosave_free flags for each page
being freed.
However, during resume PG_nosave_free set means that the page in
question is "unsafe" (ie. it will be overwritten in the process of
restoring the saved system state from the image), so it should not be
used for the image data.
Therefore free_pagedir() should not clear PG_nosave_free if it's called
during resume (otherwise "unsafe" pages freed by it may be used for
storing the image data and the data may get corrupted later on).
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Acked-by: Pavel Machek <pavel@ucw.cz>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm/slob.c')
0 files changed, 0 insertions, 0 deletions