mirror of
https://github.com/torvalds/linux.git
synced 2026-03-08 04:04:43 +01:00
block-7.0-20260216
-----BEGIN PGP SIGNATURE----- iQJEBAABCAAuFiEEwPw5LcreJtl1+l5K99NY+ylx4KYFAmmTrNEQHGF4Ym9lQGtl cm5lbC5kawAKCRD301j7KXHgpjsOEACpUk78nFmLbEgJ5UH8+Z6daDzgoasb5YRT Mj4g+cM2J9Xc9JxgX8QR3F2EfolweTo/H6xlhnlPDcnpB+b3qj4WHuijR/wghphj MBKKqNXTEC+j0ra9uk8h3RmIKaK79xcUup7XfTcuWdYpSsMyYE/m/rck3thw6yNL OAjmWLTP4IwYzXip2AB+J7JbDDOV/qWK0aOYdWHCdbn9X8bBel/HDOITWPdybnSR DNKBeoi/Yv8KwA+axogqP213ifc3Xr6ejRDkqDOf1bgXsKkELkIxcfog6MhfHhxq 3Cqlj1pBuIBxGVU7wmBTDqL+aHrVb983tcA5x1NGZIzJao64b026o5DUhNPprwrZ HveU1MZ2jarAjAz85gE3S4oUY+6d47ooytfvO548Zp/1LY+fOxnjYqq5ksh8BBLk WyjfkJScgr17Z4SVOK8a9GboWO2WKiQJRg+hZ/TWX5fyvu5g9sbRasdwxnp1sl52 EayzkhYFq/Rdd8slwTIaccVUPl/xeEDeRG+jTJ+4Fj54TihKiJzXVsxDkSWKf46V CWmzDx+n6MlGPm9mShSERZ7HJh3VcSp4No/HAjf93u9/UXwubK/SKiV71nhpgJMf 9bWS2G3wPx/5LoME95YkF+CSgs0e/ROUusfGd8X6nIz9EBGzeabCG/mjqd5adC09 OZahOuqrIg== =PVoY -----END PGP SIGNATURE----- Merge tag 'block-7.0-20260216' of git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux Pull more block updates from Jens Axboe: - Fix partial IOVA mapping cleanup in error handling - Minor prep series ignoring discard return value, as the inline value is always known - Ensure BLK_FEAT_STABLE_WRITES is set for drbd - Fix leak of folio in bio_iov_iter_bounce_read() - Allow IOC_PR_READ_* for read-only open - Another debugfs deadlock fix - A few doc updates * tag 'block-7.0-20260216' of git://git.kernel.org/pub/scm/linux/kernel/git/axboe/linux: blk-mq: use NOIO context to prevent deadlock during debugfs creation blk-stat: convert struct blk_stat_callback to kernel-doc block: fix enum descriptions kernel-doc block: update docs for bio and bvec_iter block: change return type to void nvmet: ignore discard return value md: ignore discard return value block: fix partial IOVA mapping cleanup in blk_rq_dma_map_iova block: fix folio leak in bio_iov_iter_bounce_read() block: allow IOC_PR_READ_* ioctls with BLK_OPEN_READ drbd: always set BLK_FEAT_STABLE_WRITES
This commit is contained in:
commit
99dfe2d4da
18 changed files with 181 additions and 104 deletions
|
|
@ -559,9 +559,9 @@ int blk_trace_remove(struct request_queue *q)
|
|||
{
|
||||
int ret;
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
blk_debugfs_lock_nomemsave(q);
|
||||
ret = __blk_trace_remove(q);
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock_nomemrestore(q);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
@ -767,6 +767,7 @@ int blk_trace_setup(struct request_queue *q, char *name, dev_t dev,
|
|||
struct blk_user_trace_setup2 buts2;
|
||||
struct blk_user_trace_setup buts;
|
||||
struct blk_trace *bt;
|
||||
unsigned int memflags;
|
||||
int ret;
|
||||
|
||||
ret = copy_from_user(&buts, arg, sizeof(buts));
|
||||
|
|
@ -785,16 +786,16 @@ int blk_trace_setup(struct request_queue *q, char *name, dev_t dev,
|
|||
.pid = buts.pid,
|
||||
};
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
memflags = blk_debugfs_lock(q);
|
||||
bt = blk_trace_setup_prepare(q, name, dev, buts.buf_size, buts.buf_nr,
|
||||
bdev);
|
||||
if (IS_ERR(bt)) {
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
return PTR_ERR(bt);
|
||||
}
|
||||
blk_trace_setup_finalize(q, name, 1, bt, &buts2);
|
||||
strscpy(buts.name, buts2.name, BLKTRACE_BDEV_SIZE);
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
|
||||
if (copy_to_user(arg, &buts, sizeof(buts))) {
|
||||
blk_trace_remove(q);
|
||||
|
|
@ -809,6 +810,7 @@ static int blk_trace_setup2(struct request_queue *q, char *name, dev_t dev,
|
|||
{
|
||||
struct blk_user_trace_setup2 buts2;
|
||||
struct blk_trace *bt;
|
||||
unsigned int memflags;
|
||||
|
||||
if (copy_from_user(&buts2, arg, sizeof(buts2)))
|
||||
return -EFAULT;
|
||||
|
|
@ -819,15 +821,15 @@ static int blk_trace_setup2(struct request_queue *q, char *name, dev_t dev,
|
|||
if (buts2.flags != 0)
|
||||
return -EINVAL;
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
memflags = blk_debugfs_lock(q);
|
||||
bt = blk_trace_setup_prepare(q, name, dev, buts2.buf_size, buts2.buf_nr,
|
||||
bdev);
|
||||
if (IS_ERR(bt)) {
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
return PTR_ERR(bt);
|
||||
}
|
||||
blk_trace_setup_finalize(q, name, 2, bt, &buts2);
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
|
||||
if (copy_to_user(arg, &buts2, sizeof(buts2))) {
|
||||
blk_trace_remove(q);
|
||||
|
|
@ -844,6 +846,7 @@ static int compat_blk_trace_setup(struct request_queue *q, char *name,
|
|||
struct blk_user_trace_setup2 buts2;
|
||||
struct compat_blk_user_trace_setup cbuts;
|
||||
struct blk_trace *bt;
|
||||
unsigned int memflags;
|
||||
|
||||
if (copy_from_user(&cbuts, arg, sizeof(cbuts)))
|
||||
return -EFAULT;
|
||||
|
|
@ -860,15 +863,15 @@ static int compat_blk_trace_setup(struct request_queue *q, char *name,
|
|||
.pid = cbuts.pid,
|
||||
};
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
memflags = blk_debugfs_lock(q);
|
||||
bt = blk_trace_setup_prepare(q, name, dev, buts2.buf_size, buts2.buf_nr,
|
||||
bdev);
|
||||
if (IS_ERR(bt)) {
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
return PTR_ERR(bt);
|
||||
}
|
||||
blk_trace_setup_finalize(q, name, 1, bt, &buts2);
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
|
||||
if (copy_to_user(arg, &buts2.name, ARRAY_SIZE(buts2.name))) {
|
||||
blk_trace_remove(q);
|
||||
|
|
@ -898,9 +901,9 @@ int blk_trace_startstop(struct request_queue *q, int start)
|
|||
{
|
||||
int ret;
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
blk_debugfs_lock_nomemsave(q);
|
||||
ret = __blk_trace_startstop(q, start);
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock_nomemrestore(q);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
|
@ -2041,7 +2044,7 @@ static ssize_t sysfs_blk_trace_attr_show(struct device *dev,
|
|||
struct blk_trace *bt;
|
||||
ssize_t ret = -ENXIO;
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
blk_debugfs_lock_nomemsave(q);
|
||||
|
||||
bt = rcu_dereference_protected(q->blk_trace,
|
||||
lockdep_is_held(&q->debugfs_mutex));
|
||||
|
|
@ -2062,7 +2065,7 @@ static ssize_t sysfs_blk_trace_attr_show(struct device *dev,
|
|||
ret = sprintf(buf, "%llu\n", bt->end_lba);
|
||||
|
||||
out_unlock_bdev:
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock_nomemrestore(q);
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
|
@ -2073,6 +2076,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
|
|||
struct block_device *bdev = dev_to_bdev(dev);
|
||||
struct request_queue *q = bdev_get_queue(bdev);
|
||||
struct blk_trace *bt;
|
||||
unsigned int memflags;
|
||||
u64 value;
|
||||
ssize_t ret = -EINVAL;
|
||||
|
||||
|
|
@ -2092,7 +2096,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
|
|||
goto out;
|
||||
}
|
||||
|
||||
mutex_lock(&q->debugfs_mutex);
|
||||
memflags = blk_debugfs_lock(q);
|
||||
|
||||
bt = rcu_dereference_protected(q->blk_trace,
|
||||
lockdep_is_held(&q->debugfs_mutex));
|
||||
|
|
@ -2127,7 +2131,7 @@ static ssize_t sysfs_blk_trace_attr_store(struct device *dev,
|
|||
}
|
||||
|
||||
out_unlock_bdev:
|
||||
mutex_unlock(&q->debugfs_mutex);
|
||||
blk_debugfs_unlock(q, memflags);
|
||||
out:
|
||||
return ret ? ret : count;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue