Server IP : 104.21.38.3 / Your IP : 172.69.176.168 Web Server : Apache System : Linux krdc-ubuntu-s-2vcpu-4gb-amd-blr1-01.localdomain 5.15.0-142-generic #152-Ubuntu SMP Mon May 19 10:54:31 UTC 2025 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/src/linux-headers-5.15.0-142/tools/testing/selftests/net/ |
Upload File : |
#!/bin/bash # SPDX-License-Identifier: GPL-2.0 # # ns: h1 | ns: h2 # 192.168.0.1/24 | # eth0 | # | 192.168.1.1/32 # veth0 <---|---> veth1 # Validate source address selection for route without gateway PAUSE_ON_FAIL=no VERBOSE=0 ret=0 ################################################################################ # helpers log_test() { local rc=$1 local expected=$2 local msg="$3" if [ ${rc} -eq ${expected} ]; then printf "TEST: %-60s [ OK ]\n" "${msg}" nsuccess=$((nsuccess+1)) else ret=1 nfail=$((nfail+1)) printf "TEST: %-60s [FAIL]\n" "${msg}" if [ "${PAUSE_ON_FAIL}" = "yes" ]; then echo echo "hit enter to continue, 'q' to quit" read a [ "$a" = "q" ] && exit 1 fi fi [ "$VERBOSE" = "1" ] && echo } run_cmd() { local cmd="$*" local out local rc if [ "$VERBOSE" = "1" ]; then echo "COMMAND: $cmd" fi out=$(eval $cmd 2>&1) rc=$? if [ "$VERBOSE" = "1" -a -n "$out" ]; then echo "$out" fi [ "$VERBOSE" = "1" ] && echo return $rc } ################################################################################ # config setup() { ip netns add h1 ip -n h1 link set lo up ip netns add h2 ip -n h2 link set lo up # Add a fake eth0 to support an ip address ip -n h1 link add name eth0 type dummy ip -n h1 link set eth0 up ip -n h1 address add 192.168.0.1/24 dev eth0 # Configure veths (same @mac, arp off) ip -n h1 link add name veth0 type veth peer name veth1 netns h2 ip -n h1 link set veth0 up ip -n h2 link set veth1 up # Configure @IP in the peer netns ip -n h2 address add 192.168.1.1/32 dev veth1 ip -n h2 route add default dev veth1 # Add a nexthop without @gw and use it in a route ip -n h1 nexthop add id 1 dev veth0 ip -n h1 route add 192.168.1.1 nhid 1 } cleanup() { ip netns del h1 2>/dev/null ip netns del h2 2>/dev/null } trap cleanup EXIT ################################################################################ # main while getopts :pv o do case $o in p) PAUSE_ON_FAIL=yes;; v) VERBOSE=1;; esac done cleanup setup run_cmd ip -netns h1 route get 192.168.1.1 log_test $? 0 "nexthop: get route with nexthop without gw" run_cmd ip netns exec h1 ping -c1 192.168.1.1 log_test $? 0 "nexthop: ping through nexthop without gw" exit $ret