|
@@ -986,7 +986,6 @@ static int __blkdev_put(struct block_device *bdev, fmode_t mode, int for_part);
|
|
static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
{
|
|
{
|
|
struct gendisk *disk;
|
|
struct gendisk *disk;
|
|
- struct hd_struct *part = NULL;
|
|
|
|
int ret;
|
|
int ret;
|
|
int partno;
|
|
int partno;
|
|
int perm = 0;
|
|
int perm = 0;
|
|
@@ -1004,24 +1003,25 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
return ret;
|
|
return ret;
|
|
}
|
|
}
|
|
|
|
|
|
- ret = -ENXIO;
|
|
|
|
-
|
|
|
|
lock_kernel();
|
|
lock_kernel();
|
|
|
|
|
|
|
|
+ ret = -ENXIO;
|
|
disk = get_gendisk(bdev->bd_dev, &partno);
|
|
disk = get_gendisk(bdev->bd_dev, &partno);
|
|
if (!disk)
|
|
if (!disk)
|
|
goto out_unlock_kernel;
|
|
goto out_unlock_kernel;
|
|
- part = disk_get_part(disk, partno);
|
|
|
|
- if (!part)
|
|
|
|
- goto out_unlock_kernel;
|
|
|
|
|
|
|
|
mutex_lock_nested(&bdev->bd_mutex, for_part);
|
|
mutex_lock_nested(&bdev->bd_mutex, for_part);
|
|
if (!bdev->bd_openers) {
|
|
if (!bdev->bd_openers) {
|
|
bdev->bd_disk = disk;
|
|
bdev->bd_disk = disk;
|
|
- bdev->bd_part = part;
|
|
|
|
bdev->bd_contains = bdev;
|
|
bdev->bd_contains = bdev;
|
|
if (!partno) {
|
|
if (!partno) {
|
|
struct backing_dev_info *bdi;
|
|
struct backing_dev_info *bdi;
|
|
|
|
+
|
|
|
|
+ ret = -ENXIO;
|
|
|
|
+ bdev->bd_part = disk_get_part(disk, partno);
|
|
|
|
+ if (!bdev->bd_part)
|
|
|
|
+ goto out_clear;
|
|
|
|
+
|
|
if (disk->fops->open) {
|
|
if (disk->fops->open) {
|
|
ret = disk->fops->open(bdev, mode);
|
|
ret = disk->fops->open(bdev, mode);
|
|
if (ret)
|
|
if (ret)
|
|
@@ -1049,18 +1049,17 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
bdev->bd_contains = whole;
|
|
bdev->bd_contains = whole;
|
|
bdev->bd_inode->i_data.backing_dev_info =
|
|
bdev->bd_inode->i_data.backing_dev_info =
|
|
whole->bd_inode->i_data.backing_dev_info;
|
|
whole->bd_inode->i_data.backing_dev_info;
|
|
|
|
+ bdev->bd_part = disk_get_part(disk, partno);
|
|
if (!(disk->flags & GENHD_FL_UP) ||
|
|
if (!(disk->flags & GENHD_FL_UP) ||
|
|
- !part || !part->nr_sects) {
|
|
|
|
|
|
+ !bdev->bd_part || !bdev->bd_part->nr_sects) {
|
|
ret = -ENXIO;
|
|
ret = -ENXIO;
|
|
goto out_clear;
|
|
goto out_clear;
|
|
}
|
|
}
|
|
- bd_set_size(bdev, (loff_t)part->nr_sects << 9);
|
|
|
|
|
|
+ bd_set_size(bdev, (loff_t)bdev->bd_part->nr_sects << 9);
|
|
}
|
|
}
|
|
} else {
|
|
} else {
|
|
- disk_put_part(part);
|
|
|
|
put_disk(disk);
|
|
put_disk(disk);
|
|
module_put(disk->fops->owner);
|
|
module_put(disk->fops->owner);
|
|
- part = NULL;
|
|
|
|
disk = NULL;
|
|
disk = NULL;
|
|
if (bdev->bd_contains == bdev) {
|
|
if (bdev->bd_contains == bdev) {
|
|
if (bdev->bd_disk->fops->open) {
|
|
if (bdev->bd_disk->fops->open) {
|
|
@@ -1080,6 +1079,7 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
out_clear:
|
|
out_clear:
|
|
|
|
+ disk_put_part(bdev->bd_part);
|
|
bdev->bd_disk = NULL;
|
|
bdev->bd_disk = NULL;
|
|
bdev->bd_part = NULL;
|
|
bdev->bd_part = NULL;
|
|
bdev->bd_inode->i_data.backing_dev_info = &default_backing_dev_info;
|
|
bdev->bd_inode->i_data.backing_dev_info = &default_backing_dev_info;
|
|
@@ -1091,7 +1091,6 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
|
|
out_unlock_kernel:
|
|
out_unlock_kernel:
|
|
unlock_kernel();
|
|
unlock_kernel();
|
|
|
|
|
|
- disk_put_part(part);
|
|
|
|
if (disk)
|
|
if (disk)
|
|
module_put(disk->fops->owner);
|
|
module_put(disk->fops->owner);
|
|
put_disk(disk);
|
|
put_disk(disk);
|