swap.c 16.7 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
/*
 * linux/kernel/power/swap.c
 *
 * This file provides functions for reading the suspend image from
 * and writing it to a swap partition.
 *
 * Copyright (C) 1998,2001-2005 Pavel Machek <pavel@suse.cz>
 * Copyright (C) 2006 Rafael J. Wysocki <rjw@sisk.pl>
 *
 * This file is released under the GPLv2.
 *
 */

#include <linux/module.h>
#include <linux/file.h>
#include <linux/delay.h>
#include <linux/bitops.h>
#include <linux/genhd.h>
#include <linux/device.h>
#include <linux/buffer_head.h>
#include <linux/bio.h>
A
Andrew Morton 已提交
22
#include <linux/blkdev.h>
23 24 25 26 27 28 29 30
#include <linux/swap.h>
#include <linux/swapops.h>
#include <linux/pm.h>

#include "power.h"

#define SWSUSP_SIG	"S1SUSPEND"

31
struct swsusp_header {
32
	char reserved[PAGE_SIZE - 20 - sizeof(sector_t) - sizeof(int)];
33
	sector_t image;
34
	unsigned int flags;	/* Flags to pass to the "boot" kernel */
35 36
	char	orig_sig[10];
	char	sig[10];
37 38 39
} __attribute__((packed));

static struct swsusp_header *swsusp_header;
40

41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141
/**
 *	The following functions are used for tracing the allocated
 *	swap pages, so that they can be freed in case of an error.
 */

struct swsusp_extent {
	struct rb_node node;
	unsigned long start;
	unsigned long end;
};

static struct rb_root swsusp_extents = RB_ROOT;

static int swsusp_extents_insert(unsigned long swap_offset)
{
	struct rb_node **new = &(swsusp_extents.rb_node);
	struct rb_node *parent = NULL;
	struct swsusp_extent *ext;

	/* Figure out where to put the new node */
	while (*new) {
		ext = container_of(*new, struct swsusp_extent, node);
		parent = *new;
		if (swap_offset < ext->start) {
			/* Try to merge */
			if (swap_offset == ext->start - 1) {
				ext->start--;
				return 0;
			}
			new = &((*new)->rb_left);
		} else if (swap_offset > ext->end) {
			/* Try to merge */
			if (swap_offset == ext->end + 1) {
				ext->end++;
				return 0;
			}
			new = &((*new)->rb_right);
		} else {
			/* It already is in the tree */
			return -EINVAL;
		}
	}
	/* Add the new node and rebalance the tree. */
	ext = kzalloc(sizeof(struct swsusp_extent), GFP_KERNEL);
	if (!ext)
		return -ENOMEM;

	ext->start = swap_offset;
	ext->end = swap_offset;
	rb_link_node(&ext->node, parent, new);
	rb_insert_color(&ext->node, &swsusp_extents);
	return 0;
}

/**
 *	alloc_swapdev_block - allocate a swap page and register that it has
 *	been allocated, so that it can be freed in case of an error.
 */

sector_t alloc_swapdev_block(int swap)
{
	unsigned long offset;

	offset = swp_offset(get_swap_page_of_type(swap));
	if (offset) {
		if (swsusp_extents_insert(offset))
			swap_free(swp_entry(swap, offset));
		else
			return swapdev_block(swap, offset);
	}
	return 0;
}

/**
 *	free_all_swap_pages - free swap pages allocated for saving image data.
 *	It also frees the extents used to register which swap entres had been
 *	allocated.
 */

void free_all_swap_pages(int swap)
{
	struct rb_node *node;

	while ((node = swsusp_extents.rb_node)) {
		struct swsusp_extent *ext;
		unsigned long offset;

		ext = container_of(node, struct swsusp_extent, node);
		rb_erase(node, &swsusp_extents);
		for (offset = ext->start; offset <= ext->end; offset++)
			swap_free(swp_entry(swap, offset));

		kfree(ext);
	}
}

int swsusp_swap_in_use(void)
{
	return (swsusp_extents.rb_node != NULL);
}

142
/*
143
 * General things
144 145 146
 */

static unsigned short root_swap = 0xffff;
147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162
static struct block_device *resume_bdev;

