Commit 5acbbc8e authored by Jens Axboe's avatar Jens Axboe

io_uring: only call kfree() for a non-zero pointer

It's safe to call kfree() with a NULL pointer, but it's also pointless.
Most of the time we don't have any data to free, and at millions of
requests per second, the redundant function call adds noticeable
overhead (about 1.3% of the runtime).
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent aa340845
...@@ -1519,7 +1519,8 @@ static void io_dismantle_req(struct io_kiocb *req) ...@@ -1519,7 +1519,8 @@ static void io_dismantle_req(struct io_kiocb *req)
if (req->flags & REQ_F_NEED_CLEANUP) if (req->flags & REQ_F_NEED_CLEANUP)
io_cleanup_req(req); io_cleanup_req(req);
kfree(req->io); if (req->io)
kfree(req->io);
if (req->file) if (req->file)
io_put_file(req, req->file, (req->flags & REQ_F_FIXED_FILE)); io_put_file(req, req->file, (req->flags & REQ_F_FIXED_FILE));
__io_put_req_task(req); __io_put_req_task(req);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment