@@ -30,6 +30,7 @@ struct io_accept {
int flags;
u32 file_slot;
unsigned long nofile;
+ int retarget_fd;
};
struct io_socket {
@@ -1255,6 +1256,15 @@ void io_sendrecv_fail(struct io_kiocb *req)
req->cqe.flags |= IORING_CQE_F_MORE;
}
+bool io_accept_can_retarget_rsrc(struct io_kiocb *req)
+{
+ struct io_accept *accept = io_kiocb_to_cmd(req, struct io_accept);
+
+ if (accept->retarget_fd < 0)
+ return false;
+ return io_file_peek_fixed(req, accept->retarget_fd) == req->file;
+}
+
int io_accept_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe)
{
struct io_accept *accept = io_kiocb_to_cmd(req, struct io_accept);
@@ -1285,6 +1295,11 @@ int io_accept_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe)
accept->flags = (accept->flags & ~SOCK_NONBLOCK) | O_NONBLOCK;
if (flags & IORING_ACCEPT_MULTISHOT)
req->flags |= REQ_F_APOLL_MULTISHOT;
+
+ if (req->flags & REQ_F_FIXED_FILE)
+ accept->retarget_fd = req->cqe.fd;
+ else
+ accept->retarget_fd = -1;
return 0;
}
@@ -49,6 +49,7 @@ void io_sendrecv_fail(struct io_kiocb *req);
int io_accept_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe);
int io_accept(struct io_kiocb *req, unsigned int issue_flags);
+bool io_accept_can_retarget_rsrc(struct io_kiocb *req);
int io_socket_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe);
int io_socket(struct io_kiocb *req, unsigned int issue_flags);
@@ -207,6 +207,7 @@ const struct io_op_def io_op_defs[] = {
#if defined(CONFIG_NET)
.prep = io_accept_prep,
.issue = io_accept,
+ .can_retarget_rsrc = io_accept_can_retarget_rsrc,
#else
.prep = io_eopnotsupp_prep,
#endif
Add can_retarget_rsrc handler for accept Signed-off-by: Dylan Yudaken <dylany@meta.com> --- io_uring/net.c | 15 +++++++++++++++ io_uring/net.h | 1 + io_uring/opdef.c | 1 + 3 files changed, 17 insertions(+)