/**
 *	submit - submit BIO request.
 *	@rw:	READ or WRITE.
 *	@off	physical offset of page.
 *	@page:	page we're reading or writing.
 *	@bio_chain: list of pending biod (for async reading)
 *
 *	Straight from the textbook - allocate and initialize the bio.
 *	If we're reading, make sure the page is marked as dirty.
 *	Then submit it and, if @bio_chain == NULL, wait.
 */
static int submit(int rw, pgoff_t page_off, struct page *page,
			struct bio **bio_chain)
{
163
	const int bio_rw = rw | (1 << BIO_RW_SYNCIO) | (1 << BIO_RW_UNPLUG);
164 165
	struct bio *bio;

R
Rafael J. Wysocki 已提交
166
	bio = bio_alloc(__GFP_WAIT | __GFP_HIGH, 1);
167 168 169 170 171
	bio->bi_sector = page_off * (PAGE_SIZE >> 9);
	bio->bi_bdev = resume_bdev;
	bio->bi_end_io = end_swap_bio_read;

	if (bio_add_page(bio, page, PAGE_SIZE, 0) < PAGE_SIZE) {
R
Rafael J. Wysocki 已提交
172 173
		printk(KERN_ERR "PM: Adding page to bio failed at %ld\n",
			page_off);
174 175 176 177 178 179 180 181
		bio_put(bio);
		return -EFAULT;
	}

	lock_page(page);
	bio_get(bio);

	if (bio_chain == NULL) {
182
		submit_bio(bio_rw, bio);
183 184 185 186 187 188 189 190 191
		wait_on_page_locked(page);
		if (rw == READ)
			bio_set_pages_dirty(bio);
		bio_put(bio);
	} else {
		if (rw == READ)
			get_page(page);	/* These pages are freed later */
		bio->bi_private = *bio_chain;
		*bio_chain = bio;
192
		submit_bio(bio_rw, bio);
193 194 195 196 197 198 199 200 201
	}
	return 0;
}

static int bio_read_page(pgoff_t page_off, void *addr, struct bio **bio_chain)
{
	return submit(READ, page_off, virt_to_page(addr), bio_chain);
}

202
static int bio_write_page(pgoff_t page_off, void *addr, struct bio **bio_chain)
203
{
204
	return submit(WRITE, page_off, virt_to_page(addr), bio_chain);
205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237
}

static int wait_on_bio_chain(struct bio **bio_chain)
{
	struct bio *bio;
	struct bio *next_bio;
	int ret = 0;

	if (bio_chain == NULL)
		return 0;

	bio = *bio_chain;
	if (bio == NULL)
		return 0;
	while (bio) {
		struct page *page;

		next_bio = bio->bi_private;
		page = bio->bi_io_vec[0].bv_page;
		wait_on_page_locked(page);
		if (!PageUptodate(page) || PageError(page))
			ret = -EIO;
		put_page(page);
		bio_put(bio);
		bio = next_bio;
	}
	*bio_chain = NULL;
	return ret;
}

/*
 * Saving part
 */
238

239
static int mark_swapfiles(sector_t start, unsigned int flags)
240 241 242
{
	int error;

243 244 245 246 247 248
	bio_read_page(swsusp_resume_block, swsusp_header, NULL);
	if (!memcmp("SWAP-SPACE",swsusp_header->sig, 10) ||
	    !memcmp("SWAPSPACE2",swsusp_header->sig, 10)) {
		memcpy(swsusp_header->orig_sig,swsusp_header->sig, 10);
		memcpy(swsusp_header->sig,SWSUSP_SIG, 10);
		swsusp_header->image = start;
249
		swsusp_header->flags = flags;
250
		error = bio_write_page(swsusp_resume_block,
251
					swsusp_header, NULL);
252
	} else {
R
Rafael J. Wysocki 已提交
253
		printk(KERN_ERR "PM: Swap header not found!\n");
254 255 256 257 258 259 260 261 262 263 264 265
		error = -ENODEV;
	}
	return error;
}

/**
 *	swsusp_swap_check - check if the resume device is a swap device
 *	and get its index (if so)
 */

static int swsusp_swap_check(void) /* This is called before saving image */
{
266 267
	int res;

268 269
	res = swap_type_of(swsusp_resume_device, swsusp_resume_block,
			&resume_bdev);
270 271 272 273
	if (res < 0)
		return res;

	root_swap = res;
274
	res = blkdev_get(resume_bdev, FMODE_WRITE);
275 276
	if (res)
		return res;
277 278 279

	res = set_blocksize(resume_bdev, PAGE_SIZE);
	if (res < 0)
A
Al Viro 已提交
280
		blkdev_put(resume_bdev, FMODE_WRITE);
281 282 283 284 285 286 287 288

	return res;
}

