Skip to content

Commit

Permalink
batman-adv: Drop tt queries with foreign dest
Browse files Browse the repository at this point in the history
When enabling promiscuous mode, tt queries for other hosts might be
received. Before this patch, "foreign" tt queries were processed like
any other query and thus forwarded to its destination again and thereby
causing a loop.

This patch adds a check to drop foreign tt queries.

Signed-off-by: Martin Hundebøll <martin@hundeboll.net>
Signed-off-by: Antonio Quartulli <ordex@autistici.org>
  • Loading branch information
Martin Hundebøll authored and Antonio Quartulli committed Aug 23, 2012
1 parent ff51fd7 commit 74ee363
Showing 1 changed file with 3 additions and 15 deletions.
18 changes: 3 additions & 15 deletions net/batman-adv/routing.c
Original file line number Diff line number Diff line change
Expand Up @@ -609,29 +609,17 @@ int batadv_recv_tt_query(struct sk_buff *skb, struct batadv_hard_iface *recv_if)
struct batadv_priv *bat_priv = netdev_priv(recv_if->soft_iface);
struct batadv_tt_query_packet *tt_query;
uint16_t tt_size;
struct ethhdr *ethhdr;
int hdr_size = sizeof(*tt_query);
char tt_flag;
size_t packet_size;

/* drop packet if it has not necessary minimum size */
if (unlikely(!pskb_may_pull(skb,
sizeof(struct batadv_tt_query_packet))))
goto out;
if (batadv_check_unicast_packet(skb, hdr_size) < 0)
return NET_RX_DROP;

/* I could need to modify it */
if (skb_cow(skb, sizeof(struct batadv_tt_query_packet)) < 0)
goto out;

ethhdr = (struct ethhdr *)skb_mac_header(skb);

/* packet with unicast indication but broadcast recipient */
if (is_broadcast_ether_addr(ethhdr->h_dest))
goto out;

/* packet with broadcast sender address */
if (is_broadcast_ether_addr(ethhdr->h_source))
goto out;

tt_query = (struct batadv_tt_query_packet *)skb->data;

switch (tt_query->flags & BATADV_TT_QUERY_TYPE_MASK) {
Expand Down

0 comments on commit 74ee363

Please sign in to comment.