diff options
| author | Jesper Dangaard Brouer <brouer@redhat.com> | 2015-05-21 06:17:48 -0400 |
|---|---|---|
| committer | David S. Miller <davem@davemloft.net> | 2015-05-22 23:59:17 -0400 |
| commit | 282fb58947e129dea8badf48972ea89d027a76dc (patch) | |
| tree | f1be92dbeb67d70b4204cd19ae0d14740c71a897 /samples | |
| parent | 6f09479758be247fef02188a275383ebaddbe291 (diff) | |
pktgen: add sample script pktgen_sample02_multiqueue.sh
Add the pktgen samples script pktgen_sample02_multiqueue.sh that
demonstrates generating packets on multiqueue NICs.
Specifically notice the options "-t" that specifies how many
kernel threads to activate. Also notice the flag QUEUE_MAP_CPU,
which cause the SKB TX queue to be mapped to the CPU running the
kernel thread. For best scalability people are also encourage to
map NIC IRQ /proc/irq/*/smp_affinity to CPU number.
Usage example with "-t" 4 threads and help:
./pktgen_sample02_multiqueue.sh -i eth4 -m 00:1B:21:3C:9D:F8 -t 4
Usage: ./pktgen_sample02_multiqueue.sh [-vx] -i ethX
-i : ($DEV) output interface/device (required)
-s : ($PKT_SIZE) packet size
-d : ($DEST_IP) destination IP
-m : ($DST_MAC) destination MAC-addr
-t : ($THREADS) threads to start
-c : ($SKB_CLONE) SKB clones send before alloc new SKB
-b : ($BURST) HW level bursting of SKBs
-v : ($VERBOSE) verbose
-x : ($DEBUG) debug
Removing pktgen.conf-2-1 and pktgen.conf-2-2 as these examples
should be covered now.
Signed-off-by: Jesper Dangaard Brouer <brouer@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'samples')
| -rwxr-xr-x | samples/pktgen/pktgen.conf-2-1 | 66 | ||||
| -rwxr-xr-x | samples/pktgen/pktgen.conf-2-2 | 73 | ||||
| -rwxr-xr-x | samples/pktgen/pktgen_sample02_multiqueue.sh | 75 |
3 files changed, 75 insertions, 139 deletions
diff --git a/samples/pktgen/pktgen.conf-2-1 b/samples/pktgen/pktgen.conf-2-1 deleted file mode 100755 index e108e97d6d89..000000000000 --- a/samples/pktgen/pktgen.conf-2-1 +++ /dev/null | |||
| @@ -1,66 +0,0 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | |||
| 3 | #modprobe pktgen | ||
| 4 | |||
| 5 | |||
| 6 | function pgset() { | ||
| 7 | local result | ||
| 8 | |||
| 9 | echo $1 > $PGDEV | ||
| 10 | |||
| 11 | result=`cat $PGDEV | fgrep "Result: OK:"` | ||
| 12 | if [ "$result" = "" ]; then | ||
| 13 | cat $PGDEV | fgrep Result: | ||
| 14 | fi | ||
| 15 | } | ||
| 16 | |||
| 17 | # Config Start Here ----------------------------------------------------------- | ||
| 18 | |||
| 19 | |||
| 20 | # thread config | ||
| 21 | # Each CPU has its own thread. Two CPU example. We add eth1 to the first | ||
| 22 | # and leave the second idle. | ||
| 23 | |||
| 24 | PGDEV=/proc/net/pktgen/kpktgend_0 | ||
| 25 | echo "Removing all devices" | ||
| 26 | pgset "rem_device_all" | ||
| 27 | echo "Adding eth1" | ||
| 28 | pgset "add_device eth1" | ||
| 29 | |||
| 30 | # We need to remove old config since we dont use this thread. We can only | ||
| 31 | # one NIC on one CPU due to affinity reasons. | ||
| 32 | |||
| 33 | PGDEV=/proc/net/pktgen/kpktgend_1 | ||
| 34 | echo "Removing all devices" | ||
| 35 | pgset "rem_device_all" | ||
| 36 | |||
| 37 | # device config | ||
| 38 | # delay 0 means maximum speed. | ||
| 39 | |||
| 40 | CLONE_SKB="clone_skb 1000000" | ||
| 41 | # NIC adds 4 bytes CRC | ||
| 42 | PKT_SIZE="pkt_size 60" | ||
| 43 | |||
| 44 | # COUNT 0 means forever | ||
| 45 | #COUNT="count 0" | ||
| 46 | COUNT="count 10000000" | ||
| 47 | DELAY="delay 0" | ||
| 48 | |||
| 49 | PGDEV=/proc/net/pktgen/eth1 | ||
| 50 | echo "Configuring $PGDEV" | ||
| 51 | pgset "$COUNT" | ||
| 52 | pgset "$CLONE_SKB" | ||
| 53 | pgset "$PKT_SIZE" | ||
| 54 | pgset "$DELAY" | ||
| 55 | pgset "dst 10.10.11.2" | ||
| 56 | pgset "dst_mac 00:04:23:08:91:dc" | ||
| 57 | |||
| 58 | |||
| 59 | # Time to run | ||
| 60 | PGDEV=/proc/net/pktgen/pgctrl | ||
| 61 | |||
| 62 | echo "Running... ctrl^C to stop" | ||
| 63 | trap true INT | ||
| 64 | pgset "start" | ||
| 65 | echo "Done" | ||
| 66 | cat /proc/net/pktgen/eth1 | ||
diff --git a/samples/pktgen/pktgen.conf-2-2 b/samples/pktgen/pktgen.conf-2-2 deleted file mode 100755 index acea15503e71..000000000000 --- a/samples/pktgen/pktgen.conf-2-2 +++ /dev/null | |||
| @@ -1,73 +0,0 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | |||
| 3 | #modprobe pktgen | ||
| 4 | |||
| 5 | |||
| 6 | function pgset() { | ||
| 7 | local result | ||
| 8 | |||
| 9 | echo $1 > $PGDEV | ||
| 10 | |||
| 11 | result=`cat $PGDEV | fgrep "Result: OK:"` | ||
| 12 | if [ "$result" = "" ]; then | ||
| 13 | cat $PGDEV | fgrep Result: | ||
| 14 | fi | ||
| 15 | } | ||
| 16 | |||
| 17 | # Config Start Here ----------------------------------------------------------- | ||
| 18 | |||
| 19 | |||
| 20 | # thread config | ||
| 21 | # Each CPU has its own thread. Two CPU example. We add eth1, eth2 respectively. | ||
| 22 | |||
| 23 | PGDEV=/proc/net/pktgen/kpktgend_0 | ||
| 24 | echo "Removing all devices" | ||
| 25 | pgset "rem_device_all" | ||
| 26 | echo "Adding eth1" | ||
| 27 | pgset "add_device eth1" | ||
| 28 | |||
| 29 | PGDEV=/proc/net/pktgen/kpktgend_1 | ||
| 30 | echo "Removing all devices" | ||
| 31 | pgset "rem_device_all" | ||
| 32 | echo "Adding eth2" | ||
| 33 | pgset "add_device eth2" | ||
| 34 | |||
| 35 | |||
| 36 | # device config | ||
| 37 | # delay 0 means maximum speed. | ||
| 38 | |||
| 39 | CLONE_SKB="clone_skb 1000000" | ||
| 40 | # NIC adds 4 bytes CRC | ||
| 41 | PKT_SIZE="pkt_size 60" | ||
| 42 | |||
| 43 | # COUNT 0 means forever | ||
| 44 | #COUNT="count 0" | ||
| 45 | COUNT="count 10000000" | ||
| 46 | DELAY="delay 0" | ||
| 47 | |||
| 48 | PGDEV=/proc/net/pktgen/eth1 | ||
| 49 | echo "Configuring $PGDEV" | ||
| 50 | pgset "$COUNT" | ||
| 51 | pgset "$CLONE_SKB" | ||
| 52 | pgset "$PKT_SIZE" | ||
| 53 | pgset "$DELAY" | ||
| 54 | pgset "dst 10.10.11.2" | ||
| 55 | pgset "dst_mac 00:04:23:08:91:dc" | ||
| 56 | |||
| 57 | PGDEV=/proc/net/pktgen/eth2 | ||
| 58 | echo "Configuring $PGDEV" | ||
| 59 | pgset "$COUNT" | ||
| 60 | pgset "$CLONE_SKB" | ||
| 61 | pgset "$PKT_SIZE" | ||
| 62 | pgset "$DELAY" | ||
| 63 | pgset "dst 192.168.2.2" | ||
| 64 | pgset "dst_mac 00:04:23:08:91:de" | ||
| 65 | |||
| 66 | # Time to run | ||
| 67 | PGDEV=/proc/net/pktgen/pgctrl | ||
| 68 | |||
| 69 | echo "Running... ctrl^C to stop" | ||
| 70 | trap true INT | ||
| 71 | pgset "start" | ||
| 72 | echo "Done" | ||
| 73 | cat /proc/net/pktgen/eth1 /proc/net/pktgen/eth2 | ||
diff --git a/samples/pktgen/pktgen_sample02_multiqueue.sh b/samples/pktgen/pktgen_sample02_multiqueue.sh new file mode 100755 index 000000000000..32467aea8e47 --- /dev/null +++ b/samples/pktgen/pktgen_sample02_multiqueue.sh | |||
| @@ -0,0 +1,75 @@ | |||
| 1 | #!/bin/bash | ||
| 2 | # | ||
| 3 | # Multiqueue: Using pktgen threads for sending on multiple CPUs | ||
| 4 | # * adding devices to kernel threads | ||
| 5 | # * notice the naming scheme for keeping device names unique | ||
| 6 | # * nameing scheme: dev@thread_number | ||
| 7 | # * flow variation via random UDP source port | ||
| 8 | # | ||
| 9 | basedir=`dirname $0` | ||
| 10 | source ${basedir}/functions.sh | ||
| 11 | root_check_run_with_sudo "$@" | ||
| 12 | # | ||
| 13 | # Required param: -i dev in $DEV | ||
| 14 | source ${basedir}/parameters.sh | ||
| 15 | |||
| 16 | # Base Config | ||
| 17 | DELAY="0" # Zero means max speed | ||
| 18 | COUNT="100000" # Zero means indefinitely | ||
| 19 | [ -z "$CLONE_SKB" ] && CLONE_SKB="0" | ||
| 20 | |||
| 21 | # Flow variation random source port between min and max | ||
| 22 | UDP_MIN=9 | ||
| 23 | UDP_MAX=109 | ||
| 24 | |||
| 25 | # (example of setting default params in your script) | ||
| 26 | [ -z "$DEST_IP" ] && DEST_IP="198.18.0.42" | ||
| 27 | [ -z "$DST_MAC" ] && DST_MAC="90:e2:ba:ff:ff:ff" | ||
| 28 | |||
| 29 | # General cleanup everything since last run | ||
| 30 | pg_ctrl "reset" | ||
| 31 | |||
| 32 | # Threads are specified with parameter -t value in $THREADS | ||
| 33 | for ((thread = 0; thread < $THREADS; thread++)); do | ||
| 34 | # The device name is extended with @name, using thread number to | ||
| 35 | # make then unique, but any name will do. | ||
| 36 | dev=${DEV}@${thread} | ||
| 37 | |||
| 38 | # Add remove all other devices and add_device $dev to thread | ||
| 39 | pg_thread $thread "rem_device_all" | ||
| 40 | pg_thread $thread "add_device" $dev | ||
| 41 | |||
| 42 | # Notice config queue to map to cpu (mirrors smp_processor_id()) | ||
| 43 | # It is beneficial to map IRQ /proc/irq/*/smp_affinity 1:1 to CPU number | ||
| 44 | pg_set $dev "flag QUEUE_MAP_CPU" | ||
| 45 | |||
| 46 | # Base config of dev | ||
| 47 | pg_set $dev "count $COUNT" | ||
| 48 | pg_set $dev "clone_skb $CLONE_SKB" | ||
| 49 | pg_set $dev "pkt_size $PKT_SIZE" | ||
| 50 | pg_set $dev "delay $DELAY" | ||
| 51 | |||
| 52 | # Flag example disabling timestamping | ||
| 53 | pg_set $dev "flag NO_TIMESTAMP" | ||
| 54 | |||
| 55 | # Destination | ||
| 56 | pg_set $dev "dst_mac $DST_MAC" | ||
| 57 | pg_set $dev "dst $DEST_IP" | ||
| 58 | |||
| 59 | # Setup random UDP port src range | ||
| 60 | pg_set $dev "flag UDPSRC_RND" | ||
| 61 | pg_set $dev "udp_src_min $UDP_MIN" | ||
| 62 | pg_set $dev "udp_src_max $UDP_MAX" | ||
| 63 | done | ||
| 64 | |||
| 65 | # start_run | ||
| 66 | echo "Running... ctrl^C to stop" >&2 | ||
| 67 | pg_ctrl "start" | ||
| 68 | echo "Done" >&2 | ||
| 69 | |||
| 70 | # Print results | ||
| 71 | for ((thread = 0; thread < $THREADS; thread++)); do | ||
| 72 | dev=${DEV}@${thread} | ||
| 73 | echo "Device: $dev" | ||
| 74 | cat /proc/net/pktgen/$dev | grep -A2 "Result:" | ||
| 75 | done | ||