/**
 *	write_page - Write one page to given swap location.
 *	@buf:		Address we're writing.
 *	@offset:	Offset of the swap page we're writing to.
A
Andrew Morton 已提交
289
 *	@bio_chain:	Link the next write BIO here
290 291
 */

292
static int write_page(void *buf, sector_t offset, struct bio **bio_chain)
293
{
294 295 296 297 298 299
	void *src;

	if (!offset)
		return -ENOSPC;

	if (bio_chain) {
R
Rafael J. Wysocki 已提交
300
		src = (void *)__get_free_page(__GFP_WAIT | __GFP_HIGH);
301 302 303 304 305 306
		if (src) {
			memcpy(src, buf, PAGE_SIZE);
		} else {
			WARN_ON_ONCE(1);
			bio_chain = NULL;	/* Go synchronous */
			src = buf;
A
Andrew Morton 已提交
307
		}
308 309
	} else {
		src = buf;
310
	}
311
	return bio_write_page(offset, src, bio_chain);
312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328
}

/*
 *	The swap map is a data structure used for keeping track of each page
 *	written to a swap partition.  It consists of many swap_map_page
 *	structures that contain each an array of MAP_PAGE_SIZE swap entries.
 *	These structures are stored on the swap and linked together with the
 *	help of the .next_swap member.
 *
 *	The swap map is created during suspend.  The swap map pages are
 *	allocated and populated one at a time, so we only need one memory
 *	page to set up the entire structure.
 *
 *	During resume we also only need to use one swap_map_page structure
 *	at a time.
 */

329
#define MAP_PAGE_ENTRIES	(PAGE_SIZE / sizeof(sector_t) - 1)
330 331

struct swap_map_page {
332 333
	sector_t entries[MAP_PAGE_ENTRIES];
	sector_t next_swap;
334 335 336 337 338 339 340 341 342
};

/**
 *	The swap_map_handle structure is used for handling swap in
 *	a file-alike way
 */

struct swap_map_handle {
	struct swap_map_page *cur;
343
	sector_t cur_swap;
344 345 346 347 348 349 350 351 352 353 354 355 356 357 358
	unsigned int k;
};

static void release_swap_writer(struct swap_map_handle *handle)
{
	if (handle->cur)
		free_page((unsigned long)handle->cur);
	handle->cur = NULL;
}

static int get_swap_writer(struct swap_map_handle *handle)
{
	handle->cur = (struct swap_map_page *)get_zeroed_page(GFP_KERNEL);
	if (!handle->cur)
		return -ENOMEM;
359
	handle->cur_swap = alloc_swapdev_block(root_swap);
360 361 362 363 364 365 366 367
	if (!handle->cur_swap) {
		release_swap_writer(handle);
		return -ENOSPC;
	}
	handle->k = 0;
	return 0;
}

A
Andrew Morton 已提交
368 369 370 371
static int swap_write_page(struct swap_map_handle *handle, void *buf,
				struct bio **bio_chain)
{
	int error = 0;
372
	sector_t offset;
373 374 375

	if (!handle->cur)
		return -EINVAL;
376
	offset = alloc_swapdev_block(root_swap);
A
Andrew Morton 已提交
377
	error = write_page(buf, offset, bio_chain);
378 379 380 381
	if (error)
		return error;
	handle->cur->entries[handle->k++] = offset;
	if (handle->k >= MAP_PAGE_ENTRIES) {
A
Andrew Morton 已提交
382 383 384
		error = wait_on_bio_chain(bio_chain);
		if (error)
			goto out;
385
		offset = alloc_swapdev_block(root_swap);
386 387 388
		if (!offset)
			return -ENOSPC;
		handle->cur->next_swap = offset;
A
Andrew Morton 已提交
389
		error = write_page(handle->cur, handle->cur_swap, NULL);
390
		if (error)
A
Andrew Morton 已提交
391
			goto out;
392 393 394 395
		memset(handle->cur, 0, PAGE_SIZE);
		handle->cur_swap = offset;
		handle->k = 0;
	}
R
Rafael J. Wysocki 已提交
396
 out:
A
Andrew Morton 已提交
397
	return error;
398 399 400 401 402
}

