[PATCH] swap: show span of swap extents

The "Adding %dk swap" message shows the number of swap extents, as a guide to
how fragmented the swapfile may be.  But a useful further guide is what total
extent they span across (sometimes scarily large).

And there's no need to keep nr_extents in swap_info: it's unused after the
initial message, so save a little space by keeping it on stack.

Signed-off-by: Hugh Dickins <hugh@veritas.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
This commit is contained in:
Hugh Dickins 2005-09-03 15:54:34 -07:00 committed by Linus Torvalds
parent 11d31886db
commit 53092a7402
2 changed files with 30 additions and 15 deletions

View file

@ -123,7 +123,6 @@ struct swap_info_struct {
struct file *swap_file; struct file *swap_file;
struct block_device *bdev; struct block_device *bdev;
struct list_head extent_list; struct list_head extent_list;
int nr_extents;
struct swap_extent *curr_swap_extent; struct swap_extent *curr_swap_extent;
unsigned old_block_size; unsigned old_block_size;
unsigned short * swap_map; unsigned short * swap_map;

View file

@ -854,7 +854,6 @@ static void destroy_swap_extents(struct swap_info_struct *sis)
list_del(&se->list); list_del(&se->list);
kfree(se); kfree(se);
} }
sis->nr_extents = 0;
} }
/* /*
@ -893,8 +892,7 @@ add_swap_extent(struct swap_info_struct *sis, unsigned long start_page,
new_se->start_block = start_block; new_se->start_block = start_block;
list_add_tail(&new_se->list, &sis->extent_list); list_add_tail(&new_se->list, &sis->extent_list);
sis->nr_extents++; return 1;
return 0;
} }
/* /*
@ -928,7 +926,7 @@ add_swap_extent(struct swap_info_struct *sis, unsigned long start_page,
* This is extremely effective. The average number of iterations in * This is extremely effective. The average number of iterations in
* map_swap_page() has been measured at about 0.3 per page. - akpm. * map_swap_page() has been measured at about 0.3 per page. - akpm.
*/ */
static int setup_swap_extents(struct swap_info_struct *sis) static int setup_swap_extents(struct swap_info_struct *sis, sector_t *span)
{ {
struct inode *inode; struct inode *inode;
unsigned blocks_per_page; unsigned blocks_per_page;
@ -936,11 +934,15 @@ static int setup_swap_extents(struct swap_info_struct *sis)
unsigned blkbits; unsigned blkbits;
sector_t probe_block; sector_t probe_block;
sector_t last_block; sector_t last_block;
sector_t lowest_block = -1;
sector_t highest_block = 0;
int nr_extents = 0;
int ret; int ret;
inode = sis->swap_file->f_mapping->host; inode = sis->swap_file->f_mapping->host;
if (S_ISBLK(inode->i_mode)) { if (S_ISBLK(inode->i_mode)) {
ret = add_swap_extent(sis, 0, sis->max, 0); ret = add_swap_extent(sis, 0, sis->max, 0);
*span = sis->pages;
goto done; goto done;
} }
@ -985,19 +987,28 @@ static int setup_swap_extents(struct swap_info_struct *sis)
} }
} }
first_block >>= (PAGE_SHIFT - blkbits);
if (page_no) { /* exclude the header page */
if (first_block < lowest_block)
lowest_block = first_block;
if (first_block > highest_block)
highest_block = first_block;
}
/* /*
* We found a PAGE_SIZE-length, PAGE_SIZE-aligned run of blocks * We found a PAGE_SIZE-length, PAGE_SIZE-aligned run of blocks
*/ */
ret = add_swap_extent(sis, page_no, 1, ret = add_swap_extent(sis, page_no, 1, first_block);
first_block >> (PAGE_SHIFT - blkbits)); if (ret < 0)
if (ret)
goto out; goto out;
nr_extents += ret;
page_no++; page_no++;
probe_block += blocks_per_page; probe_block += blocks_per_page;
reprobe: reprobe:
continue; continue;
} }
ret = 0; ret = nr_extents;
*span = 1 + highest_block - lowest_block;
if (page_no == 0) if (page_no == 0)
page_no = 1; /* force Empty message */ page_no = 1; /* force Empty message */
sis->max = page_no; sis->max = page_no;
@ -1265,6 +1276,8 @@ asmlinkage long sys_swapon(const char __user * specialfile, int swap_flags)
union swap_header *swap_header = NULL; union swap_header *swap_header = NULL;
int swap_header_version; int swap_header_version;
int nr_good_pages = 0; int nr_good_pages = 0;
int nr_extents;
sector_t span;
unsigned long maxpages = 1; unsigned long maxpages = 1;
int swapfilesize; int swapfilesize;
unsigned short *swap_map; unsigned short *swap_map;
@ -1300,7 +1313,6 @@ asmlinkage long sys_swapon(const char __user * specialfile, int swap_flags)
nr_swapfiles = type+1; nr_swapfiles = type+1;
INIT_LIST_HEAD(&p->extent_list); INIT_LIST_HEAD(&p->extent_list);
p->flags = SWP_USED; p->flags = SWP_USED;
p->nr_extents = 0;
p->swap_file = NULL; p->swap_file = NULL;
p->old_block_size = 0; p->old_block_size = 0;
p->swap_map = NULL; p->swap_map = NULL;
@ -1477,9 +1489,11 @@ asmlinkage long sys_swapon(const char __user * specialfile, int swap_flags)
p->swap_map[0] = SWAP_MAP_BAD; p->swap_map[0] = SWAP_MAP_BAD;
p->max = maxpages; p->max = maxpages;
p->pages = nr_good_pages; p->pages = nr_good_pages;
error = setup_swap_extents(p); nr_extents = setup_swap_extents(p, &span);
if (error) if (nr_extents < 0) {
error = nr_extents;
goto bad_swap; goto bad_swap;
}
nr_good_pages = p->pages; nr_good_pages = p->pages;
} }
if (!nr_good_pages) { if (!nr_good_pages) {
@ -1494,9 +1508,11 @@ asmlinkage long sys_swapon(const char __user * specialfile, int swap_flags)
p->flags = SWP_ACTIVE; p->flags = SWP_ACTIVE;
nr_swap_pages += nr_good_pages; nr_swap_pages += nr_good_pages;
total_swap_pages += nr_good_pages; total_swap_pages += nr_good_pages;
printk(KERN_INFO "Adding %dk swap on %s. Priority:%d extents:%d\n",
nr_good_pages<<(PAGE_SHIFT-10), name, printk(KERN_INFO "Adding %dk swap on %s. "
p->prio, p->nr_extents); "Priority:%d extents:%d across:%lluk\n",
nr_good_pages<<(PAGE_SHIFT-10), name, p->prio,
nr_extents, (unsigned long long)span<<(PAGE_SHIFT-10));
/* insert swap space into swap_list: */ /* insert swap space into swap_list: */
prev = -1; prev = -1;