serval-dna/INSTALL.md
Andrew Bettison 29a771e315 Overhaul Makefile.in
Changed the built libraries and updated INSTALL.md accordingly:
- the 'servaldwrap' executable is now built
- libservald.[a,so] now contains the full daemon executable
- libservalclient.[a,so] contains the client library
- libserval.a is no longer built

Building the 'servaldwrap' executable is a step towards ensuring that
the libservald.so library can be linked and executed, without requiring
an Android build to reveal any failure.

Added the SOURCE_PREFIX variable that allows the make to be invoked from
within any current working directory, not just the serval-dna
repository's root directory.

Fixed the serval_version.o target to invoke the version_string.sh
script with the --repository=DIR option, so that the build will work
even if the current working directory is not within the serval-dna
repository.

Re-ordered and added some comments for clarity, and added some missing
.PHONY declarations.
2016-10-13 16:23:09 +10:30

8.8 KiB

Serval DNA Build and Test

Serval Project, September 2016

Supported Architectures

These instructions will build Serval DNA successfully for the following platforms:

  • Debian Linux, ix86 and x86_64, kernel versions 2.6 to 4.6, using gcc 4.4 and later, gcc 5 and gcc 6
  • Mac OS-X x86_64, releases 10.7 “Lion” to 10.11 “El Capitan”, using Xcode versions 3.2 to 8, and GNU tools available from homebrew
  • Oracle SunOs 5.10 (Solaris), Sparc, using gcc 4.4 and GNU tools installed

Serval DNA also runs on the following platforms, to which these build instructions do not apply:

Download

Serval DNA source code is available from the serval-dna repository on GitHub. You can use Git to download the latest version:

$ cd $HOME/src
$ git clone -q git://github.com/servalproject/serval-dna.git
$ cd serval-dna
$

Dependencies

The dependencies for build are expressed in configure.ac. Most mandatory dependencies are present in the standard Linux development environment.

Mandatory dependencies:

  • standard C library libc and standard headers
  • standard math library libm and headers <math.h> <float.h>
  • network services library libnsl and headers
  • dynamic link library libdl and header <dlfcn.h>
  • Native Posix Threads Library libpthread and header <pthread.h>
  • elliptic curve encryption library libsodium and header <sodium.h>, version 1.0.2 or greater
  • on Solaris, the realtime library librt (for the nanosleep() function)
  • autoconf 2.67-2.69 (2.70 may work but has not been tested)
  • automake 1.15

The libsodium development files are available on Debian/Ubuntu systems in the libsodium-dev package. On other systems, like Mac OS-X, it must be compiled from source. The Notes for Developers give more details.

Optional:

  • Java compiler and SDK
  • ALSA sound library and headers (present on Linux, not on Android)

Test dependencies:

  • bash 3.2.48 or later
  • GNU grep, sed and awk (on Mac OS-X and Solaris, as ggrep, gsed and gawk)
  • jq 1.3 or later
  • curl

Bash and curl are both provided by the XCode package for Mac OS X. GNU grep, GNU sed, GNU awk and jq can all be installed on Mac OS-X using the homebrew package manager. The Notes for Developers give more details.

Build

To compile a native (ie, not cross-compiled) Serval DNA from source, run the following commands:

$ cd $HOME/src/serval-dna
$ autoreconf -f -i -I m4
$ ./configure
$ make
$

A successful session should appear something like:

$ cd $HOME/src/serval-dna
$ autoreconf -f -i -I m4
$ ./configure
checking build system type... i686-pc-linux-gnu
checking host system type... i686-pc-linux-gnu
checking target system type... i686-pc-linux-gnu
checking for pkg-config... /usr/bin/pkg-config
checking pkg-config is at least version 0.9.0... yes
checking for gcc... gcc
...
checking for library containing strlcpy... no
configure: creating ./config.status
config.status: creating Makefile
config.status: creating testconfig.sh
$ make
SERVALD CC conf.c
SERVALD CC cli.c
...
CC cli.c
CC commandline.c
...
CC xprintf.c
LINK servald
LINK libmonitorclient.so
AR libmonitorclient.a
CC tfw_createfile.c
LINK tfw_createfile
$

On Solaris, the system make command may not be GNU Make, and the system cc command may not be GNU Gcc. The following may work:

$ cd $HOME/src/serval-dna
$ autoreconf -f -i -I m4
$ CC=gcc
$ export CC
$ ./configure
$ gmake
$

In the event of a build failure:

Built artifacts

The build process produces the following artifacts:

  • servald is the main Serval DNA executable, which includes the daemon and many client and utility commands.

  • libservald.a is a library containing the complete executable code of servald, which can be linked and invoked by calling an entry point such as parseCommandLine(), or various JNI entry points.

  • directory_service is the executable for the Serval Infrastructure daemon.

  • libmonitorclient.a and libmonitorclient.so are libraries implementing the client end of the monitor interface with the servald daemon. They are linked into the batphone Java executable at run time and contain JNI entry points to functions for managing the client end of a monitor connection with the servald daemon.

  • fakeradio is a utility used by test scripts to simulate the serial interface to the RFD900 packet radio used in the Serval Mesh Extender

  • simulator is a utility used by test scripts for simulating wireless packet transmission under different conditions.

  • tfw_createfile is a utility needed by test scripts for creating large data files with unique, non-repeating content.

  • config_test is a utility that will fail to link if any external dependencies creep into the configuration subsystem.

Test scripts

After building the native servald executable, run all the tests with the following command:

$ ./tests/all
1 [PASS.] (logging) By default, only errors and warnings are logged to stderr
2 [PASS.] (logging) Configure all messages logged to stderr
3 [PASS.] (logging) Configure no messages logged to stderr
4 [PASS.] (logging) By Default, all messages are appended to a configured file
...
158 [PASS.] (rhizomeprotocol) One way direct pull bundle from configured peer
159 [PASS.] (rhizomeprotocol) Two-way direct sync bundles with configured peer
160 [PASS.] (directory_service) Publish and retrieve a directory entry
161 [PASS.] (directory_service) Ping via relay node
161 tests, 161 pass, 0 fail, 0 error
$

Every test run writes log files into the testlog/all directory (relative to the current working directory), deleting any logs from the previous run.

See Serval DNA Testing for more information on running and developing test scripts.

Configure

Before running servald, it must be configured correctly. The doc/Servald-Configuration document describes the configuration of Serval DNA in detail.

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.


Copyright 2013-2015 Serval Project Inc.
Copyright 2016 Flinders University
CC-BY-4.0 This document is available under the Creative Commons Attribution 4.0 International licence.