Message ID | 1618800836-76736-2-git-send-email-liyonglong@chinatelecom.cn |
---|---|
State | Accepted, archived |
Commit | 3a43a9f8d6df229c9e2c2eedafea2c736d37dfe0 |
Delegated to: | Matthieu Baerts |
Headers | show |
Series | [v4,1/2] mptcp: add MSG_PEEK support | expand |
On Mon, 2021-04-19 at 10:53 +0800, Yonglong Li wrote: > Extend mptcp_connect tool with MSG_PEEK support and add a test case in > mptcp_connect.sh that checks the data recvived from/after recv() with > MSG_PEEK. > > Signed-off-by: Yonglong Li <liyonglong@chinatelecom.cn> > --- > tools/testing/selftests/net/mptcp/mptcp_connect.c | 48 +++++++++++++++++++++- > tools/testing/selftests/net/mptcp/mptcp_connect.sh | 17 ++++++++ > 2 files changed, 63 insertions(+), 2 deletions(-) > > diff --git a/tools/testing/selftests/net/mptcp/mptcp_connect.c b/tools/testing/selftests/net/mptcp/mptcp_connect.c > index 2f207cf..d88e1fd 100644 > --- a/tools/testing/selftests/net/mptcp/mptcp_connect.c > +++ b/tools/testing/selftests/net/mptcp/mptcp_connect.c > @@ -45,7 +45,14 @@ enum cfg_mode { > CFG_MODE_SENDFILE, > }; > > +enum cfg_peek { > + CFG_NONE_PEEK, > + CFG_WITH_PEEK, > + CFG_AFTER_PEEK, > +}; > + > static enum cfg_mode cfg_mode = CFG_MODE_POLL; > +static enum cfg_peek cfg_peek = CFG_NONE_PEEK; > static const char *cfg_host; > static const char *cfg_port = "12000"; > static int cfg_sock_proto = IPPROTO_MPTCP; > @@ -73,6 +80,8 @@ static void die_usage(void) > fprintf(stderr, "\t-M mark -- set socket packet mark\n"); > fprintf(stderr, "\t-u -- check mptcp ulp\n"); > fprintf(stderr, "\t-w num -- wait num sec before closing the socket\n"); > + fprintf(stderr, > + "\t-P [saveWithPeek|saveAfterPeek] -- save data with/after MSG_PEEK form tcp socket\n"); > exit(1); > } > > @@ -331,6 +340,8 @@ static size_t do_write(const int fd, char *buf, const size_t len) > > static ssize_t do_rnd_read(const int fd, char *buf, const size_t len) > { > + int ret = 0; > + char tmp[16384]; > size_t cap = rand(); > > cap &= 0xffff; > @@ -340,7 +351,17 @@ static ssize_t do_rnd_read(const int fd, char *buf, const size_t len) > else if (cap > len) > cap = len; > > - return read(fd, buf, cap); > + if (cfg_peek == CFG_WITH_PEEK) { > + ret = recv(fd, buf, cap, MSG_PEEK); > + ret = (ret < 0) ? ret : read(fd, tmp, ret); > + } else if (cfg_peek == CFG_AFTER_PEEK) { > + ret = recv(fd, buf, cap, MSG_PEEK); > + ret = (ret < 0) ? ret : read(fd, buf, cap); > + } else { > + ret = read(fd, buf, cap); > + } > + > + return ret; > } > > static void set_nonblock(int fd) > @@ -819,6 +840,26 @@ int parse_mode(const char *mode) > return 0; > } > > +int parse_peek(const char *mode) > +{ > + if (!strcasecmp(mode, "saveWithPeek")) > + return CFG_WITH_PEEK; > + if (!strcasecmp(mode, "saveAfterPeek")) > + return CFG_AFTER_PEEK; > + > + fprintf(stderr, "Unknown: %s\n", mode); > + fprintf(stderr, "Supported MSG_PEEK mode are:\n"); > + fprintf(stderr, > + "\t\t\"saveWithPeek\" - recv data with flags 'MSG_PEEK' and save the peek data into file\n"); > + fprintf(stderr, > + "\t\t\"saveAfterPeek\" - read and save data into file after recv with flags 'MSG_PEEK'\n"); > + > + die_usage(); > + > + /* silence compiler warning */ > + return 0; > +} > + > static int parse_int(const char *size) > { > unsigned long s; > @@ -846,7 +887,7 @@ static void parse_opts(int argc, char **argv) > { > int c; > > - while ((c = getopt(argc, argv, "6jr:lp:s:hut:m:S:R:w:M:")) != -1) { > + while ((c = getopt(argc, argv, "6jr:lp:s:hut:m:S:R:w:M:P:")) != -1) { > switch (c) { > case 'j': > cfg_join = true; > @@ -899,6 +940,9 @@ static void parse_opts(int argc, char **argv) > case 'M': > cfg_mark = strtol(optarg, NULL, 0); > break; > + case 'P': > + cfg_peek = parse_peek(optarg); > + break; > } > } > > diff --git a/tools/testing/selftests/net/mptcp/mptcp_connect.sh b/tools/testing/selftests/net/mptcp/mptcp_connect.sh > index 385cdc9..319d166 100755 > --- a/tools/testing/selftests/net/mptcp/mptcp_connect.sh > +++ b/tools/testing/selftests/net/mptcp/mptcp_connect.sh > @@ -23,6 +23,8 @@ rcvbuf=0 > options_log=true > do_tcp=0 > filesize=0 > +peekmode="" > +testpeek=false > > if [ $tc_loss -eq 100 ];then > tc_loss=1% > @@ -393,6 +395,10 @@ do_transfer() > extra_args="$extra_args -m $testmode" > fi > > + if $testpeek; then > + extra_args="$extra_args -P $peekmode" > + fi > + > if [ -n "$extra_args" ] && $options_log; then > options_log=false > echo "INFO: extra options: $extra_args" > @@ -732,6 +738,17 @@ for sender in $ns1 $ns2 $ns3 $ns4;do > run_tests "$ns4" $sender dead:beef:3::1 > done > > +testpeek=true > +options_log=true > +peekmode="saveAfterPeek" > +run_tests_lo "$ns1" "$ns1" 10.0.1.1 1 > +run_tests_lo "$ns1" $sender dead:beef:1::1 1 > + > +options_log=true > +peekmode="saveAfterPeek" > +run_tests_lo "$ns1" "$ns1" 10.0.1.1 1 > +run_tests_lo "$ns1" $sender dead:beef:1::1 1 > + > time_end=$(date +%s) > time_run=$((time_end-time_start)) LGTM! and to checkpatch, also! Acked-by: Paolo Abeni <pabeni@redhat.com>
diff --git a/tools/testing/selftests/net/mptcp/mptcp_connect.c b/tools/testing/selftests/net/mptcp/mptcp_connect.c index 2f207cf..d88e1fd 100644 --- a/tools/testing/selftests/net/mptcp/mptcp_connect.c +++ b/tools/testing/selftests/net/mptcp/mptcp_connect.c @@ -45,7 +45,14 @@ enum cfg_mode { CFG_MODE_SENDFILE, }; +enum cfg_peek { + CFG_NONE_PEEK, + CFG_WITH_PEEK, + CFG_AFTER_PEEK, +}; + static enum cfg_mode cfg_mode = CFG_MODE_POLL; +static enum cfg_peek cfg_peek = CFG_NONE_PEEK; static const char *cfg_host; static const char *cfg_port = "12000"; static int cfg_sock_proto = IPPROTO_MPTCP; @@ -73,6 +80,8 @@ static void die_usage(void) fprintf(stderr, "\t-M mark -- set socket packet mark\n"); fprintf(stderr, "\t-u -- check mptcp ulp\n"); fprintf(stderr, "\t-w num -- wait num sec before closing the socket\n"); + fprintf(stderr, + "\t-P [saveWithPeek|saveAfterPeek] -- save data with/after MSG_PEEK form tcp socket\n"); exit(1); } @@ -331,6 +340,8 @@ static size_t do_write(const int fd, char *buf, const size_t len) static ssize_t do_rnd_read(const int fd, char *buf, const size_t len) { + int ret = 0; + char tmp[16384]; size_t cap = rand(); cap &= 0xffff; @@ -340,7 +351,17 @@ static ssize_t do_rnd_read(const int fd, char *buf, const size_t len) else if (cap > len) cap = len; - return read(fd, buf, cap); + if (cfg_peek == CFG_WITH_PEEK) { + ret = recv(fd, buf, cap, MSG_PEEK); + ret = (ret < 0) ? ret : read(fd, tmp, ret); + } else if (cfg_peek == CFG_AFTER_PEEK) { + ret = recv(fd, buf, cap, MSG_PEEK); + ret = (ret < 0) ? ret : read(fd, buf, cap); + } else { + ret = read(fd, buf, cap); + } + + return ret; } static void set_nonblock(int fd) @@ -819,6 +840,26 @@ int parse_mode(const char *mode) return 0; } +int parse_peek(const char *mode) +{ + if (!strcasecmp(mode, "saveWithPeek")) + return CFG_WITH_PEEK; + if (!strcasecmp(mode, "saveAfterPeek")) + return CFG_AFTER_PEEK; + + fprintf(stderr, "Unknown: %s\n", mode); + fprintf(stderr, "Supported MSG_PEEK mode are:\n"); + fprintf(stderr, + "\t\t\"saveWithPeek\" - recv data with flags 'MSG_PEEK' and save the peek data into file\n"); + fprintf(stderr, + "\t\t\"saveAfterPeek\" - read and save data into file after recv with flags 'MSG_PEEK'\n"); + + die_usage(); + + /* silence compiler warning */ + return 0; +} + static int parse_int(const char *size) { unsigned long s; @@ -846,7 +887,7 @@ static void parse_opts(int argc, char **argv) { int c; - while ((c = getopt(argc, argv, "6jr:lp:s:hut:m:S:R:w:M:")) != -1) { + while ((c = getopt(argc, argv, "6jr:lp:s:hut:m:S:R:w:M:P:")) != -1) { switch (c) { case 'j': cfg_join = true; @@ -899,6 +940,9 @@ static void parse_opts(int argc, char **argv) case 'M': cfg_mark = strtol(optarg, NULL, 0); break; + case 'P': + cfg_peek = parse_peek(optarg); + break; } } diff --git a/tools/testing/selftests/net/mptcp/mptcp_connect.sh b/tools/testing/selftests/net/mptcp/mptcp_connect.sh index 385cdc9..319d166 100755 --- a/tools/testing/selftests/net/mptcp/mptcp_connect.sh +++ b/tools/testing/selftests/net/mptcp/mptcp_connect.sh @@ -23,6 +23,8 @@ rcvbuf=0 options_log=true do_tcp=0 filesize=0 +peekmode="" +testpeek=false if [ $tc_loss -eq 100 ];then tc_loss=1% @@ -393,6 +395,10 @@ do_transfer() extra_args="$extra_args -m $testmode" fi + if $testpeek; then + extra_args="$extra_args -P $peekmode" + fi + if [ -n "$extra_args" ] && $options_log; then options_log=false echo "INFO: extra options: $extra_args" @@ -732,6 +738,17 @@ for sender in $ns1 $ns2 $ns3 $ns4;do run_tests "$ns4" $sender dead:beef:3::1 done +testpeek=true +options_log=true +peekmode="saveAfterPeek" +run_tests_lo "$ns1" "$ns1" 10.0.1.1 1 +run_tests_lo "$ns1" $sender dead:beef:1::1 1 + +options_log=true +peekmode="saveAfterPeek" +run_tests_lo "$ns1" "$ns1" 10.0.1.1 1 +run_tests_lo "$ns1" $sender dead:beef:1::1 1 + time_end=$(date +%s) time_run=$((time_end-time_start))
Extend mptcp_connect tool with MSG_PEEK support and add a test case in mptcp_connect.sh that checks the data recvived from/after recv() with MSG_PEEK. Signed-off-by: Yonglong Li <liyonglong@chinatelecom.cn> --- tools/testing/selftests/net/mptcp/mptcp_connect.c | 48 +++++++++++++++++++++- tools/testing/selftests/net/mptcp/mptcp_connect.sh | 17 ++++++++ 2 files changed, 63 insertions(+), 2 deletions(-)