block-6.9-20240420
-----BEGIN PGP SIGNATURE----- iQJEBAABCAAuFiEEwPw5LcreJtl1+l5K99NY+ylx4KYFAmYj3soQHGF4Ym9lQGtl cm5lbC5kawAKCRD301j7KXHgpin7D/9wn9XnjUJVp8Pw2by2gY+j9V4Mlr30+HIW 7XT51PHEYWpHQfMCm2gMdc16hb2w+GKkf40ymU9/fnEuqWfs2MAiw3tD7Seo8vTr qiLCp4hYQNM6YF6MQA4It2HJE2r0o8QRPjwFQSY0pnPZe+NPT/cdyKgJAlns4VW8 d5kMOw7hLfZvN6iLjOW0hz0dQqoFdOGP9/QrXFgNzaexnJxDA+N8D7E5WEGjXvJj mHCqXXZEKMj2phuUlKfSeRDGGVDL8Zv2/whPD1TlNHn/8683lSwHXISEaw5KCBb2 9dVFPMQv4eFY0yCBbqmfxOBki/0KElYKZ+ri3A0kdEnJG67F7LCIWEyGhIfZuGXl MGjzaSI8HSdUfUPgn0b4Ad1/cTpUaeHIu7b+x63KlbBO5sBbwh4tKUkuj30s7wP4 FC9egqFL+B4JyzuMPvWtDKvA8v+KMRYsMBNUkYEy/DfQUuf2lmf6dtGSDBK94QvX n7Vdzxkm0gTHuJPnrkt4esS2dwCgMqgk6BpQDJ6ODkMWLtebw7ZYMIoFDJknbWgT W8uovm1uejUbsdjzvvG1ioL/ry3GiaP6sN8TEWHeq0RZrFGPwDjjpu4HVeEXrD0Z PpglL9LDj5bE2IJVCpaEyn86O3eqVeFfoHatAoFrbAKuJjSDALGM9wpC4UNgBFvN CSZ/ZiTKlA== =EMuq -----END PGP SIGNATURE----- Merge tag 'block-6.9-20240420' of git://git.kernel.dk/linux Pull block fixes from Jens Axboe: "Just two minor fixes that should go into the 6.9 kernel release, one fixing a regression with partition scanning errors, and one fixing a WARN_ON() that can get triggered if we race with a timer" * tag 'block-6.9-20240420' of git://git.kernel.dk/linux: blk-iocost: do not WARN if iocg was already offlined block: propagate partition scanning errors to the BLKRRPART ioctl
This commit is contained in:
commit
977b1ef518
29
block/bdev.c
29
block/bdev.c
@ -645,6 +645,14 @@ static void blkdev_flush_mapping(struct block_device *bdev)
|
|||||||
bdev_write_inode(bdev);
|
bdev_write_inode(bdev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void blkdev_put_whole(struct block_device *bdev)
|
||||||
|
{
|
||||||
|
if (atomic_dec_and_test(&bdev->bd_openers))
|
||||||
|
blkdev_flush_mapping(bdev);
|
||||||
|
if (bdev->bd_disk->fops->release)
|
||||||
|
bdev->bd_disk->fops->release(bdev->bd_disk);
|
||||||
|
}
|
||||||
|
|
||||||
static int blkdev_get_whole(struct block_device *bdev, blk_mode_t mode)
|
static int blkdev_get_whole(struct block_device *bdev, blk_mode_t mode)
|
||||||
{
|
{
|
||||||
struct gendisk *disk = bdev->bd_disk;
|
struct gendisk *disk = bdev->bd_disk;
|
||||||
@ -663,18 +671,19 @@ static int blkdev_get_whole(struct block_device *bdev, blk_mode_t mode)
|
|||||||
|
|
||||||
if (!atomic_read(&bdev->bd_openers))
|
if (!atomic_read(&bdev->bd_openers))
|
||||||
set_init_blocksize(bdev);
|
set_init_blocksize(bdev);
|
||||||
if (test_bit(GD_NEED_PART_SCAN, &disk->state))
|
|
||||||
bdev_disk_changed(disk, false);
|
|
||||||
atomic_inc(&bdev->bd_openers);
|
atomic_inc(&bdev->bd_openers);
|
||||||
return 0;
|
if (test_bit(GD_NEED_PART_SCAN, &disk->state)) {
|
||||||
|
/*
|
||||||
|
* Only return scanning errors if we are called from contexts
|
||||||
|
* that explicitly want them, e.g. the BLKRRPART ioctl.
|
||||||
|
*/
|
||||||
|
ret = bdev_disk_changed(disk, false);
|
||||||
|
if (ret && (mode & BLK_OPEN_STRICT_SCAN)) {
|
||||||
|
blkdev_put_whole(bdev);
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
static void blkdev_put_whole(struct block_device *bdev)
|
return 0;
|
||||||
{
|
|
||||||
if (atomic_dec_and_test(&bdev->bd_openers))
|
|
||||||
blkdev_flush_mapping(bdev);
|
|
||||||
if (bdev->bd_disk->fops->release)
|
|
||||||
bdev->bd_disk->fops->release(bdev->bd_disk);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int blkdev_get_part(struct block_device *part, blk_mode_t mode)
|
static int blkdev_get_part(struct block_device *part, blk_mode_t mode)
|
||||||
|
@ -1439,8 +1439,11 @@ static void iocg_pay_debt(struct ioc_gq *iocg, u64 abs_vpay,
|
|||||||
lockdep_assert_held(&iocg->ioc->lock);
|
lockdep_assert_held(&iocg->ioc->lock);
|
||||||
lockdep_assert_held(&iocg->waitq.lock);
|
lockdep_assert_held(&iocg->waitq.lock);
|
||||||
|
|
||||||
/* make sure that nobody messed with @iocg */
|
/*
|
||||||
WARN_ON_ONCE(list_empty(&iocg->active_list));
|
* make sure that nobody messed with @iocg. Check iocg->pd.online
|
||||||
|
* to avoid warn when removing blkcg or disk.
|
||||||
|
*/
|
||||||
|
WARN_ON_ONCE(list_empty(&iocg->active_list) && iocg->pd.online);
|
||||||
WARN_ON_ONCE(iocg->inuse > 1);
|
WARN_ON_ONCE(iocg->inuse > 1);
|
||||||
|
|
||||||
iocg->abs_vdebt -= min(abs_vpay, iocg->abs_vdebt);
|
iocg->abs_vdebt -= min(abs_vpay, iocg->abs_vdebt);
|
||||||
|
@ -563,7 +563,8 @@ static int blkdev_common_ioctl(struct block_device *bdev, blk_mode_t mode,
|
|||||||
return -EACCES;
|
return -EACCES;
|
||||||
if (bdev_is_partition(bdev))
|
if (bdev_is_partition(bdev))
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
return disk_scan_partitions(bdev->bd_disk, mode);
|
return disk_scan_partitions(bdev->bd_disk,
|
||||||
|
mode | BLK_OPEN_STRICT_SCAN);
|
||||||
case BLKTRACESTART:
|
case BLKTRACESTART:
|
||||||
case BLKTRACESTOP:
|
case BLKTRACESTOP:
|
||||||
case BLKTRACETEARDOWN:
|
case BLKTRACETEARDOWN:
|
||||||
|
@ -128,6 +128,8 @@ typedef unsigned int __bitwise blk_mode_t;
|
|||||||
#define BLK_OPEN_WRITE_IOCTL ((__force blk_mode_t)(1 << 4))
|
#define BLK_OPEN_WRITE_IOCTL ((__force blk_mode_t)(1 << 4))
|
||||||
/* open is exclusive wrt all other BLK_OPEN_WRITE opens to the device */
|
/* open is exclusive wrt all other BLK_OPEN_WRITE opens to the device */
|
||||||
#define BLK_OPEN_RESTRICT_WRITES ((__force blk_mode_t)(1 << 5))
|
#define BLK_OPEN_RESTRICT_WRITES ((__force blk_mode_t)(1 << 5))
|
||||||
|
/* return partition scanning errors */
|
||||||
|
#define BLK_OPEN_STRICT_SCAN ((__force blk_mode_t)(1 << 6))
|
||||||
|
|
||||||
struct gendisk {
|
struct gendisk {
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user