From: Geliang Tang <tanggeliang@kylinos.cn>
Add tests for IP_LOCAL_PORT_RANGE:
- Sets port range to 30000-31000
- Verifies the range via getsockopt
- Covers both IPv4 and IPv6
- Reports results in test script
Signed-off-by: Geliang Tang <tanggeliang@kylinos.cn>
---
.../selftests/net/mptcp/mptcp_sockopt.c | 25 +++++++++++++++++++
.../selftests/net/mptcp/mptcp_sockopt.sh | 6 +++--
2 files changed, 29 insertions(+), 2 deletions(-)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_sockopt.c b/tools/testing/selftests/net/mptcp/mptcp_sockopt.c
index ca1a40492aa4..25074e5b4eaa 100644
--- a/tools/testing/selftests/net/mptcp/mptcp_sockopt.c
+++ b/tools/testing/selftests/net/mptcp/mptcp_sockopt.c
@@ -262,6 +262,15 @@ static void do_setsockopt_bind_address_no_port(int fd)
perror("setsockopt(IP_BIND_ADDRESS_NO_PORT)");
}
+static void do_setsockopt_local_port_range(int fd)
+{
+ uint32_t port_range = (31000 << 16 | 30000); // [30000 - 31000]
+
+ if (setsockopt(fd, SOL_IP, IP_LOCAL_PORT_RANGE, &port_range,
+ sizeof(port_range)))
+ perror("setsockopt(IP_LOCAL_PORT_RANGE)");
+}
+
static void do_setsockopts(int fd)
{
do_setsockopt_reuseaddr(fd);
@@ -271,6 +280,7 @@ static void do_setsockopts(int fd)
do_setsockopt_freebind(fd);
do_setsockopt_transparent(fd);
do_setsockopt_bind_address_no_port(fd);
+ do_setsockopt_local_port_range(fd);
}
static int sock_listen_mptcp(const char * const listenaddr,
@@ -734,6 +744,19 @@ static void do_getsockopt_bind_address_no_port(int fd)
assert(enable == 1);
}
+static void do_getsockopt_local_port_range(int fd)
+{
+ uint32_t port_range;
+ socklen_t len;
+
+ len = sizeof(port_range);
+ if (getsockopt(fd, SOL_IP, IP_LOCAL_PORT_RANGE,
+ &port_range, &len))
+ die_perror("getsockopt(IP_LOCAL_PORT_RANGE)");
+
+ assert(port_range == (31000 << 16 | 30000));
+}
+
static void do_getsockopts(struct so_state *s, int fd, size_t r, size_t w)
{
do_getsockopt_mptcp_info(s, fd, w);
@@ -758,6 +781,8 @@ static void do_getsockopts(struct so_state *s, int fd, size_t r, size_t w)
do_getsockopt_transparent(fd);
do_getsockopt_bind_address_no_port(fd);
+
+ do_getsockopt_local_port_range(fd);
}
static void connect_one_server(int fd, int pipefd)
diff --git a/tools/testing/selftests/net/mptcp/mptcp_sockopt.sh b/tools/testing/selftests/net/mptcp/mptcp_sockopt.sh
index 3756b537e2a6..2016adde1553 100755
--- a/tools/testing/selftests/net/mptcp/mptcp_sockopt.sh
+++ b/tools/testing/selftests/net/mptcp/mptcp_sockopt.sh
@@ -273,7 +273,8 @@ do_mptcp_sockopt_tests()
"SO_REUSEADDR" "SO_REUSEPORT" \
"SO_BINDTODEVICE" "SO_BINDTOIFINDEX" \
"IP_FREEBIND" "IP_TRANSPARENT" \
- "IP_BIND_ADDRESS_NO_PORT"; do
+ "IP_BIND_ADDRESS_NO_PORT" \
+ "IP_LOCAL_PORT_RANGE"; do
print_title "$opt sockopt v4"
mptcp_lib_pr_ok
mptcp_lib_result_pass "$opt sockopt v4"
@@ -294,7 +295,8 @@ do_mptcp_sockopt_tests()
"SO_REUSEADDR" "SO_REUSEPORT" \
"SO_BINDTODEVICE" "SO_BINDTOIFINDEX" \
"IPV6_FREEBIND" "IPV6_TRANSPARENT" \
- "IP_BIND_ADDRESS_NO_PORT"; do
+ "IP_BIND_ADDRESS_NO_PORT" \
+ "IP_LOCAL_PORT_RANGE"; do
print_title "$opt sockopt v6"
mptcp_lib_pr_ok
mptcp_lib_result_pass "$opt sockopt v6"
--
2.48.1