Commit 6c882bdc authored by Juhee Kang's avatar Juhee Kang Committed by David S. Miller

samples: pktgen: add trap SIGINT for printing execution result

All pktgen samples can send indefinitely num messages per thread by
setting the count option to 0(-n 0). If running sample with setting
count 0 and press Ctrl-C to stop this program, the program prints the
result of the execution so far. Currently, the samples besides
sample{3...5} don't work properly. Because Ctrl-C stops the script, not
just pktgen.

This is results of samples:

    # DEV=eth0 DEST_IP=10.1.0.1 DST_MAC=00:11:22:33:44:55 ./pktgen_sample04_many_flows.sh -n 0
    Running... ctrl^C to stop
    ^CDevice: eth0@0
    Result: OK: 569657(c569538+d118) usec, 84650 (60byte,0frags)
    148597pps 71Mb/sec (71326560bps) errors: 0

    # DEV=eth0 DEST_IP=10.1.0.1 DST_MAC=00:11:22:33:44:55 ./pktgen_sample01_simple.sh -n 0
    Running... ctrl^C to stop
    ^C

In order to solve this, this commit adds trap SIGINT. Also, this commit
changes control_c function to print_result to maintain consistency with
other samples.
Signed-off-by: default avatarJuhee Kang <claudiajkang@gmail.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent c0e9422c
...@@ -89,14 +89,21 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do ...@@ -89,14 +89,21 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
pg_set $dev "burst $BURST" pg_set $dev "burst $BURST"
done done
# Run if user hits control-c
function print_result() {
# Print results
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
dev=${DEV}@${thread}
echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done
}
# trap keyboard interrupt (Ctrl-C)
trap true SIGINT
# start_run # start_run
echo "Running... ctrl^C to stop" >&2 echo "Running... ctrl^C to stop" >&2
pg_ctrl "start" pg_ctrl "start"
echo "Done" >&2 echo "Done" >&2
# Print results print_result
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
dev=${DEV}@${thread}
echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done
...@@ -69,14 +69,21 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do ...@@ -69,14 +69,21 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
pg_set $dev "xmit_mode queue_xmit" pg_set $dev "xmit_mode queue_xmit"
done done
# Run if user hits control-c
function print_result {
# Print results
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
dev=${DEV}@${thread}
echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done
}
# trap keyboard interrupt (Ctrl-C)
trap true SIGINT
# start_run # start_run
echo "Running... ctrl^C to stop" >&2 echo "Running... ctrl^C to stop" >&2
pg_ctrl "start" pg_ctrl "start"
echo "Done" >&2 echo "Done" >&2
# Print results print_result
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
dev=${DEV}@${thread}
echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done
...@@ -79,15 +79,22 @@ pg_set $DEV "flag UDPSRC_RND" ...@@ -79,15 +79,22 @@ pg_set $DEV "flag UDPSRC_RND"
pg_set $DEV "udp_src_min $UDP_SRC_MIN" pg_set $DEV "udp_src_min $UDP_SRC_MIN"
pg_set $DEV "udp_src_max $UDP_SRC_MAX" pg_set $DEV "udp_src_max $UDP_SRC_MAX"
# Run if user hits control-c
function print_result() {
# Print results
echo "Result device: $DEV"
cat /proc/net/pktgen/$DEV
}
# trap keyboard interrupt (Ctrl-C)
trap true SIGINT
if [ -z "$APPEND" ]; then if [ -z "$APPEND" ]; then
# start_run # start_run
echo "Running... ctrl^C to stop" >&2 echo "Running... ctrl^C to stop" >&2
pg_ctrl "start" pg_ctrl "start"
echo "Done" >&2 echo "Done" >&2
# Print results print_result
echo "Result device: $DEV"
cat /proc/net/pktgen/$DEV
else else
echo "Append mode: config done. Do more or use 'pg_ctrl start' to run" echo "Append mode: config done. Do more or use 'pg_ctrl start' to run"
fi fi
\ No newline at end of file
...@@ -83,18 +83,25 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do ...@@ -83,18 +83,25 @@ for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
pg_set $dev "udp_src_max $UDP_SRC_MAX" pg_set $dev "udp_src_max $UDP_SRC_MAX"
done done
if [ -z "$APPEND" ]; then # Run if user hits control-c
# start_run function print_result() {
echo "Running... ctrl^C to stop" >&2
pg_ctrl "start"
echo "Done" >&2
# Print results # Print results
for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
dev=${DEV}@${thread} dev=${DEV}@${thread}
echo "Device: $dev" echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:" cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done done
}
# trap keyboard interrupt (Ctrl-C)
trap true SIGINT
if [ -z "$APPEND" ]; then
# start_run
echo "Running... ctrl^C to stop" >&2
pg_ctrl "start"
echo "Done" >&2
print_result
else else
echo "Append mode: config done. Do more or use 'pg_ctrl start' to run" echo "Append mode: config done. Do more or use 'pg_ctrl start' to run"
fi fi
...@@ -100,12 +100,8 @@ for ((i = 0; i < $THREADS; i++)); do ...@@ -100,12 +100,8 @@ for ((i = 0; i < $THREADS; i++)); do
pg_set $dev "udp_src_max $UDP_SRC_MAX" pg_set $dev "udp_src_max $UDP_SRC_MAX"
done done
# start_run # Run if user hits control-c
if [ -z "$APPEND" ]; then function print_result() {
echo "Running... ctrl^C to stop" >&2
pg_ctrl "start"
echo "Done" >&2
# Print results # Print results
for ((i = 0; i < $THREADS; i++)); do for ((i = 0; i < $THREADS; i++)); do
thread=${cpu_array[$((i+F_THREAD))]} thread=${cpu_array[$((i+F_THREAD))]}
...@@ -113,6 +109,17 @@ if [ -z "$APPEND" ]; then ...@@ -113,6 +109,17 @@ if [ -z "$APPEND" ]; then
echo "Device: $dev" echo "Device: $dev"
cat /proc/net/pktgen/$dev | grep -A2 "Result:" cat /proc/net/pktgen/$dev | grep -A2 "Result:"
done done
}
# trap keyboard interrupt (Ctrl-C)
trap true SIGINT
# start_run
if [ -z "$APPEND" ]; then
echo "Running... ctrl^C to stop" >&2
pg_ctrl "start"
echo "Done" >&2
print_result
else else
echo "Append mode: config done. Do more or use 'pg_ctrl start' to run" echo "Append mode: config done. Do more or use 'pg_ctrl start' to run"
fi fi
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment