urlgrey / hsmm-pi

A set of tools to easily configure the Raspberry Pi to function as a High-Speed Multimedia (HSMM) wireless node.
MIT License
370 stars 92 forks source link

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:

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:

BeagleBone Node:

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:

Diagram

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

  1. 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.
  2. 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
  3. Insert the card into a Raspberry Pi
  4. Connect the wired Ethernet port on the Pi to a network with Internet access
  5. Apply power to the Pi
  6. Login to the Pi through an SSH session, the console, or the terminal application. The username is "pi" and the password is "raspberry".
  7. Run the Raspberry Pi Setup program:

    sudo raspi-config
  8. Expand the filesystem to fill the SD memory card
  9. Change the password for the "pi" account
  10. 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
  11. 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
  12. Login to the web application on the Pi: http://(wired Ethernet IP of the node):8080/
  13. Access the Admin account using the username "admin" and password "changeme".
  14. Change the password for HSMM-Pi
  15. Configure as either an Internal or Gateway node

BeagleBone Black Installation

  1. Download the latest BeagleBone Black Ubuntu 12.04 image: http://www.armhf.com/index.php/boards/beaglebone-black/#precise
  2. Write the image to an SD memory card using the steps on the page referenced in the previous step
  3. Insert the SD card into a BeagleBone Black board
  4. Apply power to the BeagleBone Black
  5. Login to the BeagleBone Black through an SSH session or the console using the 'ubuntu' account
  6. Transfer the image to the running BeagleBone Black using SCP
  7. Write the image to the eMMC flash memory using the steps mentioned in the first step here.
  8. Wait for all 4 LEDs to go solid (could take several minutes)
  9. Shutdown the Beaglbone Black (sudo /sbin/init 0)
  10. Remove the memory card from the BeagleBone Black
  11. Apply power to the BeagleBone Black
  12. Login to the BeagleBone Black through an SSH session or the console using the 'ubuntu' account
  13. Change the password for the 'ubuntu' account
  14. 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
  15. 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
  16. 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
  17. Login to the web application: http://(wired Ethernet IP of the node):8080/
  18. Access the Admin account using the 'admin' username and 'changeme' password.
  19. Change the password for HSMM-Pi
  20. 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.

  1. Login to the host using SSH or the console
  2. Run the following commands to upgrade:

    cd ~/hsmm-pi
    git pull
    sh install.sh
  3. Access the web UI and check the configuration. Save the Network and Location settings, even if no changes are needed.
  4. 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/
  5. Repeat the step of reviewing and saving the configuration through the web UI.

Internal Mesh Node Configuration

This represents the minimum set of steps:

  1. Select Admin->Network from the menubar
  2. Configure the WiFi interface:
    1. 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.
  3. Configure the Wired interface:
    1. Set the Wired interface mode to LAN
  4. Configure the Mesh settings
    1. Specify your node name, likely a composition of your callsign and a unique number in your mesh (i.e. KK6DCI-7)
  5. Click 'Save'
  6. If successful, click the 'Reboot' button in the alert and proceed.

Gateway Node Configuration

This represents the minimum set of steps:

  1. Select Admin->Network from the menubar
  2. Configure the WiFi interface:
    1. 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.
  3. Configure the Wired interface:
    1. Set the Wired interface mode to WAN
  4. Configure the Mesh settings
    1. Specify your node name, likely a composition of your callsign and a unique number in your mesh (i.e. KK6DCI-7)
  5. Click 'Save'
  6. 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.