Path: blob/master/tools/testing/selftests/drivers/net/ping.py
26288 views
#!/usr/bin/env python31# SPDX-License-Identifier: GPL-2.023import os4import random, string, time5from lib.py import ksft_run, ksft_exit6from lib.py import ksft_eq, KsftSkipEx, KsftFailEx7from lib.py import EthtoolFamily, NetDrvEpEnv8from lib.py import bkg, cmd, wait_port_listen, rand_port9from lib.py import defer, ethtool, ip1011no_sleep=False1213def _test_v4(cfg) -> None:14if not cfg.addr_v["4"]:15return1617cmd("ping -c 1 -W0.5 " + cfg.remote_addr_v["4"])18cmd("ping -c 1 -W0.5 " + cfg.addr_v["4"], host=cfg.remote)19cmd("ping -s 65000 -c 1 -W0.5 " + cfg.remote_addr_v["4"])20cmd("ping -s 65000 -c 1 -W0.5 " + cfg.addr_v["4"], host=cfg.remote)2122def _test_v6(cfg) -> None:23if not cfg.addr_v["6"]:24return2526cmd("ping -c 1 -W5 " + cfg.remote_addr_v["6"])27cmd("ping -c 1 -W5 " + cfg.addr_v["6"], host=cfg.remote)28cmd("ping -s 65000 -c 1 -W0.5 " + cfg.remote_addr_v["6"])29cmd("ping -s 65000 -c 1 -W0.5 " + cfg.addr_v["6"], host=cfg.remote)3031def _test_tcp(cfg) -> None:32cfg.require_cmd("socat", local=False, remote=True)3334port = rand_port()35listen_cmd = f"socat -{cfg.addr_ipver} -t 2 -u TCP-LISTEN:{port},reuseport STDOUT"3637test_string = ''.join(random.choice(string.ascii_lowercase) for _ in range(65536))38with bkg(listen_cmd, exit_wait=True) as nc:39wait_port_listen(port)4041cmd(f"echo {test_string} | socat -t 2 -u STDIN TCP:{cfg.baddr}:{port}",42shell=True, host=cfg.remote)43ksft_eq(nc.stdout.strip(), test_string)4445test_string = ''.join(random.choice(string.ascii_lowercase) for _ in range(65536))46with bkg(listen_cmd, host=cfg.remote, exit_wait=True) as nc:47wait_port_listen(port, host=cfg.remote)4849cmd(f"echo {test_string} | socat -t 2 -u STDIN TCP:{cfg.remote_baddr}:{port}", shell=True)50ksft_eq(nc.stdout.strip(), test_string)5152def _schedule_checksum_reset(cfg, netnl) -> None:53features = ethtool(f"-k {cfg.ifname}", json=True)54setting = ""55for side in ["tx", "rx"]:56f = features[0][side + "-checksumming"]57if not f["fixed"]:58setting += " " + side59setting += " " + ("on" if f["requested"] or f["active"] else "off")60defer(ethtool, f" -K {cfg.ifname} " + setting)6162def _set_offload_checksum(cfg, netnl, on) -> None:63try:64ethtool(f" -K {cfg.ifname} rx {on} tx {on} ")65except:66return6768def _set_xdp_generic_sb_on(cfg) -> None:69prog = cfg.net_lib_dir / "xdp_dummy.bpf.o"70cmd(f"ip link set dev {cfg.remote_ifname} mtu 1500", shell=True, host=cfg.remote)71cmd(f"ip link set dev {cfg.ifname} mtu 1500 xdpgeneric obj {prog} sec xdp", shell=True)72defer(cmd, f"ip link set dev {cfg.ifname} xdpgeneric off")7374if no_sleep != True:75time.sleep(10)7677def _set_xdp_generic_mb_on(cfg) -> None:78prog = cfg.net_lib_dir / "xdp_dummy.bpf.o"79cmd(f"ip link set dev {cfg.remote_ifname} mtu 9000", shell=True, host=cfg.remote)80defer(ip, f"link set dev {cfg.remote_ifname} mtu 1500", host=cfg.remote)81ip("link set dev %s mtu 9000 xdpgeneric obj %s sec xdp.frags" % (cfg.ifname, prog))82defer(ip, f"link set dev {cfg.ifname} mtu 1500 xdpgeneric off")8384if no_sleep != True:85time.sleep(10)8687def _set_xdp_native_sb_on(cfg) -> None:88prog = cfg.net_lib_dir / "xdp_dummy.bpf.o"89cmd(f"ip link set dev {cfg.remote_ifname} mtu 1500", shell=True, host=cfg.remote)90cmd(f"ip -j link set dev {cfg.ifname} mtu 1500 xdp obj {prog} sec xdp", shell=True)91defer(ip, f"link set dev {cfg.ifname} mtu 1500 xdp off")92xdp_info = ip("-d link show %s" % (cfg.ifname), json=True)[0]93if xdp_info['xdp']['mode'] != 1:94"""95If the interface doesn't support native-mode, it falls back to generic mode.96The mode value 1 is native and 2 is generic.97So it raises an exception if mode is not 1(native mode).98"""99raise KsftSkipEx('device does not support native-XDP')100101if no_sleep != True:102time.sleep(10)103104def _set_xdp_native_mb_on(cfg) -> None:105prog = cfg.net_lib_dir / "xdp_dummy.bpf.o"106cmd(f"ip link set dev {cfg.remote_ifname} mtu 9000", shell=True, host=cfg.remote)107defer(ip, f"link set dev {cfg.remote_ifname} mtu 1500", host=cfg.remote)108try:109cmd(f"ip link set dev {cfg.ifname} mtu 9000 xdp obj {prog} sec xdp.frags", shell=True)110defer(ip, f"link set dev {cfg.ifname} mtu 1500 xdp off")111except Exception as e:112raise KsftSkipEx('device does not support native-multi-buffer XDP')113114if no_sleep != True:115time.sleep(10)116117def _set_xdp_offload_on(cfg) -> None:118prog = cfg.net_lib_dir / "xdp_dummy.bpf.o"119cmd(f"ip link set dev {cfg.ifname} mtu 1500", shell=True)120try:121cmd(f"ip link set dev {cfg.ifname} xdpoffload obj {prog} sec xdp", shell=True)122except Exception as e:123raise KsftSkipEx('device does not support offloaded XDP')124defer(ip, f"link set dev {cfg.ifname} xdpoffload off")125cmd(f"ip link set dev {cfg.remote_ifname} mtu 1500", shell=True, host=cfg.remote)126127if no_sleep != True:128time.sleep(10)129130def get_interface_info(cfg) -> None:131global no_sleep132133if cfg.remote_ifname == "":134raise KsftFailEx('Can not get remote interface')135local_info = ip("-d link show %s" % (cfg.ifname), json=True)[0]136if 'parentbus' in local_info and local_info['parentbus'] == "netdevsim":137no_sleep=True138if 'linkinfo' in local_info and local_info['linkinfo']['info_kind'] == "veth":139no_sleep=True140141def set_interface_init(cfg) -> None:142cmd(f"ip link set dev {cfg.ifname} mtu 1500", shell=True)143cmd(f"ip link set dev {cfg.ifname} xdp off ", shell=True)144cmd(f"ip link set dev {cfg.ifname} xdpgeneric off ", shell=True)145cmd(f"ip link set dev {cfg.ifname} xdpoffload off", shell=True)146cmd(f"ip link set dev {cfg.remote_ifname} mtu 1500", shell=True, host=cfg.remote)147148def test_default_v4(cfg, netnl) -> None:149cfg.require_ipver("4")150151_schedule_checksum_reset(cfg, netnl)152_set_offload_checksum(cfg, netnl, "off")153_test_v4(cfg)154_test_tcp(cfg)155_set_offload_checksum(cfg, netnl, "on")156_test_v4(cfg)157_test_tcp(cfg)158159def test_default_v6(cfg, netnl) -> None:160cfg.require_ipver("6")161162_schedule_checksum_reset(cfg, netnl)163_set_offload_checksum(cfg, netnl, "off")164_test_v6(cfg)165_test_tcp(cfg)166_set_offload_checksum(cfg, netnl, "on")167_test_v6(cfg)168_test_tcp(cfg)169170def test_xdp_generic_sb(cfg, netnl) -> None:171_schedule_checksum_reset(cfg, netnl)172_set_xdp_generic_sb_on(cfg)173_set_offload_checksum(cfg, netnl, "off")174_test_v4(cfg)175_test_v6(cfg)176_test_tcp(cfg)177_set_offload_checksum(cfg, netnl, "on")178_test_v4(cfg)179_test_v6(cfg)180_test_tcp(cfg)181182def test_xdp_generic_mb(cfg, netnl) -> None:183_schedule_checksum_reset(cfg, netnl)184_set_xdp_generic_mb_on(cfg)185_set_offload_checksum(cfg, netnl, "off")186_test_v4(cfg)187_test_v6(cfg)188_test_tcp(cfg)189_set_offload_checksum(cfg, netnl, "on")190_test_v4(cfg)191_test_v6(cfg)192_test_tcp(cfg)193194def test_xdp_native_sb(cfg, netnl) -> None:195_schedule_checksum_reset(cfg, netnl)196_set_xdp_native_sb_on(cfg)197_set_offload_checksum(cfg, netnl, "off")198_test_v4(cfg)199_test_v6(cfg)200_test_tcp(cfg)201_set_offload_checksum(cfg, netnl, "on")202_test_v4(cfg)203_test_v6(cfg)204_test_tcp(cfg)205206def test_xdp_native_mb(cfg, netnl) -> None:207_schedule_checksum_reset(cfg, netnl)208_set_xdp_native_mb_on(cfg)209_set_offload_checksum(cfg, netnl, "off")210_test_v4(cfg)211_test_v6(cfg)212_test_tcp(cfg)213_set_offload_checksum(cfg, netnl, "on")214_test_v4(cfg)215_test_v6(cfg)216_test_tcp(cfg)217218def test_xdp_offload(cfg, netnl) -> None:219_set_xdp_offload_on(cfg)220_test_v4(cfg)221_test_v6(cfg)222_test_tcp(cfg)223224def main() -> None:225with NetDrvEpEnv(__file__) as cfg:226get_interface_info(cfg)227set_interface_init(cfg)228ksft_run([test_default_v4,229test_default_v6,230test_xdp_generic_sb,231test_xdp_generic_mb,232test_xdp_native_sb,233test_xdp_native_mb,234test_xdp_offload],235args=(cfg, EthtoolFamily()))236ksft_exit()237238239if __name__ == "__main__":240main()241242243