Andrew Bettison 0e5c5e0e98 More work on dnahelper, almost done
Servald starts DNA helper, receives startup ACK, sends requests, receives
responses, handles malformed helper responses, echoes dnahelper stderr lines to
log, sends MDP reply packet, waits for dead helper process, all asynchronously.
Shuts down helper process during servald shutdown.

Remaining issues:
 - Does not impose a timeout on helper responses.
 - Only the first URI is reported by the "dna lookup" command.
2012-07-20 18:17:43 +09:30
2012-02-27 12:45:50 +10:30
2012-07-20 18:17:43 +09:30
2012-06-27 17:23:43 +09:30
2012-07-11 14:11:59 +09:30
2012-05-11 08:14:00 +09:30
2012-06-27 16:54:42 +09:30
2012-05-11 08:14:00 +09:30
2012-05-11 08:14:00 +09:30
2012-05-24 17:11:55 +09:30
2012-05-24 17:11:55 +09:30
2012-05-15 11:09:21 +09:30
2012-07-20 18:17:43 +09:30
2012-07-11 14:11:59 +09:30
2012-05-14 18:37:32 +09:30
2012-07-10 16:33:39 +09:30
2012-07-10 16:33:39 +09:30
2011-08-10 15:39:40 +02:00
2012-07-19 17:59:45 +09:30
2012-07-19 17:59:45 +09:30
2012-06-15 15:09:21 +09:30
2012-02-23 12:45:42 +10:30
2012-07-20 18:17:43 +09:30
2012-07-19 17:59:45 +09:30
2012-07-10 14:33:14 +09:30
2012-02-23 12:45:42 +10:30
2012-07-19 17:59:45 +09:30
2012-07-20 18:17:04 +09:30
2012-07-20 18:17:04 +09:30
2011-10-25 13:39:14 +10:30
2012-07-06 10:14:39 +09:30

@PGS/20120615

Sometimes it is helpful to run more than one servald instance on a given machine
for debugging purposes.  To make this easier, there is a dummy interface driver
that servald knows about.  To use it:

1. create an empty file, e.g., dummynet0, somewhere convenient

2. For each servald instance you wish to use it, set the interface specification to include the dummynet file. Use a specification like "+>pathtodummynetfile", where pathtodummynetfile is the relative path from the instance path of that servald instance to the dummynet file.  For example, you might run:
   % servald config set interfaces "+eth0,+>../dummynet0"

3. Run each servald instance.  They should now use the dummy network.

NOTE: Because dummynets are files, not sockets, poll/select does not work on them.  As a result the main overlay loop has slightly different behaviour and timing characteristics when a dummynet is in use.

TODO: Convert dummynet interface to use a unixdomain socket, and a simple dummynet server that reflects packets among the clients connected, so that all socket semantics (including use of poll/select) are preserved.
Description
The Serval Project's core daemon that implements Distributed Numbering Architecture (DNA), MDP, VoMP, Rhizome, MeshMS, etc.
Readme 33 MiB
Languages
C 89.4%
Shell 5.9%
Java 2%
M4 1.1%
Assembly 0.6%
Other 0.9%