--- a/net/bridge/br_input.c +++ b/net/bridge/br_input.c @@ -61,7 +61,11 @@ int br_handle_frame_finish(struct sk_buf dst = NULL; - if (is_multicast_ether_addr(dest)) { + if (skb->protocol == htons(ETH_P_PAE)) { + skb2 = skb; + /* Do not forward 802.1x/EAP frames */ + skb = NULL; + } else if (is_multicast_ether_addr(dest)) { br->dev->stats.multicast++; skb2 = skb; } else if ((dst = __br_fdb_get(br, dest)) && dst->is_local) {