Skip to content

Commit e47293f

Browse files
committed
io_uring: move all prep state for IORING_OP_{SEND,RECV}_MGS to prep handler
Add struct io_sr_msg in our io_kiocb per-command union, and ensure that the send/recvmsg prep handlers have grabbed what they need from the SQE by the time prep is done. Signed-off-by: Jens Axboe <[email protected]>
1 parent 3fbb51c commit e47293f

File tree

1 file changed

+33
-31
lines changed

1 file changed

+33
-31
lines changed

fs/io_uring.c

Lines changed: 33 additions & 31 deletions
Original file line numberDiff line numberDiff line change
@@ -345,6 +345,12 @@ struct io_connect {
345345
int addr_len;
346346
};
347347

348+
struct io_sr_msg {
349+
struct file *file;
350+
struct user_msghdr __user *msg;
351+
int msg_flags;
352+
};
353+
348354
struct io_async_connect {
349355
struct sockaddr_storage address;
350356
};
@@ -389,6 +395,7 @@ struct io_kiocb {
389395
struct io_cancel cancel;
390396
struct io_timeout timeout;
391397
struct io_connect connect;
398+
struct io_sr_msg sr_msg;
392399
};
393400

394401
const struct io_uring_sqe *sqe;
@@ -2164,23 +2171,22 @@ static int io_sendmsg_prep(struct io_kiocb *req, struct io_async_ctx *io)
21642171
{
21652172
#if defined(CONFIG_NET)
21662173
const struct io_uring_sqe *sqe = req->sqe;
2167-
struct user_msghdr __user *msg;
2168-
unsigned flags;
2174+
struct io_sr_msg *sr = &req->sr_msg;
21692175

2170-
flags = READ_ONCE(sqe->msg_flags);
2171-
msg = u64_to_user_ptr(READ_ONCE(sqe->addr));
2176+
sr->msg_flags = READ_ONCE(sqe->msg_flags);
2177+
sr->msg = u64_to_user_ptr(READ_ONCE(sqe->addr));
21722178
io->msg.iov = io->msg.fast_iov;
2173-
return sendmsg_copy_msghdr(&io->msg.msg, msg, flags, &io->msg.iov);
2179+
return sendmsg_copy_msghdr(&io->msg.msg, sr->msg, sr->msg_flags,
2180+
&io->msg.iov);
21742181
#else
2175-
return 0;
2182+
return -EOPNOTSUPP;
21762183
#endif
21772184
}
21782185

21792186
static int io_sendmsg(struct io_kiocb *req, struct io_kiocb **nxt,
21802187
bool force_nonblock)
21812188
{
21822189
#if defined(CONFIG_NET)
2183-
const struct io_uring_sqe *sqe = req->sqe;
21842190
struct io_async_msghdr *kmsg = NULL;
21852191
struct socket *sock;
21862192
int ret;
@@ -2194,12 +2200,6 @@ static int io_sendmsg(struct io_kiocb *req, struct io_kiocb **nxt,
21942200
struct sockaddr_storage addr;
21952201
unsigned flags;
21962202

2197-
flags = READ_ONCE(sqe->msg_flags);
2198-
if (flags & MSG_DONTWAIT)
2199-
req->flags |= REQ_F_NOWAIT;
2200-
else if (force_nonblock)
2201-
flags |= MSG_DONTWAIT;
2202-
22032203
if (req->io) {
22042204
kmsg = &req->io->msg;
22052205
kmsg->msg.msg_name = &addr;
@@ -2215,6 +2215,12 @@ static int io_sendmsg(struct io_kiocb *req, struct io_kiocb **nxt,
22152215
goto out;
22162216
}
22172217

2218+
flags = req->sr_msg.msg_flags;
2219+
if (flags & MSG_DONTWAIT)
2220+
req->flags |= REQ_F_NOWAIT;
2221+
else if (force_nonblock)
2222+
flags |= MSG_DONTWAIT;
2223+
22182224
ret = __sys_sendmsg_sock(sock, &kmsg->msg, flags);
22192225
if (force_nonblock && ret == -EAGAIN) {
22202226
if (req->io)
@@ -2245,25 +2251,22 @@ static int io_sendmsg(struct io_kiocb *req, struct io_kiocb **nxt,
22452251
static int io_recvmsg_prep(struct io_kiocb *req, struct io_async_ctx *io)
22462252
{
22472253
#if defined(CONFIG_NET)
2248-
const struct io_uring_sqe *sqe = req->sqe;
2249-
struct user_msghdr __user *msg;
2250-
unsigned flags;
2254+
struct io_sr_msg *sr = &req->sr_msg;
22512255

2252-
flags = READ_ONCE(sqe->msg_flags);
2253-
msg = u64_to_user_ptr(READ_ONCE(sqe->addr));
2256+
sr->msg_flags = READ_ONCE(req->sqe->msg_flags);
2257+
sr->msg = u64_to_user_ptr(READ_ONCE(req->sqe->addr));
22542258
io->msg.iov = io->msg.fast_iov;
2255-
return recvmsg_copy_msghdr(&io->msg.msg, msg, flags, &io->msg.uaddr,
2256-
&io->msg.iov);
2259+
return recvmsg_copy_msghdr(&io->msg.msg, sr->msg, sr->msg_flags,
2260+
&io->msg.uaddr, &io->msg.iov);
22572261
#else
2258-
return 0;
2262+
return -EOPNOTSUPP;
22592263
#endif
22602264
}
22612265

22622266
static int io_recvmsg(struct io_kiocb *req, struct io_kiocb **nxt,
22632267
bool force_nonblock)
22642268
{
22652269
#if defined(CONFIG_NET)
2266-
const struct io_uring_sqe *sqe = req->sqe;
22672270
struct io_async_msghdr *kmsg = NULL;
22682271
struct socket *sock;
22692272
int ret;
@@ -2273,18 +2276,10 @@ static int io_recvmsg(struct io_kiocb *req, struct io_kiocb **nxt,
22732276

22742277
sock = sock_from_file(req->file, &ret);
22752278
if (sock) {
2276-
struct user_msghdr __user *msg;
22772279
struct io_async_ctx io;
22782280
struct sockaddr_storage addr;
22792281
unsigned flags;
22802282

2281-
flags = READ_ONCE(sqe->msg_flags);
2282-
if (flags & MSG_DONTWAIT)
2283-
req->flags |= REQ_F_NOWAIT;
2284-
else if (force_nonblock)
2285-
flags |= MSG_DONTWAIT;
2286-
2287-
msg = u64_to_user_ptr(READ_ONCE(sqe->addr));
22882283
if (req->io) {
22892284
kmsg = &req->io->msg;
22902285
kmsg->msg.msg_name = &addr;
@@ -2300,7 +2295,14 @@ static int io_recvmsg(struct io_kiocb *req, struct io_kiocb **nxt,
23002295
goto out;
23012296
}
23022297

2303-
ret = __sys_recvmsg_sock(sock, &kmsg->msg, msg, kmsg->uaddr, flags);
2298+
flags = req->sr_msg.msg_flags;
2299+
if (flags & MSG_DONTWAIT)
2300+
req->flags |= REQ_F_NOWAIT;
2301+
else if (force_nonblock)
2302+
flags |= MSG_DONTWAIT;
2303+
2304+
ret = __sys_recvmsg_sock(sock, &kmsg->msg, req->sr_msg.msg,
2305+
kmsg->uaddr, flags);
23042306
if (force_nonblock && ret == -EAGAIN) {
23052307
if (req->io)
23062308
return -EAGAIN;

0 commit comments

Comments
 (0)