mirror of https://gitee.com/openkylin/linux.git
io_uring: move all io_kiocb init early in io_init_req()
If we hit an error path in the function, make sure that the io_kiocb is fully initialized at that point so that freeing the request always sees a valid state. Signed-off-by: Jens Axboe <axboe@kernel.dk>
This commit is contained in:
parent
70e3512509
commit
93e68e036c
|
@ -6327,6 +6327,9 @@ static int io_init_req(struct io_ring_ctx *ctx, struct io_kiocb *req,
|
|||
refcount_set(&req->refs, 2);
|
||||
req->task = current;
|
||||
req->result = 0;
|
||||
req->work.list.next = NULL;
|
||||
req->work.creds = NULL;
|
||||
req->work.flags = 0;
|
||||
|
||||
/* enforce forwards compatibility on users */
|
||||
if (unlikely(sqe_flags & ~SQE_VALID_FLAGS)) {
|
||||
|
@ -6344,17 +6347,13 @@ static int io_init_req(struct io_ring_ctx *ctx, struct io_kiocb *req,
|
|||
!io_op_defs[req->opcode].buffer_select)
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
req->work.list.next = NULL;
|
||||
personality = READ_ONCE(sqe->personality);
|
||||
if (personality) {
|
||||
req->work.creds = xa_load(&ctx->personalities, personality);
|
||||
if (!req->work.creds)
|
||||
return -EINVAL;
|
||||
get_cred(req->work.creds);
|
||||
} else {
|
||||
req->work.creds = NULL;
|
||||
}
|
||||
req->work.flags = 0;
|
||||
state = &ctx->submit_state;
|
||||
|
||||
/*
|
||||
|
|
Loading…
Reference in New Issue