SUNRPC: Remove redundant socket flags from svc_tcp_sendmsg()

Now that the caller controls the TCP_CORK socket option, it is redundant
to set MSG_MORE and MSG_SENDPAGE_NOTLAST in the calls to
kernel_sendpage().

Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
This commit is contained in:
Trond Myklebust 2021-02-16 12:17:23 -05:00 committed by Chuck Lever
parent e0a912e8dd
commit 987c7b1d09

View File

@ -1088,12 +1088,11 @@ static int svc_tcp_sendmsg(struct socket *sock, struct msghdr *msg,
.iov_base = &marker, .iov_base = &marker,
.iov_len = sizeof(marker), .iov_len = sizeof(marker),
}; };
int flags, ret; int ret;
*sentp = 0; *sentp = 0;
xdr_alloc_bvec(xdr, GFP_KERNEL); xdr_alloc_bvec(xdr, GFP_KERNEL);
msg->msg_flags = MSG_MORE;
ret = kernel_sendmsg(sock, msg, &rm, 1, rm.iov_len); ret = kernel_sendmsg(sock, msg, &rm, 1, rm.iov_len);
if (ret < 0) if (ret < 0)
return ret; return ret;
@ -1101,8 +1100,7 @@ static int svc_tcp_sendmsg(struct socket *sock, struct msghdr *msg,
if (ret != rm.iov_len) if (ret != rm.iov_len)
return -EAGAIN; return -EAGAIN;
flags = head->iov_len < xdr->len ? MSG_MORE | MSG_SENDPAGE_NOTLAST : 0; ret = svc_tcp_send_kvec(sock, head, 0);
ret = svc_tcp_send_kvec(sock, head, flags);
if (ret < 0) if (ret < 0)
return ret; return ret;
*sentp += ret; *sentp += ret;
@ -1116,15 +1114,11 @@ static int svc_tcp_sendmsg(struct socket *sock, struct msghdr *msg,
bvec = xdr->bvec + (xdr->page_base >> PAGE_SHIFT); bvec = xdr->bvec + (xdr->page_base >> PAGE_SHIFT);
offset = offset_in_page(xdr->page_base); offset = offset_in_page(xdr->page_base);
remaining = xdr->page_len; remaining = xdr->page_len;
flags = MSG_MORE | MSG_SENDPAGE_NOTLAST;
while (remaining > 0) { while (remaining > 0) {
if (remaining <= PAGE_SIZE && tail->iov_len == 0)
flags = 0;
len = min(remaining, bvec->bv_len - offset); len = min(remaining, bvec->bv_len - offset);
ret = kernel_sendpage(sock, bvec->bv_page, ret = kernel_sendpage(sock, bvec->bv_page,
bvec->bv_offset + offset, bvec->bv_offset + offset,
len, flags); len, 0);
if (ret < 0) if (ret < 0)
return ret; return ret;
*sentp += ret; *sentp += ret;