xref: /linux/samples/pktgen/pktgen_sample05_flow_per_thread.sh (revision 40f843ee5e17673780c0969c8248b31a8d926b17)
1d25692e4SJesper Dangaard Brouer#!/bin/bash
2b2441318SGreg Kroah-Hartman# SPDX-License-Identifier: GPL-2.0
3d25692e4SJesper Dangaard Brouer#
4d25692e4SJesper Dangaard Brouer# Script will generate one flow per thread (-t N)
5d25692e4SJesper Dangaard Brouer#  - Same destination IP
6d25692e4SJesper Dangaard Brouer#  - Fake source IPs for each flow (fixed based on thread number)
7d25692e4SJesper Dangaard Brouer#
8d25692e4SJesper Dangaard Brouer# Useful for scale testing on receiver, to see whether silo'ing flows
9d25692e4SJesper Dangaard Brouer# works and scales.  For optimal scalability (on receiver) each
10d25692e4SJesper Dangaard Brouer# separate-flow should not access shared variables/data. This script
11d25692e4SJesper Dangaard Brouer# helps magnify any of these scaling issues by overloading the receiver.
12d25692e4SJesper Dangaard Brouer#
13d25692e4SJesper Dangaard Brouerbasedir=`dirname $0`
14d25692e4SJesper Dangaard Brouersource ${basedir}/functions.sh
15d25692e4SJesper Dangaard Brouerroot_check_run_with_sudo "$@"
16d25692e4SJesper Dangaard Brouer
17d25692e4SJesper Dangaard Brouer# Parameter parsing via include
18d25692e4SJesper Dangaard Brouersource ${basedir}/parameters.sh
19d25692e4SJesper Dangaard Brouer# Set some default params, if they didn't get set
20d25692e4SJesper Dangaard Brouer[ -z "$DEST_IP" ]   && DEST_IP="198.18.0.42"
21d25692e4SJesper Dangaard Brouer[ -z "$DST_MAC" ]   && DST_MAC="90:e2:ba:ff:ff:ff"
22d25692e4SJesper Dangaard Brouer[ -z "$CLONE_SKB" ] && CLONE_SKB="0"
23d25692e4SJesper Dangaard Brouer[ -z "$BURST" ]     && BURST=32
2469137ea6STariq Toukan[ -z "$COUNT" ]     && COUNT="0" # Zero means indefinitely
25*40f843eeSDaniel T. Leeif [ -n "$DEST_IP" ]; then
26*40f843eeSDaniel T. Lee    validate_addr $DEST_IP
27*40f843eeSDaniel T. Lee    read -r DST_MIN DST_MAX <<< $(parse_addr $DEST_IP)
28*40f843eeSDaniel T. Leefi
296e32a74aSDaniel T. Leeif [ -n "$DST_PORT" ]; then
30723d2904SDaniel T. Lee    read -r UDP_DST_MIN UDP_DST_MAX <<< $(parse_ports $DST_PORT)
31723d2904SDaniel T. Lee    validate_ports $UDP_DST_MIN $UDP_DST_MAX
326e32a74aSDaniel T. Leefi
33d25692e4SJesper Dangaard Brouer
34d25692e4SJesper Dangaard Brouer# Base Config
35d25692e4SJesper Dangaard BrouerDELAY="0"  # Zero means max speed
36d25692e4SJesper Dangaard Brouer
37d25692e4SJesper Dangaard Brouer# General cleanup everything since last run
38d25692e4SJesper Dangaard Brouerpg_ctrl "reset"
39d25692e4SJesper Dangaard Brouer
40d25692e4SJesper Dangaard Brouer# Threads are specified with parameter -t value in $THREADS
41e0e16672STariq Toukanfor ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
42d25692e4SJesper Dangaard Brouer    dev=${DEV}@${thread}
43d25692e4SJesper Dangaard Brouer
44d25692e4SJesper Dangaard Brouer    # Add remove all other devices and add_device $dev to thread
45d25692e4SJesper Dangaard Brouer    pg_thread $thread "rem_device_all"
46d25692e4SJesper Dangaard Brouer    pg_thread $thread "add_device" $dev
47d25692e4SJesper Dangaard Brouer
48d25692e4SJesper Dangaard Brouer    # Base config
49d25692e4SJesper Dangaard Brouer    pg_set $dev "flag QUEUE_MAP_CPU"
50d25692e4SJesper Dangaard Brouer    pg_set $dev "count $COUNT"
51d25692e4SJesper Dangaard Brouer    pg_set $dev "clone_skb $CLONE_SKB"
52d25692e4SJesper Dangaard Brouer    pg_set $dev "pkt_size $PKT_SIZE"
53d25692e4SJesper Dangaard Brouer    pg_set $dev "delay $DELAY"
54d25692e4SJesper Dangaard Brouer    pg_set $dev "flag NO_TIMESTAMP"
55d25692e4SJesper Dangaard Brouer
56d25692e4SJesper Dangaard Brouer    # Single destination
57d25692e4SJesper Dangaard Brouer    pg_set $dev "dst_mac $DST_MAC"
58*40f843eeSDaniel T. Lee    pg_set $dev "dst_min $DST_MIN"
59*40f843eeSDaniel T. Lee    pg_set $dev "dst_max $DST_MAX"
60d25692e4SJesper Dangaard Brouer
616e32a74aSDaniel T. Lee    if [ -n "$DST_PORT" ]; then
626e32a74aSDaniel T. Lee	# Single destination port or random port range
636e32a74aSDaniel T. Lee	pg_set $dev "flag UDPDST_RND"
64723d2904SDaniel T. Lee	pg_set $dev "udp_dst_min $UDP_DST_MIN"
65723d2904SDaniel T. Lee	pg_set $dev "udp_dst_max $UDP_DST_MAX"
666e32a74aSDaniel T. Lee    fi
676e32a74aSDaniel T. Lee
68d25692e4SJesper Dangaard Brouer    # Setup source IP-addresses based on thread number
69d25692e4SJesper Dangaard Brouer    pg_set $dev "src_min 198.18.$((thread+1)).1"
70d25692e4SJesper Dangaard Brouer    pg_set $dev "src_max 198.18.$((thread+1)).1"
71d25692e4SJesper Dangaard Brouer
72d25692e4SJesper Dangaard Brouer    # Setup burst, for easy testing -b 0 disable bursting
73d25692e4SJesper Dangaard Brouer    # (internally in pktgen default and minimum burst=1)
74d25692e4SJesper Dangaard Brouer    if [[ ${BURST} -ne 0 ]]; then
75d25692e4SJesper Dangaard Brouer	pg_set $dev "burst $BURST"
76d25692e4SJesper Dangaard Brouer    else
77d25692e4SJesper Dangaard Brouer	info "$dev: Not using burst"
78d25692e4SJesper Dangaard Brouer    fi
79d25692e4SJesper Dangaard Brouer
80d25692e4SJesper Dangaard Brouerdone
81d25692e4SJesper Dangaard Brouer
82d25692e4SJesper Dangaard Brouer# Run if user hits control-c
83d25692e4SJesper Dangaard Brouerfunction print_result() {
84d25692e4SJesper Dangaard Brouer    # Print results
85e0e16672STariq Toukan    for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
86d25692e4SJesper Dangaard Brouer	dev=${DEV}@${thread}
87d25692e4SJesper Dangaard Brouer	echo "Device: $dev"
88d25692e4SJesper Dangaard Brouer	cat /proc/net/pktgen/$dev | grep -A2 "Result:"
89d25692e4SJesper Dangaard Brouer    done
90d25692e4SJesper Dangaard Brouer}
91d25692e4SJesper Dangaard Brouer# trap keyboard interrupt (Ctrl-C)
92d25692e4SJesper Dangaard Brouertrap true SIGINT
93d25692e4SJesper Dangaard Brouer
94d25692e4SJesper Dangaard Brouerecho "Running... ctrl^C to stop" >&2
95d25692e4SJesper Dangaard Brouerpg_ctrl "start"
96d25692e4SJesper Dangaard Brouer
97d25692e4SJesper Dangaard Brouerprint_result
98