aboutsummaryrefslogtreecommitdiffstats
path: root/net/socket.c
diff options
context:
space:
mode:
authorTom Herbert <tom@herbertland.com>2016-03-07 17:11:02 -0500
committerDavid S. Miller <davem@davemloft.net>2016-03-09 16:36:13 -0500
commit28a94d8fb35b3a75b802f368ae6f4a9f6b0d435a (patch)
tree1d24107d12e749671b067af927542155ce7e0b43 /net/socket.c
parentf4a00aacdb5f6784d46e8c999b6bb52ece4b306b (diff)
net: Allow MSG_EOR in each msghdr of sendmmsg
This patch allows setting MSG_EOR in each individual msghdr passed in sendmmsg. This allows a sendmmsg to send multiple messages when using SOCK_SEQPACKET. Signed-off-by: Tom Herbert <tom@herbertland.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/socket.c')
-rw-r--r--net/socket.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/net/socket.c b/net/socket.c
index 38a78d4d50f5..0dd4dd818f41 100644
--- a/net/socket.c
+++ b/net/socket.c
@@ -1875,7 +1875,8 @@ static int copy_msghdr_from_user(struct msghdr *kmsg,
1875 1875
1876static int ___sys_sendmsg(struct socket *sock, struct user_msghdr __user *msg, 1876static int ___sys_sendmsg(struct socket *sock, struct user_msghdr __user *msg,
1877 struct msghdr *msg_sys, unsigned int flags, 1877 struct msghdr *msg_sys, unsigned int flags,
1878 struct used_address *used_address) 1878 struct used_address *used_address,
1879 unsigned int allowed_msghdr_flags)
1879{ 1880{
1880 struct compat_msghdr __user *msg_compat = 1881 struct compat_msghdr __user *msg_compat =
1881 (struct compat_msghdr __user *)msg; 1882 (struct compat_msghdr __user *)msg;
@@ -1901,6 +1902,7 @@ static int ___sys_sendmsg(struct socket *sock, struct user_msghdr __user *msg,
1901 1902
1902 if (msg_sys->msg_controllen > INT_MAX) 1903 if (msg_sys->msg_controllen > INT_MAX)
1903 goto out_freeiov; 1904 goto out_freeiov;
1905 flags |= (msg_sys->msg_flags & allowed_msghdr_flags);
1904 ctl_len = msg_sys->msg_controllen; 1906 ctl_len = msg_sys->msg_controllen;
1905 if ((MSG_CMSG_COMPAT & flags) && ctl_len) { 1907 if ((MSG_CMSG_COMPAT & flags) && ctl_len) {
1906 err = 1908 err =
@@ -1979,7 +1981,7 @@ long __sys_sendmsg(int fd, struct user_msghdr __user *msg, unsigned flags)
1979 if (!sock) 1981 if (!sock)
1980 goto out; 1982 goto out;
1981 1983
1982 err = ___sys_sendmsg(sock, msg, &msg_sys, flags, NULL); 1984 err = ___sys_sendmsg(sock, msg, &msg_sys, flags, NULL, 0);
1983 1985
1984 fput_light(sock->file, fput_needed); 1986 fput_light(sock->file, fput_needed);
1985out: 1987out:
@@ -2024,7 +2026,7 @@ int __sys_sendmmsg(int fd, struct mmsghdr __user *mmsg, unsigned int vlen,
2024 while (datagrams < vlen) { 2026 while (datagrams < vlen) {
2025 if (MSG_CMSG_COMPAT & flags) { 2027 if (MSG_CMSG_COMPAT & flags) {
2026 err = ___sys_sendmsg(sock, (struct user_msghdr __user *)compat_entry, 2028 err = ___sys_sendmsg(sock, (struct user_msghdr __user *)compat_entry,
2027 &msg_sys, flags, &used_address); 2029 &msg_sys, flags, &used_address, MSG_EOR);
2028 if (err < 0) 2030 if (err < 0)
2029 break; 2031 break;
2030 err = __put_user(err, &compat_entry->msg_len); 2032 err = __put_user(err, &compat_entry->msg_len);
@@ -2032,7 +2034,7 @@ int __sys_sendmmsg(int fd, struct mmsghdr __user *mmsg, unsigned int vlen,
2032 } else { 2034 } else {
2033 err = ___sys_sendmsg(sock, 2035 err = ___sys_sendmsg(sock,
2034 (struct user_msghdr __user *)entry, 2036 (struct user_msghdr __user *)entry,
2035 &msg_sys, flags, &used_address); 2037 &msg_sys, flags, &used_address, MSG_EOR);
2036 if (err < 0) 2038 if (err < 0)
2037 break; 2039 break;
2038 err = put_user(err, &entry->msg_len); 2040 err = put_user(err, &entry->msg_len);