mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-25 13:14:07 +08:00
batman-adv: implement AP-isolation on the sender side
If a node has to send a packet issued by a WIFI client to another WIFI client, the packet is dropped. Signed-off-by: Antonio Quartulli <ordex@autistici.org> Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
This commit is contained in:
parent
59b699cdee
commit
3d393e4732
@ -1535,7 +1535,7 @@ static int check_unicast_ttvn(struct bat_priv *bat_priv,
|
|||||||
|
|
||||||
ethhdr = (struct ethhdr *)(skb->data +
|
ethhdr = (struct ethhdr *)(skb->data +
|
||||||
sizeof(struct unicast_packet));
|
sizeof(struct unicast_packet));
|
||||||
orig_node = transtable_search(bat_priv, ethhdr->h_dest);
|
orig_node = transtable_search(bat_priv, NULL, ethhdr->h_dest);
|
||||||
|
|
||||||
if (!orig_node) {
|
if (!orig_node) {
|
||||||
if (!is_my_client(bat_priv, ethhdr->h_dest))
|
if (!is_my_client(bat_priv, ethhdr->h_dest))
|
||||||
|
@ -597,7 +597,8 @@ static int interface_tx(struct sk_buff *skb, struct net_device *soft_iface)
|
|||||||
/* Register the client MAC in the transtable */
|
/* Register the client MAC in the transtable */
|
||||||
tt_local_add(soft_iface, ethhdr->h_source, skb->skb_iif);
|
tt_local_add(soft_iface, ethhdr->h_source, skb->skb_iif);
|
||||||
|
|
||||||
orig_node = transtable_search(bat_priv, ethhdr->h_dest);
|
orig_node = transtable_search(bat_priv, ethhdr->h_source,
|
||||||
|
ethhdr->h_dest);
|
||||||
if (is_multicast_ether_addr(ethhdr->h_dest) ||
|
if (is_multicast_ether_addr(ethhdr->h_dest) ||
|
||||||
(orig_node && orig_node->gw_flags)) {
|
(orig_node && orig_node->gw_flags)) {
|
||||||
ret = gw_is_target(bat_priv, skb, orig_node);
|
ret = gw_is_target(bat_priv, skb, orig_node);
|
||||||
|
@ -794,29 +794,43 @@ static bool _is_ap_isolated(struct tt_local_entry *tt_local_entry,
|
|||||||
}
|
}
|
||||||
|
|
||||||
struct orig_node *transtable_search(struct bat_priv *bat_priv,
|
struct orig_node *transtable_search(struct bat_priv *bat_priv,
|
||||||
const uint8_t *addr)
|
const uint8_t *src, const uint8_t *addr)
|
||||||
{
|
{
|
||||||
struct tt_global_entry *tt_global_entry;
|
struct tt_local_entry *tt_local_entry = NULL;
|
||||||
|
struct tt_global_entry *tt_global_entry = NULL;
|
||||||
struct orig_node *orig_node = NULL;
|
struct orig_node *orig_node = NULL;
|
||||||
|
|
||||||
tt_global_entry = tt_global_hash_find(bat_priv, addr);
|
if (src && atomic_read(&bat_priv->ap_isolation)) {
|
||||||
|
tt_local_entry = tt_local_hash_find(bat_priv, src);
|
||||||
|
if (!tt_local_entry)
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
tt_global_entry = tt_global_hash_find(bat_priv, addr);
|
||||||
if (!tt_global_entry)
|
if (!tt_global_entry)
|
||||||
goto out;
|
goto out;
|
||||||
|
|
||||||
|
/* check whether the clients should not communicate due to AP
|
||||||
|
* isolation */
|
||||||
|
if (tt_local_entry && _is_ap_isolated(tt_local_entry, tt_global_entry))
|
||||||
|
goto out;
|
||||||
|
|
||||||
if (!atomic_inc_not_zero(&tt_global_entry->orig_node->refcount))
|
if (!atomic_inc_not_zero(&tt_global_entry->orig_node->refcount))
|
||||||
goto free_tt;
|
goto out;
|
||||||
|
|
||||||
/* A global client marked as PENDING has already moved from that
|
/* A global client marked as PENDING has already moved from that
|
||||||
* originator */
|
* originator */
|
||||||
if (tt_global_entry->flags & TT_CLIENT_PENDING)
|
if (tt_global_entry->flags & TT_CLIENT_PENDING)
|
||||||
goto free_tt;
|
goto out;
|
||||||
|
|
||||||
orig_node = tt_global_entry->orig_node;
|
orig_node = tt_global_entry->orig_node;
|
||||||
|
|
||||||
free_tt:
|
|
||||||
tt_global_entry_free_ref(tt_global_entry);
|
|
||||||
out:
|
out:
|
||||||
|
if (tt_global_entry)
|
||||||
|
tt_global_entry_free_ref(tt_global_entry);
|
||||||
|
if (tt_local_entry)
|
||||||
|
tt_local_entry_free_ref(tt_local_entry);
|
||||||
|
|
||||||
return orig_node;
|
return orig_node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -43,7 +43,7 @@ void tt_global_del(struct bat_priv *bat_priv,
|
|||||||
struct orig_node *orig_node, const unsigned char *addr,
|
struct orig_node *orig_node, const unsigned char *addr,
|
||||||
const char *message, bool roaming);
|
const char *message, bool roaming);
|
||||||
struct orig_node *transtable_search(struct bat_priv *bat_priv,
|
struct orig_node *transtable_search(struct bat_priv *bat_priv,
|
||||||
const uint8_t *addr);
|
const uint8_t *src, const uint8_t *addr);
|
||||||
void tt_save_orig_buffer(struct bat_priv *bat_priv, struct orig_node *orig_node,
|
void tt_save_orig_buffer(struct bat_priv *bat_priv, struct orig_node *orig_node,
|
||||||
const unsigned char *tt_buff, uint8_t tt_num_changes);
|
const unsigned char *tt_buff, uint8_t tt_num_changes);
|
||||||
uint16_t tt_local_crc(struct bat_priv *bat_priv);
|
uint16_t tt_local_crc(struct bat_priv *bat_priv);
|
||||||
|
@ -299,8 +299,10 @@ int unicast_send_skb(struct sk_buff *skb, struct bat_priv *bat_priv)
|
|||||||
goto find_router;
|
goto find_router;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* check for tt host - increases orig_node refcount */
|
/* check for tt host - increases orig_node refcount.
|
||||||
orig_node = transtable_search(bat_priv, ethhdr->h_dest);
|
* returns NULL in case of AP isolation */
|
||||||
|
orig_node = transtable_search(bat_priv, ethhdr->h_source,
|
||||||
|
ethhdr->h_dest);
|
||||||
|
|
||||||
find_router:
|
find_router:
|
||||||
/**
|
/**
|
||||||
|
Loading…
Reference in New Issue
Block a user