static int flush_swap_writer(struct swap_map_handle *handle)
{
	if (handle->cur && handle->cur_swap)
A
Andrew Morton 已提交
403
		return write_page(handle->cur, handle->cur_swap, NULL);
404 405 406 407 408 409 410 411 412 413
	else
		return -EINVAL;
}

/**
 *	save_image - save the suspend image data
 */

static int save_image(struct swap_map_handle *handle,
                      struct snapshot_handle *snapshot,
414
                      unsigned int nr_to_write)
415 416 417
{
	unsigned int m;
	int ret;
418
	int nr_pages;
A
Andrew Morton 已提交
419 420
	int err2;
	struct bio *bio;
421 422
	struct timeval start;
	struct timeval stop;
423

R
Rafael J. Wysocki 已提交
424 425
	printk(KERN_INFO "PM: Saving image data pages (%u pages) ...     ",
		nr_to_write);
426
	m = nr_to_write / 100;
427 428 429
	if (!m)
		m = 1;
	nr_pages = 0;
A
Andrew Morton 已提交
430
	bio = NULL;
431
	do_gettimeofday(&start);
432
	while (1) {
433
		ret = snapshot_read_next(snapshot, PAGE_SIZE);
434 435 436 437 438 439
		if (ret <= 0)
			break;
		ret = swap_write_page(handle, data_of(*snapshot), &bio);
		if (ret)
			break;
		if (!(nr_pages % m))
J
Jiri Slaby 已提交
440
			printk(KERN_CONT "\b\b\b\b%3d%%", nr_pages / m);
441 442
		nr_pages++;
	}
A
Andrew Morton 已提交
443
	err2 = wait_on_bio_chain(&bio);
444
	do_gettimeofday(&stop);
445 446 447
	if (!ret)
		ret = err2;
	if (!ret)
J
Jiri Slaby 已提交
448
		printk(KERN_CONT "\b\b\b\bdone\n");
449
	else
J
Jiri Slaby 已提交
450
		printk(KERN_CONT "\n");
451
	swsusp_show_speed(&start, &stop, nr_to_write, "Wrote");
452
	return ret;
453 454 455 456 457 458 459 460 461 462 463 464 465
}

/**
 *	enough_swap - Make sure we have enough swap to save the image.
 *
 *	Returns TRUE or FALSE after checking the total amount of swap
 *	space avaiable from the resume partition.
 */

static int enough_swap(unsigned int nr_pages)
{
	unsigned int free_swap = count_swap_pages(root_swap, 1);

R
Rafael J. Wysocki 已提交
466
	pr_debug("PM: Free swap pages: %u\n", free_swap);
467
	return free_swap > nr_pages + PAGES_FOR_IO;
468 469 470 471
}

/**
 *	swsusp_write - Write entire image and metadata.
472
 *	@flags: flags to pass to the "boot" kernel in the image header
473 474 475 476 477 478 479
 *
 *	It is important _NOT_ to umount filesystems at this point. We want
 *	them synced (in case something goes wrong) but we DO not want to mark
 *	filesystem clean: it is not. (And it does not matter, if we resume
 *	correctly, we'll mark system clean, anyway.)
 */

480
int swsusp_write(unsigned int flags)
481 482 483 484 485 486
{
	struct swap_map_handle handle;
	struct snapshot_handle snapshot;
	struct swsusp_info *header;
	int error;

487 488
	error = swsusp_swap_check();
	if (error) {
R
Rafael J. Wysocki 已提交
489
		printk(KERN_ERR "PM: Cannot find swap device, try "
A
Andrew Morton 已提交
490
				"swapon -a.\n");
491 492 493 494
		return error;
	}
	memset(&snapshot, 0, sizeof(struct snapshot_handle));
	error = snapshot_read_next(&snapshot, PAGE_SIZE);
495 496 497 498 499 500
	if (error < PAGE_SIZE) {
		if (error >= 0)
			error = -EFAULT;

		goto out;
	}
501 502
	header = (struct swsusp_info *)data_of(snapshot);
	if (!enough_swap(header->pages)) {
R
Rafael J. Wysocki 已提交
503
		printk(KERN_ERR "PM: Not enough free swap\n");
504 505
		error = -ENOSPC;
		goto out;
506 507 508
	}
	error = get_swap_writer(&handle);
	if (!error) {
509 510
		sector_t start = handle.cur_swap;

A
Andrew Morton 已提交
511
		error = swap_write_page(&handle, header, NULL);
A
Andrew Morton 已提交
512 513 514
		if (!error)
			error = save_image(&handle, &snapshot,
					header->pages - 1);
515

A
Andrew Morton 已提交
516 517
		if (!error) {
			flush_swap_writer(&handle);
R
Rafael J. Wysocki 已提交
518
			printk(KERN_INFO "PM: S");
519
			error = mark_swapfiles(start, flags);
A
Andrew Morton 已提交
520 521
			printk("|\n");
		}
522 523
	}
	if (error)
524 525
		free_all_swap_pages(root_swap);

526
	release_swap_writer(&handle);
R
Rafael J. Wysocki 已提交
527
 out:
528
	swsusp_close(FMODE_WRITE);
529 530 531 532 533 534 535 536 537 538 539 540 541 542 543
	return error;
}

