mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-17 02:15:57 +00:00
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:
parent
e0a912e8dd
commit
987c7b1d09
@ -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;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user