Repository : ssh://git@open-mesh.org/doc
On branches: backup-redmine/2017-07-13,master
>---------------------------------------------------------------
commit 32871ef30567d8f354590008ddec686736ccd184
Author: Marek Lindner <mareklindner(a)neomailbox.ch>
Date: Mon Jun 21 12:26:39 2010 +0000
doc: batman-adv/Wiki
>---------------------------------------------------------------
32871ef30567d8f354590008ddec686736ccd184
batman-adv/Wiki.textile | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/batman-adv/Wiki.textile b/batman-adv/Wiki.textile
index 577f17db..7ac14a08 100644
--- a/batman-adv/Wiki.textile
+++ b/batman-adv/Wiki.textile
@@ -6,7 +6,7 @@
B.A.T.M.A.N. advanced (often referenced as batman-adv) is an implementation of the B.A.T.M.A.N. routing protocol in form of a linux kernel module operating on layer 2. The rest of this document will explain the conceptual details and their implications. If you are looking for explanations how to use the module, please consult our [wiki:batman-adv-quick-start-guide quick start guide].
-== Layer 2 ? ==
+=== Layer 2 ? ===
Most other wireless routing protocol implementations (e.g. the batman daemon) operate on layer 3 which means they exchange routing information by sending UDP packets and bring their routing decision into effect by manipulating the kernel routing table. Batman-adv operates entirely on ISO/OSI Layer 2 - not only the routing information is transported using raw ethernet frames but also the data traffic is handled by batman-adv. It encapsulates and forwards all traffic until it reaches the destination, hence emulating a virtual network switch of all nodes participating. Therefore all nodes appear to be link local and unaware of the network's topology as well as unaffected by any network changes.
@@ -17,12 +17,12 @@ This design bears some interesting characteristics:
* roaming of non-mesh clients
* optimizing the data flow through the mesh (e.g. interface alternating, multicast, forward error correction, etc)
-== A kernel module ? ==
+=== A kernel module ? ===
A layer 2 routing protocol also has to handle the data traffic because usually one can't route/forward ethernet packets. Processing packets in userland is very expensive in terms of CPU cycles, as each packet has to be read() and write() to the kernel and back, which limits the sustainable bandwidth especially on low-end devices. To have good support for these devices as well, we implemented batman-adv as a kernel driver. It introduces a negligible packet processing overhead even under a high load.
-== batctl ? ==
+=== batctl ? ===
To still have a handy tool to configure & debug the batman-adv kernel module, the batctl tool was developed. It offers a convenient interface to all the module's settings as well as status information. It also contains a layer 2 version of ping, traceroute and tcpdump, since the virtual network switch is completely transparent for all protocols above layer 2.