Blame view
samples/pktgen/pktgen_bench_xmit_mode_netif_receive.sh
3.22 KB
05a14d5e1 pktgen: add bench... |
1 |
#!/bin/bash |
b24413180 License cleanup: ... |
2 |
# SPDX-License-Identifier: GPL-2.0 |
05a14d5e1 pktgen: add bench... |
3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
# # Benchmark script: # - developed for benchmarking ingress qdisc path # # Script for injecting packets into RX path of the stack with pktgen # "xmit_mode netif_receive". With an invalid dst_mac this will only # measure the ingress code path as packets gets dropped in ip_rcv(). # # This script don't really need any hardware. It benchmarks software # RX path just after NIC driver level. With bursting is also # "removes" the SKB alloc/free overhead. # # Setup scenarios for measuring ingress qdisc (with invalid dst_mac): # ------------------------------------------------------------------ # (1) no ingress (uses static_key_false(&ingress_needed)) # # (2) ingress on other dev (change ingress_needed and calls # handle_ing() but exit early) # # config: tc qdisc add dev $SOMEDEV handle ffff: ingress # # (3) ingress on this dev, handle_ing() -> tc_classify() # # config: tc qdisc add dev $DEV handle ffff: ingress # # (4) ingress on this dev + drop at u32 classifier/action. # basedir=`dirname $0` source ${basedir}/functions.sh root_check_run_with_sudo "$@" # Parameter parsing via include source ${basedir}/parameters.sh # Using invalid DST_MAC will cause the packets to get dropped in # ip_rcv() which is part of the test |
0f06a6787 samples: Add an I... |
38 39 40 |
if [ -z "$DEST_IP" ]; then [ -z "$IP6" ] && DEST_IP="198.18.0.42" || DEST_IP="FD00::1" fi |
05a14d5e1 pktgen: add bench... |
41 42 |
[ -z "$DST_MAC" ] && DST_MAC="90:e2:ba:ff:ff:ff" [ -z "$BURST" ] && BURST=1024 |
69137ea60 pktgen: Specify n... |
43 |
[ -z "$COUNT" ] && COUNT="10000000" # Zero means indefinitely |
40f843ee5 samples: pktgen: ... |
44 45 46 47 |
if [ -n "$DEST_IP" ]; then validate_addr${IP6} $DEST_IP read -r DST_MIN DST_MAX <<< $(parse_addr${IP6} $DEST_IP) fi |
6e32a74a6 samples: pktgen: ... |
48 |
if [ -n "$DST_PORT" ]; then |
723d2904a samples: pktgen: ... |
49 50 |
read -r UDP_DST_MIN UDP_DST_MAX <<< $(parse_ports $DST_PORT) validate_ports $UDP_DST_MIN $UDP_DST_MAX |
6e32a74a6 samples: pktgen: ... |
51 |
fi |
05a14d5e1 pktgen: add bench... |
52 53 54 |
# Base Config DELAY="0" # Zero means max speed |
05a14d5e1 pktgen: add bench... |
55 56 57 58 59 |
# General cleanup everything since last run pg_ctrl "reset" # Threads are specified with parameter -t value in $THREADS |
e0e16672e pktgen: Specify t... |
60 |
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do |
05a14d5e1 pktgen: add bench... |
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 |
# The device name is extended with @name, using thread number to # make then unique, but any name will do. dev=${DEV}@${thread} # Add remove all other devices and add_device $dev to thread pg_thread $thread "rem_device_all" pg_thread $thread "add_device" $dev # Base config of dev pg_set $dev "flag QUEUE_MAP_CPU" pg_set $dev "count $COUNT" pg_set $dev "pkt_size $PKT_SIZE" pg_set $dev "delay $DELAY" pg_set $dev "flag NO_TIMESTAMP" # Destination pg_set $dev "dst_mac $DST_MAC" |
40f843ee5 samples: pktgen: ... |
78 79 |
pg_set $dev "dst${IP6}_min $DST_MIN" pg_set $dev "dst${IP6}_max $DST_MAX" |
05a14d5e1 pktgen: add bench... |
80 |
|
6e32a74a6 samples: pktgen: ... |
81 82 83 |
if [ -n "$DST_PORT" ]; then # Single destination port or random port range pg_set $dev "flag UDPDST_RND" |
723d2904a samples: pktgen: ... |
84 85 |
pg_set $dev "udp_dst_min $UDP_DST_MIN" pg_set $dev "udp_dst_max $UDP_DST_MAX" |
6e32a74a6 samples: pktgen: ... |
86 |
fi |
05a14d5e1 pktgen: add bench... |
87 88 89 90 91 92 93 94 95 96 97 98 99 |
# Inject packet into RX path of stack pg_set $dev "xmit_mode netif_receive" # Burst allow us to avoid measuring SKB alloc/free overhead pg_set $dev "burst $BURST" done # start_run echo "Running... ctrl^C to stop" >&2 pg_ctrl "start" echo "Done" >&2 # Print results |
e0e16672e pktgen: Specify t... |
100 |
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do |
05a14d5e1 pktgen: add bench... |
101 102 103 104 |
dev=${DEV}@${thread} echo "Device: $dev" cat /proc/net/pktgen/$dev | grep -A2 "Result:" done |