diff options
| author | Simon Wunderlich <simon.wunderlich@s2003.tu-chemnitz.de> | 2012-01-22 20:00:19 +0100 | 
|---|---|---|
| committer | Antonio Quartulli <ordex@autistici.org> | 2012-04-11 14:28:58 +0200 | 
| commit | 23721387c409087fd3b97e274f34d3ddc0970b74 (patch) | |
| tree | cf386c6f169a1b2b6e8c8ef77be5226e10046689 /Documentation/networking | |
| parent | a7f6ee9493677ba40625d810258de5bd521cc1b0 (diff) | |
batman-adv: add basic bridge loop avoidance code
This second version of the bridge loop avoidance for batman-adv
avoids loops between the mesh and a backbone (usually a LAN).
By connecting multiple batman-adv mesh nodes to the same ethernet
segment a loop can be created when the soft-interface is bridged
into that ethernet segment. A simple visualization of the loop
involving the most common case - a LAN as ethernet segment:
node1  <-- LAN  -->  node2
  |                   |
wifi   <-- mesh -->  wifi
Packets from the LAN (e.g. ARP broadcasts) will circle forever from
node1 or node2 over the mesh back into the LAN.
With this patch, batman recognizes backbone gateways, nodes which are
part of the mesh and backbone/LAN at the same time. Each backbone
gateway "claims" clients from within the mesh to handle them
exclusively. By restricting that only responsible backbone gateways
may handle their claimed clients traffic, loops are effectively
avoided.
Signed-off-by: Simon Wunderlich <siwu@hrz.tu-chemnitz.de>
Signed-off-by: Antonio Quartulli <ordex@autistici.org>
Diffstat (limited to 'Documentation/networking')
| -rw-r--r-- | Documentation/networking/batman-adv.txt | 14 | 
1 files changed, 8 insertions, 6 deletions
| diff --git a/Documentation/networking/batman-adv.txt b/Documentation/networking/batman-adv.txt index 221ad0cdf11..9523e9ed19e 100644 --- a/Documentation/networking/batman-adv.txt +++ b/Documentation/networking/batman-adv.txt @@ -67,10 +67,11 @@ To deactivate an interface you have  to  write  "none"  into  its  All  mesh  wide  settings  can be found in batman's own interface  folder: -#  ls  /sys/class/net/bat0/mesh/ -# aggregated_ogms   fragmentation gw_sel_class   vis_mode -# ap_isolation      gw_bandwidth  hop_penalty -# bonding           gw_mode       orig_interval +# ls /sys/class/net/bat0/mesh/ +# aggregated_ogms        fragmentation          hop_penalty +# ap_isolation           gw_bandwidth           log_level +# bonding                gw_mode                orig_interval +# bridge_loop_avoidance  gw_sel_class           vis_mode  There is a special folder for debugging information: @@ -202,12 +203,13 @@ abled  during run time. Following log_levels are defined:  1 - Enable messages related to routing / flooding / broadcasting  2 - Enable messages related to route added / changed / deleted  4 - Enable messages related to translation table operations -7 - Enable all messages +8 - Enable messages related to bridge loop avoidance +15 - enable all messages  The debug output can be changed at runtime  using  the  file  /sys/class/net/bat0/mesh/log_level. e.g. -# echo 2 > /sys/class/net/bat0/mesh/log_level +# echo 6 > /sys/class/net/bat0/mesh/log_level  will enable debug messages for when routes change. | 
