io_uring: only call kfree() for a non-zero pointer
authorJens Axboe <axboe@kernel.dk>
Wed, 8 Jul 2020 21:15:26 +0000 (15:15 -0600)
committerJens Axboe <axboe@kernel.dk>
Wed, 8 Jul 2020 21:15:26 +0000 (15:15 -0600)
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: Jens Axboe <axboe@kernel.dk>
fs/io_uring.c

index 14168fb..51ff883 100644 (file)
@@ -1519,7 +1519,8 @@ static void io_dismantle_req(struct io_kiocb *req)
        if (req->flags & REQ_F_NEED_CLEANUP)
                io_cleanup_req(req);
 
-       kfree(req->io);
+       if (req->io)
+               kfree(req->io);
        if (req->file)
                io_put_file(req, req->file, (req->flags & REQ_F_FIXED_FILE));
        __io_put_req_task(req);