/**
 *	The following functions allow us to read data using a swap map
 *	in a file-alike way
 */

static void release_swap_reader(struct swap_map_handle *handle)
{
	if (handle->cur)
		free_page((unsigned long)handle->cur);
	handle->cur = NULL;
}

544
static int get_swap_reader(struct swap_map_handle *handle, sector_t start)
545 546 547
{
	int error;

548
	if (!start)
549
		return -EINVAL;
550

R
Rafael J. Wysocki 已提交
551
	handle->cur = (struct swap_map_page *)get_zeroed_page(__GFP_WAIT | __GFP_HIGH);
552 553
	if (!handle->cur)
		return -ENOMEM;
554 555

	error = bio_read_page(start, handle->cur, NULL);
556 557 558 559 560 561 562 563
	if (error) {
		release_swap_reader(handle);
		return error;
	}
	handle->k = 0;
	return 0;
}

A
Andrew Morton 已提交
564 565
static int swap_read_page(struct swap_map_handle *handle, void *buf,
				struct bio **bio_chain)
566
{
567
	sector_t offset;
568 569 570 571 572 573 574
	int error;

	if (!handle->cur)
		return -EINVAL;
	offset = handle->cur->entries[handle->k];
	if (!offset)
		return -EFAULT;
A
Andrew Morton 已提交
575
	error = bio_read_page(offset, buf, bio_chain);
576 577 578
	if (error)
		return error;
	if (++handle->k >= MAP_PAGE_ENTRIES) {
A
Andrew Morton 已提交
579
		error = wait_on_bio_chain(bio_chain);
580 581 582 583
		handle->k = 0;
		offset = handle->cur->next_swap;
		if (!offset)
			release_swap_reader(handle);
A
Andrew Morton 已提交
584 585
		else if (!error)
			error = bio_read_page(offset, handle->cur, NULL);
586 587 588 589 590 591 592 593 594 595 596 597
	}
	return error;
}

/**
 *	load_image - load the image using the swap map handle
 *	@handle and the snapshot handle @snapshot
 *	(assume there are @nr_pages pages to load)
 */

static int load_image(struct swap_map_handle *handle,
                      struct snapshot_handle *snapshot,
A
Andrew Morton 已提交
598
                      unsigned int nr_to_read)
599 600 601
{
	unsigned int m;
	int error = 0;
602 603
	struct timeval start;
	struct timeval stop;
A
Andrew Morton 已提交
604 605 606
	struct bio *bio;
	int err2;
	unsigned nr_pages;
607

R
Rafael J. Wysocki 已提交
608 609
	printk(KERN_INFO "PM: Loading image data pages (%u pages) ...     ",
		nr_to_read);
A
Andrew Morton 已提交
610
	m = nr_to_read / 100;
611 612 613
	if (!m)
		m = 1;
	nr_pages = 0;
A
Andrew Morton 已提交
614
	bio = NULL;
615
	do_gettimeofday(&start);
A
Andrew Morton 已提交
616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631
	for ( ; ; ) {
		error = snapshot_write_next(snapshot, PAGE_SIZE);
		if (error <= 0)
			break;
		error = swap_read_page(handle, data_of(*snapshot), &bio);
		if (error)
			break;
		if (snapshot->sync_read)
			error = wait_on_bio_chain(&bio);
		if (error)
			break;
		if (!(nr_pages % m))
			printk("\b\b\b\b%3d%%", nr_pages / m);
		nr_pages++;
	}
	err2 = wait_on_bio_chain(&bio);
632
	do_gettimeofday(&stop);
A
Andrew Morton 已提交
633 634
	if (!error)
		error = err2;
635
	if (!error) {
636
		printk("\b\b\b\bdone\n");
637
		snapshot_write_finalize(snapshot);
638 639
		if (!snapshot_image_loaded(snapshot))
			error = -ENODATA;
640 641
	} else
		printk("\n");
642
	swsusp_show_speed(&start, &stop, nr_to_read, "Read");
643 644 645
	return error;
}

