block: don't depend on consecutive minor space
* Implement disk_devt() and part_devt() and use them to directly access devt instead of computing it from ->major and ->first_minor. Note that all references to ->major and ->first_minor outside of block layer is used to determine devt of the disk (the part0) and as ->major and ->first_minor will continue to represent devt for the disk, converting these users aren't strictly necessary. However, convert them for consistency. * Implement disk_max_parts() to avoid directly deferencing genhd->minors. * Update bdget_disk() such that it doesn't assume consecutive minor space. * Move devt computation from register_disk() to add_disk() and make it the only one (all other usages use the initially determined value). These changes clean up the code and will help disk->part dereference fix and extended block device numbers. Signed-off-by: Tejun Heo <tj@kernel.org> Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
This commit is contained in:
@@ -426,7 +426,7 @@ static int list_devices(struct dm_ioctl *param, size_t param_size)
|
||||
old_nl->next = (uint32_t) ((void *) nl -
|
||||
(void *) old_nl);
|
||||
disk = dm_disk(hc->md);
|
||||
nl->dev = huge_encode_dev(MKDEV(disk->major, disk->first_minor));
|
||||
nl->dev = huge_encode_dev(disk_devt(disk));
|
||||
nl->next = 0;
|
||||
strcpy(nl->name, hc->name);
|
||||
|
||||
@@ -539,7 +539,7 @@ static int __dev_status(struct mapped_device *md, struct dm_ioctl *param)
|
||||
if (dm_suspended(md))
|
||||
param->flags |= DM_SUSPEND_FLAG;
|
||||
|
||||
param->dev = huge_encode_dev(MKDEV(disk->major, disk->first_minor));
|
||||
param->dev = huge_encode_dev(disk_devt(disk));
|
||||
|
||||
/*
|
||||
* Yes, this will be out of date by the time it gets back
|
||||
|
@@ -284,8 +284,8 @@ static int stripe_end_io(struct dm_target *ti, struct bio *bio,
|
||||
|
||||
memset(major_minor, 0, sizeof(major_minor));
|
||||
sprintf(major_minor, "%d:%d",
|
||||
bio->bi_bdev->bd_disk->major,
|
||||
bio->bi_bdev->bd_disk->first_minor);
|
||||
MAJOR(disk_devt(bio->bi_bdev->bd_disk)),
|
||||
MINOR(disk_devt(bio->bi_bdev->bd_disk)));
|
||||
|
||||
/*
|
||||
* Test to see which stripe drive triggered the event
|
||||
|
@@ -1146,7 +1146,7 @@ static void unlock_fs(struct mapped_device *md);
|
||||
|
||||
static void free_dev(struct mapped_device *md)
|
||||
{
|
||||
int minor = md->disk->first_minor;
|
||||
int minor = MINOR(disk_devt(md->disk));
|
||||
|
||||
if (md->suspended_bdev) {
|
||||
unlock_fs(md);
|
||||
@@ -1267,7 +1267,7 @@ static struct mapped_device *dm_find_md(dev_t dev)
|
||||
|
||||
md = idr_find(&_minor_idr, minor);
|
||||
if (md && (md == MINOR_ALLOCED ||
|
||||
(dm_disk(md)->first_minor != minor) ||
|
||||
(MINOR(disk_devt(dm_disk(md))) != minor) ||
|
||||
test_bit(DMF_FREEING, &md->flags))) {
|
||||
md = NULL;
|
||||
goto out;
|
||||
@@ -1318,7 +1318,8 @@ void dm_put(struct mapped_device *md)
|
||||
|
||||
if (atomic_dec_and_lock(&md->holders, &_minor_lock)) {
|
||||
map = dm_get_table(md);
|
||||
idr_replace(&_minor_idr, MINOR_ALLOCED, dm_disk(md)->first_minor);
|
||||
idr_replace(&_minor_idr, MINOR_ALLOCED,
|
||||
MINOR(disk_devt(dm_disk(md))));
|
||||
set_bit(DMF_FREEING, &md->flags);
|
||||
spin_unlock(&_minor_lock);
|
||||
if (!dm_suspended(md)) {
|
||||
|
Reference in New Issue
Block a user