mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-23 20:24:12 +08:00
block: don't add or resize partition on the disk with GENHD_FL_NO_PART
Commita33df75c63
("block: use an xarray for disk->part_tbl") remove disk_expand_part_tbl() in add_partition(), which means all kinds of devices will support extended dynamic `dev_t`. However, some devices with GENHD_FL_NO_PART are not expected to add or resize partition. Fix this by adding check of GENHD_FL_NO_PART before add or resize partition. Fixes:a33df75c63
("block: use an xarray for disk->part_tbl") Signed-off-by: Li Lingfeng <lilingfeng3@huawei.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Link: https://lore.kernel.org/r/20230831075900.1725842-1-lilingfeng@huaweicloud.com Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
0d997f1de8
commit
1a721de848
@ -20,6 +20,8 @@ static int blkpg_do_ioctl(struct block_device *bdev,
|
|||||||
struct blkpg_partition p;
|
struct blkpg_partition p;
|
||||||
long long start, length;
|
long long start, length;
|
||||||
|
|
||||||
|
if (disk->flags & GENHD_FL_NO_PART)
|
||||||
|
return -EINVAL;
|
||||||
if (!capable(CAP_SYS_ADMIN))
|
if (!capable(CAP_SYS_ADMIN))
|
||||||
return -EACCES;
|
return -EACCES;
|
||||||
if (copy_from_user(&p, upart, sizeof(struct blkpg_partition)))
|
if (copy_from_user(&p, upart, sizeof(struct blkpg_partition)))
|
||||||
|
Loading…
Reference in New Issue
Block a user