test_ingress_egress_chaining.sh 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. #!/bin/bash
  2. # SPDX-License-Identifier: GPL-2.0
  3. # This test runs a simple ingress tc setup between two veth pairs,
  4. # and chains a single egress rule to test ingress chaining to egress.
  5. #
  6. # Kselftest framework requirement - SKIP code is 4.
  7. ksft_skip=4
  8. if [ "$(id -u)" -ne 0 ];then
  9. echo "SKIP: Need root privileges"
  10. exit $ksft_skip
  11. fi
  12. needed_mods="act_mirred cls_flower sch_ingress"
  13. for mod in $needed_mods; do
  14. modinfo $mod &>/dev/null || { echo "SKIP: Need act_mirred module"; exit $ksft_skip; }
  15. done
  16. ns="ns$((RANDOM%899+100))"
  17. veth1="veth1$((RANDOM%899+100))"
  18. veth2="veth2$((RANDOM%899+100))"
  19. peer1="peer1$((RANDOM%899+100))"
  20. peer2="peer2$((RANDOM%899+100))"
  21. ip_peer1=198.51.100.5
  22. ip_peer2=198.51.100.6
  23. function fail() {
  24. echo "FAIL: $@" >> /dev/stderr
  25. exit 1
  26. }
  27. function cleanup() {
  28. killall -q -9 udpgso_bench_rx
  29. ip link del $veth1 &> /dev/null
  30. ip link del $veth2 &> /dev/null
  31. ip netns del $ns &> /dev/null
  32. }
  33. trap cleanup EXIT
  34. function config() {
  35. echo "Setup veth pairs [$veth1, $peer1], and veth pair [$veth2, $peer2]"
  36. ip link add $veth1 type veth peer name $peer1
  37. ip link add $veth2 type veth peer name $peer2
  38. ip addr add $ip_peer1/24 dev $peer1
  39. ip link set $peer1 up
  40. ip netns add $ns
  41. ip link set dev $peer2 netns $ns
  42. ip netns exec $ns ip addr add $ip_peer2/24 dev $peer2
  43. ip netns exec $ns ip link set $peer2 up
  44. ip link set $veth1 up
  45. ip link set $veth2 up
  46. echo "Add tc filter ingress->egress forwarding $veth1 <-> $veth2"
  47. tc qdisc add dev $veth2 ingress
  48. tc qdisc add dev $veth1 ingress
  49. tc filter add dev $veth2 ingress prio 1 proto all flower \
  50. action mirred egress redirect dev $veth1
  51. tc filter add dev $veth1 ingress prio 1 proto all flower \
  52. action mirred egress redirect dev $veth2
  53. echo "Add tc filter egress->ingress forwarding $peer1 -> $veth1, bypassing the veth pipe"
  54. tc qdisc add dev $peer1 clsact
  55. tc filter add dev $peer1 egress prio 20 proto ip flower \
  56. action mirred ingress redirect dev $veth1
  57. }
  58. function test_run() {
  59. echo "Run tcp traffic"
  60. ./udpgso_bench_rx -t &
  61. sleep 1
  62. ip netns exec $ns timeout -k 2 10 ./udpgso_bench_tx -t -l 2 -4 -D $ip_peer1 || fail "traffic failed"
  63. echo "Test passed"
  64. }
  65. config
  66. test_run
  67. trap - EXIT
  68. cleanup