[PATCH mptcp-next] Squash-to: "selftests: mptcp: mptfo Initiator/Listener": fix mmap failure

Paolo Abeni posted 1 patch 1 year, 5 months ago
Failed in applying to current master (apply log)
.../selftests/net/mptcp/mptcp_connect.c       | 57 ++++++++++++++-----
1 file changed, 43 insertions(+), 14 deletions(-)
[PATCH mptcp-next] Squash-to: "selftests: mptcp: mptfo Initiator/Listener": fix mmap failure
Posted by Paolo Abeni 1 year, 5 months ago
In TFO scenarios we need to completelly spool the partially xmitted
buffer (and accunt for that) before starting sendfile/mmap xmit,
otherwise the relevant tests will fail.

Signed-off-by: Paolo Abeni <pabeni@redhat.com>
---
 .../selftests/net/mptcp/mptcp_connect.c       | 57 ++++++++++++++-----
 1 file changed, 43 insertions(+), 14 deletions(-)

diff --git a/tools/testing/selftests/net/mptcp/mptcp_connect.c b/tools/testing/selftests/net/mptcp/mptcp_connect.c
index 8635619ab1fd..ee8d320b071c 100644
--- a/tools/testing/selftests/net/mptcp/mptcp_connect.c
+++ b/tools/testing/selftests/net/mptcp/mptcp_connect.c
@@ -95,6 +95,7 @@ struct wstate {
 	char buf[8192];
 	unsigned int len;
 	unsigned int off;
+	unsigned int total_len;
 };
 
 static struct tcp_inq_state tcp_inq;
