Commit 5265a014 authored by David Ahern's avatar David Ahern Committed by Jakub Kicinski

selftests: Add separate option to nettest for address binding

Add separate option to nettest to specify local address
binding in client mode.
Signed-off-by: default avatarDavid Ahern <dsahern@kernel.org>
Signed-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent f26a008c
...@@ -854,7 +854,7 @@ ipv4_tcp_md5_novrf() ...@@ -854,7 +854,7 @@ ipv4_tcp_md5_novrf()
show_hint "Should timeout due to MD5 mismatch" show_hint "Should timeout due to MD5 mismatch"
run_cmd nettest -s -M ${MD5_PW} -m ${NS_NET} & run_cmd nettest -s -M ${MD5_PW} -m ${NS_NET} &
sleep 1 sleep 1
run_cmd_nsb nettest -l ${NSB_LO_IP} -r ${NSA_IP} -X ${MD5_PW} run_cmd_nsb nettest -c ${NSB_LO_IP} -r ${NSA_IP} -X ${MD5_PW}
log_test $? 2 "MD5: Prefix config, client address not in configured prefix" log_test $? 2 "MD5: Prefix config, client address not in configured prefix"
} }
...@@ -922,7 +922,7 @@ ipv4_tcp_md5() ...@@ -922,7 +922,7 @@ ipv4_tcp_md5()
show_hint "Should timeout since client address is outside of prefix" show_hint "Should timeout since client address is outside of prefix"
run_cmd nettest -s -I ${VRF} -M ${MD5_PW} -m ${NS_NET} & run_cmd nettest -s -I ${VRF} -M ${MD5_PW} -m ${NS_NET} &
sleep 1 sleep 1
run_cmd_nsb nettest -l ${NSB_LO_IP} -r ${NSA_IP} -X ${MD5_PW} run_cmd_nsb nettest -c ${NSB_LO_IP} -r ${NSA_IP} -X ${MD5_PW}
log_test $? 2 "MD5: VRF: Prefix config, client address not in configured prefix" log_test $? 2 "MD5: VRF: Prefix config, client address not in configured prefix"
# #
...@@ -1706,11 +1706,11 @@ ipv4_addr_bind_novrf() ...@@ -1706,11 +1706,11 @@ ipv4_addr_bind_novrf()
# #
a=${NSA_IP} a=${NSA_IP}
log_start log_start
run_cmd nettest -l ${a} -r ${NSB_IP} -t1 -b run_cmd nettest -c ${a} -r ${NSB_IP} -t1 -b
log_test_addr ${a} $? 0 "TCP socket bind to local address" log_test_addr ${a} $? 0 "TCP socket bind to local address"
log_start log_start
run_cmd nettest -l ${a} -r ${NSB_IP} -d ${NSA_DEV} -t1 -b run_cmd nettest -c ${a} -r ${NSB_IP} -d ${NSA_DEV} -t1 -b
log_test_addr ${a} $? 0 "TCP socket bind to local address after device bind" log_test_addr ${a} $? 0 "TCP socket bind to local address after device bind"
# Sadly, the kernel allows binding a socket to a device and then # Sadly, the kernel allows binding a socket to a device and then
...@@ -2318,7 +2318,7 @@ ipv6_tcp_md5_novrf() ...@@ -2318,7 +2318,7 @@ ipv6_tcp_md5_novrf()
show_hint "Should timeout due to MD5 mismatch" show_hint "Should timeout due to MD5 mismatch"
run_cmd nettest -6 -s -M ${MD5_PW} -m ${NS_NET6} & run_cmd nettest -6 -s -M ${MD5_PW} -m ${NS_NET6} &
sleep 1 sleep 1
run_cmd_nsb nettest -6 -l ${NSB_LO_IP6} -r ${NSA_IP6} -X ${MD5_PW} run_cmd_nsb nettest -6 -c ${NSB_LO_IP6} -r ${NSA_IP6} -X ${MD5_PW}
log_test $? 2 "MD5: Prefix config, client address not in configured prefix" log_test $? 2 "MD5: Prefix config, client address not in configured prefix"
} }
...@@ -2386,7 +2386,7 @@ ipv6_tcp_md5() ...@@ -2386,7 +2386,7 @@ ipv6_tcp_md5()
show_hint "Should timeout since client address is outside of prefix" show_hint "Should timeout since client address is outside of prefix"
run_cmd nettest -6 -s -I ${VRF} -M ${MD5_PW} -m ${NS_NET6} & run_cmd nettest -6 -s -I ${VRF} -M ${MD5_PW} -m ${NS_NET6} &
sleep 1 sleep 1
run_cmd_nsb nettest -6 -l ${NSB_LO_IP6} -r ${NSA_IP6} -X ${MD5_PW} run_cmd_nsb nettest -6 -c ${NSB_LO_IP6} -r ${NSA_IP6} -X ${MD5_PW}
log_test $? 2 "MD5: VRF: Prefix config, client address not in configured prefix" log_test $? 2 "MD5: VRF: Prefix config, client address not in configured prefix"
# #
......
...@@ -48,6 +48,7 @@ ...@@ -48,6 +48,7 @@
struct sock_args { struct sock_args {
/* local address */ /* local address */
const char *local_addr_str; const char *local_addr_str;
const char *client_local_addr_str;
union { union {
struct in_addr in; struct in_addr in;
struct in6_addr in6; struct in6_addr in6;
...@@ -1630,6 +1631,7 @@ static int do_client(struct sock_args *args) ...@@ -1630,6 +1631,7 @@ static int do_client(struct sock_args *args)
log_msg("Switched client netns\n"); log_msg("Switched client netns\n");
} }
args->local_addr_str = args->client_local_addr_str;
if (resolve_devices(args) || validate_addresses(args)) if (resolve_devices(args) || validate_addresses(args))
return 1; return 1;
...@@ -1770,7 +1772,7 @@ static int ipc_parent(int cpid, int fd, struct sock_args *args) ...@@ -1770,7 +1772,7 @@ static int ipc_parent(int cpid, int fd, struct sock_args *args)
return client_status; return client_status;
} }
#define GETOPT_STR "sr:l:p:t:g:P:DRn:M:X:m:d:I:BN:O:SCi6L:0:1:2:3:Fbq" #define GETOPT_STR "sr:l:c:p:t:g:P:DRn:M:X:m:d:I:BN:O:SCi6L:0:1:2:3:Fbq"
static void print_usage(char *prog) static void print_usage(char *prog)
{ {
...@@ -1791,7 +1793,8 @@ static void print_usage(char *prog) ...@@ -1791,7 +1793,8 @@ static void print_usage(char *prog)
" -6 IPv6 (default is IPv4)\n" " -6 IPv6 (default is IPv4)\n"
" -P proto protocol for socket: icmp, ospf (default: none)\n" " -P proto protocol for socket: icmp, ospf (default: none)\n"
" -D|R datagram (D) / raw (R) socket (default stream)\n" " -D|R datagram (D) / raw (R) socket (default stream)\n"
" -l addr local address to bind to\n" " -l addr local address to bind to in server mode\n"
" -c addr local address to bind to in client mode\n"
"\n" "\n"
" -d dev bind socket to given device name\n" " -d dev bind socket to given device name\n"
" -I dev bind socket to given device name - server mode\n" " -I dev bind socket to given device name - server mode\n"
...@@ -1859,6 +1862,10 @@ int main(int argc, char *argv[]) ...@@ -1859,6 +1862,10 @@ int main(int argc, char *argv[])
args.has_remote_ip = 1; args.has_remote_ip = 1;
args.remote_addr_str = optarg; args.remote_addr_str = optarg;
break; break;
case 'c':
args.has_local_ip = 1;
args.client_local_addr_str = optarg;
break;
case 'p': case 'p':
if (str_to_uint(optarg, 1, 65535, &tmp) != 0) { if (str_to_uint(optarg, 1, 65535, &tmp) != 0) {
fprintf(stderr, "Invalid port\n"); fprintf(stderr, "Invalid port\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment