xref: /linux/samples/pktgen/pktgen_sample05_flow_per_thread.sh (revision c8fd4852022ca8ae85ac4d30d05950eaf506b828)
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
2540f843eeSDaniel T. Leeif [ -n "$DEST_IP" ]; then
2640f843eeSDaniel T. Lee    validate_addr $DEST_IP
2740f843eeSDaniel T. Lee    read -r DST_MIN DST_MAX <<< $(parse_addr $DEST_IP)
2840f843eeSDaniel 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# General cleanup everything since last run
35*c8fd4852SIgor Russkikh[ -z "$APPEND" ] && pg_ctrl "reset"
36d25692e4SJesper Dangaard Brouer
37d25692e4SJesper Dangaard Brouer# Threads are specified with parameter -t value in $THREADS
38e0e16672STariq Toukanfor ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
39d25692e4SJesper Dangaard Brouer    dev=${DEV}@${thread}
40d25692e4SJesper Dangaard Brouer
41d25692e4SJesper Dangaard Brouer    # Add remove all other devices and add_device $dev to thread
42*c8fd4852SIgor Russkikh    [ -z "$APPEND" ] && pg_thread $thread "rem_device_all"
43d25692e4SJesper Dangaard Brouer    pg_thread $thread "add_device" $dev
44d25692e4SJesper Dangaard Brouer
45d25692e4SJesper Dangaard Brouer    # Base config
46d25692e4SJesper Dangaard Brouer    pg_set $dev "flag QUEUE_MAP_CPU"
47d25692e4SJesper Dangaard Brouer    pg_set $dev "count $COUNT"
48d25692e4SJesper Dangaard Brouer    pg_set $dev "clone_skb $CLONE_SKB"
49d25692e4SJesper Dangaard Brouer    pg_set $dev "pkt_size $PKT_SIZE"
50d25692e4SJesper Dangaard Brouer    pg_set $dev "delay $DELAY"
51d25692e4SJesper Dangaard Brouer    pg_set $dev "flag NO_TIMESTAMP"
52d25692e4SJesper Dangaard Brouer
53d25692e4SJesper Dangaard Brouer    # Single destination
54d25692e4SJesper Dangaard Brouer    pg_set $dev "dst_mac $DST_MAC"
5540f843eeSDaniel T. Lee    pg_set $dev "dst_min $DST_MIN"
5640f843eeSDaniel T. Lee    pg_set $dev "dst_max $DST_MAX"
57d25692e4SJesper Dangaard Brouer
586e32a74aSDaniel T. Lee    if [ -n "$DST_PORT" ]; then
596e32a74aSDaniel T. Lee	# Single destination port or random port range
606e32a74aSDaniel T. Lee	pg_set $dev "flag UDPDST_RND"
61723d2904SDaniel T. Lee	pg_set $dev "udp_dst_min $UDP_DST_MIN"
62723d2904SDaniel T. Lee	pg_set $dev "udp_dst_max $UDP_DST_MAX"
636e32a74aSDaniel T. Lee    fi
646e32a74aSDaniel T. Lee
65d25692e4SJesper Dangaard Brouer    # Setup source IP-addresses based on thread number
66d25692e4SJesper Dangaard Brouer    pg_set $dev "src_min 198.18.$((thread+1)).1"
67d25692e4SJesper Dangaard Brouer    pg_set $dev "src_max 198.18.$((thread+1)).1"
68d25692e4SJesper Dangaard Brouer
69d25692e4SJesper Dangaard Brouer    # Setup burst, for easy testing -b 0 disable bursting
70d25692e4SJesper Dangaard Brouer    # (internally in pktgen default and minimum burst=1)
71d25692e4SJesper Dangaard Brouer    if [[ ${BURST} -ne 0 ]]; then
72d25692e4SJesper Dangaard Brouer	pg_set $dev "burst $BURST"
73d25692e4SJesper Dangaard Brouer    else
74d25692e4SJesper Dangaard Brouer	info "$dev: Not using burst"
75d25692e4SJesper Dangaard Brouer    fi
76d25692e4SJesper Dangaard Brouer
77d25692e4SJesper Dangaard Brouerdone
78d25692e4SJesper Dangaard Brouer
79d25692e4SJesper Dangaard Brouer# Run if user hits control-c
80d25692e4SJesper Dangaard Brouerfunction print_result() {
81d25692e4SJesper Dangaard Brouer    # Print results
82e0e16672STariq Toukan    for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
83d25692e4SJesper Dangaard Brouer	dev=${DEV}@${thread}
84d25692e4SJesper Dangaard Brouer	echo "Device: $dev"
85d25692e4SJesper Dangaard Brouer	cat /proc/net/pktgen/$dev | grep -A2 "Result:"
86d25692e4SJesper Dangaard Brouer    done
87d25692e4SJesper Dangaard Brouer}
88d25692e4SJesper Dangaard Brouer# trap keyboard interrupt (Ctrl-C)
89d25692e4SJesper Dangaard Brouertrap true SIGINT
90d25692e4SJesper Dangaard Brouer
91*c8fd4852SIgor Russkikhif [ -z "$APPEND" ]; then
92d25692e4SJesper Dangaard Brouer    echo "Running... ctrl^C to stop" >&2
93d25692e4SJesper Dangaard Brouer    pg_ctrl "start"
94d25692e4SJesper Dangaard Brouer
95d25692e4SJesper Dangaard Brouer    print_result
96*c8fd4852SIgor Russkikhelse
97*c8fd4852SIgor Russkikh    echo "Append mode: config done. Do more or use 'pg_ctrl start' to run"
98*c8fd4852SIgor Russkikhfi
99