pktgen_bench_xmit_mode_netif_receive.sh 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. #
  4. # Benchmark script:
  5. # - developed for benchmarking ingress qdisc path
  6. #
  7. # Script for injecting packets into RX path of the stack with pktgen
  8. # "xmit_mode netif_receive". With an invalid dst_mac this will only
  9. # measure the ingress code path as packets gets dropped in ip_rcv().
  10. #
  11. # This script don't really need any hardware. It benchmarks software
  12. # RX path just after NIC driver level. With bursting is also
  13. # "removes" the SKB alloc/free overhead.
  14. #
  15. # Setup scenarios for measuring ingress qdisc (with invalid dst_mac):
  16. # ------------------------------------------------------------------
  17. # (1) no ingress (uses static_key_false(&ingress_needed))
  18. #
  19. # (2) ingress on other dev (change ingress_needed and calls
  20. # handle_ing() but exit early)
  21. #
  22. # config: tc qdisc add dev $SOMEDEV handle ffff: ingress
  23. #
  24. # (3) ingress on this dev, handle_ing() -> tc_classify()
  25. #
  26. # config: tc qdisc add dev $DEV handle ffff: ingress
  27. #
  28. # (4) ingress on this dev + drop at u32 classifier/action.
  29. #
  30. basedir=`dirname $0`
  31. source ${basedir}/functions.sh
  32. root_check_run_with_sudo "$@"
  33. # Parameter parsing via include
  34. source ${basedir}/parameters.sh
  35. # Using invalid DST_MAC will cause the packets to get dropped in
  36. # ip_rcv() which is part of the test
  37. if [ -z "$DEST_IP" ]; then
  38. [ -z "$IP6" ] && DEST_IP="198.18.0.42" || DEST_IP="FD00::1"
  39. fi
  40. [ -z "$DST_MAC" ] && DST_MAC="90:e2:ba:ff:ff:ff"
  41. [ -z "$BURST" ] && BURST=1024
  42. [ -z "$COUNT" ] && COUNT="10000000" # Zero means indefinitely
  43. # Base Config
  44. DELAY="0" # Zero means max speed
  45. # General cleanup everything since last run
  46. pg_ctrl "reset"
  47. # Threads are specified with parameter -t value in $THREADS
  48. for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
  49. # The device name is extended with @name, using thread number to
  50. # make then unique, but any name will do.
  51. dev=${DEV}@${thread}
  52. # Add remove all other devices and add_device $dev to thread
  53. pg_thread $thread "rem_device_all"
  54. pg_thread $thread "add_device" $dev
  55. # Base config of dev
  56. pg_set $dev "flag QUEUE_MAP_CPU"
  57. pg_set $dev "count $COUNT"
  58. pg_set $dev "pkt_size $PKT_SIZE"
  59. pg_set $dev "delay $DELAY"
  60. pg_set $dev "flag NO_TIMESTAMP"
  61. # Destination
  62. pg_set $dev "dst_mac $DST_MAC"
  63. pg_set $dev "dst$IP6 $DEST_IP"
  64. # Inject packet into RX path of stack
  65. pg_set $dev "xmit_mode netif_receive"
  66. # Burst allow us to avoid measuring SKB alloc/free overhead
  67. pg_set $dev "burst $BURST"
  68. done
  69. # start_run
  70. echo "Running... ctrl^C to stop" >&2
  71. pg_ctrl "start"
  72. echo "Done" >&2
  73. # Print results
  74. for ((thread = $F_THREAD; thread <= $L_THREAD; thread++)); do
  75. dev=${DEV}@${thread}
  76. echo "Device: $dev"
  77. cat /proc/net/pktgen/$dev | grep -A2 "Result:"
  78. done