Track and print rule source in drop prints
[flowspec-xdp] / dropcount.sh
index 3cfc4ab922c4bba79a3074104aa34a7560ffaf38..4d5a74e2651284cb37fde23053c3c6a5dc26025d 100755 (executable)
@@ -1,29 +1,38 @@
-#!/bin/sh
-KEY=""
+#!/bin/bash
+function PRINTCNT() {
+if [ "$KEY" != "" ]; then
+       if [ "$KEY" = "0" ]; then
+               echo -e "$CNT:\tInvalid packet length"
+       elif [ "$KEY" = "1" ]; then
+               echo -e "$CNT:\tInvalid VLAN tag"
+       elif [ "$KEY" = "2" ]; then
+               echo -e "$CNT:\tInvalid/rejected IHL IPv4 field"
+       elif [ "$KEY" = "3" ]; then
+               echo -e "$CNT:\tRejected IPv6 fragments"
+       else
+               echo -en "$CNT:\t"
+               cat "$(dirname ${BASH_SOURCE[0]})/installed-rules.txt" | head -n $(( $KEY - 3 )) | tail -n1
+       fi
+fi
 CNT=0
-bpftool map dump id "$(bpftool map show | grep drop_cnt_map | awk '{ print $1 }' | tr -d ':')" | while read LINE; do
-       case "$LINE" in
-               "key:") ;;
-               "value"*)
-                       CNT=$(( $CNT + $(echo "$LINE" | awk '{ print "0x" $11 $10 $9 $8 $7 $6 $5 $4 }') ))
-                       ;;
-               "Found "*) ;;
-               *)
-                       if [ "$KEY" != "" ]; then
-                               if [ "$KEY" = "0x00000000" ]; then
-                                       echo "Invalid packet length: $CNT"
-                               elif [ "$KEY" = "0x00000001" ]; then
-                                       echo "Invalid VLAN tag: $CNT"
-                               elif [ "$KEY" = "0x00000002" ]; then
-                                       echo "Invalid/rejected IHL IPv4 field: $CNT"
-                               elif [ "$KEY" = "0x00000003" ]; then
-                                       echo "Rejected IPv6 fragments: $CNT"
-                               else
-                                       echo "$KEY: $CNT"
-                               fi
-                       fi
-                       KEY=$(echo "$LINE" | awk '{ print "0x" $4 $3 $2 $1 }')
-                       CNT=0
-                       ;;
-       esac
+}
+bpftool map show | grep drop_cnt_map | awk '{ print $1 }' | tr -d ':' | while read IF; do
+       bpftool map dump id "$IF" | {
+               KEY=""
+               CNT=0
+               while read LINE; do
+                       case "$LINE" in
+                               "key:") ;;
+                               "value"*)
+                                       CNT=$(( $CNT + $(echo "$LINE" | awk '{ print "0x" $11 $10 $9 $8 $7 $6 $5 $4 }') ))
+                                       ;;
+                               "Found "*) ;;
+                               *)
+                                       PRINTCNT
+                                       KEY=$((16#$(echo "$LINE" | awk '{ print $4 $3 $2 $1 }')))
+                                       ;;
+                       esac
+               done
+               PRINTCNT
+       }
 done