@@ -375,8 +376,8 @@ static int sock_connect_mptcp(const char * const remoteaddr,
 			set_mark(sock, cfg_mark);
 
 		if (cfg_sockopt_types.mptfo) {
-			if (!winfo->len)
-				winfo->len = read(infd, winfo->buf, sizeof(winfo->buf));
+			if (!winfo->total_len)
+				winfo->total_len = winfo->len = read(infd, winfo->buf, sizeof(winfo->buf));
 
 			syn_copied = sendto(sock, winfo->buf, winfo->len, MSG_FASTOPEN,
 					    a->ai_addr, a->ai_addrlen);
@@ -757,10 +758,26 @@ static int do_recvfile(int infd, int outfd)
 	return (int)r;
 }
 
-static int do_mmap(int infd, int outfd, unsigned int size)
+static int spool_buf(int fd, struct wstate *winfo)
+{
+	while (winfo->len) {
+		int ret = write(fd, winfo->buf + winfo->off, winfo->len);
+
+		if (ret < 0) {
+			perror("write");
+			return 4;
+		}
+		winfo->off += ret;
+		winfo->len -= ret;
+	}
+	return 0;
+}
+
+static int do_mmap(int infd, int outfd, unsigned int size,
+		   struct wstate *winfo)
 {
 	char *inbuf = mmap(NULL, size, PROT_READ, MAP_SHARED, infd, 0);
-	ssize_t ret = 0, off = 0;
+	ssize_t ret = 0, off = winfo->total_len;
 	size_t rem;
 
 	if (inbuf == MAP_FAILED) {
@@ -768,7 +785,11 @@ static int do_mmap(int infd, int outfd, unsigned int size)
 		return 1;
 	}
 
-	rem = size;
+	ret = spool_buf(outfd, winfo);
+	if (ret < 0)
+		return ret;
+
+	rem = size - winfo->total_len;
 
 	while (rem > 0) {
 		ret = write(outfd, inbuf + off, rem);
@@ -812,8 +833,15 @@ static int get_infd_size(int fd)
 	return (int)count;
 }
 
-static int do_sendfile(int infd, int outfd, unsigned int count)
+static int do_sendfile(int infd, int outfd, unsigned int count,
+		       struct wstate *winfo)
 {
+	int ret = spool_buf(outfd, winfo);
+	if (ret < 0)
+		return ret;
+
+	count -= winfo->total_len;
+
 	while (count > 0) {
 		ssize_t r;
 
@@ -830,7 +858,8 @@ static int do_sendfile(int infd, int outfd, unsigned int count)
 }
 
 static int copyfd_io_mmap(int infd, int peerfd, int outfd,
-			  unsigned int size, bool *in_closed_after_out)
+			  unsigned int size, bool *in_closed_after_out,
+			  struct wstate *winfo)
 {
 	int err;
 
@@ -839,9 +868,9 @@ static int copyfd_io_mmap(int infd, int peerfd, int outfd,
 		if (err)
 			return err;
 
-		err = do_mmap(infd, peerfd, size);
+		err = do_mmap(infd, peerfd, size, winfo);
 	} else {
-		err = do_mmap(infd, peerfd, size);
+		err = do_mmap(infd, peerfd, size, winfo);
 		if (err)
 			return err;
 
@@ -855,7 +884,7 @@ static int copyfd_io_mmap(int infd, int peerfd, int outfd,
 }
 
 static int copyfd_io_sendfile(int infd, int peerfd, int outfd,
-			      unsigned int size, bool *in_closed_after_out)
+			      unsigned int size, bool *in_closed_after_out, struct wstate *winfo)
 {
 	int err;
 
@@ -864,9 +893,9 @@ static int copyfd_io_sendfile(int infd, int peerfd, int outfd,
 		if (err)
 			return err;
 
-		err = do_sendfile(infd, peerfd, size);
+		err = do_sendfile(infd, peerfd, size, winfo);
 	} else {
-		err = do_sendfile(infd, peerfd, size);
+		err = do_sendfile(infd, peerfd, size, winfo);
 		if (err)
 			return err;
 
@@ -898,14 +927,14 @@ static int copyfd_io(int infd, int peerfd, int outfd, bool close_peerfd, struct
 		file_size = get_infd_size(infd);
 		if (file_size < 0)
 			return file_size;
-		ret = copyfd_io_mmap(infd, peerfd, outfd, file_size, &in_closed_after_out);
+		ret = copyfd_io_mmap(infd, peerfd, outfd, file_size, &in_closed_after_out, winfo);
 		break;
 
 	case CFG_MODE_SENDFILE:
 		file_size = get_infd_size(infd);
 		if (file_size < 0)
 			return file_size;
-		ret = copyfd_io_sendfile(infd, peerfd, outfd, file_size, &in_closed_after_out);
+		ret = copyfd_io_sendfile(infd, peerfd, outfd, file_size, &in_closed_after_out, winfo);
 		break;
 
 	default:
-- 
2.38.1
Re: [PATCH mptcp-next] Squash-to: "selftests: mptcp: mptfo Initiator/Listener": fix mmap failure
Posted by Matthieu Baerts 1 year, 5 months ago
Hi Paolo,

On 11/11/2022 17:39, Paolo Abeni wrote:
> In TFO scenarios we need to completelly spool the partially xmitted
> buffer (and accunt for that) before starting sendfile/mmap xmit,
> otherwise the relevant tests will fail.

Thank you for the patches!

Now in our tree, including a patch with the same prefix sent a few hours
ago and a small build fix from me:

- c97736cc702f: mptcp: fix compilation error in "mptcp: implement
delayed seq generation for passive fastopen"
- cb2b511f8d3d: "squashed" in "selftests: mptcp: mptfo Initiator/Listener"
- c335ade026e4: "squashed" in "selftests: mptcp: mptfo Initiator/Listener"
- Results: 0c67a168fcee..df9ca8c514fa (export)

Tests are now in progress:

https://cirrus-ci.com/github/multipath-tcp/mptcp_net-next/export/20221111T171239


Cheers,
Matt
-- 
Tessares | Belgium | Hybrid Access Solutions
www.tessares.net