mirror of
https://github.com/FEX-Emu/linux.git
synced 2025-01-14 21:48:49 +00:00
This feature/cleanup patchset includes the following patches:
- bump version strings, by Simon Wunderlich - Remove unnecessary length qualifier, by Joe Perches - Remove too short %pM field width, by Sven Eckelmann - Remove return value handling from skb_put_data, by Sven Eckelmann - Spelling fixes, by Colin Ian King - Convert batman-adv.txt to reStructuredText, by Sven Eckelmann -----BEGIN PGP SIGNATURE----- iQJKBAABCgA0FiEE1ilQI7G+y+fdhnrfoSvjmEKSnqEFAlmB364WHHN3QHNpbW9u d3VuZGVybGljaC5kZQAKCRChK+OYQpKeoUL9EADc1EFFdHxbJdLbVL/FjkDkrwpL 60exCnDNLZ06g2+XhViA/Lo5VMPjJTYvNVciG4RbphtZPGwpnXLO1mM+1EntzHLl Bkvd8pMS8SbhUIlJ4Ua8ret3GoIf2FLz3tEOr/LGO/aJ5iEOS1N9msI1nYK12E6V 4pgLJiHztoLkoEnsCaB30iF/jxlCXKE+AG2LjD65zUuG95DPR0XGGkgdP0qomlvh kaSG7G4kVCQEsS2W+6TLqC+CKoO3uGGCF1wc4KDD3wgbUU0YCmqhzehrtstCku66 ksNavOy0e0iA3bURo6md/aWWUyOV6wK2uV6QE5ef1gStgXQKYwXa6MzaHVRu8XYZ SrzfwKQRFDZXzouHTNJCNSeNhrPGKXPs6JSjeQDR1hzwZ0e+5xOct/mgp2VgHhqP v4xs0ZFcjOWPZ52Yy0kY0r/f4AKTwS20DJLSQaKEST1E0m4rlzpNUxi+/4T1wUSD LFtXjf9IonS1Weo6Ro5v6x2db4tXuX6pwmlCpfYcAdAK1FFyKIG7HHWw4UV7s85P 5nNbZP/v6K8DsGVVD3I/HEIeoZyi2DnPzYgFeV8pMJy6gYggnu/axdgmd7mgDL3J aCEaL3rvSbkmnmq6QG/pC0VwXmTR9j945uEBjGICmPq1nzV2rvUt7KvEv1MWBH28 Qv5VAUe8XsIiwKMgFA== =3oIU -----END PGP SIGNATURE----- Merge tag 'batadv-next-for-davem-20170802' of git://git.open-mesh.org/linux-merge Simon Wunderlich says: ==================== This feature/cleanup patchset includes the following patches: - bump version strings, by Simon Wunderlich - Remove unnecessary length qualifier, by Joe Perches - Remove too short %pM field width, by Sven Eckelmann - Remove return value handling from skb_put_data, by Sven Eckelmann - Spelling fixes, by Colin Ian King - Convert batman-adv.txt to reStructuredText, by Sven Eckelmann ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
f6c00a3bb8
@ -30,8 +30,6 @@ atm.txt
|
|||||||
- info on where to get ATM programs and support for Linux.
|
- info on where to get ATM programs and support for Linux.
|
||||||
ax25.txt
|
ax25.txt
|
||||||
- info on using AX.25 and NET/ROM code for Linux
|
- info on using AX.25 and NET/ROM code for Linux
|
||||||
batman-adv.txt
|
|
||||||
- B.A.T.M.A.N routing protocol on top of layer 2 Ethernet Frames.
|
|
||||||
baycom.txt
|
baycom.txt
|
||||||
- info on the driver for Baycom style amateur radio modems
|
- info on the driver for Baycom style amateur radio modems
|
||||||
bonding.txt
|
bonding.txt
|
||||||
|
220
Documentation/networking/batman-adv.rst
Normal file
220
Documentation/networking/batman-adv.rst
Normal file
@ -0,0 +1,220 @@
|
|||||||
|
==========
|
||||||
|
batman-adv
|
||||||
|
==========
|
||||||
|
|
||||||
|
Batman advanced is a new approach to wireless networking which does no longer
|
||||||
|
operate on the IP basis. Unlike the batman daemon, which exchanges information
|
||||||
|
using UDP packets and sets routing tables, batman-advanced operates on ISO/OSI
|
||||||
|
Layer 2 only and uses and routes (or better: bridges) Ethernet Frames. It
|
||||||
|
emulates a virtual network switch of all nodes participating. Therefore all
|
||||||
|
nodes appear to be link local, thus all higher operating protocols won't be
|
||||||
|
affected by any changes within the network. You can run almost any protocol
|
||||||
|
above batman advanced, prominent examples are: IPv4, IPv6, DHCP, IPX.
|
||||||
|
|
||||||
|
Batman advanced was implemented as a Linux kernel driver to reduce the overhead
|
||||||
|
to a minimum. It does not depend on any (other) network driver, and can be used
|
||||||
|
on wifi as well as ethernet lan, vpn, etc ... (anything with ethernet-style
|
||||||
|
layer 2).
|
||||||
|
|
||||||
|
|
||||||
|
Configuration
|
||||||
|
=============
|
||||||
|
|
||||||
|
Load the batman-adv module into your kernel::
|
||||||
|
|
||||||
|
$ insmod batman-adv.ko
|
||||||
|
|
||||||
|
The module is now waiting for activation. You must add some interfaces on which
|
||||||
|
batman can operate. After loading the module batman advanced will scan your
|
||||||
|
systems interfaces to search for compatible interfaces. Once found, it will
|
||||||
|
create subfolders in the ``/sys`` directories of each supported interface,
|
||||||
|
e.g.::
|
||||||
|
|
||||||
|
$ ls /sys/class/net/eth0/batman_adv/
|
||||||
|
elp_interval iface_status mesh_iface throughput_override
|
||||||
|
|
||||||
|
If an interface does not have the ``batman_adv`` subfolder, it probably is not
|
||||||
|
supported. Not supported interfaces are: loopback, non-ethernet and batman's
|
||||||
|
own interfaces.
|
||||||
|
|
||||||
|
Note: After the module was loaded it will continuously watch for new
|
||||||
|
interfaces to verify the compatibility. There is no need to reload the module
|
||||||
|
if you plug your USB wifi adapter into your machine after batman advanced was
|
||||||
|
initially loaded.
|
||||||
|
|
||||||
|
The batman-adv soft-interface can be created using the iproute2 tool ``ip``::
|
||||||
|
|
||||||
|
$ ip link add name bat0 type batadv
|
||||||
|
|
||||||
|
To activate a given interface simply attach it to the ``bat0`` interface::
|
||||||
|
|
||||||
|
$ ip link set dev eth0 master bat0
|
||||||
|
|
||||||
|
Repeat this step for all interfaces you wish to add. Now batman starts
|
||||||
|
using/broadcasting on this/these interface(s).
|
||||||
|
|
||||||
|
By reading the "iface_status" file you can check its status::
|
||||||
|
|
||||||
|
$ cat /sys/class/net/eth0/batman_adv/iface_status
|
||||||
|
active
|
||||||
|
|
||||||
|
To deactivate an interface you have to detach it from the "bat0" interface::
|
||||||
|
|
||||||
|
$ ip link set dev eth0 nomaster
|
||||||
|
|
||||||
|
|
||||||
|
All mesh wide settings can be found in batman's own interface folder::
|
||||||
|
|
||||||
|
$ ls /sys/class/net/bat0/mesh/
|
||||||
|
aggregated_ogms fragmentation isolation_mark routing_algo
|
||||||
|
ap_isolation gw_bandwidth log_level vlan0
|
||||||
|
bonding gw_mode multicast_mode
|
||||||
|
bridge_loop_avoidance gw_sel_class network_coding
|
||||||
|
distributed_arp_table hop_penalty orig_interval
|
||||||
|
|
||||||
|
There is a special folder for debugging information::
|
||||||
|
|
||||||
|
$ ls /sys/kernel/debug/batman_adv/bat0/
|
||||||
|
bla_backbone_table log neighbors transtable_local
|
||||||
|
bla_claim_table mcast_flags originators
|
||||||
|
dat_cache nc socket
|
||||||
|
gateways nc_nodes transtable_global
|
||||||
|
|
||||||
|
Some of the files contain all sort of status information regarding the mesh
|
||||||
|
network. For example, you can view the table of originators (mesh
|
||||||
|
participants) with::
|
||||||
|
|
||||||
|
$ cat /sys/kernel/debug/batman_adv/bat0/originators
|
||||||
|
|
||||||
|
Other files allow to change batman's behaviour to better fit your requirements.
|
||||||
|
For instance, you can check the current originator interval (value in
|
||||||
|
milliseconds which determines how often batman sends its broadcast packets)::
|
||||||
|
|
||||||
|
$ cat /sys/class/net/bat0/mesh/orig_interval
|
||||||
|
1000
|
||||||
|
|
||||||
|
and also change its value::
|
||||||
|
|
||||||
|
$ echo 3000 > /sys/class/net/bat0/mesh/orig_interval
|
||||||
|
|
||||||
|
In very mobile scenarios, you might want to adjust the originator interval to a
|
||||||
|
lower value. This will make the mesh more responsive to topology changes, but
|
||||||
|
will also increase the overhead.
|
||||||
|
|
||||||
|
|
||||||
|
Usage
|
||||||
|
=====
|
||||||
|
|
||||||
|
To make use of your newly created mesh, batman advanced provides a new
|
||||||
|
interface "bat0" which you should use from this point on. All interfaces added
|
||||||
|
to batman advanced are not relevant any longer because batman handles them for
|
||||||
|
you. Basically, one "hands over" the data by using the batman interface and
|
||||||
|
batman will make sure it reaches its destination.
|
||||||
|
|
||||||
|
The "bat0" interface can be used like any other regular interface. It needs an
|
||||||
|
IP address which can be either statically configured or dynamically (by using
|
||||||
|
DHCP or similar services)::
|
||||||
|
|
||||||
|
NodeA: ip link set up dev bat0
|
||||||
|
NodeA: ip addr add 192.168.0.1/24 dev bat0
|
||||||
|
|
||||||
|
NodeB: ip link set up dev bat0
|
||||||
|
NodeB: ip addr add 192.168.0.2/24 dev bat0
|
||||||
|
NodeB: ping 192.168.0.1
|
||||||
|
|
||||||
|
Note: In order to avoid problems remove all IP addresses previously assigned to
|
||||||
|
interfaces now used by batman advanced, e.g.::
|
||||||
|
|
||||||
|
$ ip addr flush dev eth0
|
||||||
|
|
||||||
|
|
||||||
|
Logging/Debugging
|
||||||
|
=================
|
||||||
|
|
||||||
|
All error messages, warnings and information messages are sent to the kernel
|
||||||
|
log. Depending on your operating system distribution this can be read in one of
|
||||||
|
a number of ways. Try using the commands: ``dmesg``, ``logread``, or looking in
|
||||||
|
the files ``/var/log/kern.log`` or ``/var/log/syslog``. All batman-adv messages
|
||||||
|
are prefixed with "batman-adv:" So to see just these messages try::
|
||||||
|
|
||||||
|
$ dmesg | grep batman-adv
|
||||||
|
|
||||||
|
When investigating problems with your mesh network, it is sometimes necessary to
|
||||||
|
see more detail debug messages. This must be enabled when compiling the
|
||||||
|
batman-adv module. When building batman-adv as part of kernel, use "make
|
||||||
|
menuconfig" and enable the option ``B.A.T.M.A.N. debugging``
|
||||||
|
(``CONFIG_BATMAN_ADV_DEBUG=y``).
|
||||||
|
|
||||||
|
Those additional debug messages can be accessed using a special file in
|
||||||
|
debugfs::
|
||||||
|
|
||||||
|
$ cat /sys/kernel/debug/batman_adv/bat0/log
|
||||||
|
|
||||||
|
The additional debug output is by default disabled. It can be enabled during
|
||||||
|
run time. Following log_levels are defined:
|
||||||
|
|
||||||
|
.. flat-table::
|
||||||
|
|
||||||
|
* - 0
|
||||||
|
- All debug output disabled
|
||||||
|
* - 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
|
||||||
|
* - 8
|
||||||
|
- Enable messages related to bridge loop avoidance
|
||||||
|
* - 16
|
||||||
|
- Enable messages related to DAT, ARP snooping and parsing
|
||||||
|
* - 32
|
||||||
|
- Enable messages related to network coding
|
||||||
|
* - 64
|
||||||
|
- Enable messages related to multicast
|
||||||
|
* - 128
|
||||||
|
- Enable messages related to throughput meter
|
||||||
|
* - 255
|
||||||
|
- Enable all messages
|
||||||
|
|
||||||
|
The debug output can be changed at runtime using the file
|
||||||
|
``/sys/class/net/bat0/mesh/log_level``. e.g.::
|
||||||
|
|
||||||
|
$ echo 6 > /sys/class/net/bat0/mesh/log_level
|
||||||
|
|
||||||
|
will enable debug messages for when routes change.
|
||||||
|
|
||||||
|
Counters for different types of packets entering and leaving the batman-adv
|
||||||
|
module are available through ethtool::
|
||||||
|
|
||||||
|
$ ethtool --statistics bat0
|
||||||
|
|
||||||
|
|
||||||
|
batctl
|
||||||
|
======
|
||||||
|
|
||||||
|
As batman advanced operates on layer 2, all hosts participating in the virtual
|
||||||
|
switch are completely transparent for all protocols above layer 2. Therefore
|
||||||
|
the common diagnosis tools do not work as expected. To overcome these problems,
|
||||||
|
batctl was created. At the moment the batctl contains ping, traceroute, tcpdump
|
||||||
|
and interfaces to the kernel module settings.
|
||||||
|
|
||||||
|
For more information, please see the manpage (``man batctl``).
|
||||||
|
|
||||||
|
batctl is available on https://www.open-mesh.org/
|
||||||
|
|
||||||
|
|
||||||
|
Contact
|
||||||
|
=======
|
||||||
|
|
||||||
|
Please send us comments, experiences, questions, anything :)
|
||||||
|
|
||||||
|
IRC:
|
||||||
|
#batman on irc.freenode.org
|
||||||
|
Mailing-list:
|
||||||
|
b.a.t.m.a.n@open-mesh.org (optional subscription at
|
||||||
|
https://lists.open-mesh.org/mm/listinfo/b.a.t.m.a.n)
|
||||||
|
|
||||||
|
You can also contact the Authors:
|
||||||
|
|
||||||
|
* Marek Lindner <mareklindner@neomailbox.ch>
|
||||||
|
* Simon Wunderlich <sw@simonwunderlich.de>
|
@ -1,215 +0,0 @@
|
|||||||
BATMAN-ADV
|
|
||||||
----------
|
|
||||||
|
|
||||||
Batman advanced is a new approach to wireless networking which
|
|
||||||
does no longer operate on the IP basis. Unlike the batman daemon,
|
|
||||||
which exchanges information using UDP packets and sets routing
|
|
||||||
tables, batman-advanced operates on ISO/OSI Layer 2 only and uses
|
|
||||||
and routes (or better: bridges) Ethernet Frames. It emulates a
|
|
||||||
virtual network switch of all nodes participating. Therefore all
|
|
||||||
nodes appear to be link local, thus all higher operating proto-
|
|
||||||
cols won't be affected by any changes within the network. You can
|
|
||||||
run almost any protocol above batman advanced, prominent examples
|
|
||||||
are: IPv4, IPv6, DHCP, IPX.
|
|
||||||
|
|
||||||
Batman advanced was implemented as a Linux kernel driver to re-
|
|
||||||
duce the overhead to a minimum. It does not depend on any (other)
|
|
||||||
network driver, and can be used on wifi as well as ethernet lan,
|
|
||||||
vpn, etc ... (anything with ethernet-style layer 2).
|
|
||||||
|
|
||||||
|
|
||||||
CONFIGURATION
|
|
||||||
-------------
|
|
||||||
|
|
||||||
Load the batman-adv module into your kernel:
|
|
||||||
|
|
||||||
# insmod batman-adv.ko
|
|
||||||
|
|
||||||
The module is now waiting for activation. You must add some in-
|
|
||||||
terfaces on which batman can operate. After loading the module
|
|
||||||
batman advanced will scan your systems interfaces to search for
|
|
||||||
compatible interfaces. Once found, it will create subfolders in
|
|
||||||
the /sys directories of each supported interface, e.g.
|
|
||||||
|
|
||||||
# ls /sys/class/net/eth0/batman_adv/
|
|
||||||
# elp_interval iface_status mesh_iface throughput_override
|
|
||||||
|
|
||||||
If an interface does not have the "batman_adv" subfolder it prob-
|
|
||||||
ably is not supported. Not supported interfaces are: loopback,
|
|
||||||
non-ethernet and batman's own interfaces.
|
|
||||||
|
|
||||||
Note: After the module was loaded it will continuously watch for
|
|
||||||
new interfaces to verify the compatibility. There is no need to
|
|
||||||
reload the module if you plug your USB wifi adapter into your ma-
|
|
||||||
chine after batman advanced was initially loaded.
|
|
||||||
|
|
||||||
The batman-adv soft-interface can be created using the iproute2
|
|
||||||
tool "ip"
|
|
||||||
|
|
||||||
# ip link add name bat0 type batadv
|
|
||||||
|
|
||||||
To activate a given interface simply attach it to the "bat0"
|
|
||||||
interface
|
|
||||||
|
|
||||||
# ip link set dev eth0 master bat0
|
|
||||||
|
|
||||||
Repeat this step for all interfaces you wish to add. Now batman
|
|
||||||
starts using/broadcasting on this/these interface(s).
|
|
||||||
|
|
||||||
By reading the "iface_status" file you can check its status:
|
|
||||||
|
|
||||||
# cat /sys/class/net/eth0/batman_adv/iface_status
|
|
||||||
# active
|
|
||||||
|
|
||||||
To deactivate an interface you have to detach it from the
|
|
||||||
"bat0" interface:
|
|
||||||
|
|
||||||
# ip link set dev eth0 nomaster
|
|
||||||
|
|
||||||
|
|
||||||
All mesh wide settings can be found in batman's own interface
|
|
||||||
folder:
|
|
||||||
|
|
||||||
# ls /sys/class/net/bat0/mesh/
|
|
||||||
# aggregated_ogms fragmentation isolation_mark routing_algo
|
|
||||||
# ap_isolation gw_bandwidth log_level vlan0
|
|
||||||
# bonding gw_mode multicast_mode
|
|
||||||
# bridge_loop_avoidance gw_sel_class network_coding
|
|
||||||
# distributed_arp_table hop_penalty orig_interval
|
|
||||||
|
|
||||||
There is a special folder for debugging information:
|
|
||||||
|
|
||||||
# ls /sys/kernel/debug/batman_adv/bat0/
|
|
||||||
# bla_backbone_table log neighbors transtable_local
|
|
||||||
# bla_claim_table mcast_flags originators
|
|
||||||
# dat_cache nc socket
|
|
||||||
# gateways nc_nodes transtable_global
|
|
||||||
|
|
||||||
Some of the files contain all sort of status information regard-
|
|
||||||
ing the mesh network. For example, you can view the table of
|
|
||||||
originators (mesh participants) with:
|
|
||||||
|
|
||||||
# cat /sys/kernel/debug/batman_adv/bat0/originators
|
|
||||||
|
|
||||||
Other files allow to change batman's behaviour to better fit your
|
|
||||||
requirements. For instance, you can check the current originator
|
|
||||||
interval (value in milliseconds which determines how often batman
|
|
||||||
sends its broadcast packets):
|
|
||||||
|
|
||||||
# cat /sys/class/net/bat0/mesh/orig_interval
|
|
||||||
# 1000
|
|
||||||
|
|
||||||
and also change its value:
|
|
||||||
|
|
||||||
# echo 3000 > /sys/class/net/bat0/mesh/orig_interval
|
|
||||||
|
|
||||||
In very mobile scenarios, you might want to adjust the originator
|
|
||||||
interval to a lower value. This will make the mesh more respon-
|
|
||||||
sive to topology changes, but will also increase the overhead.
|
|
||||||
|
|
||||||
|
|
||||||
USAGE
|
|
||||||
-----
|
|
||||||
|
|
||||||
To make use of your newly created mesh, batman advanced provides
|
|
||||||
a new interface "bat0" which you should use from this point on.
|
|
||||||
All interfaces added to batman advanced are not relevant any
|
|
||||||
longer because batman handles them for you. Basically, one "hands
|
|
||||||
over" the data by using the batman interface and batman will make
|
|
||||||
sure it reaches its destination.
|
|
||||||
|
|
||||||
The "bat0" interface can be used like any other regular inter-
|
|
||||||
face. It needs an IP address which can be either statically con-
|
|
||||||
figured or dynamically (by using DHCP or similar services):
|
|
||||||
|
|
||||||
# NodeA: ip link set up dev bat0
|
|
||||||
# NodeA: ip addr add 192.168.0.1/24 dev bat0
|
|
||||||
|
|
||||||
# NodeB: ip link set up dev bat0
|
|
||||||
# NodeB: ip addr add 192.168.0.2/24 dev bat0
|
|
||||||
# NodeB: ping 192.168.0.1
|
|
||||||
|
|
||||||
Note: In order to avoid problems remove all IP addresses previ-
|
|
||||||
ously assigned to interfaces now used by batman advanced, e.g.
|
|
||||||
|
|
||||||
# ip addr flush dev eth0
|
|
||||||
|
|
||||||
|
|
||||||
LOGGING/DEBUGGING
|
|
||||||
-----------------
|
|
||||||
|
|
||||||
All error messages, warnings and information messages are sent to
|
|
||||||
the kernel log. Depending on your operating system distribution
|
|
||||||
this can be read in one of a number of ways. Try using the com-
|
|
||||||
mands: dmesg, logread, or looking in the files /var/log/kern.log
|
|
||||||
or /var/log/syslog. All batman-adv messages are prefixed with
|
|
||||||
"batman-adv:" So to see just these messages try
|
|
||||||
|
|
||||||
# dmesg | grep batman-adv
|
|
||||||
|
|
||||||
When investigating problems with your mesh network it is some-
|
|
||||||
times necessary to see more detail debug messages. This must be
|
|
||||||
enabled when compiling the batman-adv module. When building bat-
|
|
||||||
man-adv as part of kernel, use "make menuconfig" and enable the
|
|
||||||
option "B.A.T.M.A.N. debugging".
|
|
||||||
|
|
||||||
Those additional debug messages can be accessed using a special
|
|
||||||
file in debugfs
|
|
||||||
|
|
||||||
# cat /sys/kernel/debug/batman_adv/bat0/log
|
|
||||||
|
|
||||||
The additional debug output is by default disabled. It can be en-
|
|
||||||
abled during run time. Following log_levels are defined:
|
|
||||||
|
|
||||||
0 - All debug output disabled
|
|
||||||
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
|
|
||||||
8 - Enable messages related to bridge loop avoidance
|
|
||||||
16 - Enable messages related to DAT, ARP snooping and parsing
|
|
||||||
32 - Enable messages related to network coding
|
|
||||||
64 - Enable messages related to multicast
|
|
||||||
128 - Enable messages related to throughput meter
|
|
||||||
255 - Enable all messages
|
|
||||||
|
|
||||||
The debug output can be changed at runtime using the file
|
|
||||||
/sys/class/net/bat0/mesh/log_level. e.g.
|
|
||||||
|
|
||||||
# echo 6 > /sys/class/net/bat0/mesh/log_level
|
|
||||||
|
|
||||||
will enable debug messages for when routes change.
|
|
||||||
|
|
||||||
Counters for different types of packets entering and leaving the
|
|
||||||
batman-adv module are available through ethtool:
|
|
||||||
|
|
||||||
# ethtool --statistics bat0
|
|
||||||
|
|
||||||
|
|
||||||
BATCTL
|
|
||||||
------
|
|
||||||
|
|
||||||
As batman advanced operates on layer 2 all hosts participating in
|
|
||||||
the virtual switch are completely transparent for all protocols
|
|
||||||
above layer 2. Therefore the common diagnosis tools do not work
|
|
||||||
as expected. To overcome these problems batctl was created. At
|
|
||||||
the moment the batctl contains ping, traceroute, tcpdump and
|
|
||||||
interfaces to the kernel module settings.
|
|
||||||
|
|
||||||
For more information, please see the manpage (man batctl).
|
|
||||||
|
|
||||||
batctl is available on https://www.open-mesh.org/
|
|
||||||
|
|
||||||
|
|
||||||
CONTACT
|
|
||||||
-------
|
|
||||||
|
|
||||||
Please send us comments, experiences, questions, anything :)
|
|
||||||
|
|
||||||
IRC: #batman on irc.freenode.org
|
|
||||||
Mailing-list: b.a.t.m.a.n@open-mesh.org (optional subscription
|
|
||||||
at https://lists.open-mesh.org/mm/listinfo/b.a.t.m.a.n)
|
|
||||||
|
|
||||||
You can also contact the Authors:
|
|
||||||
|
|
||||||
Marek Lindner <mareklindner@neomailbox.ch>
|
|
||||||
Simon Wunderlich <sw@simonwunderlich.de>
|
|
@ -6,6 +6,7 @@ Contents:
|
|||||||
.. toctree::
|
.. toctree::
|
||||||
:maxdepth: 2
|
:maxdepth: 2
|
||||||
|
|
||||||
|
batman-adv
|
||||||
kapi
|
kapi
|
||||||
z8530book
|
z8530book
|
||||||
|
|
||||||
|
@ -2477,7 +2477,7 @@ Q: https://patchwork.open-mesh.org/project/batman/list/
|
|||||||
S: Maintained
|
S: Maintained
|
||||||
F: Documentation/ABI/testing/sysfs-class-net-batman-adv
|
F: Documentation/ABI/testing/sysfs-class-net-batman-adv
|
||||||
F: Documentation/ABI/testing/sysfs-class-net-mesh
|
F: Documentation/ABI/testing/sysfs-class-net-mesh
|
||||||
F: Documentation/networking/batman-adv.txt
|
F: Documentation/networking/batman-adv.rst
|
||||||
F: include/uapi/linux/batman_adv.h
|
F: include/uapi/linux/batman_adv.h
|
||||||
F: net/batman-adv/
|
F: net/batman-adv/
|
||||||
|
|
||||||
|
@ -729,11 +729,9 @@ static void batadv_iv_ogm_aggregate(struct batadv_forw_packet *forw_packet_aggr,
|
|||||||
const unsigned char *packet_buff,
|
const unsigned char *packet_buff,
|
||||||
int packet_len, bool direct_link)
|
int packet_len, bool direct_link)
|
||||||
{
|
{
|
||||||
unsigned char *skb_buff;
|
|
||||||
unsigned long new_direct_link_flag;
|
unsigned long new_direct_link_flag;
|
||||||
|
|
||||||
skb_buff = skb_put_data(forw_packet_aggr->skb, packet_buff,
|
skb_put_data(forw_packet_aggr->skb, packet_buff, packet_len);
|
||||||
packet_len);
|
|
||||||
forw_packet_aggr->packet_len += packet_len;
|
forw_packet_aggr->packet_len += packet_len;
|
||||||
forw_packet_aggr->num_packets++;
|
forw_packet_aggr->num_packets++;
|
||||||
|
|
||||||
@ -1281,7 +1279,7 @@ static bool batadv_iv_ogm_calc_tq(struct batadv_orig_node *orig_node,
|
|||||||
batadv_ogm_packet->tq = combined_tq;
|
batadv_ogm_packet->tq = combined_tq;
|
||||||
|
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
||||||
"bidirectional: orig = %-15pM neigh = %-15pM => own_bcast = %2i, real recv = %2i, local tq: %3i, asym_penalty: %3i, iface_penalty: %3i, total tq: %3i, if_incoming = %s, if_outgoing = %s\n",
|
"bidirectional: orig = %pM neigh = %pM => own_bcast = %2i, real recv = %2i, local tq: %3i, asym_penalty: %3i, iface_penalty: %3i, total tq: %3i, if_incoming = %s, if_outgoing = %s\n",
|
||||||
orig_node->orig, orig_neigh_node->orig, total_count,
|
orig_node->orig, orig_neigh_node->orig, total_count,
|
||||||
neigh_rq_count, tq_own, tq_asym_penalty, tq_iface_penalty,
|
neigh_rq_count, tq_own, tq_asym_penalty, tq_iface_penalty,
|
||||||
batadv_ogm_packet->tq, if_incoming->net_dev->name,
|
batadv_ogm_packet->tq, if_incoming->net_dev->name,
|
||||||
|
@ -137,7 +137,7 @@ static void batadv_v_ogm_send(struct work_struct *work)
|
|||||||
struct batadv_priv *bat_priv;
|
struct batadv_priv *bat_priv;
|
||||||
struct batadv_ogm2_packet *ogm_packet;
|
struct batadv_ogm2_packet *ogm_packet;
|
||||||
struct sk_buff *skb, *skb_tmp;
|
struct sk_buff *skb, *skb_tmp;
|
||||||
unsigned char *ogm_buff, *pkt_buff;
|
unsigned char *ogm_buff;
|
||||||
int ogm_buff_len;
|
int ogm_buff_len;
|
||||||
u16 tvlv_len = 0;
|
u16 tvlv_len = 0;
|
||||||
int ret;
|
int ret;
|
||||||
@ -166,7 +166,7 @@ static void batadv_v_ogm_send(struct work_struct *work)
|
|||||||
goto reschedule;
|
goto reschedule;
|
||||||
|
|
||||||
skb_reserve(skb, ETH_HLEN);
|
skb_reserve(skb, ETH_HLEN);
|
||||||
pkt_buff = skb_put_data(skb, ogm_buff, ogm_buff_len);
|
skb_put_data(skb, ogm_buff, ogm_buff_len);
|
||||||
|
|
||||||
ogm_packet = (struct batadv_ogm2_packet *)skb->data;
|
ogm_packet = (struct batadv_ogm2_packet *)skb->data;
|
||||||
ogm_packet->seqno = htonl(atomic_read(&bat_priv->bat_v.ogm_seqno));
|
ogm_packet->seqno = htonl(atomic_read(&bat_priv->bat_v.ogm_seqno));
|
||||||
@ -200,7 +200,7 @@ static void batadv_v_ogm_send(struct work_struct *work)
|
|||||||
type = "unknown";
|
type = "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "OGM2 from ourselve on %s surpressed: %s\n",
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "OGM2 from ourselves on %s suppressed: %s\n",
|
||||||
hard_iface->net_dev->name, type);
|
hard_iface->net_dev->name, type);
|
||||||
|
|
||||||
batadv_hardif_put(hard_iface);
|
batadv_hardif_put(hard_iface);
|
||||||
@ -683,18 +683,18 @@ static void batadv_v_ogm_process(const struct sk_buff *skb, int ogm_offset,
|
|||||||
ogm_throughput = ntohl(ogm_packet->throughput);
|
ogm_throughput = ntohl(ogm_packet->throughput);
|
||||||
|
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
||||||
"Received OGM2 packet via NB: %pM, IF: %s [%pM] (from OG: %pM, seqno %u, troughput %u, TTL %u, V %u, tvlv_len %u)\n",
|
"Received OGM2 packet via NB: %pM, IF: %s [%pM] (from OG: %pM, seqno %u, throughput %u, TTL %u, V %u, tvlv_len %u)\n",
|
||||||
ethhdr->h_source, if_incoming->net_dev->name,
|
ethhdr->h_source, if_incoming->net_dev->name,
|
||||||
if_incoming->net_dev->dev_addr, ogm_packet->orig,
|
if_incoming->net_dev->dev_addr, ogm_packet->orig,
|
||||||
ntohl(ogm_packet->seqno), ogm_throughput, ogm_packet->ttl,
|
ntohl(ogm_packet->seqno), ogm_throughput, ogm_packet->ttl,
|
||||||
ogm_packet->version, ntohs(ogm_packet->tvlv_len));
|
ogm_packet->version, ntohs(ogm_packet->tvlv_len));
|
||||||
|
|
||||||
/* If the troughput metric is 0, immediately drop the packet. No need to
|
/* If the throughput metric is 0, immediately drop the packet. No need
|
||||||
* create orig_node / neigh_node for an unusable route.
|
* to create orig_node / neigh_node for an unusable route.
|
||||||
*/
|
*/
|
||||||
if (ogm_throughput == 0) {
|
if (ogm_throughput == 0) {
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv,
|
||||||
"Drop packet: originator packet with troughput metric of 0\n");
|
"Drop packet: originator packet with throughput metric of 0\n");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -762,7 +762,7 @@ static void batadv_v_ogm_process(const struct sk_buff *skb, int ogm_offset,
|
|||||||
type = "unknown";
|
type = "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "OGM2 packet from %pM on %s surpressed: %s\n",
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "OGM2 packet from %pM on %s suppressed: %s\n",
|
||||||
ogm_packet->orig, hard_iface->net_dev->name,
|
ogm_packet->orig, hard_iface->net_dev->name,
|
||||||
type);
|
type);
|
||||||
|
|
||||||
|
@ -834,7 +834,7 @@ int batadv_dat_cache_seq_print_text(struct seq_file *seq, void *offset)
|
|||||||
last_seen_msecs = last_seen_msecs % 60000;
|
last_seen_msecs = last_seen_msecs % 60000;
|
||||||
last_seen_secs = last_seen_msecs / 1000;
|
last_seen_secs = last_seen_msecs / 1000;
|
||||||
|
|
||||||
seq_printf(seq, " * %15pI4 %14pM %4i %6i:%02i\n",
|
seq_printf(seq, " * %15pI4 %pM %4i %6i:%02i\n",
|
||||||
&dat_entry->ip, dat_entry->mac_addr,
|
&dat_entry->ip, dat_entry->mac_addr,
|
||||||
batadv_print_vid(dat_entry->vid),
|
batadv_print_vid(dat_entry->vid),
|
||||||
last_seen_mins, last_seen_secs);
|
last_seen_mins, last_seen_secs);
|
||||||
|
@ -24,7 +24,7 @@
|
|||||||
#define BATADV_DRIVER_DEVICE "batman-adv"
|
#define BATADV_DRIVER_DEVICE "batman-adv"
|
||||||
|
|
||||||
#ifndef BATADV_SOURCE_VERSION
|
#ifndef BATADV_SOURCE_VERSION
|
||||||
#define BATADV_SOURCE_VERSION "2017.2"
|
#define BATADV_SOURCE_VERSION "2017.3"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* B.A.T.M.A.N. parameters */
|
/* B.A.T.M.A.N. parameters */
|
||||||
|
@ -911,7 +911,7 @@ static void batadv_send_outstanding_bcast_packet(struct work_struct *work)
|
|||||||
type = "unknown";
|
type = "unknown";
|
||||||
}
|
}
|
||||||
|
|
||||||
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "BCAST packet from orig %pM on %s surpressed: %s\n",
|
batadv_dbg(BATADV_DBG_BATMAN, bat_priv, "BCAST packet from orig %pM on %s suppressed: %s\n",
|
||||||
bcast_packet->orig,
|
bcast_packet->orig,
|
||||||
hard_iface->net_dev->name, type);
|
hard_iface->net_dev->name, type);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user