646 647 648 649 650 651 652
/**
 *	swsusp_read - read the hibernation image.
 *	@flags_p: flags passed by the "frozen" kernel in the image header should
 *		  be written into this memeory location
 */

int swsusp_read(unsigned int *flags_p)
653 654 655 656 657 658
{
	int error;
	struct swap_map_handle handle;
	struct snapshot_handle snapshot;
	struct swsusp_info *header;

659
	*flags_p = swsusp_header->flags;
660 661 662 663 664 665

	memset(&snapshot, 0, sizeof(struct snapshot_handle));
	error = snapshot_write_next(&snapshot, PAGE_SIZE);
	if (error < PAGE_SIZE)
		return error < 0 ? error : -EFAULT;
	header = (struct swsusp_info *)data_of(snapshot);
666
	error = get_swap_reader(&handle, swsusp_header->image);
667
	if (!error)
A
Andrew Morton 已提交
668
		error = swap_read_page(&handle, header, NULL);
669 670 671 672 673
	if (!error)
		error = load_image(&handle, &snapshot, header->pages - 1);
	release_swap_reader(&handle);

	if (!error)
R
Rafael J. Wysocki 已提交
674
		pr_debug("PM: Image successfully loaded\n");
675
	else
R
Rafael J. Wysocki 已提交
676
		pr_debug("PM: Error %d resuming\n", error);
677 678 679 680 681 682 683 684 685 686 687 688 689 690
	return error;
}

/**
 *      swsusp_check - Check for swsusp signature in the resume device
 */

int swsusp_check(void)
{
	int error;

	resume_bdev = open_by_devnum(swsusp_resume_device, FMODE_READ);
	if (!IS_ERR(resume_bdev)) {
		set_blocksize(resume_bdev, PAGE_SIZE);
691
		memset(swsusp_header, 0, PAGE_SIZE);
692
		error = bio_read_page(swsusp_resume_block,
693
					swsusp_header, NULL);
694
		if (error)
J
Jiri Slaby 已提交
695
			goto put;
696

697 698
		if (!memcmp(SWSUSP_SIG, swsusp_header->sig, 10)) {
			memcpy(swsusp_header->sig, swsusp_header->orig_sig, 10);
699
			/* Reset swap signature now */
700
			error = bio_write_page(swsusp_resume_block,
701
						swsusp_header, NULL);
702
		} else {
J
Jiri Slaby 已提交
703
			error = -EINVAL;
704
		}
J
Jiri Slaby 已提交
705 706

put:
707
		if (error)
A
Al Viro 已提交
708
			blkdev_put(resume_bdev, FMODE_READ);
709
		else
R
Rafael J. Wysocki 已提交
710
			pr_debug("PM: Signature found, resuming\n");
711 712 713 714 715
	} else {
		error = PTR_ERR(resume_bdev);
	}

	if (error)
R
Rafael J. Wysocki 已提交
716
		pr_debug("PM: Error %d checking image file\n", error);
717 718 719 720 721 722 723 724

	return error;
}

/**
 *	swsusp_close - close swap device.
 */

725
void swsusp_close(fmode_t mode)
726 727
{
	if (IS_ERR(resume_bdev)) {
R
Rafael J. Wysocki 已提交
728
		pr_debug("PM: Image device not initialised\n");
729 730 731
		return;
	}

732
	blkdev_put(resume_bdev, mode);
733
}
734 735 736 737 738 739 740 741 742 743

static int swsusp_header_init(void)
{
	swsusp_header = (struct swsusp_header*) __get_free_page(GFP_KERNEL);
	if (!swsusp_header)
		panic("Could not allocate memory for swsusp_header\n");
	return 0;
}

core_initcall(swsusp_header_init);