aboutsummaryrefslogtreecommitdiffstats
path: root/fs/logfs/dev_bdev.c
diff options
context:
space:
mode:
Diffstat (limited to 'fs/logfs/dev_bdev.c')
-rw-r--r--fs/logfs/dev_bdev.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/fs/logfs/dev_bdev.c b/fs/logfs/dev_bdev.c
index 9bd2ce2a3040..bca8e2a8e55b 100644
--- a/fs/logfs/dev_bdev.c
+++ b/fs/logfs/dev_bdev.c
@@ -9,6 +9,7 @@
9#include <linux/bio.h> 9#include <linux/bio.h>
10#include <linux/blkdev.h> 10#include <linux/blkdev.h>
11#include <linux/buffer_head.h> 11#include <linux/buffer_head.h>
12#include <linux/slab.h>
12#include <linux/gfp.h> 13#include <linux/gfp.h>
13 14
14#define PAGE_OFS(ofs) ((ofs) & (PAGE_SIZE-1)) 15#define PAGE_OFS(ofs) ((ofs) & (PAGE_SIZE-1))
@@ -320,20 +321,23 @@ static const struct logfs_device_ops bd_devops = {
320 .put_device = bdev_put_device, 321 .put_device = bdev_put_device,
321}; 322};
322 323
323int logfs_get_sb_bdev(struct file_system_type *type, int flags, 324int logfs_get_sb_bdev(struct logfs_super *p,
325 struct file_system_type *type, int flags,
324 const char *devname, struct vfsmount *mnt) 326 const char *devname, struct vfsmount *mnt)
325{ 327{
326 struct block_device *bdev; 328 struct block_device *bdev;
327 329
328 bdev = open_bdev_exclusive(devname, FMODE_READ|FMODE_WRITE, type); 330 bdev = open_bdev_exclusive(devname, FMODE_READ|FMODE_WRITE, type);
329 if (IS_ERR(bdev)) 331 if (IS_ERR(bdev)) {
332 kfree(p);
330 return PTR_ERR(bdev); 333 return PTR_ERR(bdev);
334 }
331 335
332 if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) { 336 if (MAJOR(bdev->bd_dev) == MTD_BLOCK_MAJOR) {
333 int mtdnr = MINOR(bdev->bd_dev); 337 int mtdnr = MINOR(bdev->bd_dev);
334 close_bdev_exclusive(bdev, FMODE_READ|FMODE_WRITE); 338 close_bdev_exclusive(bdev, FMODE_READ|FMODE_WRITE);
335 return logfs_get_sb_mtd(type, flags, mtdnr, mnt); 339 return logfs_get_sb_mtd(p, type, flags, mtdnr, mnt);
336 } 340 }
337 341
338 return logfs_get_sb_device(type, flags, NULL, bdev, &bd_devops, mnt); 342 return logfs_get_sb_device(p, type, flags, NULL, bdev, &bd_devops, mnt);
339} 343}