####On redhat5, Why tcpdump could not work on bonding work. OS: redhat 5. There are two 82599 interfaces eth0 and eth1. These two interfaces are used as slave of bond0, eth1 is backup of eth0.
We ping the default gateway on test machine. ping work OK, and tcpdump on bond0 show the icmp request and icmp require packets. while on eth0 only icmp request, and eth1 has no any packet.
It is impossible there is no incoming packet on any physical interface. Why tcpdump could not capture the packets on eth0.
analysis
tcpdump is pf_socket which is based on ptye_all.
linux V2.6.32
In linux v2.6.32, there is bond process before ptye_all, and thus the skb->dev will be change to bond0 from eth0. so when packet arrive ptye_all, ony match incoming dev bond0. we has no chance to capture packet on physical interface eth0.
upstream linux v3.17-rc4
bond related process is moved to dev->rx_handler, Just like the bridge or openvswitch.
Packet will first be processed by ptype_all with skb->dev is eth0 and then rx_handler(bond handler for eth0,eth1). if the rx handler return RX_HANDLER_ANOTHER, the packet arrive by ptye_all again with differentskb->dev (bond0).
2616 int __netif_receive_skb(struct sk_buff *skb) 2617 { ... 2636 if (!skb->iif) 2637 skb->iif = skb->dev->ifindex; 2638 2639 /* 2640 * bonding note: skbs received on inactive slaves should only 2641 * be delivered to pkt handlers that are exact matches. Also 2642 * the deliver_no_wcard flag will be set. If packet handlers 2643 * are sensitive to duplicate packets these skbs will need to 2644 * be dropped at the handler. The vlan accel path may have 2645 * already set the deliver_no_wcard flag. 2646 */ 2647 2648 null_or_orig = NULL; 2649 orig_dev = skb->dev; 2650 if (skb->deliver_no_wcard) 2651 null_or_orig = orig_dev; 2652 else if (orig_dev->master) { 2653 if (skb_bond_should_drop(skb)) { 2654 skb->deliver_no_wcard = 1; 2655 null_or_orig = orig_dev; /* deliver only exact match */ 2656 } else 2657 skb->dev = orig_dev->master; 2658 } ... 2677 list_for_each_entry_rcu(ptype, &ptype_all, list) { 2678 if (ptype->dev == null_or_orig || ptype->dev == skb->dev || 2679 ptype->dev == orig_dev) { 2680 if (pt_prev) 2681 ret = deliver_skb(skb, pt_prev, orig_dev); 2682 pt_prev = ptype; 2683 } 2684 }