Merge tag 'for-linus-20191010' of git://git.kernel.dk/linux-block
Pull block fixes from Jens Axboe: - Fix wbt performance regression introduced with the blk-rq-qos refactoring (Harshad) - Fix io_uring fileset removal inadvertently killing the workqueue (me) - Fix io_uring typo in linked command nonblock submission (Pavel) - Remove spurious io_uring wakeups on request free (Pavel) - Fix null_blk zoned command error return (Keith) - Don't use freezable workqueues for backing_dev, also means we can revert a previous libata hack (Mika) - Fix nbd sysfs mutex dropped too soon at removal time (Xiubo) * tag 'for-linus-20191010' of git://git.kernel.dk/linux-block: nbd: fix possible sysfs duplicate warning null_blk: Fix zoned command return code io_uring: only flush workqueues on fileset removal io_uring: remove wait loop spurious wakeups blk-wbt: fix performance regression in wbt scale_up/scale_down Revert "libata, freezer: avoid block device removal while system is frozen" bdi: Do not use freezable workqueue io_uring: fix reversed nonblock flag for link submission
这个提交包含在:
@@ -591,14 +591,6 @@ static void io_cqring_add_event(struct io_ring_ctx *ctx, u64 user_data,
|
||||
io_cqring_ev_posted(ctx);
|
||||
}
|
||||
|
||||
static void io_ring_drop_ctx_refs(struct io_ring_ctx *ctx, unsigned refs)
|
||||
{
|
||||
percpu_ref_put_many(&ctx->refs, refs);
|
||||
|
||||
if (waitqueue_active(&ctx->wait))
|
||||
wake_up(&ctx->wait);
|
||||
}
|
||||
|
||||
static struct io_kiocb *io_get_req(struct io_ring_ctx *ctx,
|
||||
struct io_submit_state *state)
|
||||
{
|
||||
@@ -646,7 +638,7 @@ static struct io_kiocb *io_get_req(struct io_ring_ctx *ctx,
|
||||
req->result = 0;
|
||||
return req;
|
||||
out:
|
||||
io_ring_drop_ctx_refs(ctx, 1);
|
||||
percpu_ref_put(&ctx->refs);
|
||||
return NULL;
|
||||
}
|
||||
|
||||
@@ -654,7 +646,7 @@ static void io_free_req_many(struct io_ring_ctx *ctx, void **reqs, int *nr)
|
||||
{
|
||||
if (*nr) {
|
||||
kmem_cache_free_bulk(req_cachep, *nr, reqs);
|
||||
io_ring_drop_ctx_refs(ctx, *nr);
|
||||
percpu_ref_put_many(&ctx->refs, *nr);
|
||||
*nr = 0;
|
||||
}
|
||||
}
|
||||
@@ -663,7 +655,7 @@ static void __io_free_req(struct io_kiocb *req)
|
||||
{
|
||||
if (req->file && !(req->flags & REQ_F_FIXED_FILE))
|
||||
fput(req->file);
|
||||
io_ring_drop_ctx_refs(req->ctx, 1);
|
||||
percpu_ref_put(&req->ctx->refs);
|
||||
kmem_cache_free(req_cachep, req);
|
||||
}
|
||||
|
||||
@@ -2761,7 +2753,7 @@ out:
|
||||
|
||||
if (link)
|
||||
io_queue_link_head(ctx, link, &link->submit, shadow_req,
|
||||
block_for_last);
|
||||
!block_for_last);
|
||||
if (statep)
|
||||
io_submit_state_end(statep);
|
||||
|
||||
@@ -2920,8 +2912,12 @@ static void io_finish_async(struct io_ring_ctx *ctx)
|
||||
static void io_destruct_skb(struct sk_buff *skb)
|
||||
{
|
||||
struct io_ring_ctx *ctx = skb->sk->sk_user_data;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < ARRAY_SIZE(ctx->sqo_wq); i++)
|
||||
if (ctx->sqo_wq[i])
|
||||
flush_workqueue(ctx->sqo_wq[i]);
|
||||
|
||||
io_finish_async(ctx);
|
||||
unix_destruct_scm(skb);
|
||||
}
|
||||
|
||||
@@ -3630,7 +3626,7 @@ SYSCALL_DEFINE6(io_uring_enter, unsigned int, fd, u32, to_submit,
|
||||
}
|
||||
}
|
||||
|
||||
io_ring_drop_ctx_refs(ctx, 1);
|
||||
percpu_ref_put(&ctx->refs);
|
||||
out_fput:
|
||||
fdput(f);
|
||||
return submitted ? submitted : ret;
|
||||
|
在新工单中引用
屏蔽一个用户