aboutsummaryrefslogtreecommitdiffstats
path: root/net/batman-adv
diff options
context:
space:
mode:
authorAntonio Quartulli <ordex@autistici.org>2011-07-07 09:35:36 -0400
committerMarek Lindner <lindner_marek@yahoo.de>2011-08-22 09:16:20 -0400
commit59b699cdee039d75915c354da06937102d1f9a84 (patch)
tree33fabd9cac27cb7bc1d3fbc765f098b5b8e8575e /net/batman-adv
parentbc2790808a7a3699a7c9f72f7ad225c8504824aa (diff)
batman-adv: implement AP-isolation on the receiver side
When a node receives a unicast packet it checks if the source and the destination client can communicate or not due to the AP isolation Signed-off-by: Antonio Quartulli <ordex@autistici.org> Signed-off-by: Marek Lindner <lindner_marek@yahoo.de>
Diffstat (limited to 'net/batman-adv')
-rw-r--r--net/batman-adv/bat_sysfs.c2
-rw-r--r--net/batman-adv/soft-interface.c4
-rw-r--r--net/batman-adv/translation-table.c42
-rw-r--r--net/batman-adv/translation-table.h1
-rw-r--r--net/batman-adv/types.h1
5 files changed, 50 insertions, 0 deletions
diff --git a/net/batman-adv/bat_sysfs.c b/net/batman-adv/bat_sysfs.c
index cd15deba60a1..b8a7414c3571 100644
--- a/net/batman-adv/bat_sysfs.c
+++ b/net/batman-adv/bat_sysfs.c
@@ -380,6 +380,7 @@ static ssize_t store_gw_bwidth(struct kobject *kobj, struct attribute *attr,
380BAT_ATTR_BOOL(aggregated_ogms, S_IRUGO | S_IWUSR, NULL); 380BAT_ATTR_BOOL(aggregated_ogms, S_IRUGO | S_IWUSR, NULL);
381BAT_ATTR_BOOL(bonding, S_IRUGO | S_IWUSR, NULL); 381BAT_ATTR_BOOL(bonding, S_IRUGO | S_IWUSR, NULL);
382BAT_ATTR_BOOL(fragmentation, S_IRUGO | S_IWUSR, update_min_mtu); 382BAT_ATTR_BOOL(fragmentation, S_IRUGO | S_IWUSR, update_min_mtu);
383BAT_ATTR_BOOL(ap_isolation, S_IRUGO | S_IWUSR, NULL);
383static BAT_ATTR(vis_mode, S_IRUGO | S_IWUSR, show_vis_mode, store_vis_mode); 384static BAT_ATTR(vis_mode, S_IRUGO | S_IWUSR, show_vis_mode, store_vis_mode);
384static BAT_ATTR(gw_mode, S_IRUGO | S_IWUSR, show_gw_mode, store_gw_mode); 385static BAT_ATTR(gw_mode, S_IRUGO | S_IWUSR, show_gw_mode, store_gw_mode);
385BAT_ATTR_UINT(orig_interval, S_IRUGO | S_IWUSR, 2 * JITTER, INT_MAX, NULL); 386BAT_ATTR_UINT(orig_interval, S_IRUGO | S_IWUSR, 2 * JITTER, INT_MAX, NULL);
@@ -396,6 +397,7 @@ static struct bat_attribute *mesh_attrs[] = {
396 &bat_attr_aggregated_ogms, 397 &bat_attr_aggregated_ogms,
397 &bat_attr_bonding, 398 &bat_attr_bonding,
398 &bat_attr_fragmentation, 399 &bat_attr_fragmentation,
400 &bat_attr_ap_isolation,
399 &bat_attr_vis_mode, 401 &bat_attr_vis_mode,
400 &bat_attr_gw_mode, 402 &bat_attr_gw_mode,
401 &bat_attr_orig_interval, 403 &bat_attr_orig_interval,
diff --git a/net/batman-adv/soft-interface.c b/net/batman-adv/soft-interface.c
index 6deed44a3703..9addbab52999 100644
--- a/net/batman-adv/soft-interface.c
+++ b/net/batman-adv/soft-interface.c
@@ -739,6 +739,9 @@ void interface_rx(struct net_device *soft_iface,
739 739
740 soft_iface->last_rx = jiffies; 740 soft_iface->last_rx = jiffies;
741 741
742 if (is_ap_isolated(bat_priv, ethhdr->h_source, ethhdr->h_dest))
743 goto dropped;
744
742 netif_rx(skb); 745 netif_rx(skb);
743 goto out; 746 goto out;
744 747
@@ -812,6 +815,7 @@ struct net_device *softif_create(const char *name)
812 815
813 atomic_set(&bat_priv->aggregated_ogms, 1); 816 atomic_set(&bat_priv->aggregated_ogms, 1);
814 atomic_set(&bat_priv->bonding, 0); 817 atomic_set(&bat_priv->bonding, 0);
818 atomic_set(&bat_priv->ap_isolation, 0);
815 atomic_set(&bat_priv->vis_mode, VIS_TYPE_CLIENT_UPDATE); 819 atomic_set(&bat_priv->vis_mode, VIS_TYPE_CLIENT_UPDATE);
816 atomic_set(&bat_priv->gw_mode, GW_MODE_OFF); 820 atomic_set(&bat_priv->gw_mode, GW_MODE_OFF);
817 atomic_set(&bat_priv->gw_sel_class, 20); 821 atomic_set(&bat_priv->gw_sel_class, 20);
diff --git a/net/batman-adv/translation-table.c b/net/batman-adv/translation-table.c
index d6305645e08d..d0ed931ad2e7 100644
--- a/net/batman-adv/translation-table.c
+++ b/net/batman-adv/translation-table.c
@@ -781,6 +781,18 @@ static void tt_global_table_free(struct bat_priv *bat_priv)
781 bat_priv->tt_global_hash = NULL; 781 bat_priv->tt_global_hash = NULL;
782} 782}
783 783
784static bool _is_ap_isolated(struct tt_local_entry *tt_local_entry,
785 struct tt_global_entry *tt_global_entry)
786{
787 bool ret = false;
788
789 if (tt_local_entry->flags & TT_CLIENT_WIFI &&
790 tt_global_entry->flags & TT_CLIENT_WIFI)
791 ret = true;
792
793 return ret;
794}
795
784struct orig_node *transtable_search(struct bat_priv *bat_priv, 796struct orig_node *transtable_search(struct bat_priv *bat_priv,
785 const uint8_t *addr) 797 const uint8_t *addr)
786{ 798{
@@ -1729,3 +1741,33 @@ void tt_commit_changes(struct bat_priv *bat_priv)
1729 atomic_inc(&bat_priv->ttvn); 1741 atomic_inc(&bat_priv->ttvn);
1730 bat_priv->tt_poss_change = false; 1742 bat_priv->tt_poss_change = false;
1731} 1743}
1744
1745bool is_ap_isolated(struct bat_priv *bat_priv, uint8_t *src, uint8_t *dst)
1746{
1747 struct tt_local_entry *tt_local_entry = NULL;
1748 struct tt_global_entry *tt_global_entry = NULL;
1749 bool ret = true;
1750
1751 if (!atomic_read(&bat_priv->ap_isolation))
1752 return false;
1753
1754 tt_local_entry = tt_local_hash_find(bat_priv, dst);
1755 if (!tt_local_entry)
1756 goto out;
1757
1758 tt_global_entry = tt_global_hash_find(bat_priv, src);
1759 if (!tt_global_entry)
1760 goto out;
1761
1762 if (_is_ap_isolated(tt_local_entry, tt_global_entry))
1763 goto out;
1764
1765 ret = false;
1766
1767out:
1768 if (tt_global_entry)
1769 tt_global_entry_free_ref(tt_global_entry);
1770 if (tt_local_entry)
1771 tt_local_entry_free_ref(tt_local_entry);
1772 return ret;
1773}
diff --git a/net/batman-adv/translation-table.h b/net/batman-adv/translation-table.h
index 4d1ca35c6818..f1d148ef0e36 100644
--- a/net/batman-adv/translation-table.h
+++ b/net/batman-adv/translation-table.h
@@ -63,5 +63,6 @@ void handle_tt_response(struct bat_priv *bat_priv,
63void send_roam_adv(struct bat_priv *bat_priv, uint8_t *client, 63void send_roam_adv(struct bat_priv *bat_priv, uint8_t *client,
64 struct orig_node *orig_node); 64 struct orig_node *orig_node);
65void tt_commit_changes(struct bat_priv *bat_priv); 65void tt_commit_changes(struct bat_priv *bat_priv);
66bool is_ap_isolated(struct bat_priv *bat_priv, uint8_t *src, uint8_t *dst);
66 67
67#endif /* _NET_BATMAN_ADV_TRANSLATION_TABLE_H_ */ 68#endif /* _NET_BATMAN_ADV_TRANSLATION_TABLE_H_ */
diff --git a/net/batman-adv/types.h b/net/batman-adv/types.h
index bd0ced8a9a9e..1ae355750511 100644
--- a/net/batman-adv/types.h
+++ b/net/batman-adv/types.h
@@ -146,6 +146,7 @@ struct bat_priv {
146 atomic_t aggregated_ogms; /* boolean */ 146 atomic_t aggregated_ogms; /* boolean */
147 atomic_t bonding; /* boolean */ 147 atomic_t bonding; /* boolean */
148 atomic_t fragmentation; /* boolean */ 148 atomic_t fragmentation; /* boolean */
149 atomic_t ap_isolation; /* boolean */
149 atomic_t vis_mode; /* VIS_TYPE_* */ 150 atomic_t vis_mode; /* VIS_TYPE_* */
150 atomic_t gw_mode; /* GW_MODE_* */ 151 atomic_t gw_mode; /* GW_MODE_* */
151 atomic_t gw_sel_class; /* uint */ 152 atomic_t gw_sel_class; /* uint */