blob: cff51f861506d12aeb3d08f75c7329a811518d84 [file] [log] [blame]
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +02001#!/bin/bash
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01002# SPDX-License-Identifier: GPL-2.0
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +02003#
4# Script example for many flows testing
5#
6# Number of simultaneous flows limited by variable $FLOWS
7# and number of packets per flow controlled by variable $FLOWLEN
8#
9basedir=`dirname $0`
10source ${basedir}/functions.sh
11root_check_run_with_sudo "$@"
12
13# Parameter parsing via include
14source ${basedir}/parameters.sh
15# Set some default params, if they didn't get set
Juhee Kang0f0c4f12021-08-13 00:08:13 +090016if [ -z "$DEST_IP" ]; then
17 [ -z "$IP6" ] && DEST_IP="198.18.0.42" || DEST_IP="FD00::1"
18fi
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020019[ -z "$DST_MAC" ] && DST_MAC="90:e2:ba:ff:ff:ff"
20[ -z "$CLONE_SKB" ] && CLONE_SKB="0"
Tariq Toukan69137ea2017-06-15 19:07:21 +030021[ -z "$COUNT" ] && COUNT="0" # Zero means indefinitely
Daniel T. Lee40f843e2019-10-05 17:25:09 +090022if [ -n "$DEST_IP" ]; then
Juhee Kang0f0c4f12021-08-13 00:08:13 +090023 validate_addr${IP6} $DEST_IP
24 read -r DST_MIN DST_MAX <<< $(parse_addr${IP6} $DEST_IP)
Daniel T. Lee40f843e2019-10-05 17:25:09 +090025fi
Daniel T. Lee6e32a742019-06-29 22:33:58 +090026if [ -n "$DST_PORT" ]; then
Daniel T. Lee723d2902019-10-05 17:25:06 +090027 read -r UDP_DST_MIN UDP_DST_MAX <<< $(parse_ports $DST_PORT)
28 validate_ports $UDP_DST_MIN $UDP_DST_MAX
Daniel T. Lee6e32a742019-06-29 22:33:58 +090029fi
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020030
31# NOTICE: Script specific settings
32# =======
33# Limiting the number of concurrent flows ($FLOWS)
34# and also set how many packets each flow contains ($FLOWLEN)
35#
36[ -z "$FLOWS" ] && FLOWS="8000"
37[ -z "$FLOWLEN" ] && FLOWLEN="10"
38
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020039if [[ -n "$BURST" ]]; then
40 err 1 "Bursting not supported for this mode"
41fi
42
Daniel T. Lee40f843e2019-10-05 17:25:09 +090043# 198.18.0.0 / 198.19.255.255
44read -r SRC_MIN SRC_MAX <<< $(parse_addr 198.18.0.0/15)
45
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020046# General cleanup everything since last run
Igor Russkikhc8fd4852021-03-11 11:32:53 +010047[ -z "$APPEND" ] && pg_ctrl "reset"
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020048
49# Threads are specified with parameter -t value in $THREADS
Tariq Toukane0e16672017-06-15 19:07:22 +030050for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020051 dev=${DEV}@${thread}
52
53 # Add remove all other devices and add_device $dev to thread
Igor Russkikhc8fd4852021-03-11 11:32:53 +010054 [ -z "$APPEND" ] && pg_thread $thread "rem_device_all"
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020055 pg_thread $thread "add_device" $dev
56
57 # Base config
58 pg_set $dev "flag QUEUE_MAP_CPU"
59 pg_set $dev "count $COUNT"
60 pg_set $dev "clone_skb $CLONE_SKB"
61 pg_set $dev "pkt_size $PKT_SIZE"
62 pg_set $dev "delay $DELAY"
63 pg_set $dev "flag NO_TIMESTAMP"
64
65 # Single destination
66 pg_set $dev "dst_mac $DST_MAC"
Juhee Kang0f0c4f12021-08-13 00:08:13 +090067 pg_set $dev "dst${IP6}_min $DST_MIN"
68 pg_set $dev "dst${IP6}_max $DST_MAX"
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020069
Daniel T. Lee6e32a742019-06-29 22:33:58 +090070 if [ -n "$DST_PORT" ]; then
71 # Single destination port or random port range
72 pg_set $dev "flag UDPDST_RND"
Daniel T. Lee723d2902019-10-05 17:25:06 +090073 pg_set $dev "udp_dst_min $UDP_DST_MIN"
74 pg_set $dev "udp_dst_max $UDP_DST_MAX"
Daniel T. Lee6e32a742019-06-29 22:33:58 +090075 fi
76
Lorenzo Bianconi460a9aa2021-05-28 16:06:35 +020077 [ ! -z "$UDP_CSUM" ] && pg_set $dev "flag UDPCSUM"
78
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020079 # Randomize source IP-addresses
80 pg_set $dev "flag IPSRC_RND"
Daniel T. Lee40f843e2019-10-05 17:25:09 +090081 pg_set $dev "src_min $SRC_MIN"
82 pg_set $dev "src_max $SRC_MAX"
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +020083
84 # Limit number of flows (max 65535)
85 pg_set $dev "flows $FLOWS"
86 #
87 # How many packets a flow will send, before flow "entry" is
88 # re-generated/setup.
89 pg_set $dev "flowlen $FLOWLEN"
90 #
91 # Flag FLOW_SEQ will cause $FLOWLEN packets from the same flow
92 # being send back-to-back, before next flow is selected
93 # incrementally. This helps lookup caches, and is more realistic.
94 #
95 pg_set $dev "flag FLOW_SEQ"
96
97done
98
99# Run if user hits control-c
100function print_result() {
101 # Print results
Tariq Toukane0e16672017-06-15 19:07:22 +0300102 for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +0200103 dev=${DEV}@${thread}
104 echo "Device: $dev"
105 cat /proc/net/pktgen/$dev | grep -A2 "Result:"
106 done
107}
108# trap keyboard interrupt (Ctrl-C)
109trap true SIGINT
110
Igor Russkikhc8fd4852021-03-11 11:32:53 +0100111if [ -z "$APPEND" ]; then
112 echo "Running... ctrl^C to stop" >&2
113 pg_ctrl "start"
Jesper Dangaard Brouer15f2cbb2016-07-13 22:06:04 +0200114
Igor Russkikhc8fd4852021-03-11 11:32:53 +0100115 print_result
116else
117 echo "Append mode: config done. Do more or use 'pg_ctrl start' to run"
118fi