1 <?xml version=
"1.0" encoding=
"ISO-8859-1"?>
2 <rss version='
2.0' xmlns:lj='http://www.livejournal.org/rss/lj/
1.0/'
>
4 <title>Petter Reinholdtsen - Entries from October
2013</title>
5 <description>Entries from October
2013</description>
6 <link>http://people.skolelinux.org/pere/blog/
</link>
10 <title>A Raspberry Pi based batman-adv Mesh network node
</title>
11 <link>http://people.skolelinux.org/pere/blog/A_Raspberry_Pi_based_batman_adv_Mesh_network_node.html
</link>
12 <guid isPermaLink=
"true">http://people.skolelinux.org/pere/blog/A_Raspberry_Pi_based_batman_adv_Mesh_network_node.html
</guid>
13 <pubDate>Mon,
21 Oct
2013 11:
40:
00 +
0200</pubDate>
14 <description><p
>The last few days I have been experimenting with
15 <a href=
"http://www.open-mesh.org/projects/batman-adv/wiki
">the
16 batman-adv mech technology
</a
>. I want to gain some experience to see
17 if it will fit
<a href=
"https://wiki.debian.org/FreedomBox
">the
18 Freedombox project
</a
>, and together with my neighbors try to build a
19 mesh network around the park where I live. Batman-adv is a layer
2
20 mesh system (
"ethernet
" in other words), where the mesh network appear
21 as if all the mesh clients are connected to the same switch.
</p
>
23 <p
>My hardware of choice was the Linksys WRT54GL routers I had lying
24 around, but I
've been unable to get them working with batman-adv. So
25 instead, I started playing with a
26 <a href=
"http://www.raspberrypi.org/
">Raspberry Pi
</a
>, and tried to
27 get it working as a mesh node. My idea is to use it to create a mesh
28 node which function as a switch port, where everything connected to
29 the Raspberry Pi ethernet plug is connected (bridged) to the mesh
30 network. This allow me to hook a wifi base station like the Linksys
31 WRT54GL to the mesh by plugging it into a Raspberry Pi, and allow
32 non-mesh clients to hook up to the mesh. This in turn is useful for
33 Android phones using
<a href=
"http://servalproject.org/
">the Serval
34 Project
</a
> voip client, allowing every one around the playground to
35 phone and message each other for free. The reason is that Android
36 phones do not see ad-hoc wifi networks (they are filtered away from
37 the GUI view), and can not join the mesh without being rooted. But if
38 they are connected using a normal wifi base station, they can talk to
39 every client on the local network.
</p
>
41 <p
>To get this working, I
've created a debian package
42 <a href=
"https://github.com/petterreinholdtsen/meshfx-node
">meshfx-node
</a
>
44 <a href=
"https://github.com/petterreinholdtsen/meshfx-node/blob/master/build-rpi-mesh-node
">build-rpi-mesh-node
</a
>
45 to create the Raspberry Pi boot image. I
'm using Debian Jessie (and
46 not Raspbian), to get more control over the packages available.
47 Unfortunately a huge binary blob need to be inserted into the boot
48 image to get it booting, but I
'll ignore that for now. Also, as
49 Debian lack support for the CPU features available in the Raspberry
50 Pi, the system do not use the hardware floating point unit. I hope
51 the routing performance isn
't affected by the lack of hardware FPU
54 <p
>To create an image, run the following with a sudo enabled user
55 after inserting the target SD card into the build machine:
</p
>
58 % wget -O build-rpi-mesh-node \
59 https://raw.github.com/petterreinholdtsen/meshfx-node/master/build-rpi-mesh-node
60 % sudo bash -x ./build-rpi-mesh-node
> build.log
2>&1
61 % dd if=/root/rpi/rpi_basic_jessie_$(date +%Y%m%d).img of=/dev/mmcblk0 bs=
1M
63 </pre
></p
>
65 <p
>Booting with the resulting SD card on a Raspberry PI with a USB
66 wifi card inserted should give you a mesh node. At least it does for
67 me with a the wifi card I am using. The default mesh settings are the
68 ones used by the Oslo mesh project at Hackeriet, as I mentioned in
69 <a href=
"http://people.skolelinux.org/pere/blog/Oslo_community_mesh_network___with_NUUG_and_Hackeriet_at_Hausmania.html
">an
70 earlier blog post about this mesh testing
</a
>.
</p
>
72 <p
>The mesh node was not horribly expensive either. I bought
73 everything over the counter in shops nearby. If I had ordered online
74 from the lowest bidder, the price should be significantly lower:
</p
>
76 <p
><table
>
78 <tr
><th
>Supplier
</th
><th
>Model
</th
><th
>NOK
</th
></tr
>
79 <tr
><td
>Teknikkmagasinet
</td
><td
>Raspberry Pi model B
</td
><td
>349.90</td
></tr
>
80 <tr
><td
>Teknikkmagasinet
</td
><td
>Raspberry Pi type B case
</td
><td
>99.90</td
></tr
>
81 <tr
><td
>Lefdal
</td
><td
>Jensen Air:Link
25150</td
><td
>295.-
</td
></tr
>
82 <tr
><td
>Clas Ohlson
</td
><td
>Kingston
16 GB SD card
</td
><td
>199.-
</td
></tr
>
83 <tr
><td
>Total cost
</td
><td
></td
><td
>943.80</td
></tr
>
85 </table
></p
>
87 <p
>Now my mesh network at home consist of one laptop in the basement
88 connected to my production network, one Raspberry Pi node on the
1th
89 floor that can be seen by my neighbor across the park, and one
90 play-node I use to develop the image building script. And some times
91 I hook up work horse laptop to the mesh to test it. I look forward to
92 figuring out what kind of latency the batman-adv setup will give, and
93 how much packet loss we will experience around the park. :)
</p
>
98 <title>Perl library to control the Spykee robot moved to github
</title>
99 <link>http://people.skolelinux.org/pere/blog/Perl_library_to_control_the_Spykee_robot_moved_to_github.html
</link>
100 <guid isPermaLink=
"true">http://people.skolelinux.org/pere/blog/Perl_library_to_control_the_Spykee_robot_moved_to_github.html
</guid>
101 <pubDate>Sat,
19 Oct
2013 10:
20:
00 +
0200</pubDate>
102 <description><p
>Back in
2010, I created a Perl library to talk to
103 <a href=
"http://en.wikipedia.org/wiki/Spykee
">the Spykee robot
</a
>
104 (with two belts, wifi, USB and Linux) and made it available from my
105 web page. Today I concluded that it should move to a site that is
106 easier to use to cooperate with others, and moved it to github. If
107 you got a Spykee robot, you might want to check out
108 <a href=
"https://github.com/petterreinholdtsen/libspykee-perl
">the
109 libspykee-perl github repository
</a
>.
</p
>
114 <title>Good causes: Debian Outreach Program for Women, EFF documenting the spying and Open access in Norway
</title>
115 <link>http://people.skolelinux.org/pere/blog/Good_causes__Debian_Outreach_Program_for_Women__EFF_documenting_the_spying_and_Open_access_in_Norway.html
</link>
116 <guid isPermaLink=
"true">http://people.skolelinux.org/pere/blog/Good_causes__Debian_Outreach_Program_for_Women__EFF_documenting_the_spying_and_Open_access_in_Norway.html
</guid>
117 <pubDate>Tue,
15 Oct
2013 21:
30:
00 +
0200</pubDate>
118 <description><p
>The last few days I came across a few good causes that should get
119 wider attention. I recommend signing and donating to each one of
122 <p
>Via
<a href=
"http://www.debian.org/News/weekly/
2013/
18/
">Debian
123 Project News for
2013-
10-
14</a
> I came across the Outreach Program for
124 Women program which is a Google Summer of Code like initiative to get
125 more women involved in free software. One debian sponsor has offered
126 to match
<a href=
"http://debian.ch/opw2013
">any donation done to Debian
127 earmarked
</a
> for this initiative. I donated a few minutes ago, and
128 hope you will to. :)
</p
>
130 <p
>And the Electronic Frontier Foundation just announced plans to
131 create
<a href=
"https://supporters.eff.org/donate/nsa-videos
">video
132 documentaries about the excessive spying
</a
> on every Internet user that
133 take place these days, and their need to fund the work. I
've already
134 donated. Are you next?
</p
>
136 <p
>For my Norwegian audience, the organisation Studentenes og
137 Akademikernes Internasjonale Hjelpefond is collecting signatures for a
138 statement under the heading
139 <a href=
"http://saih.no/Bloggers_United/
">Bloggers United for Open
140 Access
</a
> for those of us asking for more focus on open access in the
141 Norwegian government. So far
499 signatures. I hope you will sign it
147 <title>Oslo community mesh network - with NUUG and Hackeriet at Hausmania
</title>
148 <link>http://people.skolelinux.org/pere/blog/Oslo_community_mesh_network___with_NUUG_and_Hackeriet_at_Hausmania.html
</link>
149 <guid isPermaLink=
"true">http://people.skolelinux.org/pere/blog/Oslo_community_mesh_network___with_NUUG_and_Hackeriet_at_Hausmania.html
</guid>
150 <pubDate>Fri,
11 Oct
2013 14:
10:
00 +
0200</pubDate>
151 <description><p
>Wireless mesh networks are self organising and self healing
152 networks that can be used to connect computers across small and large
153 areas, depending on the radio technology used. Normal wifi equipment
154 can be used to create home made radio networks, and there are several
155 successful examples like
156 <a href=
"http://www.freifunk.net/
">Freifunk
</a
> and
157 <a href=
"http://www.awmn.net/
">Athens Wireless Metropolitan Network
</a
>
159 <a href=
"http://en.wikipedia.org/wiki/List_of_wireless_community_networks_by_region#Greece
">wikipedia
160 for a large list
</a
>) around the globe. To give you an idea how it
161 work, check out the nice overview of the Kiel Freifunk community which
162 can be seen from their
163 <a href=
"http://freifunk.in-kiel.de/ffmap/nodes.html
">dynamically
164 updated node graph and map
</a
>, where one can see how the mesh nodes
165 automatically handle routing and recover from nodes disappearing.
166 There is also a small community mesh network group in Oslo, Norway,
167 and that is the main topic of this blog post.
</p
>
169 <p
>I
've wanted to check out mesh networks for a while now, and hoped
170 to do it as part of my involvement with the
<a
171 href=
"http://www.nuug.no/
">NUUG member organisation
</a
> community, and
172 my recent involvement in
173 <a href=
"https://wiki.debian.org/FreedomBox
">the Freedombox project
</a
>
174 finally lead me to give mesh networks some priority, as I suspect a
175 Freedombox should use mesh networks to connect neighbours and family
176 when possible, given that most communication between people are
177 between those nearby (as shown for example by research on Facebook
178 communication patterns). It also allow people to communicate without
179 any central hub to tap into for those that want to listen in on the
180 private communication of citizens, which have become more and more
181 important over the years.
</p
>
183 <p
>So far I have only been able to find one group of people in Oslo
184 working on community mesh networks, over at the hack space
185 <a href=
"http://hackeriet.no/
">Hackeriet
</a
> at Husmania. They seem to
186 have started with some Freifunk based effort using OLSR, called
187 <a href=
"http://oslo.freifunk.net/index.php?title=Main_Page
">the Oslo
188 Freifunk project
</a
>, but that effort is now dead and the people
189 behind it have moved on to a batman-adv based system called
190 <a href=
"http://meshfx.org/trac
">meshfx
</a
>. Unfortunately the wiki
191 site for the Oslo Freifunk project is no longer possible to update to
192 reflect this fact, so the old project page can
't be updated to point to
193 the new project. A while back, the people at Hackeriet invited people
194 from the Freifunk community to Oslo to talk about mesh networks. I
195 came across this video where Hans Jørgen Lysglimt interview the
196 speakers about this talk (from
197 <a href=
"https://www.youtube.com/watch?v=N2Kd7CLkhSY
">youtube
</a
>):
</p
>
199 <p
><iframe width=
"420" height=
"315" src=
"https://www.youtube.com/embed/N2Kd7CLkhSY
" frameborder=
"0" allowfullscreen
></iframe
></p
>
201 <p
>I mentioned OLSR and batman-adv, which are mesh routing protocols.
202 There are heaps of different protocols, and I am still struggling to
203 figure out which one would be
"best
" for some definitions of best, but
204 given that the community mesh group in Oslo is so small, I believe it
205 is best to hook up with the existing one instead of trying to create a
206 completely different setup, and thus I have decided to focus on
207 batman-adv for now. It sure help me to know that the very cool
208 <a href=
"http://www.servalproject.org/
">Serval project in Australia
</a
>
209 is using batman-adv as their meshing technology when it create a self
210 organizing and self healing telephony system for disaster areas and
211 less industrialized communities. Check out this cool video presenting
213 <a href=
"https://www.youtube.com/watch?v=
30qNfzJCQOA
">youtube
</a
>):
</p
>
215 <p
><iframe width=
"560" height=
"315" src=
"https://www.youtube.com/embed/
30qNfzJCQOA
" frameborder=
"0" allowfullscreen
></iframe
></p
>
217 <p
>According to the wikipedia page on
218 <a href=
"http://en.wikipedia.org/wiki/Wireless_mesh_network
">Wireless
219 mesh network
</a
> there are around
70 competing schemes for routing
220 packets across mesh networks, and OLSR, B.A.T.M.A.N. and
221 B.A.T.M.A.N. advanced are protocols used by several free software
222 based community mesh networks.
</p
>
224 <p
>The batman-adv protocol is a bit special, as it provide layer
2
225 (as in ethernet ) routing, allowing ipv4 and ipv6 to work on the same
226 network. One way to think about it is that it provide a mesh based
227 vlan you can bridge to or handle like any other vlan connected to your
228 computer. The required drivers are already in the Linux kernel at
229 least since Debian Wheezy, and it is fairly easy to set up. A
230 <a href=
"http://www.open-mesh.org/projects/batman-adv/wiki/Quick-start-guide
">good
231 introduction
</a
> is available from the Open Mesh project. These are
232 the key settings needed to join the Oslo meshfx network:
</p
>
234 <p
><table
>
235 <tr
><th
>Setting
</th
><th
>Value
</th
></tr
>
236 <tr
><td
>Protocol / kernel module
</td
><td
>batman-adv
</td
></tr
>
237 <tr
><td
>ESSID
</td
><td
>meshfx@hackeriet
</td
></tr
>
238 <td
>Channel / Frequency
</td
><td
>11 /
2462</td
></tr
>
239 <td
>Cell ID
</td
><td
>02:BA:
00:
00:
00:
01</td
>
240 </table
></p
>
242 <p
>The reason for setting ad-hoc wifi Cell ID is to work around bugs
243 in firmware used in wifi card and wifi drivers. (See a nice post from
245 "<a href=
"http://tiebing.blogspot.no/
2009/
12/ad-hoc-cell-splitting-re-post-original.html
">Information
246 about cell-id splitting, stuck beacons, and failed IBSS merges!
</a
>
247 for details.) When these settings are activated and you have some
248 other mesh node nearby, your computer will be connected to the mesh
249 network and can communicate with any mesh node that is connected to
250 any of the nodes in your network of nodes. :)
</p
>
252 <p
>My initial plan was to reuse my old Linksys WRT54GL as a mesh node,
253 but that seem to be very hard, as I have not been able to locate a
254 firmware supporting batman-adv. If anyone know how to use that old
255 wifi access point with batman-adv these days, please let me know.
</p
>
257 <p
>If you find this project interesting and want to join, please join
258 us on IRC, either channel
259 <a href=
"irc://irc.freenode.net/#oslohackerspace
">#oslohackerspace
</a
>
260 or
<a href=
"irc://irc.freenode.net/#nuug
">#nuug
</a
> on
261 irc.freenode.net.
</p
>
263 <p
>While investigating mesh networks in Oslo, I came across an old
264 research paper from the university of Stavanger and Telenor Research
265 and Innovation called
266 <a href=
"http://folk.uio.no/paalee/publications/netrel-egeland-iswcs-
2008.pdf
">The
267 reliability of wireless backhaul mesh networks
</a
> and elsewhere
268 learned that Telenor have been experimenting with mesh networks at
269 Grünerløkka in Oslo. So mesh networks are also interesting for
270 commercial companies, even though Telenor discovered that it was hard
271 to figure out a good business plan for mesh networking and as far as I
272 know have closed down the experiment. Perhaps Telenor or others would
273 be interested in a cooperation?
</p
>
275 <p
><strong
>Update
2013-
10-
12</strong
>: I was just
276 <a href=
"http://lists.alioth.debian.org/pipermail/freedombox-discuss/
2013-October/
005900.html
">told
277 by the Serval project developers
</a
> that they no longer use
278 batman-adv (but are compatible with it), but their own crypto based
279 mesh system.
</p
>
284 <title>Skolelinux / Debian Edu
7.1 install and overview video from Marcelo Salvador
</title>
285 <link>http://people.skolelinux.org/pere/blog/Skolelinux___Debian_Edu_7_1_install_and_overview_video_from_Marcelo_Salvador.html
</link>
286 <guid isPermaLink=
"true">http://people.skolelinux.org/pere/blog/Skolelinux___Debian_Edu_7_1_install_and_overview_video_from_Marcelo_Salvador.html
</guid>
287 <pubDate>Tue,
8 Oct
2013 17:
10:
00 +
0200</pubDate>
288 <description><p
>The other day I was pleased and surprised to discover that Marcelo
289 Salvador had published a
290 <a href=
"https://www.youtube.com/watch?v=w-GgpdqgLFc
">video on
291 Youtube
</a
> showing how to install the standalone Debian Edu /
292 Skolelinux profile. This is the profile intended for use at home or
293 on laptops that should not be integrated into the provided network
294 services (no central home directory, no Kerberos / LDAP directory etc,
295 in other word a single user machine). The result is
11 minutes long,
296 and show some user applications (seem to be rather randomly picked).
297 Missed a few of my favorites like celestia, planets and chromium
298 showing the
<a href=
"http://www.zygotebody.com/
">Zygote Body
3D model
299 of the human body
</a
>, but I guess he did not know about those or find
300 other programs more interesting. :) And the video do not show the
301 advantages I believe is one of the most valuable featuers in Debian
302 Edu, its central school server making it possible to run hundreds of
303 computers without hard drives by installing one central
304 <a href=
"http://www.ltsp.org/
">LTSP server
</a
>.
</p
>
306 <p
>Anyway, check out the video, embedded below and linked to above:
</p
>
308 <iframe width=
"420" height=
"315" src=
"http://www.youtube.com/embed/w-GgpdqgLFc
" frameborder=
"0" allowfullscreen
></iframe
>
310 <p
>Are there other nice videos demonstrating Skolelinux? Please let
311 me know. :)
</p
>