* [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address
@ 2023-08-25 3:50 Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 01/10] selftests: mptcp: add evts_get_info helper Geliang Tang
` (9 more replies)
0 siblings, 10 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
v6:
- add a new helper get_info_value, update chk_mptcp_info(),
verify_listener_events() and pedit_action_pkts() too.
- only patch 1, 2, 4 are changed, other patches are the same as v5.
v5:
- update userspace_pm_add_addr/sf helpers.
- add userspace_pm_rm_addr/sf helpers.
- remove id 0 subflow or address will send MP_RST, add chk_rst_nr for
them.
- add two selftests cleanups using for-loop.
v4:
- add evts_get_info and chk_subflows helpers.
- split the selftests patch into three.
v3:
- address Matt's comments in v2.
v2:
- fix CI errors.
This patchset addresses #379 and #391, add the abilities to remove id 0
subflow and address for userspace PM. And a selftest.
Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/379
Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/391
Geliang Tang (10):
selftests: mptcp: add evts_get_info helper
selftests: mptcp: update userspace pm add helpers
selftests: mptcp: update userspace pm rm helpers
selftests: mptcp: userspace pm remove id 0 subflow
mptcp: userspace pm allow creating id 0 subflow
selftests: mptcp: userspace pm create id 0 subflow
mptcp: userspace pm remove id 0 address
selftests: mptcp: userspace pm remove id 0 address
selftests: mptcp: simplify checksum_tests
selftests: mptcp: simplify deny_join_id0_tests
net/mptcp/pm_userspace.c | 40 +-
.../testing/selftests/net/mptcp/mptcp_join.sh | 353 +++++++++++-------
2 files changed, 243 insertions(+), 150 deletions(-)
--
2.35.3
^ permalink raw reply [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 01/10] selftests: mptcp: add evts_get_info helper
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 02/10] selftests: mptcp: update userspace pm add helpers Geliang Tang
` (8 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds a new helper get_info_value(), using 'sed' command to
parse the value of the given item name in the line with the given keyword,
to make chk_mptcp_info() and pedit_action_pkts() more readable.
Also add another helper evts_get_info() to use get_info_value() to parse
the output of 'pm_nl_ctl events' command, to make the userpsace pm
selftests more readable.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 31 ++++++++++++-------
1 file changed, 20 insertions(+), 11 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index ee1f89a872b3..8540a1ba5ef2 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -1850,6 +1850,12 @@ chk_subflow_nr()
fi
}
+# $1: get value of this info $2: keyword in this line
+get_info_value()
+{
+ grep "${2}" | sed -n 's/.*\('${1}':\)\([0-9a-f:.]*\).*$/\2/p;q'
+}
+
chk_mptcp_info()
{
local info1=$1
@@ -1862,10 +1868,8 @@ chk_mptcp_info()
print_check "mptcp_info ${info1:0:8}=$exp1:$exp2"
- cnt1=$(ss -N $ns1 -inmHM | grep "$info1:" |
- sed -n 's/.*\('"$info1"':\)\([[:digit:]]*\).*$/\2/p;q')
- cnt2=$(ss -N $ns2 -inmHM | grep "$info2:" |
- sed -n 's/.*\('"$info2"':\)\([[:digit:]]*\).*$/\2/p;q')
+ cnt1=$(ss -N $ns1 -inmHM | get_info_value "$info1" "$info1")
+ cnt2=$(ss -N $ns2 -inmHM | get_info_value "$info2" "$info2")
# 'ss' only display active connections and counters that are not 0.
[ -z "$cnt1" ] && cnt1=0
[ -z "$cnt2" ] && cnt2=0
@@ -2794,6 +2798,12 @@ backup_tests()
fi
}
+# $1: info name ; $2: evts_ns ; $3: event type
+evts_get_info()
+{
+ cat "${2}" | get_info_value "${1}" "^type:${3:-1},"
+}
+
LISTENER_CREATED=15 #MPTCP_EVENT_LISTENER_CREATED
LISTENER_CLOSED=16 #MPTCP_EVENT_LISTENER_CLOSED
@@ -2828,13 +2838,13 @@ verify_listener_events()
return
fi
- type=$(grep "type:$e_type," $evt | sed -n 's/.*\(type:\)\([[:digit:]]*\).*$/\2/p;q')
- family=$(grep "type:$e_type," $evt | sed -n 's/.*\(family:\)\([[:digit:]]*\).*$/\2/p;q')
- sport=$(grep "type:$e_type," $evt | sed -n 's/.*\(sport:\)\([[:digit:]]*\).*$/\2/p;q')
+ type=$(evts_get_info type "$evt" "$e_type")
+ family=$(evts_get_info family "$evt" "$e_type")
+ sport=$(evts_get_info sport "$evt" "$e_type")
if [ $family ] && [ $family = $AF_INET6 ]; then
- saddr=$(grep "type:$e_type," $evt | sed -n 's/.*\(saddr6:\)\([0-9a-f:.]*\).*$/\2/p;q')
+ saddr=$(evts_get_info saddr6 "$evt" "$e_type")
else
- saddr=$(grep "type:$e_type," $evt | sed -n 's/.*\(saddr4:\)\([0-9.]*\).*$/\2/p;q')
+ saddr=$(evts_get_info saddr4 "$evt" "$e_type")
fi
if [ $type ] && [ $type = $e_type ] &&
@@ -3229,8 +3239,7 @@ fastclose_tests()
pedit_action_pkts()
{
tc -n $ns2 -j -s action show action pedit index 100 | \
- grep "packets" | \
- sed 's/.*"packets":\([0-9]\+\),.*/\1/'
+ get_info_value \"packets\" packets
}
fail_tests()
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 02/10] selftests: mptcp: update userspace pm add helpers
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 01/10] selftests: mptcp: add evts_get_info helper Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 03/10] selftests: mptcp: update userspace pm rm helpers Geliang Tang
` (7 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds a new argument namespace to userspace_pm_add_addr() and
userspace_pm_add_sf() to make these two helper more versatile.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 29 ++++++++++---------
1 file changed, 16 insertions(+), 13 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 8540a1ba5ef2..3e2745717913 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -3264,15 +3264,16 @@ fail_tests()
fi
}
+# $1: ns ; $2: addr ; $3: id
userspace_pm_add_addr()
{
- local addr=$1
- local id=$2
+ local evts=$evts_ns1
local tk
- tk=$(grep "type:1," "$evts_ns1" |
- sed -n 's/.*\(token:\)\([[:digit:]]*\).*$/\2/p;q')
- ip netns exec $ns1 ./pm_nl_ctl ann $addr token $tk id $id
+ [ "$1" == "$ns2" ] && evts=$evts_ns2
+ tk=$(evts_get_info token "$evts")
+
+ ip netns exec $1 ./pm_nl_ctl ann $2 token $tk id $3
sleep 1
}
@@ -3297,16 +3298,18 @@ userspace_pm_rm_sf_addr_ns1()
wait_rm_sf $ns1 1
}
+# $1: ns ; $2: addr ; $3: id
userspace_pm_add_sf()
{
- local addr=$1
- local id=$2
+ local evts=$evts_ns1
local tk da dp
- tk=$(sed -n 's/.*\(token:\)\([[:digit:]]*\).*$/\2/p;q' "$evts_ns2")
- da=$(sed -n 's/.*\(daddr4:\)\([0-9.]*\).*$/\2/p;q' "$evts_ns2")
- dp=$(sed -n 's/.*\(dport:\)\([[:digit:]]*\).*$/\2/p;q' "$evts_ns2")
- ip netns exec $ns2 ./pm_nl_ctl csf lip $addr lid $id \
+ [ "$1" == "$ns2" ] && evts=$evts_ns2
+ tk=$(evts_get_info token "$evts")
+ da=$(evts_get_info daddr4 "$evts")
+ dp=$(evts_get_info dport "$evts")
+
+ ip netns exec $1 ./pm_nl_ctl csf lip $2 lid $3 \
rip $da rport $dp token $tk
sleep 1
}
@@ -3413,7 +3416,7 @@ userspace_tests()
run_tests $ns1 $ns2 10.0.1.1 &
local tests_pid=$!
wait_mpj $ns1
- userspace_pm_add_addr 10.0.2.1 10
+ userspace_pm_add_addr $ns1 10.0.2.1 10
chk_join_nr 1 1 1
chk_add_nr 1 1
chk_mptcp_info subflows 1 subflows 1
@@ -3434,7 +3437,7 @@ userspace_tests()
run_tests $ns1 $ns2 10.0.1.1 &
local tests_pid=$!
wait_mpj $ns2
- userspace_pm_add_sf 10.0.3.2 20
+ userspace_pm_add_sf $ns2 10.0.3.2 20
chk_join_nr 1 1 1
chk_mptcp_info subflows 1 subflows 1
userspace_pm_rm_sf_addr_ns2 10.0.3.2 20
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 03/10] selftests: mptcp: update userspace pm rm helpers
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 01/10] selftests: mptcp: add evts_get_info helper Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 02/10] selftests: mptcp: update userspace pm add helpers Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 04/10] selftests: mptcp: userspace pm remove id 0 subflow Geliang Tang
` (6 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
Add two more versatile helpers for userspace pm remove subflow or address:
userspace_pm_rm_addr() and userspace_pm_rm_sf(). The original test helpers
userspace_pm_rm_sf_addr_ns1() and userspace_pm_rm_sf_addr_ns2() can be
replaced by these new helpers.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 59 +++++++++----------
1 file changed, 27 insertions(+), 32 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 3e2745717913..2017f14408b5 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -3277,25 +3277,17 @@ userspace_pm_add_addr()
sleep 1
}
-userspace_pm_rm_sf_addr_ns1()
+# $1: ns ; $2: id
+userspace_pm_rm_addr()
{
- local addr=$1
- local id=$2
- local tk sp da dp
-
- tk=$(grep "type:1," "$evts_ns1" |
- sed -n 's/.*\(token:\)\([[:digit:]]*\).*$/\2/p;q')
- sp=$(grep "type:10" "$evts_ns1" |
- sed -n 's/.*\(sport:\)\([[:digit:]]*\).*$/\2/p;q')
- da=$(grep "type:10" "$evts_ns1" |
- sed -n 's/.*\(daddr6:\)\([0-9a-f:.]*\).*$/\2/p;q')
- dp=$(grep "type:10" "$evts_ns1" |
- sed -n 's/.*\(dport:\)\([[:digit:]]*\).*$/\2/p;q')
- ip netns exec $ns1 ./pm_nl_ctl rem token $tk id $id
- ip netns exec $ns1 ./pm_nl_ctl dsf lip "::ffff:$addr" \
- lport $sp rip $da rport $dp token $tk
- wait_rm_addr $ns1 1
- wait_rm_sf $ns1 1
+ local evts=$evts_ns1
+ local tk
+
+ [ "$1" == "$ns2" ] && evts=$evts_ns2
+ tk=$(evts_get_info token "$evts")
+
+ ip netns exec $1 ./pm_nl_ctl rem token $tk id $2
+ wait_rm_addr $1 1
}
# $1: ns ; $2: addr ; $3: id
@@ -3314,22 +3306,23 @@ userspace_pm_add_sf()
sleep 1
}
-userspace_pm_rm_sf_addr_ns2()
+# $1: ns ; $2: event type ; $3: addr
+userspace_pm_rm_sf()
{
- local addr=$1
- local id=$2
+ local evts=$evts_ns1
+ local ip=4
local tk da dp sp
- tk=$(sed -n 's/.*\(token:\)\([[:digit:]]*\).*$/\2/p;q' "$evts_ns2")
- da=$(sed -n 's/.*\(daddr4:\)\([0-9.]*\).*$/\2/p;q' "$evts_ns2")
- dp=$(sed -n 's/.*\(dport:\)\([[:digit:]]*\).*$/\2/p;q' "$evts_ns2")
- sp=$(grep "type:10" "$evts_ns2" |
- sed -n 's/.*\(sport:\)\([[:digit:]]*\).*$/\2/p;q')
- ip netns exec $ns2 ./pm_nl_ctl rem token $tk id $id
- ip netns exec $ns2 ./pm_nl_ctl dsf lip $addr lport $sp \
+ [ "$1" == "$ns2" ] && evts=$evts_ns2
+ if is_v6 $3; then ip=6; fi
+ tk=$(evts_get_info token "$evts")
+ da=$(evts_get_info "daddr$ip" "$evts" "$2")
+ dp=$(evts_get_info dport "$evts" "$2")
+ sp=$(evts_get_info sport "$evts" "$2")
+
+ ip netns exec $1 ./pm_nl_ctl dsf lip $3 lport $sp \
rip $da rport $dp token $tk
- wait_rm_addr $ns2 1
- wait_rm_sf $ns2 1
+ wait_rm_sf $1 1
}
userspace_tests()
@@ -3421,7 +3414,8 @@ userspace_tests()
chk_add_nr 1 1
chk_mptcp_info subflows 1 subflows 1
chk_mptcp_info add_addr_signal 1 add_addr_accepted 1
- userspace_pm_rm_sf_addr_ns1 10.0.2.1 10
+ userspace_pm_rm_addr $ns1 10
+ userspace_pm_rm_sf $ns1 10 "::ffff:10.0.2.1"
chk_rm_nr 1 1 invert
chk_mptcp_info subflows 0 subflows 0
kill_events_pids
@@ -3440,7 +3434,8 @@ userspace_tests()
userspace_pm_add_sf $ns2 10.0.3.2 20
chk_join_nr 1 1 1
chk_mptcp_info subflows 1 subflows 1
- userspace_pm_rm_sf_addr_ns2 10.0.3.2 20
+ userspace_pm_rm_addr $ns2 20
+ userspace_pm_rm_sf $ns2 10 10.0.3.2
chk_rm_nr 1 1
chk_mptcp_info subflows 0 subflows 0
kill_events_pids
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 04/10] selftests: mptcp: userspace pm remove id 0 subflow
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (2 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 03/10] selftests: mptcp: update userspace pm rm helpers Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 05/10] mptcp: userspace pm allow creating " Geliang Tang
` (5 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds a selftest for userpsace PM to remove id 0 subflow. Use
userspace_pm_add_sf() to add a subflow, and pass initial ip address to
userspace_pm_rm_sf() to remove id 0 subflow.
Add a new helper chk_all_subflows(), in it use 'ss' command
ss -ti | grep -c tcp-ulp-mptcp
to get the "correct" amount of subflows, including the initial
subflow.
When closing the initial subflow in __mptcp_close_ssk(), dispose_it is
false, then tcp_disconnect is invoked. This will send a MP_RST to close
a subflow on the peer too. So chk_rst_nr() is added in this test, and
chk_all_subflows after closing the initial subflow is '1 1', not '2 1'.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 47 +++++++++++++++++++
1 file changed, 47 insertions(+)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 2017f14408b5..c6babafa3b47 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -1850,6 +1850,31 @@ chk_subflow_nr()
fi
}
+# $1: subflows in ns1 ; $2: subflows in ns2
+# number of all subflows, including the initial subflow.
+chk_all_subflows()
+{
+ local cnt1
+ local cnt2
+
+ print_check "all subflows $1:$2"
+
+ cnt1=$(ss -N $ns1 -ti | grep -c tcp-ulp-mptcp)
+ cnt2=$(ss -N $ns2 -ti | grep -c tcp-ulp-mptcp)
+
+ if [ "$1" != "$cnt1" ] || [ "$2" != "$cnt2" ]; then
+ fail_test "got subflows $cnt1:$cnt2 expected $1:$2"
+ dump_stats=1
+ else
+ print_ok
+ fi
+
+ if [ "$dump_stats" = 1 ]; then
+ ss -N $ns1 -ti
+ ss -N $ns2 -ti
+ fi
+}
+
# $1: get value of this info $2: keyword in this line
get_info_value()
{
@@ -3441,6 +3466,28 @@ userspace_tests()
kill_events_pids
wait $tests_pid
fi
+
+ # userspace pm remove id 0 subflow
+ if reset_with_events "userspace pm remove id 0 subflow" &&
+ continue_if mptcp_lib_has_file '/proc/sys/net/mptcp/pm_type'; then
+ set_userspace_pm $ns2
+ pm_nl_set_limits $ns1 0 1
+ speed=10 \
+ run_tests $ns1 $ns2 10.0.1.1 &
+ local tests_pid=$!
+ wait_mpj $ns2
+ userspace_pm_add_sf $ns2 10.0.3.2 20
+ chk_join_nr 1 1 1
+ chk_mptcp_info subflows 1 subflows 1
+ chk_all_subflows 2 2
+ userspace_pm_rm_sf $ns2 1 10.0.1.2
+ chk_rm_nr 0 1
+ chk_rst_nr 1 1 invert
+ chk_mptcp_info subflows 1 subflows 1
+ chk_all_subflows 1 1
+ kill_events_pids
+ wait $tests_pid
+ fi
}
endpoint_tests()
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 05/10] mptcp: userspace pm allow creating id 0 subflow
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (3 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 04/10] selftests: mptcp: userspace pm remove id 0 subflow Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 06/10] selftests: mptcp: userspace pm create " Geliang Tang
` (4 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang, Matthieu Baerts
This patch drops id 0 limitation in mptcp_nl_cmd_sf_create() to allow
creating additional subflows with the local addr ID 0.
There is no reason not to allow additional subflows from this local
address: we should be able to create new subflows from the initial
endpoint. This limitation was breaking fullmesh support from userspace.
Fixes: 702c2f646d42 ("mptcp: netlink: allow userspace-driven subflow establishment")
Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/391
Suggested-by: Matthieu Baerts <matthieu.baerts@tessares.net>
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
net/mptcp/pm_userspace.c | 6 ------
1 file changed, 6 deletions(-)
diff --git a/net/mptcp/pm_userspace.c b/net/mptcp/pm_userspace.c
index b5a8aa4c1ebd..d042d32beb4d 100644
--- a/net/mptcp/pm_userspace.c
+++ b/net/mptcp/pm_userspace.c
@@ -307,12 +307,6 @@ int mptcp_nl_cmd_sf_create(struct sk_buff *skb, struct genl_info *info)
goto create_err;
}
- if (addr_l.id == 0) {
- NL_SET_ERR_MSG_ATTR(info->extack, laddr, "missing local addr id");
- err = -EINVAL;
- goto create_err;
- }
-
err = mptcp_pm_parse_addr(raddr, info, &addr_r);
if (err < 0) {
NL_SET_ERR_MSG_ATTR(info->extack, raddr, "error parsing remote addr");
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 06/10] selftests: mptcp: userspace pm create id 0 subflow
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (4 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 05/10] mptcp: userspace pm allow creating " Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 07/10] mptcp: userspace pm remove id 0 address Geliang Tang
` (3 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds a selftest to create id 0 subflow. Pass id 0 to the
helper userspace_pm_add_sf() to create id 0 subflow. chk_mptcp_info
shows one subflow but chk_all_subflows shows two subflows in each
namespace.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 19 +++++++++++++++++++
1 file changed, 19 insertions(+)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index c6babafa3b47..9862a27da487 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -3467,6 +3467,25 @@ userspace_tests()
wait $tests_pid
fi
+ # userspace pm create id 0 subflow
+ if reset_with_events "userspace pm create id 0 subflow" &&
+ continue_if mptcp_lib_has_file '/proc/sys/net/mptcp/pm_type'; then
+ set_userspace_pm $ns2
+ pm_nl_set_limits $ns1 0 1
+ speed=slow \
+ run_tests $ns1 $ns2 10.0.1.1 &
+ local tests_pid=$!
+ wait_mpj $ns2
+ chk_mptcp_info subflows 0 subflows 0
+ chk_all_subflows 1 1
+ userspace_pm_add_sf $ns2 10.0.3.2 0
+ chk_join_nr 1 1 1
+ chk_mptcp_info subflows 1 subflows 1
+ chk_all_subflows 2 2
+ kill_events_pids
+ wait $tests_pid
+ fi
+
# userspace pm remove id 0 subflow
if reset_with_events "userspace pm remove id 0 subflow" &&
continue_if mptcp_lib_has_file '/proc/sys/net/mptcp/pm_type'; then
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 07/10] mptcp: userspace pm remove id 0 address
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (5 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 06/10] selftests: mptcp: userspace pm create " Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 08/10] selftests: " Geliang Tang
` (2 subsequent siblings)
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds the ability to send RM_ADDR for local ID 0. Check
whether id 0 address is removed, if not, put id 0 into a removing
list, pass it to mptcp_pm_remove_addr() to remove id 0 address.
There is no reason not to allow the userspace to remove the initial
address (ID 0). This special case was not taken into account not
letting the userspace to delete all addresses as announced.
Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/379
Fixes: d9a4594edabf ("mptcp: netlink: Add MPTCP_PM_CMD_REMOVE")
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
net/mptcp/pm_userspace.c | 34 ++++++++++++++++++++++++++++++++++
1 file changed, 34 insertions(+)
diff --git a/net/mptcp/pm_userspace.c b/net/mptcp/pm_userspace.c
index d042d32beb4d..41d2d57b570c 100644
--- a/net/mptcp/pm_userspace.c
+++ b/net/mptcp/pm_userspace.c
@@ -208,6 +208,37 @@ int mptcp_nl_cmd_announce(struct sk_buff *skb, struct genl_info *info)
return err;
}
+static int mptcp_userspace_remove_id_zero_address(struct mptcp_sock *msk,
+ struct genl_info *info)
+{
+ struct mptcp_rm_list list = { .nr = 0 };
+ struct mptcp_subflow_context *subflow;
+ bool has_id_0 = false;
+ int err = -EINVAL;
+
+ lock_sock((struct sock *)msk);
+ spin_lock_bh(&msk->pm.lock);
+ mptcp_for_each_subflow(msk, subflow) {
+ if (subflow->remote_id == 0) {
+ has_id_0 = true;
+ break;
+ }
+ }
+ if (!has_id_0) {
+ GENL_SET_ERR_MSG(info, "address with id 0 not found");
+ goto out;
+ }
+
+ list.ids[list.nr++] = 0;
+ mptcp_pm_remove_addr(msk, &list);
+ err = 0;
+out:
+ spin_unlock_bh(&msk->pm.lock);
+ release_sock((struct sock *)msk);
+ sock_put((struct sock *)msk);
+ return err;
+}
+
int mptcp_nl_cmd_remove(struct sk_buff *skb, struct genl_info *info)
{
struct nlattr *token = info->attrs[MPTCP_PM_ATTR_TOKEN];
@@ -239,6 +270,9 @@ int mptcp_nl_cmd_remove(struct sk_buff *skb, struct genl_info *info)
goto remove_err;
}
+ if (id_val == 0)
+ return mptcp_userspace_remove_id_zero_address(msk, info);
+
lock_sock((struct sock *)msk);
list_for_each_entry(entry, &msk->pm.userspace_pm_local_addr_list, list) {
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 08/10] selftests: mptcp: userspace pm remove id 0 address
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (6 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 07/10] mptcp: userspace pm remove id 0 address Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 09/10] selftests: mptcp: simplify checksum_tests Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 10/10] selftests: mptcp: simplify deny_join_id0_tests Geliang Tang
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
This patch adds a selftest for userpsace PM to remove id 0 address.
Use userspace_pm_add_addr() helper to add a id 10 address, then use
userspace_pm_rm_addr() helper to remove id 0 address.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 24 +++++++++++++++++++
1 file changed, 24 insertions(+)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 9862a27da487..83a625c36044 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -3507,6 +3507,30 @@ userspace_tests()
kill_events_pids
wait $tests_pid
fi
+
+ # userspace pm remove id 0 address
+ if reset_with_events "userspace pm remove id 0 address" &&
+ continue_if mptcp_lib_has_file '/proc/sys/net/mptcp/pm_type'; then
+ set_userspace_pm $ns1
+ pm_nl_set_limits $ns2 1 1
+ speed=10 \
+ run_tests $ns1 $ns2 10.0.1.1 &
+ local tests_pid=$!
+ wait_mpj $ns1
+ userspace_pm_add_addr $ns1 10.0.2.1 10
+ chk_join_nr 1 1 1
+ chk_add_nr 1 1
+ chk_mptcp_info subflows 1 subflows 1
+ chk_all_subflows 2 2
+ chk_mptcp_info add_addr_signal 1 add_addr_accepted 1
+ userspace_pm_rm_addr $ns1 0
+ chk_rm_nr 1 0 invert
+ chk_rst_nr 1 1 invert
+ chk_mptcp_info subflows 1 subflows 1
+ chk_all_subflows 1 1
+ kill_events_pids
+ wait $tests_pid
+ fi
}
endpoint_tests()
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 09/10] selftests: mptcp: simplify checksum_tests
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (7 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 08/10] selftests: " Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 10/10] selftests: mptcp: simplify deny_join_id0_tests Geliang Tang
9 siblings, 0 replies; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
The four checksum tests are similar, only one line is different. So
a for-loop can be used to simplify these tests.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 40 +++++--------------
1 file changed, 10 insertions(+), 30 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 83a625c36044..59f613c6d387 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -3039,37 +3039,17 @@ syncookies_tests()
checksum_tests()
{
- # checksum test 0 0
- if reset_with_checksum 0 0; then
- pm_nl_set_limits $ns1 0 1
- pm_nl_set_limits $ns2 0 1
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 0 0 0
- fi
+ local enable
- # checksum test 1 1
- if reset_with_checksum 1 1; then
- pm_nl_set_limits $ns1 0 1
- pm_nl_set_limits $ns2 0 1
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 0 0 0
- fi
-
- # checksum test 0 1
- if reset_with_checksum 0 1; then
- pm_nl_set_limits $ns1 0 1
- pm_nl_set_limits $ns2 0 1
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 0 0 0
- fi
-
- # checksum test 1 0
- if reset_with_checksum 1 0; then
- pm_nl_set_limits $ns1 0 1
- pm_nl_set_limits $ns2 0 1
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 0 0 0
- fi
+ for enable in "0 0" "1 1" "0 1" "1 0"; do
+ # checksum test 0 0, 1 1, 0 1, 1 0
+ if reset_with_checksum $enable; then
+ pm_nl_set_limits $ns1 0 1
+ pm_nl_set_limits $ns2 0 1
+ run_tests $ns1 $ns2 10.0.1.1
+ chk_join_nr 0 0 0
+ fi
+ done
}
deny_join_id0_tests()
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* [PATCH mptcp-next v6 10/10] selftests: mptcp: simplify deny_join_id0_tests
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
` (8 preceding siblings ...)
2023-08-25 3:50 ` [PATCH mptcp-next v6 09/10] selftests: mptcp: simplify checksum_tests Geliang Tang
@ 2023-08-25 3:50 ` Geliang Tang
2023-08-25 4:53 ` selftests: mptcp: simplify deny_join_id0_tests: Tests Results MPTCP CI
9 siblings, 1 reply; 12+ messages in thread
From: Geliang Tang @ 2023-08-25 3:50 UTC (permalink / raw)
To: mptcp; +Cc: Geliang Tang
The six join id0 tests can be divided into three groups in sequence,
with two tests in each one. Both tests in one group are similar, only
different namespaces used. So a for-loop can be used to simplify these
tests.
Signed-off-by: Geliang Tang <geliang.tang@suse.com>
---
.../testing/selftests/net/mptcp/mptcp_join.sh | 104 ++++++++----------
1 file changed, 46 insertions(+), 58 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_join.sh b/tools/testing/selftests/net/mptcp/mptcp_join.sh
index 59f613c6d387..084d7a8088fb 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_join.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_join.sh
@@ -383,11 +383,17 @@ reset_with_checksum()
reset_with_allow_join_id0()
{
- local ns1_enable=$2
- local ns2_enable=$3
+ local ns1_enable=0
+ local ns2_enable=0
reset "${1}" || return 1
+ if [ "${2}" == "ns1" ]; then
+ ns1_enable=1
+ elif [ "${2}" == "ns2" ]; then
+ ns2_enable=1
+ fi
+
ip netns exec $ns1 sysctl -q net.mptcp.allow_join_initial_addr_port=$ns1_enable
ip netns exec $ns2 sysctl -q net.mptcp.allow_join_initial_addr_port=$ns2_enable
}
@@ -3054,65 +3060,47 @@ checksum_tests()
deny_join_id0_tests()
{
- # subflow allow join id0 ns1
- if reset_with_allow_join_id0 "single subflow allow join id0 ns1" 1 0; then
- pm_nl_set_limits $ns1 1 1
- pm_nl_set_limits $ns2 1 1
- pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 1 1 1
- fi
+ local ns
- # subflow allow join id0 ns2
- if reset_with_allow_join_id0 "single subflow allow join id0 ns2" 0 1; then
- pm_nl_set_limits $ns1 1 1
- pm_nl_set_limits $ns2 1 1
- pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 0 0 0
- fi
-
- # signal address allow join id0 ns1
- # ADD_ADDRs are not affected by allow_join_id0 value.
- if reset_with_allow_join_id0 "signal address allow join id0 ns1" 1 0; then
- pm_nl_set_limits $ns1 1 1
- pm_nl_set_limits $ns2 1 1
- pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 1 1 1
- chk_add_nr 1 1
- fi
-
- # signal address allow join id0 ns2
- # ADD_ADDRs are not affected by allow_join_id0 value.
- if reset_with_allow_join_id0 "signal address allow join id0 ns2" 0 1; then
- pm_nl_set_limits $ns1 1 1
- pm_nl_set_limits $ns2 1 1
- pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 1 1 1
- chk_add_nr 1 1
- fi
+ for ns in "ns1" "ns2"; do
+ # subflow allow join id0 ns1/ns2
+ if reset_with_allow_join_id0 "single subflow allow join id0 $ns" "$ns"; then
+ pm_nl_set_limits $ns1 1 1
+ pm_nl_set_limits $ns2 1 1
+ pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
+ run_tests $ns1 $ns2 10.0.1.1
+ if [ "$ns" == "ns1" ]; then
+ chk_join_nr 1 1 1
+ elif [ "$ns" == "ns2" ]; then
+ chk_join_nr 0 0 0
+ fi
+ fi
- # subflow and address allow join id0 ns1
- if reset_with_allow_join_id0 "subflow and address allow join id0 1" 1 0; then
- pm_nl_set_limits $ns1 2 2
- pm_nl_set_limits $ns2 2 2
- pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
- pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 2 2 2
- fi
+ # signal address allow join id0 ns1/ns2
+ # ADD_ADDRs are not affected by allow_join_id0 value.
+ if reset_with_allow_join_id0 "signal address allow join id0 $ns" "$ns"; then
+ pm_nl_set_limits $ns1 1 1
+ pm_nl_set_limits $ns2 1 1
+ pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
+ run_tests $ns1 $ns2 10.0.1.1
+ chk_join_nr 1 1 1
+ chk_add_nr 1 1
+ fi
- # subflow and address allow join id0 ns2
- if reset_with_allow_join_id0 "subflow and address allow join id0 2" 0 1; then
- pm_nl_set_limits $ns1 2 2
- pm_nl_set_limits $ns2 2 2
- pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
- pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
- run_tests $ns1 $ns2 10.0.1.1
- chk_join_nr 1 1 1
- fi
+ # subflow and address allow join id0 ns1/ns2
+ if reset_with_allow_join_id0 "subflow & address allow join id0 $ns" "$ns"; then
+ pm_nl_set_limits $ns1 2 2
+ pm_nl_set_limits $ns2 2 2
+ pm_nl_add_endpoint $ns1 10.0.2.1 flags signal
+ pm_nl_add_endpoint $ns2 10.0.3.2 flags subflow
+ run_tests $ns1 $ns2 10.0.1.1
+ if [ "$ns" == "ns1" ]; then
+ chk_join_nr 2 2 2
+ elif [ "$ns" == "ns2" ]; then
+ chk_join_nr 1 1 1
+ fi
+ fi
+ done
}
fullmesh_tests()
--
2.35.3
^ permalink raw reply related [flat|nested] 12+ messages in thread
* Re: selftests: mptcp: simplify deny_join_id0_tests: Tests Results
2023-08-25 3:50 ` [PATCH mptcp-next v6 10/10] selftests: mptcp: simplify deny_join_id0_tests Geliang Tang
@ 2023-08-25 4:53 ` MPTCP CI
0 siblings, 0 replies; 12+ messages in thread
From: MPTCP CI @ 2023-08-25 4:53 UTC (permalink / raw)
To: Geliang Tang; +Cc: mptcp
Hi Geliang,
Thank you for your modifications, that's great!
Our CI did some validations and here is its report:
- KVM Validation: normal (except selftest_mptcp_join):
- Unstable: 1 failed test(s): selftest_simult_flows 🔴:
- Task: https://cirrus-ci.com/task/5236949145878528
- Summary: https://api.cirrus-ci.com/v1/artifact/task/5236949145878528/summary/summary.txt
- KVM Validation: normal (only selftest_mptcp_join):
- Success! ✅:
- Task: https://cirrus-ci.com/task/6362849052721152
- Summary: https://api.cirrus-ci.com/v1/artifact/task/6362849052721152/summary/summary.txt
- KVM Validation: debug (only selftest_mptcp_join):
- Unstable: 1 failed test(s): selftest_mptcp_join 🔴:
- Task: https://cirrus-ci.com/task/6081374076010496
- Summary: https://api.cirrus-ci.com/v1/artifact/task/6081374076010496/summary/summary.txt
- KVM Validation: debug (except selftest_mptcp_join):
- Success! ✅:
- Task: https://cirrus-ci.com/task/4955474169167872
- Summary: https://api.cirrus-ci.com/v1/artifact/task/4955474169167872/summary/summary.txt
Initiator: Patchew Applier
Commits: https://github.com/multipath-tcp/mptcp_net-next/commits/6f79eddd1835
If there are some issues, you can reproduce them using the same environment as
the one used by the CI thanks to a docker image, e.g.:
$ cd [kernel source code]
$ docker run -v "${PWD}:${PWD}:rw" -w "${PWD}" --privileged --rm -it \
--pull always mptcp/mptcp-upstream-virtme-docker:latest \
auto-debug
For more details:
https://github.com/multipath-tcp/mptcp-upstream-virtme-docker
Please note that despite all the efforts that have been already done to have a
stable tests suite when executed on a public CI like here, it is possible some
reported issues are not due to your modifications. Still, do not hesitate to
help us improve that ;-)
Cheers,
MPTCP GH Action bot
Bot operated by Matthieu Baerts (Tessares)
^ permalink raw reply [flat|nested] 12+ messages in thread
end of thread, other threads:[~2023-08-25 4:53 UTC | newest]
Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-08-25 3:50 [PATCH mptcp-next v6 00/10] userspace pm remove id 0 subflow & address Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 01/10] selftests: mptcp: add evts_get_info helper Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 02/10] selftests: mptcp: update userspace pm add helpers Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 03/10] selftests: mptcp: update userspace pm rm helpers Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 04/10] selftests: mptcp: userspace pm remove id 0 subflow Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 05/10] mptcp: userspace pm allow creating " Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 06/10] selftests: mptcp: userspace pm create " Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 07/10] mptcp: userspace pm remove id 0 address Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 08/10] selftests: " Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 09/10] selftests: mptcp: simplify checksum_tests Geliang Tang
2023-08-25 3:50 ` [PATCH mptcp-next v6 10/10] selftests: mptcp: simplify deny_join_id0_tests Geliang Tang
2023-08-25 4:53 ` selftests: mptcp: simplify deny_join_id0_tests: Tests Results MPTCP CI
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.