summaryrefslogtreecommitdiff
path: root/sys/kern
diff options
context:
space:
mode:
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/subr_hibernate.c113
1 files changed, 12 insertions, 101 deletions
diff --git a/sys/kern/subr_hibernate.c b/sys/kern/subr_hibernate.c
index 5edd5dc48be..7f585ebdb13 100644
--- a/sys/kern/subr_hibernate.c
+++ b/sys/kern/subr_hibernate.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: subr_hibernate.c,v 1.41 2012/07/11 16:19:04 mlarkin Exp $ */
+/* $OpenBSD: subr_hibernate.c,v 1.42 2012/07/12 09:44:09 mlarkin Exp $ */
/*
* Copyright (c) 2011 Ariane van der Steldt <ariane@stack.nl>
@@ -797,7 +797,7 @@ void
hibernate_inflate_region(union hibernate_info *hiber_info, paddr_t dest,
paddr_t src, size_t size)
{
- int rle, end_stream = 0 ;
+ int end_stream = 0 ;
struct hibernate_zlib_state *hibernate_state;
hibernate_state = (struct hibernate_zlib_state *)HIBERNATE_HIBALLOC_PAGE;
@@ -809,19 +809,6 @@ hibernate_inflate_region(union hibernate_info *hiber_info, paddr_t dest,
/* Flush cache and TLB */
hibernate_flush();
- /* Consume RLE skipped pages */
- do {
- rle = hibernate_get_next_rle();
- if (rle == -1) {
- end_stream = 1;
- goto next_page;
- }
-
- if (rle != 0)
- dest += (rle * PAGE_SIZE);
-
- } while (rle != 0);
-
/*
* Is this a special page? If yes, redirect the
* inflate output to a scratch page (eg, discard it)
@@ -838,7 +825,6 @@ hibernate_inflate_region(union hibernate_info *hiber_info, paddr_t dest,
hibernate_flush();
end_stream = hibernate_inflate_page();
-next_page:
dest += PAGE_SIZE;
} while (!end_stream);
}
@@ -1252,7 +1238,7 @@ hibernate_write_chunks(union hibernate_info *hiber_info)
struct hibernate_disk_chunk *chunks;
vaddr_t hibernate_io_page = hiber_info->piglet_va + PAGE_SIZE;
daddr_t blkctr = hiber_info->image_offset, offset = 0;
- int i, rle;
+ int i;
struct hibernate_zlib_state *hibernate_state;
hibernate_state = (struct hibernate_zlib_state *)HIBERNATE_HIBALLOC_PAGE;
@@ -1333,81 +1319,6 @@ hibernate_write_chunks(union hibernate_info *hiber_info)
temp_inaddr = (inaddr & PAGE_MASK) +
hibernate_copy_page;
- if (hibernate_inflate_skip(hiber_info, inaddr))
- rle = 1;
- else
- rle = uvm_page_rle(inaddr);
-
- while (rle != 0 && inaddr < range_end) {
- hibernate_state->hib_stream.next_in =
- (char *)&rle;
- hibernate_state->hib_stream.avail_in =
- sizeof(rle);
- hibernate_state->hib_stream.next_out =
- (caddr_t)hibernate_io_page +
- (PAGE_SIZE - out_remaining);
- hibernate_state->hib_stream.avail_out =
- out_remaining;
-
- if (deflate(&hibernate_state->hib_stream,
- Z_PARTIAL_FLUSH) != Z_OK)
- return (1);
-
- out_remaining =
- hibernate_state->hib_stream.avail_out;
- inaddr += (rle * PAGE_SIZE);
- if (inaddr > range_end)
- inaddr = range_end;
- else
- rle = uvm_page_rle(inaddr);
- }
-
- if (out_remaining == 0) {
- /* Filled up the page */
- nblocks = PAGE_SIZE / hiber_info->secsize;
-
- if (hiber_info->io_func(hiber_info->device,
- blkctr, (vaddr_t)hibernate_io_page,
- PAGE_SIZE, HIB_W, hiber_info->io_page))
- return (1);
-
- blkctr += nblocks;
- out_remaining = PAGE_SIZE;
- }
-
- /* Write '0' RLE code */
- if (inaddr < range_end) {
- hibernate_state->hib_stream.next_in =
- (char *)&rle;
- hibernate_state->hib_stream.avail_in =
- sizeof(rle);
- hibernate_state->hib_stream.next_out =
- (caddr_t)hibernate_io_page +
- (PAGE_SIZE - out_remaining);
- hibernate_state->hib_stream.avail_out =
- out_remaining;
-
- if (deflate(&hibernate_state->hib_stream,
- Z_PARTIAL_FLUSH) != Z_OK)
- return (1);
-
- out_remaining =
- hibernate_state->hib_stream.avail_out;
- }
-
- if (out_remaining == 0) {
- /* Filled up the page */
- nblocks = PAGE_SIZE / hiber_info->secsize;
-
- if (hiber_info->io_func(hiber_info->device,
- blkctr, (vaddr_t)hibernate_io_page,
- PAGE_SIZE, HIB_W, hiber_info->io_page))
- return (1);
-
- blkctr += nblocks;
- out_remaining = PAGE_SIZE;
- }
-
/* Deflate from temp_inaddr to IO page */
if (inaddr != range_end) {
pmap_kenter_pa(hibernate_temp_page,
@@ -1421,18 +1332,18 @@ hibernate_write_chunks(union hibernate_info *hiber_info)
inaddr += hibernate_deflate(hiber_info,
temp_inaddr, &out_remaining);
}
- }
- if (out_remaining == 0) {
- /* Filled up the page */
- nblocks = PAGE_SIZE / hiber_info->secsize;
+ if (out_remaining == 0) {
+ /* Filled up the page */
+ nblocks = PAGE_SIZE / hiber_info->secsize;
- if (hiber_info->io_func(hiber_info->device,
- blkctr, (vaddr_t)hibernate_io_page,
- PAGE_SIZE, HIB_W, hiber_info->io_page))
- return (1);
+ if (hiber_info->io_func(hiber_info->device,
+ blkctr, (vaddr_t)hibernate_io_page,
+ PAGE_SIZE, HIB_W, hiber_info->io_page))
+ return (1);
- blkctr += nblocks;
+ blkctr += nblocks;
+ }
}
}