io_uring: Remove unnecessary BUILD_BUG_ON
authorBreno Leitao <leitao@debian.org>
Thu, 4 May 2023 12:18:56 +0000 (05:18 -0700)
committerJens Axboe <axboe@kernel.dk>
Thu, 4 May 2023 14:19:05 +0000 (08:19 -0600)
In the io_uring_cmd_prep_async() there is an unnecessary compilation time
check to check if cmd is correctly placed at field 48 of the SQE.

This is unnecessary, since this check is already in place at
io_uring_init():

          BUILD_BUG_SQE_ELEM(48, __u64,  addr3);

Remove it and the uring_cmd_pdu_size() function, which is not used
anymore.

Keith started a discussion about this topic in the following thread:
Link: https://lore.kernel.org/lkml/ZDBmQOhbyU0iLhMw@kbusch-mbp.dhcp.thefacebook.com/
Signed-off-by: Breno Leitao <leitao@debian.org>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Pavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/20230504121856.904491-4-leitao@debian.org
Signed-off-by: Jens Axboe <axboe@kernel.dk>
io_uring/uring_cmd.c
io_uring/uring_cmd.h

index ed536d7499db92b6d1c04d0f1f9b468cd5aeea8d..5e32db48696d4bb0a46c48addc042b076a284ebf 100644 (file)
@@ -70,9 +70,6 @@ int io_uring_cmd_prep_async(struct io_kiocb *req)
 {
        struct io_uring_cmd *ioucmd = io_kiocb_to_cmd(req, struct io_uring_cmd);
 
-       BUILD_BUG_ON(uring_cmd_pdu_size(0) != 16);
-       BUILD_BUG_ON(uring_cmd_pdu_size(1) != 80);
-
        memcpy(req->async_data, ioucmd->sqe, uring_sqe_size(req->ctx));
        ioucmd->sqe = req->async_data;
        return 0;
index 7c6697d13cb2e4ddfdcbcdd3362af57e285b6334..8117684ec3cac3c4e5765475ffaecd35e0448561 100644 (file)
@@ -3,11 +3,3 @@
 int io_uring_cmd(struct io_kiocb *req, unsigned int issue_flags);
 int io_uring_cmd_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe);
 int io_uring_cmd_prep_async(struct io_kiocb *req);
-
-/*
- * The URING_CMD payload starts at 'cmd' in the first sqe, and continues into
- * the following sqe if SQE128 is used.
- */
-#define uring_cmd_pdu_size(is_sqe128)                          \
-       ((1 + !!(is_sqe128)) * sizeof(struct io_uring_sqe) -    \
-               offsetof(struct io_uring_sqe, cmd))