diff --git a/[refs] b/[refs] index ab11ed2fb4a9..ec6c7125bd66 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: ec79be26875f6c1468784876cb99192b7f41c7a5 +refs/heads/master: dddac6a7b445de95515f64fdf82fe5dc36c02f26 diff --git a/trunk/fs/block_dev.c b/trunk/fs/block_dev.c index 3a6d4fb2a329..94dfda24c06e 100644 --- a/trunk/fs/block_dev.c +++ b/trunk/fs/block_dev.c @@ -564,6 +564,16 @@ struct block_device *bdget(dev_t dev) EXPORT_SYMBOL(bdget); +/** + * bdgrab -- Grab a reference to an already referenced block device + * @bdev: Block device to grab a reference to. + */ +struct block_device *bdgrab(struct block_device *bdev) +{ + atomic_inc(&bdev->bd_inode->i_count); + return bdev; +} + long nr_blockdev_pages(void) { struct block_device *bdev; diff --git a/trunk/include/linux/fs.h b/trunk/include/linux/fs.h index 0872372184fe..a36ffa5a77a4 100644 --- a/trunk/include/linux/fs.h +++ b/trunk/include/linux/fs.h @@ -1946,6 +1946,7 @@ extern void putname(const char *name); extern int register_blkdev(unsigned int, const char *); extern void unregister_blkdev(unsigned int, const char *); extern struct block_device *bdget(dev_t); +extern struct block_device *bdgrab(struct block_device *bdev); extern void bd_set_size(struct block_device *, loff_t size); extern void bd_forget(struct inode *inode); extern void bdput(struct block_device *); diff --git a/trunk/mm/swapfile.c b/trunk/mm/swapfile.c index d1ade1a48ee7..8ffdc0d23c53 100644 --- a/trunk/mm/swapfile.c +++ b/trunk/mm/swapfile.c @@ -753,7 +753,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p) if (!bdev) { if (bdev_p) - *bdev_p = bdget(sis->bdev->bd_dev); + *bdev_p = bdgrab(sis->bdev); spin_unlock(&swap_lock); return i; @@ -765,7 +765,7 @@ int swap_type_of(dev_t device, sector_t offset, struct block_device **bdev_p) struct swap_extent, list); if (se->start_block == offset) { if (bdev_p) - *bdev_p = bdget(sis->bdev->bd_dev); + *bdev_p = bdgrab(sis->bdev); spin_unlock(&swap_lock); bdput(bdev);