diff options
Diffstat (limited to 'fs/block_dev.c')
-rw-r--r-- | fs/block_dev.c | 34 |
1 files changed, 19 insertions, 15 deletions
diff --git a/fs/block_dev.c b/fs/block_dev.c index 257b00e98428..1a2421f908f0 100644 --- a/fs/block_dev.c +++ b/fs/block_dev.c | |||
@@ -1120,6 +1120,15 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part) | |||
1120 | goto restart; | 1120 | goto restart; |
1121 | } | 1121 | } |
1122 | } | 1122 | } |
1123 | |||
1124 | if (!ret && !bdev->bd_openers) { | ||
1125 | bd_set_size(bdev,(loff_t)get_capacity(disk)<<9); | ||
1126 | bdi = blk_get_backing_dev_info(bdev); | ||
1127 | if (bdi == NULL) | ||
1128 | bdi = &default_backing_dev_info; | ||
1129 | bdev_inode_switch_bdi(bdev->bd_inode, bdi); | ||
1130 | } | ||
1131 | |||
1123 | /* | 1132 | /* |
1124 | * If the device is invalidated, rescan partition | 1133 | * If the device is invalidated, rescan partition |
1125 | * if open succeeded or failed with -ENOMEDIUM. | 1134 | * if open succeeded or failed with -ENOMEDIUM. |
@@ -1130,14 +1139,6 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part) | |||
1130 | rescan_partitions(disk, bdev); | 1139 | rescan_partitions(disk, bdev); |
1131 | if (ret) | 1140 | if (ret) |
1132 | goto out_clear; | 1141 | goto out_clear; |
1133 | |||
1134 | if (!bdev->bd_openers) { | ||
1135 | bd_set_size(bdev,(loff_t)get_capacity(disk)<<9); | ||
1136 | bdi = blk_get_backing_dev_info(bdev); | ||
1137 | if (bdi == NULL) | ||
1138 | bdi = &default_backing_dev_info; | ||
1139 | bdev_inode_switch_bdi(bdev->bd_inode, bdi); | ||
1140 | } | ||
1141 | } else { | 1142 | } else { |
1142 | struct block_device *whole; | 1143 | struct block_device *whole; |
1143 | whole = bdget_disk(disk, 0); | 1144 | whole = bdget_disk(disk, 0); |
@@ -1237,6 +1238,8 @@ int blkdev_get(struct block_device *bdev, fmode_t mode, void *holder) | |||
1237 | res = __blkdev_get(bdev, mode, 0); | 1238 | res = __blkdev_get(bdev, mode, 0); |
1238 | 1239 | ||
1239 | if (whole) { | 1240 | if (whole) { |
1241 | struct gendisk *disk = whole->bd_disk; | ||
1242 | |||
1240 | /* finish claiming */ | 1243 | /* finish claiming */ |
1241 | mutex_lock(&bdev->bd_mutex); | 1244 | mutex_lock(&bdev->bd_mutex); |
1242 | spin_lock(&bdev_lock); | 1245 | spin_lock(&bdev_lock); |
@@ -1263,15 +1266,16 @@ int blkdev_get(struct block_device *bdev, fmode_t mode, void *holder) | |||
1263 | spin_unlock(&bdev_lock); | 1266 | spin_unlock(&bdev_lock); |
1264 | 1267 | ||
1265 | /* | 1268 | /* |
1266 | * Block event polling for write claims. Any write | 1269 | * Block event polling for write claims if requested. Any |
1267 | * holder makes the write_holder state stick until all | 1270 | * write holder makes the write_holder state stick until |
1268 | * are released. This is good enough and tracking | 1271 | * all are released. This is good enough and tracking |
1269 | * individual writeable reference is too fragile given | 1272 | * individual writeable reference is too fragile given the |
1270 | * the way @mode is used in blkdev_get/put(). | 1273 | * way @mode is used in blkdev_get/put(). |
1271 | */ | 1274 | */ |
1272 | if (!res && (mode & FMODE_WRITE) && !bdev->bd_write_holder) { | 1275 | if (!res && (mode & FMODE_WRITE) && !bdev->bd_write_holder && |
1276 | (disk->flags & GENHD_FL_BLOCK_EVENTS_ON_EXCL_WRITE)) { | ||
1273 | bdev->bd_write_holder = true; | 1277 | bdev->bd_write_holder = true; |
1274 | disk_block_events(bdev->bd_disk); | 1278 | disk_block_events(disk); |
1275 | } | 1279 | } |
1276 | 1280 | ||
1277 | mutex_unlock(&bdev->bd_mutex); | 1281 | mutex_unlock(&bdev->bd_mutex); |