/ptp-cab

Personal Telco Project node configuration and build machinery

Primary LanguageShell

Personal Telco Project packages for OpenWrt

For more information about OpenWrt, visit https://openwrt.org/

For more information about the Personal Telco Project, visit https://personaltelco.net/wiki/

Authors: Russell Senior (blame me), Jason MacArthur, Keegan Quinn (thank them)

This is a second whack at the problem, particularly of .config creation, based on an initial stab by Keegan Quinn. This version starts from the existing state of package selections, and thus represents a smaller departure from the status quo than Keegan's version did, which allows it to be an immediately useful replacement. Over time, more functionality will be moved here.

This feed should be used in combination with the FooCab files-master "files" overlay creator available by cloning the git tree, thusly:

git clone git://git.personaltelco.net/files-master

This will allow anyone to build bog-standard Personal Telco Project nodes (you need only coordinate with us to get a key to attach to the virtual OLSR-over-OpenVpn mesh).

Concept

The goal of this project is to assist in generating Personal Telco OpenWrt node device images, initially just by automating the creation of .config files used in building OpenWrt.

Usage

Add to your feeds.conf:

src-git ptpcab git://github.com/RussellSenior/ptpcab.git

You feeds.conf must also minimally include:

src-git packages git://nbd.name/packages.git

Then retrieve and install the packages:

scripts/feeds update -a 
scripts/feeds install -a

Because the standard node disables two default packages, firewall and ppp, and because OpenWrt dependency resolution does not support automatic de-selection of packages, and until something comes along that is better, do the following:

For your chosen target (alix2, wgt634u, atheros, net45xx), copy the starting config to .config:

cp feeds/ptpcab/ptp-node/files/.config-alix2 .config

The OpenWrt buildroot uses the CONFIG_DOWNLOAD_FOLDER variable to store downloaded source tarballs. If you have an existing archive of downloaded tarballs, adapt as needed. For example, building on gentoo systems, a value of:

CONFIG_DOWNLOAD_FOLDER="/usr/portage/distfiles"

is preferred (make sure you have permission to write there). Complete the configuration using the defconfig make target:

make defconfig

In the case of alix2 and net45xx, the default is to build as an ethernet-only gateway. If you are installing a radio as well,

make menuconfig

and select the desired wireless driver from the PTP menu (this will also select a set of wireless utilities to accompany the driver).

This will provide you an appropriate .config with which to build. The other essential component to a Personal Telco Project node is the set of configuration files. OpenWrt allows the builder to override files that are baked into the image filesystem by means of a "files" tree. Compute one, consisting of configuration files and local tweaks using the files-master FOOCAB.pl script. In the files-master directory, edit the tab-delimited nodedb.txt file, and use a command like:

perl FOOCAB.pl --host <hostname>

to create a provisional tree in a local directory called "output". Move it to one called "files" in the OpenWrt $TOPDIR, and compile using something like this:

time make -j8 BUILD_LOG=1 IGNORE_ERRORS=m V=99