---------- Forwarded message ---------- From: Robert Schuster <theBohemian@gmx.net> Date: Fri, Jun 27, 2008 at 12:01 AM
Subject: Freifunk@FreeRunner: OLSRD To: List for Openmoko community discussion <community@lists.openmoko.org>
Hi, you know we already have B.A.T.M.A.N in OpenEmbedded but now I gave good
old OLSRD a try too.
I added a recipe for the latest release 0.5.5 and tested it on the device. It is working nicely along with the ar6000 being in ad-hoc mode (the preferred mode for mesh networks ;) ). No luck with 0.5.3 though -
it crashes when I want to view the page generated by the httpinfo plugin.
I wanted to do some NATting between the wifi interface and the usbnet connection (effectively making my desktop computer an internet gateway
for the Berlin Freifunk community).
However this was impossible since OpenMoko does not provide the iptables package (you can get the kernel modules but not the userspace application). You can build it on your own and then everything is fine
though.
There are also some minor issues with the wifi driver. I reported this[0] a while ago already.
I am already happy but I would be so even more if: - olsrd version preference could be set to 0.5.5
- iptables could be installed directly via opkg
The FreeRunner as a wifi mesh-node is a nice use case for the time after being a mobile phone. It would be one of the very few nodes that have a screen attached. :)
I would like to offer screen shots but there is nothing spectacular to see on them. But perhaps you like some console output instead:
Actually I could find something that may show I am really using this on
the Neo. I attached is httpinfo plugin generated webpage showing my configuration. There are few devices where eth0 is a wifi card. :D
If you are interested I also attached by olsrd.conf. You need to have olsrd-plugin-httpinfo, olsrd-plugin-nameservice (didn't work as
expected) and olsrd-plugin-dyngw installed besides the daemon.
Version: olsr.org - 0.5.5 (built on 2008-06-26 23:09:18 on linkist) OS: GNU/Linux System time: Fri, 27 Jun 2008 14:27:37 Olsrd uptime: 00 hours 15 minutes 55 seconds
HTTP stats(ok/dyn/error/illegal): 20/0/0/0 Click here to generate a configuration file for this node.
# # Lines starting with a # are discarded
# # This file was edited by Elektra and needs # olsrd-0.4.10 CVS or higher #
# This file is an example of a typical configuration # for a huge (250 Nodes or more), reliable, scalable # routing-loop-free (well, almost :) and mostly static
# network (regarding mobility) using the LQ extention # and FishEyeAlgorithm with LinkQualityDijkstraLimit # to reduce CPU-Overhead
# Debug level(0-9) # If set to 0 the daemon runs in the background # Use Debug level 0 on a embedded system -
# debugging draws a lot of CPU-Power
DebugLevel 0
# FishEyeAlgorithm - Disable only if you want to # experience routing loops :) # See the README about Fisheye in the olsrd-source
LinkQualityFishEye 1
# Don't recalculate the Dijkstra-Table for every # incoming TC-Message from nodes more than n hops away - # Disable this algorithm in a huge mesh only if you are # interested to accelerate global warming with overheated CPUs
# The first integer tells the algorithm to recalculate # the Dijkstra-table when a TC-Message arrives from a node # not more than n hops away. If set to 0 it will not # recalculate it upon incoming TCs # The second number (float) sets the time interval when
# the Dijkstra table will be recalculated anyway. # Whatever comes first...
LinkQualityDijkstraLimit 0 10.0
# IP version to use (4 or 6)
IpVersion 4
# Clear the screen each time the internal state changes
ClearScreen yes
# HNA IPv4 routes # syntax: netaddr netmask # Example Internet gateway: # 0.0.0.00.0.0.0
Hna4 { # Don't use this to announce an Internet Gateway - # rather use the dyn_gw plugin that checks wheter you are # actually a gateway or a black hole for other peoples # internet traffic...
# HNA IPv6 routes # syntax: netaddr prefix # Example Internet gateway: Hna6 { # Internet gateway: # :: 0 # more entries can be added: # fec0:2200:106:: 48 }
# Should olsrd keep on running even if there are # no interfaces available? This is a good idea # for a PCMCIA/USB hotswap environment. # "yes" OR "no"
AllowNoInt yes
# TOS(type of service) value for
# the IP header of control traffic. # If not set it will default to 16
#TosValue 16
# The fixed willingness to use(0-7) # If not set willingness will be calculated # dynamically based on battery/power status
# if such information is available
Willingness 7
# Allow processes like the GUI front-end # to connect to the daemon.
IpcConnect { # Determines how many simultaneously # IPC connections that will be allowed
# Setting this to 0 disables IPC
MaxConnections 1
# By default only 127.0.0.1 is allowed # to connect. Here allowed hosts can # be added
# Enable Hysteresis only if you want your routing table
# to brake down every 5 seconds # Hysteresis is one of this fancy looking 'optimizations' # in RFC 3626 that don't work in real life # If unsure say "NO!"
UseHysteresis no
# Hysteresis parameters
# Do not alter these unless you know # what you are doing! # # If you know what you are doing # you make sure that hysteresis # is completely SWITCHED OFF! # # Set to auto by default. Allowed # values are floating point values
# in the interval 0,1 # THR_LOW must always be lower than # THR_HIGH.
# Link quality level # 0 = do not use link quality # 1 = use link quality for MPR selection
# 2 = use link quality for MPR selection and routing # Defaults to 0
LinkQualityLevel 2
# Link quality window size # Defaults to 10 # 100 is slow but stable...
LinkQualityWinSize 100
# Polling rate in seconds(float). # Default value 0.05 sec
Pollrate 0.05
# TC redundancy # Specifies how much neighbor info should # be sent in TC messages # Possible values are:
# 0 - only send MPR selectors # 1 - send MPR selectors and MPRs # 2 - send all neighbors # # defaults to 0 # MultiPointRelais is another notorious # 'optimization' feature in RFC3626... # Switch it off by chosing redundancy value 2
TcRedundancy 2
# # MPR coverage # Specifies how many MPRs a node should # try select to reach every 2 hop neighbor # # Can be set to any integer >0 # # defaults to 1 # # Full coverage is the way to get rid of this
# annoying 'optimization'
MprCoverage 7
# Olsrd plugins to load # This must be the absolute path to the file # or the loader will use the following scheme: # - Try the paths in the LD_LIBRARY_PATH
# environment variable. # - The list of libraries cached in /etc/ld.so.cache # - /lib, followed by /usr/lib
# Example plugin entry with parameters:
# This plugin generates the information to make those fancy
# 2D and 3D topology graphs
# This plugin announces that this node is a gateway into # other networks, it it actually is:
LoadPlugin "olsrd_dyn_gw.so.0.4" { # Here parameters are set to be sent to the # plugin. Theese are on the form "key" "value".
# Parameters ofcause, differs from plugin to plugin. # Consult the documentation of your plugin for details.
# Example: dyn_gw params
# how often to check for Internet connectivity # defaults to 5 secs
PlParam "Interval" "40"
# if one or more IPv4 addresses are given, do a ping on these in # descending order to validate that there is not only an entry in # routing table, but also a real internet connection. If any of
# these addresses could be pinged successfully, the test was # succesful, i.e. if the ping on the 1st address was successful,the # 2nd won't be pinged PlParam "Ping" "141.1.1.1"
PlParam "Ping" "194.25.2.129" }
# This plugin announces services available on your router: # Of course the configfile should be present...
# Interfaces and their rules # Omitted options will be set to the # default values. Multiple interfaces # can be specified in the same block # and multiple blocks can be set.
# !!CHANGE THE INTERFACE LABEL(s) TO MATCH YOUR INTERFACE(s)!! # (eg. wlan0 or eth1):
Interface "eth0" {
# IPv4 broadcast address to use. The # one usefull example would be 255.255.255.255
# If not defined the broadcastaddress # every card is configured with is used
# IPv6 address scope to use.
# Must be 'site-local' or 'global'
# Ip6AddrType site-local
# IPv6 multicast address to use when # using site-local addresses. # If not defined, ff05::15 is used
# Ip6MulticastSite ff05::11
# IPv6 multicast address to use when # using global addresses # If not defined, ff0e::1 is used
# Ip6MulticastGlobal ff0e::1
# Emission intervals.
# If not defined, RFC proposed values will # be used in most cases.
# Hello interval in seconds(float) HelloInterval 5.0
# HELLO validity time HelloValidityTime 300.0
# TC interval in seconds(float)
TcInterval 2.0
# TC validity time TcValidityTime 300.0
# MID interval in seconds(float) MidInterval 5.0
# MID validity time MidValidityTime 300.0
# HNA interval in seconds(float)
HnaInterval 5.0
# HNA validity time HnaValidityTime 300.0
# When multiple links exist between hosts # the weight of interface is used to determine # the link to use. Normally the weight is
# automatically calculated by olsrd based # on the characteristics of the interface, # but here you can specify a fixed value. # Olsrd will choose links with the lowest value.