HSMM-Pi
HSMM-Pi is a set of tools designed to easily configure the Raspberry Pi to function as a High-Speed Multimedia (HSMM) wireless mesh node, compatible with Broadband Hamnet (BBHN) and AREDN. Mesh networks offer amateur radio operators (hams) the ability to operate high-speed data networks in the frequencies shared with unlicenced users of 802.11 b/g/n networking equipment. Hams can operate HSMM or BBHN at higher power with larger antennas than are available to unlicensed users. The HSMM-Pi project makes it possible to run an HSMM mesh node on the Raspberry Pi. The project has been tested to work on other embedded computing platforms, including the BeagleBone and BeagleBone Black.
The HSMM-Pi project can used by people not possessing an amateur radio license so long as they are in compliance with the transmission rules set by the FCC or the local regulating body. This typically means sticking with the WiFi antenna provided with your WiFi adapter.
HSMM-Pi Blog:
http://hsmmpi.wordpress.com/
For a video tour, see the following YouTube video:
http://www.youtube.com/watch?v=ltUAw02vfqk
The project consists of a PHP web application that is used to configure and monitor the mesh node, and an installation shell script that installs dependencies and puts things in the right spots.
The HSMM-Pi project is designed to run on Ubuntu 12.04 systems. Rather than providing an OS image for HSMM-Pi, I've instead created an installation script that will transform a newly-imaged host into an HSMM-Pi node. This has several benefits:
- Greater transparency: You can see exactly which changes are made to the base system by looking at the install shell script.
- Easier to port to more platforms: Any platform that runs the supported Ubuntu releases ought to be capable of running HSMM-Pi
- Easier to host: I only need to post the installation script and webapp files on Github and it's done.
- Easier to seek support: Ubuntu is widely used and supported, no need to introduce another customization.
Hardware Requirements
HSMM-Pi has been tested to work with the Raspberry Pi running the Raspbian OS, with the BeagleBone running Debian, and with the BeagleBone Black running Ubuntu 12.04 from the onboard eMMC flash memory. The requirements for each are listed below.
Raspberry-Pi Node:
- Raspberry Pi (any model)
- USB WiFi adapter (tested with the N150 adapter using the Ralink 5370 chipset, and with the Alfa AWSU036NH), or built-in WiFi adapter (on Raspberry Pi 3)
- SD memory card (4GB minimum)
BeagleBone Node:
- BeagleBone or BeagleBone Black
- USB WiFi adapter (tested with the N150 adapter using the Ralink 5370 chipset)
- SD memory card (4GB minimum) (in the case of BeagleBone Black, used for initial imaging of the eMMC flash memory only)
Modes
HSMM-Pi has two modes: Internal and Mesh Gateway. A description of each is provided below.
Mesh Gateway Mode
A node in Mesh Gateway mode routes traffic throughout the mesh, and provides the mesh with Internet access through the wired Ethernet port. The gateway obtains a DHCP lease on the wired interface, and advertises its Internet link to mesh nodes using OLSR.
Internal Mode
A node in Internal mode routes traffic throughout the mesh and provides mesh access to any hosts connected to its wired Ethernet port. The node in this mode runs a DHCP server that issues DHCP leases to any hosts on the wired connection. It also runs a DNS server that can provide name resolution for both mesh nodes and Internet hosts. The following diagram shows how the two types of nodes can be deployed:
There could be any number of mesh nodes in the Ad-Hoc WiFi Network. The route among the nodes is managed entirely with OLSR.
I've done all of my testing with N150 USB wifi adapters that use the Ralink 5370 wireless chipset. These adapters are cheap (~$7 USD), compact, and easy to come by. They also use drivers that are bundled with most Ubuntu distributions, making setup easy. The N150 adapter tested included a threaded antenna connector that should make it easy to add a linear amplifier and aftermarket antenna (outside the scope of the HSMM-Pi project).
Raspberry Pi Installation
- Download the Raspbian Jessie or Raspbian Jessie Lite disk image. The Lite image is suitable for headless installations as it omits the graphical interface, web browser, etc.
- Write the image to an SD memory card. This involves formatting the SD card; I recommend the steps described at http://elinux.org/RPi_Easy_SD_Card_Setup
- Insert the card into a Raspberry Pi
- Connect the wired Ethernet port on the Pi to a network with Internet access
- Apply power to the Pi
- Login to the Pi through an SSH session, the console, or the terminal application. The username is "pi" and the password is "raspberry".
-
Run the Raspberry Pi Setup program:
sudo raspi-config
- Expand the filesystem to fill the SD memory card
- Change the password for the "pi" account
- If installing over an SSH connection to the Pi, then I recommend you install "screen" (
sudo apt-get install screen
) to ensure that the installation script is not stopped prematurely if you lose connectivity with the Pi. This is optional, but I highly recommend using screen if installing over the network. You can find more info on screen here: http://linux.die.net/man/1/screen
-
Run the following commands to download the HSMM-Pi project and install
sudo apt-get update
sudo apt-get install -y git
git clone https://github.com/urlgrey/hsmm-pi.git
cd hsmm-pi
sh install.sh
- Login to the web application on the Pi:
http://(wired Ethernet IP of the node):8080/
- Access the Admin account using the username "admin" and password "changeme".
- Change the password for HSMM-Pi
- Configure as either an Internal or Gateway node
BeagleBone Black Installation
- Download the latest BeagleBone Black Ubuntu 12.04 image: http://www.armhf.com/index.php/boards/beaglebone-black/#precise
- Write the image to an SD memory card using the steps on the page referenced in the previous step
- Insert the SD card into a BeagleBone Black board
- Apply power to the BeagleBone Black
- Login to the BeagleBone Black through an SSH session or the console using the 'ubuntu' account
- Transfer the image to the running BeagleBone Black using SCP
- Write the image to the eMMC flash memory using the steps mentioned in the first step here.
- Wait for all 4 LEDs to go solid (could take several minutes)
- Shutdown the Beaglbone Black (sudo /sbin/init 0)
- Remove the memory card from the BeagleBone Black
- Apply power to the BeagleBone Black
- Login to the BeagleBone Black through an SSH session or the console using the 'ubuntu' account
- Change the password for the 'ubuntu' account
-
Install the development tools necessary to build OLSRD and retrieve the HSMM-Pi project:
sudo apt-get upgrade
sudo apt-get install make gcc git
- If installing over an SSH connection, then I recommend you install 'screen' (sudo apt-get install screen) to ensure that the installation script is not stopped prematurely if you lose connectivity. This is optional, but I highly recommend using screen if installing over the network. You can find more info on screen here: http://linux.die.net/man/1/screen
-
Run the following commands to download the HSMM-Pi project and install
git clone https://github.com/urlgrey/hsmm-pi.git
cd hsmm-pi
sh install.sh
- Login to the web application:
http://(wired Ethernet IP of the node):8080/
- Access the Admin account using the 'admin' username and 'changeme' password.
- Change the password for HSMM-Pi
- Configure as either an Internal or Gateway node
Upgrade Steps
This is experimental, and you should fall back to a fresh installation if things aren't functioning as you'd expect. This is supported only on the HEAD of the master branch at this time.
- Login to the host using SSH or the console
-
Run the following commands to upgrade:
cd ~/hsmm-pi
git pull
sh install.sh
- Access the web UI and check the configuration. Save the Network and Location settings, even if no changes are needed.
-
If the save operation fails, then you might need to replace the SQLite database file due to database schema changes. Run the following command:
cd ~/hsmm-pi/
sudo cp src/var/data/hsmm-pi/hsmm-pi.sqlite /var/data/hsmm-pi/
- Repeat the step of reviewing and saving the configuration through the web UI.
Internal Mesh Node Configuration
This represents the minimum set of steps:
- Select Admin->Network from the menubar
- Configure the WiFi interface:
- Specify an IP address that will be unique throughout the mesh network. This will be different every mesh node. A default will be provided based on the last 3 fragments of the WiFi adapter MAC address.
- Configure the Wired interface:
- Set the Wired interface mode to LAN
- Configure the Mesh settings
- Specify your node name, likely a composition of your callsign and a unique number in your mesh (i.e. KK6DCI-7)
- Click 'Save'
- If successful, click the 'Reboot' button in the alert and proceed.
Gateway Node Configuration
This represents the minimum set of steps:
- Select Admin->Network from the menubar
- Configure the WiFi interface:
- Specify an IP address that will be unique throughout the mesh network. This will be different every mesh node. A default will be provided based on the last 3 fragments of the WiFi adapter MAC address.
- Configure the Wired interface:
- Set the Wired interface mode to WAN
- Configure the Mesh settings
- Specify your node name, likely a composition of your callsign and a unique number in your mesh (i.e. KK6DCI-7)
- Click 'Save'
- If successful, click the 'Reboot' button in the alert and proceed.
FAQ
A list of frequently asked questions can be found on our wiki, at the FAQ page.