Commit 3a4f7577 authored by Andrew Morton's avatar Andrew Morton Committed by Linus Torvalds

[PATCH] swsusp: add write-speed instrumentation

Add some instrumentation to the swsusp writeout code to show what bandwidth
we're achieving.

Cc: Pavel Machek <pavel@ucw.cz>
Cc: "Rafael J. Wysocki" <rjw@sisk.pl>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 930631ed
...@@ -146,6 +146,26 @@ static void release_swap_writer(struct swap_map_handle *handle) ...@@ -146,6 +146,26 @@ static void release_swap_writer(struct swap_map_handle *handle)
handle->bitmap = NULL; handle->bitmap = NULL;
} }
static void show_speed(struct timeval *start, struct timeval *stop,
unsigned nr_pages, char *msg)
{
s64 elapsed_centisecs64;
int centisecs;
int k;
int kps;
elapsed_centisecs64 = timeval_to_ns(stop) - timeval_to_ns(start);
do_div(elapsed_centisecs64, NSEC_PER_SEC / 100);
centisecs = elapsed_centisecs64;
if (centisecs == 0)
centisecs = 1; /* avoid div-by-zero */
k = nr_pages * (PAGE_SIZE / 1024);
kps = (k * 100) / centisecs;
printk("%s %d kbytes in %d.%02d seconds (%d.%02d MB/s)\n", msg, k,
centisecs / 100, centisecs % 100,
kps / 1000, (kps % 1000) / 10);
}
static int get_swap_writer(struct swap_map_handle *handle) static int get_swap_writer(struct swap_map_handle *handle)
{ {
handle->cur = (struct swap_map_page *)get_zeroed_page(GFP_KERNEL); handle->cur = (struct swap_map_page *)get_zeroed_page(GFP_KERNEL);
...@@ -206,17 +226,21 @@ static int flush_swap_writer(struct swap_map_handle *handle) ...@@ -206,17 +226,21 @@ static int flush_swap_writer(struct swap_map_handle *handle)
static int save_image(struct swap_map_handle *handle, static int save_image(struct swap_map_handle *handle,
struct snapshot_handle *snapshot, struct snapshot_handle *snapshot,
unsigned int nr_pages) unsigned int nr_to_write)
{ {
unsigned int m; unsigned int m;
int ret; int ret;
int error = 0; int error = 0;
int nr_pages;
struct timeval start;
struct timeval stop;
printk("Saving image data pages (%u pages) ... ", nr_pages); printk("Saving image data pages (%u pages) ... ", nr_to_write);
m = nr_pages / 100; m = nr_to_write / 100;
if (!m) if (!m)
m = 1; m = 1;
nr_pages = 0; nr_pages = 0;
do_gettimeofday(&start);
do { do {
ret = snapshot_read_next(snapshot, PAGE_SIZE); ret = snapshot_read_next(snapshot, PAGE_SIZE);
if (ret > 0) { if (ret > 0) {
...@@ -228,8 +252,10 @@ static int save_image(struct swap_map_handle *handle, ...@@ -228,8 +252,10 @@ static int save_image(struct swap_map_handle *handle,
nr_pages++; nr_pages++;
} }
} while (ret > 0); } while (ret > 0);
do_gettimeofday(&stop);
if (!error) if (!error)
printk("\b\b\b\bdone\n"); printk("\b\b\b\bdone\n");
show_speed(&start, &stop, nr_to_write, "Wrote");
return error; return error;
} }
......
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