mirror of
https://github.com/servalproject/serval-dna.git
synced 2025-01-02 11:26:45 +00:00
576 lines
23 KiB
Markdown
576 lines
23 KiB
Markdown
Serval DNA on OpenWRT
|
|
=====================
|
|
[Serval Project], March 2014
|
|
|
|
These are instructions for building, developing and releasing [Serval DNA][]
|
|
for [OpenWRT][] 12.09 “Attitude Adjustment” released in April, 2013.
|
|
|
|
OpenWRT release 12.09 is the one used to create firmware for the [Serval Mesh
|
|
Extender][], so these instructions should be suitable for building a Mesh
|
|
Extender firmware image.
|
|
|
|
The OpenWRT build system
|
|
------------------------
|
|
|
|
The [OpenWRT 12.09 Buildroot][] package itself contains almost no code that
|
|
ends up as an executable on the target hardware. Instead, it is an elaborate
|
|
menu-based configuration and build system that downloads and cross-compiles a
|
|
chosen set of *packages* from source code and aggregates the compiled binaries
|
|
into a firmware image.
|
|
|
|
Buildroot must be configured with a list of package providers called *feeds*.
|
|
Each [OpenWRT feed][] contains a directory tree with a structure like
|
|
`$category_name/$package_name/Makefile` that contains one [OpenWRT Makefile][]
|
|
per package (plus optionally some OpenWRT-specific config files and patches).
|
|
|
|
Each [OpenWRT Makefile][] contains commands for downloading and compiling a
|
|
single package from source.
|
|
|
|
Before building OpenWRT, its list of feeds must be configured, and each feed
|
|
updated by downloading copies of its contents. Once this is done, the OpenWRT
|
|
build is invoked by running the `make` command in the OpenWRT source directory,
|
|
which progresses through the following steps:
|
|
|
|
- checks that all software tools and libraries it depends on are present,
|
|
- on the first invocation only, runs a manual component selection and
|
|
configuration dialog called *menuconfig*
|
|
- for each selected package, invokes the package's [OpenWRT Makefile][], which
|
|
downloads the package's source code and cross-compiles it for the selected
|
|
target architecture
|
|
- aggregates all compiled components into a firmware image
|
|
|
|
During the build, continuous Internet access is required to allow downloading
|
|
of packages.
|
|
|
|
OpenWRT Dependencies
|
|
--------------------
|
|
|
|
You will need to install the following development tools and packages before
|
|
running an OpenWRT build:
|
|
|
|
* [GNU make][] -- dependency-driven software build utility
|
|
* [getopt][] -- command-line option parsing utility, available in the
|
|
[util-linux][] package
|
|
* [GNU coreutils][] -- file manipulation utilities like [cp(1)][], etc.
|
|
* [gcc][] and [g++][]-- GNU C and C++ compilers
|
|
* [binutils][] -- GNU assembler, linker and binary executable utilities
|
|
* [C standard library][] development -- headers and linkage binaries
|
|
* [ncurses][] -- terminal-mode user interface headers and library
|
|
* [zlib][] -- compression library headers and library
|
|
* [GNU awk][] -- programmable text processing utility
|
|
* [flex][] -- fast lexical analyzer generator
|
|
* [unzip][] -- file de-archive and de-compression utility
|
|
* [bzip2][] -- file compression utility
|
|
* [patch][] -- source code diff-style patch applicator
|
|
* [Perl 5][] -- scripting language
|
|
* [Python][] -- scripting language
|
|
* [GNU wget][] -- command-line HTTP client utility
|
|
* [Git][] -- distributed source code version control
|
|
* [GNU tar][] -- directory tree archiver utility
|
|
* [Subversion][] -- source code version control
|
|
* [GNU findutils][] -- directory tree traversal and search utility
|
|
* [pkg-config][] -- package installation metadata utility
|
|
* [gettext][] -- GNU language localisation tool
|
|
|
|
[Debian][] uses [eglibc][] as its [C standard library][], but other platforms
|
|
may use [GNU libc][].
|
|
|
|
The following command will install and/or upgrade all the necessary packages on
|
|
[Debian][] and on derivatives like [Ubuntu][]:
|
|
|
|
$ sudo apt-get install make util-linux coreutils gcc g++ binutils libc6-dev \
|
|
libncurses5-dev zlib1g-dev gawk flex unzip bzip2 \
|
|
patch perl python wget git tar subversion \
|
|
pkg-config gettext
|
|
$
|
|
|
|
Download OpenWRT 12.09
|
|
----------------------
|
|
|
|
The [OpenWRT 12.09 Buildroot][] package is available as a [Git][] repository,
|
|
which is the recommended way to download it:
|
|
|
|
$ mkdir -p 12.09
|
|
$ cd 12.09
|
|
$ git clone -q git://git.openwrt.org/12.09/openwrt.git
|
|
$ cd openwrt
|
|
$
|
|
|
|
If this does not work, see the [OpenWRT Buildroot installation HOWTO][], which
|
|
may have changed since this was written.
|
|
|
|
Update OpenWRT package feeds
|
|
----------------------------
|
|
|
|
Make sure that the feeds you want are configured, by creating a `feeds.conf`
|
|
file. If this file is missing, the `feeds.conf.default` file is used, which,
|
|
in the [OpenWRT 12.09 Buildroot][] repository is:
|
|
|
|
src-svn packages svn://svn.openwrt.org/openwrt/branches/packages_12.09
|
|
src-svn xwrt http://x-wrt.googlecode.com/svn/trunk/package
|
|
src-svn luci http://svn.luci.subsignal.org/luci/branches/luci-0.11/contrib/package
|
|
src-git routing git://github.com/openwrt-routing/packages.git;for-12.09.x
|
|
#src-svn phone svn://svn.openwrt.org/openwrt/feeds/phone
|
|
#src-svn efl svn://svn.openwrt.org/openwrt/feeds/efl
|
|
#src-svn xorg svn://svn.openwrt.org/openwrt/feeds/xorg
|
|
#src-svn desktop svn://svn.openwrt.org/openwrt/feeds/desktop
|
|
#src-svn xfce svn://svn.openwrt.org/openwrt/feeds/xfce
|
|
#src-svn lxde svn://svn.openwrt.org/openwrt/feeds/lxde
|
|
#src-link custom /usr/src/openwrt/custom-feed
|
|
|
|
Lines beginning with `#` are comments. Once the feeds are configured, fetch
|
|
them all:
|
|
|
|
$ cd 12.09/openwrt
|
|
$ ./scripts/feeds update
|
|
Updating feed 'packages' from 'svn://svn.openwrt.org/openwrt/branches/packages_12.09' ...
|
|
Updating '.':
|
|
At revision 39583.
|
|
Create index file './feeds/packages.index'
|
|
Updating feed 'xwrt' from 'http://x-wrt.googlecode.com/svn/trunk/package' ...
|
|
Updating '.':
|
|
At revision 4987.
|
|
Create index file './feeds/xwrt.index'
|
|
Updating feed 'luci' from 'http://svn.luci.subsignal.org/luci/branches/luci-0.11/contrib/package' ...
|
|
Updating '.':
|
|
At revision 9955.
|
|
Create index file './feeds/luci.index'
|
|
Updating feed 'routing' from 'git://github.com/openwrt-routing/packages.git;for-12.09.x' ...
|
|
Already up-to-date.
|
|
Create index file './feeds/routing.index'
|
|
$
|
|
|
|
Build OpenWRT without Serval DNA
|
|
--------------------------------
|
|
|
|
Before building OpenWRT with a Serval feed, build OpenWRT out of the box, to
|
|
ensure that all dependencies are met and to resolve any other build issues:
|
|
|
|
$ cd 12.09/openwrt
|
|
$ make
|
|
Collecting package info: done
|
|
Collecting target info: done
|
|
Checking 'working-make'... ok.
|
|
Checking 'case-sensitive-fs'... ok.
|
|
Checking 'getopt'... ok.
|
|
Checking 'fileutils'... ok.
|
|
Checking 'working-gcc'... ok.
|
|
Checking 'working-g++'... ok.
|
|
Checking 'ncurses'... ok.
|
|
Checking 'zlib'... ok.
|
|
Checking 'gawk'... ok.
|
|
Checking 'unzip'... ok.
|
|
Checking 'bzip2'... ok.
|
|
Checking 'patch'... ok.
|
|
Checking 'perl'... ok.
|
|
Checking 'python'... ok.
|
|
Checking 'wget'... ok.
|
|
Checking 'git'... ok.
|
|
Checking 'gnutar'... ok.
|
|
Checking 'svn'... ok.
|
|
Checking 'gnu-find'... ok.
|
|
Checking 'getopt-extended'... ok.
|
|
Checking 'non-root'... ok.
|
|
make[2]: Entering directory `/home/username/12.09/openwrt/scripts/config'
|
|
...
|
|
|
|
If all dependencies are ok, OpenWRT's interactive *menuconfig* screen will
|
|
appear. (This only happens the first time that a build has been run. On all
|
|
subsequent builds, the *menuconfig* step will be skipped, but can be run
|
|
manually with the `make menuconfig` command.)
|
|
|
|
The following example *meniconfig* configuration chooses the target system of
|
|
the [Serval Mesh Extender][] which is based on the [TP-LINK TL-MR3020][]
|
|
wireless router, models 1.7 and 1.8 (for more information, see the [OpenWRT
|
|
TP-LINK TL-MR3020][] page). The remaining settings are taken from the
|
|
[config.ar71xx.generic][] file in the pre-build binary supplied by OpenWRT.
|
|
Alter these settings to suit your needs:
|
|
|
|
* Target System: Atheros AR7xxx/AR9xxx
|
|
* Subtarget: Generic
|
|
* Target Profile: TP-LINK LP-MR3020
|
|
* Target Images: (default)
|
|
* Global build settings:
|
|
* Compile with support for patented functionality
|
|
* Enable shadow password support
|
|
* Collect kernel debug information
|
|
* Compile the kernel with SysRq support
|
|
* Enable process core dump support
|
|
* Enable printk timestamps
|
|
* Enable IPv6 support in packages
|
|
* Compile certain packages parallelized
|
|
* Use top-level make jobserver for packages
|
|
* Binary stripping method: sstrip
|
|
* Preferred standard C++ library: uClibc++
|
|
* Advanced configuration options (for developers):
|
|
* Automatic rebuild of packages
|
|
* Enable log files during build process
|
|
* Toolchain options:
|
|
* Binutils version: binutils 2.22
|
|
* GCC compiler Version: gcc 4.6.x with Linaro enhancements
|
|
* Build/install c++ compiler and libstdc++?
|
|
* C Library implementation: Use uClibc
|
|
* uClibc Version: uClibc 0.9.33.2
|
|
* Build gdb
|
|
* Build the OpenWrt Image Builder
|
|
* Build the OpenWrt SDK
|
|
* Build the OpenWrt based Toolchain
|
|
* Image configuration:
|
|
* Preinit configuration options:
|
|
* Suppress stderr messages during preinit
|
|
* Failsafe wait timeout: 2
|
|
* IP address for preinit network messages: 192.168.1.1
|
|
* Netmask for preinit network messages: 255.255.255.0
|
|
* Broadcast address for preinit network messages: 192.168.1.255
|
|
* Init configuration options:
|
|
* PATH for regular boot: /bin:/sbin:/usr/bin:/usr/sbin
|
|
* Init command: /sbin/init
|
|
* Suppress stderr messages of init
|
|
* Version configuration options:
|
|
* Release distribution: OpenWrt
|
|
* Release version nickname: Attitude Adjustment
|
|
* Release version number: 12.09
|
|
* Release repository: http://downloads.openwrt.org/attitude_adjustment/12.09.1/%S/packages
|
|
* Base system:
|
|
* base-files: Y
|
|
* block-mount: M
|
|
* bridge: M
|
|
* busybox: Y
|
|
* dnsmasq: Y
|
|
* dnsmasq-dhcpv6: M
|
|
* dropbear: Y
|
|
* ead: M
|
|
* firewall: Y
|
|
* hotplug2: Y
|
|
* libc: ---
|
|
* libgcc: ---
|
|
* libpthread: M
|
|
* librt: M
|
|
* libstdcpp: M
|
|
* mtd: Y
|
|
* netifd: ---
|
|
* nvram: M
|
|
* om: M
|
|
* opkg: Y
|
|
* qos: M
|
|
* resolveip: M
|
|
* swconfig: Y
|
|
* ubus: ---
|
|
* ubusd: ---
|
|
* uci: Y
|
|
* udev: M
|
|
* wireless: Y
|
|
|
|
Exit *autoconfig*, saving the OpenWRT configuration file. The
|
|
download-and-build phase will commence, and can take the better part of an
|
|
hour, depending on Internet download speeds and CPU/memory performance:
|
|
|
|
*** End of OpenWrt configuration.
|
|
...
|
|
make[1] world
|
|
make[2] tools/install
|
|
make[3] -C tools/m4 compile
|
|
make[3] -C tools/m4 install
|
|
make[3] -C tools/sed compile
|
|
...
|
|
make[3] -C target/sdk install
|
|
make[3] -C target/imagebuilder install
|
|
make[3] -C target/toolchain install
|
|
make[2] package/index
|
|
$
|
|
|
|
The built firmware images are in the `bin` directory:
|
|
|
|
$ ls -s -h -1 bin
|
|
total 182M
|
|
5.0M kernel-debug.tar.bz2
|
|
4.0K md5sums
|
|
1.8M openwrt-ar71xx-generic-rootfs.tar.gz
|
|
2.2M openwrt-ar71xx-generic-root.jffs2-128k
|
|
2.2M openwrt-ar71xx-generic-root.jffs2-256k
|
|
2.2M openwrt-ar71xx-generic-root.jffs2-64k
|
|
1.7M openwrt-ar71xx-generic-root.squashfs
|
|
1.4M openwrt-ar71xx-generic-root.squashfs-64k
|
|
3.8M openwrt-ar71xx-generic-tl-mr3020-v1-jffs2-factory.bin
|
|
3.1M openwrt-ar71xx-generic-tl-mr3020-v1-jffs2-sysupgrade.bin
|
|
3.8M openwrt-ar71xx-generic-tl-mr3020-v1-squashfs-factory.bin
|
|
2.3M openwrt-ar71xx-generic-tl-mr3020-v1-squashfs-sysupgrade.bin
|
|
1.3M openwrt-ar71xx-generic-uImage-gzip.bin
|
|
916K openwrt-ar71xx-generic-uImage-lzma.bin
|
|
2.7M openwrt-ar71xx-generic-vmlinux.bin
|
|
2.7M openwrt-ar71xx-generic-vmlinux.elf
|
|
1.3M openwrt-ar71xx-generic-vmlinux.gz
|
|
964K openwrt-ar71xx-generic-vmlinux.lzma
|
|
924K openwrt-ar71xx-generic-vmlinux-lzma.elf
|
|
36M OpenWrt-ImageBuilder-ar71xx_generic-for-linux-i486.tar.bz2
|
|
67M OpenWrt-SDK-ar71xx-for-linux-i486-gcc-4.6-linaro_uClibc-0.9.33.2.tar.bz2
|
|
40M OpenWrt-Toolchain-ar71xx-for-mips_r2-gcc-4.6-linaro_uClibc-0.9.33.2.tar.bz2
|
|
4.0K packages
|
|
$
|
|
|
|
Add the Serval feed to OpenWRT
|
|
------------------------------
|
|
|
|
Once an out-of-the-box build has succeeded, add the Serval feed by creating a
|
|
`feeds.conf` file that contains a line for downloading the *master* branch of
|
|
the [Serval OpenWRT feed][] from GitHub:
|
|
|
|
$ cp feeds.conf.default feeds.conf
|
|
$ cat >>feeds.conf <<EOF
|
|
src-git serval git://github.com/servalproject/openwrt-packages.git;master
|
|
EOF
|
|
$
|
|
|
|
(Other branches of the [Serval OpenWRT feed][] are available; see the
|
|
[README][Serval OpenWRT feed] for more information.)
|
|
|
|
Download the Serval feed:
|
|
|
|
$ ./scripts/feeds update serval
|
|
Updating feed 'serval' from 'git://github.com/servalproject/openwrt-packages.git;master' ...
|
|
Cloning into './feeds/serval'...
|
|
remote: Counting objects: 6, done.
|
|
remote: Compressing objects: 100% (4/4), done.
|
|
remote: Total 6 (delta 0), reused 4 (delta 0)
|
|
Receiving objects: 100% (6/6), done.
|
|
Checking connectivity... done.
|
|
Create index file './feeds/serval.index'
|
|
Collecting package info: done
|
|
$
|
|
|
|
Add all the packages from the Serval feed to the OpenWRT package menu:
|
|
|
|
$ ./scripts/feeds install -a -p serval
|
|
Installing all packages from feed serval.
|
|
$
|
|
|
|
Add the Serval DNA package to the OpenWRT build
|
|
-----------------------------------------------
|
|
|
|
Run *menuconfig* and select the Serval packages for building:
|
|
|
|
$ make menuconfig
|
|
...
|
|
|
|
* Network
|
|
* Mesh networking
|
|
* Serval DNA: Y
|
|
|
|
Exit *menuconfig*, saving the OpenWRT configuration file, then build:
|
|
|
|
*** End of OpenWrt configuration.
|
|
*** Execute 'make' to build the OpenWrt or try 'make help'.
|
|
$ make
|
|
make[1] world
|
|
make[2] target/compile
|
|
make[3] -C target/linux compile
|
|
...
|
|
make[3] -C feeds/serval/net/serval-dna compile
|
|
...
|
|
make[2] package/install
|
|
...
|
|
make[3] -C feeds/serval/net/serval-dna install
|
|
...
|
|
make[3] -C target/toolchain install
|
|
make[2] package/index
|
|
$
|
|
|
|
The [Serval DNA][] daemon is now included in the firmware image.
|
|
|
|
Appendix A - Developing Serval DNA for OpenWRT
|
|
----------------------------------------------
|
|
|
|
The instructions above are not useful for a typical *edit-compile-test*
|
|
development cycle, because before every single *compile* step, the latest edits
|
|
would have to be committed and pushed to the package's remote repository, then
|
|
the package's feed edited to put the new Git commit ID into the package's
|
|
[OpenWRT Makefile][] which must then be pushed to its remote repository. The
|
|
OpenWRT *compile* step would then download these changes and recompile from
|
|
scratch. Cumbersome and inconvenient.
|
|
|
|
Instead, developers should use the following files while developing, to avoid
|
|
unnecessary Git commits, pushes and downloads:
|
|
|
|
* set up a `src-link` [OpenWRT feed][] that points to the [development
|
|
OpenWRT feed](../openwrt/packages/) directory, which will remove the need
|
|
for any uploading, downloading, or feed updating;
|
|
|
|
* this feed contains the [development OpenWRT Makefile][] which uses the Git
|
|
working copy instead of Git clone or Git fetch, thus avoiding the need for
|
|
Git commits, uploads and downloads prior to each compile.
|
|
|
|
See the header comments in the [development OpenWRT Makefile][] for more
|
|
complete instructions.
|
|
|
|
Appendix B - Releasing Serval DNA for OpenWRT
|
|
---------------------------------------------
|
|
|
|
The OpenWRT Makefiles in the [Serval OpenWRT feed][] all refer to fixed,
|
|
specific commits within the [Serval DNA repository][], either by tag name or by
|
|
SHA1 identifier. This means that as newer versions of Serval DNA are tested
|
|
and released into other products (like [Batphone][]), they do not automatically
|
|
get released to OpenWRT. This must be done manually every single time.
|
|
|
|
The [sp-openwrt-release][] script in the [Serval Tools repository][serval-tools]
|
|
automates the procedure for releasing Serval DNA for OpenWRT package (in fact,
|
|
it is general enough to update the release of any Serval repository which is
|
|
available as a package for OpenWRT, not just Serval DNA).
|
|
|
|
For example, to release the HEAD of the Serval DNA repository (local clone in
|
|
`~/src/serval-dna`) to the OpenWRT *development* feed, first make sure that
|
|
[Serval Tools][serval-tools] are installed, then use the following
|
|
[sp-openwrt-release][] command, which will print progress messages as it works:
|
|
|
|
$ sp-openwrt-release --commit --push development ~/src/serval-dna=HEAD
|
|
+ cd /home/username/src/serval-dna
|
|
+ git clone git@github.com:servalproject/openwrt-packages.git /tmp/sp-openwrt-release/openwrt-packages
|
|
Cloning into '/tmp/sp-openwrt-release/openwrt-packages'...
|
|
remote: Counting objects: 29, done.
|
|
remote: Compressing objects: 100% (17/17), done.
|
|
remote: Total 29 (delta 6), reused 9 (delta 1)
|
|
Receiving objects: 100% (29/29), 4.06 KiB | 0 bytes/s, done.
|
|
Resolving deltas: 100% (6/6), done.
|
|
Checking connectivity... done.
|
|
+ cd /tmp/sp-openwrt-release/openwrt-packages
|
|
+ git checkout development
|
|
Branch development set up to track remote branch development from origin.
|
|
Switched to a new branch 'development'
|
|
+ git merge --ff-only origin/development
|
|
Already up-to-date.
|
|
+ rm -rf /tmp/sp-openwrt-release/clone-serval-dna
|
|
+ git clone --local --shared /home/username/serval-dna /tmp/sp-openwrt-release/clone-serval-dna
|
|
Cloning into '/tmp/sp-openwrt-release/clone-serval-dna'...
|
|
done.
|
|
+ cd /tmp/sp-openwrt-release/clone-serval-dna
|
|
+ git checkout --quiet HEAD
|
|
+ cd /tmp/sp-openwrt-release/openwrt-packages
|
|
update openwrt-packages/net/serval-dna/Makefile:
|
|
PKG_VERSION = START-2951-g7081e70
|
|
PKG_SOURCE_VERSION = 7081e7044fd9d5762bc124430d5f9cade0d2d52c
|
|
PKG_RELEASE = 2 (was 1)
|
|
+ cd /tmp/sp-openwrt-release/openwrt-packages
|
|
+ git add .
|
|
+ git commit -m Release serval-dna START-2951-g7081e70
|
|
[development 844af68] Release serval-dna START-2951-g7081e70
|
|
1 file changed, 3 insertions(+), 3 deletions(-)
|
|
+ cd /tmp/sp-openwrt-release/openwrt-packages
|
|
+ git push origin development
|
|
Counting objects: 17, done.
|
|
Delta compression using up to 2 threads.
|
|
Compressing objects: 100% (3/3), done.
|
|
Writing objects: 100% (5/5), 487 bytes | 0 bytes/s, done.
|
|
Total 5 (delta 1), reused 0 (delta 0)
|
|
To git@github.com:servalproject/openwrt-packages.git
|
|
9e77219..844af68 development -> development
|
|
$
|
|
|
|
Instead of using `HEAD` as the commit to release, any commit can be specified
|
|
using either a tag name or any other [Git rev][] notation for referring to
|
|
a single commit.
|
|
|
|
For more instructions, see:
|
|
|
|
* [Serval Tools README][serval-tools] for installation of the
|
|
[sp-openwrt-release][] utility
|
|
|
|
* [sp-openwrt-release documentation][sp-openwrt-release] for more examples of
|
|
using the [sp-openwrt-release][] utility
|
|
|
|
* the [sp-openwrt-release][] built-in help:
|
|
|
|
$ sp-openwrt-release --help
|
|
|
|
* the [Serval OpenWRT feed][] for information about different OpenWRT release
|
|
branches available from the [Serval Project][]
|
|
|
|
Appendix C - Adding a new package to OpenWRT
|
|
--------------------------------------------
|
|
|
|
To improve understanding of [OpenWRT 12.09 Buildroot][], it can be helpful to
|
|
consider the steps necessary to add a new package to OpenWRT. The [OpenWRT
|
|
feed][] page gives complete instructions. In summary:
|
|
|
|
- the package's source code must be accessible in some conventional form such
|
|
as a directory on the local file system, or a directory tree that can be
|
|
downloaded, such as a tarball, a [Subversion][] or [Git][] repository, or
|
|
even a few files on an FTP server;
|
|
- choose a unique name for the package, that is not already used in any of the
|
|
existing feeds;
|
|
- an [OpenWRT Makefile][] must be created for the package, that contains
|
|
the package's name and commands for downloading, unpacking and compiling the
|
|
package's source code;
|
|
- the package's [OpenWRT Makefile][] must be added to an [OpenWRT feed][];
|
|
either one which is already configured by default into OpenWRT, or a new
|
|
one;
|
|
- the URL of the [OpenWRT feed][] must be added to the OpenWRT `feeds.conf`
|
|
file, along with a simple name chosen to identify the feed;
|
|
- the package must be installed:
|
|
|
|
$ ./scripts/feeds install $package_name
|
|
$
|
|
|
|
About the examples
|
|
------------------
|
|
|
|
The examples in this document are [Bourne shell][] commands, using standard
|
|
quoting and variable expansion. Commands issued by the user are prefixed with
|
|
the shell prompt `$` to distinguish them from the output of the command.
|
|
Single and double quotes around arguments are part of the shell syntax, so are
|
|
not seen by the command. Lines ending in backslash `\` continue the command on
|
|
the next line.
|
|
|
|
The directory paths used in the examples are for illustrative purposes only,
|
|
and may need to be changed for your particular circumstances.
|
|
|
|
|
|
[Serval Project]: http://www.servalproject.org/
|
|
[Serval DNA]: ../README.md
|
|
[OpenWRT]: http://openwrt.org/
|
|
[OpenWRT 12.09 Buildroot]: https://dev.openwrt.org/browser/tags/attitude_adjustment_12.09
|
|
[Serval Mesh Extender]: http://developer.servalproject.org/dokuwiki/doku.php?id=content:meshextender:
|
|
[Batphone]: http://developer.servalproject.org/dokuwiki/doku.php?id=content:servalmesh:
|
|
[OpenWRT build system]: http://wiki.openwrt.org/about/toolchain
|
|
[OpenWRT feed]: http://wiki.openwrt.org/doc/devel/feeds
|
|
[OpenWRT Buildroot installation HOWTO]:http://wiki.openwrt.org/doc/howto/buildroot.exigence
|
|
[OpenWRT Makefile]: http://wiki.openwrt.org/doc/devel/packages
|
|
[development OpenWRT Makefile]: ../openwrt/packages/net/serval-dna/Makefile
|
|
[Serval OpenWRT feed]: https://github.com/servalproject/openwrt-packages
|
|
[Serval OpenWRT feed README]: https://github.com/servalproject/openwrt-packages
|
|
[Serval DNA repository]: https://github.com/servalproject/serval-dna
|
|
[serval-tools]: https://github.com/servalproject/serval-tools
|
|
[sp-openwrt-release]: https://github.com/servalproject/serval-tools/blob/master/doc/sp-openwrt-release.md
|
|
[GNU make]: http://www.gnu.org/software/make/
|
|
[getopt]: http://en.wikipedia.org/wiki/Getopt
|
|
[util-linux]: http://en.wikipedia.org/wiki/Util-linux
|
|
[GNU coreutils]: http://www.gnu.org/software/coreutils/
|
|
[cp(1)]: http://man.cx/cp(1)
|
|
[gcc]: http://gcc.gnu.org/
|
|
[g++]: http://gcc.gnu.org/
|
|
[binutils]: http://www.gnu.org/software/binutils/
|
|
[C standard library]: http://en.wikipedia.org/wiki/C_standard_library
|
|
[ncurses]: http://www.gnu.org/software/ncurses/
|
|
[zlib]: http://www.zlib.net/
|
|
[GNU awk]: http://www.gnu.org/software/gawk/
|
|
[flex]: http://flex.sourceforge.net/
|
|
[unzip]: http://www.info-zip.org/UnZip.html
|
|
[bzip2]: http://www.bzip.org/
|
|
[patch]: http://en.wikipedia.org/wiki/Patch_(Unix)
|
|
[Perl 5]: http://www.perl.org/
|
|
[Python]: http://www.python.org/
|
|
[GNU wget]: http://www.gnu.org/software/wget/
|
|
[Git]: http://git-scm.com/
|
|
[Git rev]: https://www.kernel.org/pub/software/scm/git/docs/git-rev-parse.html
|
|
[GNU tar]: http://www.gnu.org/software/tar/
|
|
[Subversion]: http://subversion.apache.org/
|
|
[GNU findutils]: http://www.gnu.org/software/findutils/
|
|
[pkg-config]: http://www.freedesktop.org/wiki/Software/pkg-config/
|
|
[gettext]: http://www.gnu.org/software/gettext/
|
|
[eglibc]: http://www.eglibc.org
|
|
[GNU libc]: http://www.gnu.org/software/libc/
|
|
[Debian]: http://www.debian.org/
|
|
[Ubuntu]: http://www.ubuntu.com/desktop
|
|
[TP-LINK TL-MR3020]: http://www.tp-link.com/en/products/details/?model=TL-MR3020
|
|
[OpenWRT TP-LINK TL-MR3020]: http://wiki.openwrt.org/toh/tp-link/tl-mr3020
|
|
[config.ar71xx.generic]: http://downloads.openwrt.org/attitude_adjustment/12.09/ar71xx/generic/config.ar71xx_generic
|
|
[Bourne shell]: http://en.wikipedia.org/wiki/Bourne_shell
|