HSMM-Pi is a set of tools designed to easily configure the Raspberry Pi to function as a High-Speed Multimedia (HSMM) or Broadband-Hamnet (BBHN) wireless node. HSMM and BBHN offer radio amateurs (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 or BBHN 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.
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 (256MB or 512MB) or Raspberry Pi 2
- USB WiFi adapter (tested with the N150 adapter using the Ralink 5370 chipset, and with the Alfa AWSU036NH)
- 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)
The HSMM-Pi can function as an internal mesh node or as a gateway mesh node. A description of each is provided below.
The Mesh Gateway is capable of routing traffic throughout the mesh, and provides an Internet link to the mesh 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.
This node is capable of routing traffic throughout the mesh and providing mesh access to any hosts connected to its wired Ethernet port. The node can run 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 mesh nodes and Internet hosts. The following sequence shows how the two types of nodes can be deployed:
(Client1) --> (Switch) --> (Internal Mesh Node) -->
(Ad-Hoc WiFi Network) --> (Mesh Gateway) --> (Internet)
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).
-
Download the Raspbian Wheezy 2015-02-16 disk image on your Mac/PC/whatever (http://downloads.raspberrypi.org/raspbian/images/raspbian-2015-02-17/)
-
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, either through an SSH session or the console, using the 'pi' account
-
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
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 'admin' username and 'changeme' password.
-
Change the password for HSMM-Pi
-
Configure as either an Internal or Gateway node
-
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
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.
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 amatuer radio callsign (i.e. KK6DCI)
- 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.
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 amatuer radio callsign (i.e. KK6DCI)
- 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.
A list of frequently asked questions can be found on our wiki, at the FAQ page.