File: README

package info (click to toggle)
mptcpd 0.14-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,612 kB
  • sloc: ansic: 9,472; sh: 5,154; makefile: 467; cpp: 61
file content (305 lines) | stat: -rw-r--r-- 11,356 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
[C/C++ CI] [Coverage Status] [Contributor Covenant]

  [C/C++ CI]: https://github.com/multipath-tcp/mptcpd/actions/workflows/ccpp.yml/badge.svg
  [1]: https://github.com/multipath-tcp/mptcpd/actions/workflows/ccpp.yml
  [Coverage Status]: https://coveralls.io/repos/github/multipath-tcp/mptcpd/badge.svg?branch=main
  [2]: https://coveralls.io/github/multipath-tcp/mptcpd?branch=main
  [Contributor Covenant]: https://img.shields.io/badge/Contributor%20Covenant-2.0-4baaaa.svg
  [3]: CODE_OF_CONDUCT.md

Multipath TCP Daemon

The Multipath TCP Daemon - mptcpd - is a daemon for Linux based
operating systems that performs multipath TCP path management related
operations in the user space. It interacts with the Linux kernel through
a generic netlink connection to track per-connection information (e.g.
available remote addresses), available network interfaces, request new
MPTCP subflows, handle requests for subflows, etc.

  [multipath TCP]: https://www.rfc-editor.org/rfc/rfc8684.html
  [path management]: https://www.rfc-editor.org/rfc/rfc8684.html#section-3.4

Behavior

By default, this daemon will load the addr_adv plugin, which will add
MPTCP endpoints with the subflow flag ("client" mode) for the default
in-kernel path-manager. Note that this is something NetworkManager 1.40
or newer does by default. Having several daemons configuring the MPTCP
endpoints at the same time should be avoided. This daemon is usually
recommended when NetworkManager 1.40 or newer is not available, or when
advanced per-connection path management is needed, using the userspace
path-manager and a custom made plugin using the C API.

  [NetworkManager 1.40 or newer]: https://networkmanager.dev/blog/networkmanager-1-40/#mptcp-support
  [plugin]: https://github.com/multipath-tcp/mptcpd/wiki/Plugins
  [C API]: https://mptcpd.mptcp.dev/doc/html/

To change this behavior, with NetworkManager, look for the
connection.mptcp-flags option in the settings, while for mptcpd, look at
the /etc/mptcpd/mptcpd.conf config file, or disable the service if it is
not needed. Make sure not to have both NetworkManager and mptcpd
conflicting to configure the MPTCP endpoints.

  [settings]: https://networkmanager.dev/docs/api/latest/nm-settings-nmcli.html#nm-settings-nmcli.property.connection.mptcp-flags

Installing mptcpd

mptcpd is packaged in most major distributions:

[Packaging status]

  [Packaging status]: https://repology.org/badge/vertical-allrepos/mptcpd.svg
  [4]: https://repology.org/project/mptcpd/versions

Do not hesitate to help with the packaging.

Building mptcpd

mptcpd is built in much the same way most Autotool-enabled software
packages are built. This includes the build approach for both clones of
the mptcpd Git repository and self-contained mptcpd release tar archive
(e.g. mptcpd-0.1.tar.gz).

  [Autotool]: https://www.gnu.org/software/automake/manual/html_node/Autotools-Introduction.html

Dependencies

Build dependencies for mptcpd vary depending on whether or not you are
building from a self-contained maintainer generated mptcpd tar archive
or from a cloned Git mptcpd repository, for example.

-   Basic mptcpd Build Dependencies
    -   C compiler (C99 compliant)
    -   Embedded Linux Library >= v0.30
    -   Argp library (either the GNU libc built-in or standalone)
    -   Linux kernel MPTCP user API headers
    -   pkg-config
-   Additional Build Dependencies for Maintainers, and mptcpd Git
    Repository Clones
    -   GNU Autoconf
    -   GNU Automake
    -   GNU Libtool
    -   GNU Autoconf Archive
    -   Pandoc >= 2.2.1 (needed to convert README.md contents from the
        GitHub markdown format content to plain text)
    -   Doxygen (only needed to build documentation)

  [Embedded Linux Library]: https://git.kernel.org/pub/scm/libs/ell/ell.git
  [built-in]: https://www.gnu.org/software/libc/manual/html_node/Argp.html
  [standalone]: http://www.lysator.liu.se/~nisse/misc/
  [pkg-config]: https://www.freedesktop.org/wiki/Software/pkg-config/
  [GNU Autoconf]: https://www.gnu.org/software/autoconf/
  [GNU Automake]: https://www.gnu.org/software/automake/
  [GNU Libtool]: https://www.gnu.org/software/libtool/
  [GNU Autoconf Archive]: https://www.gnu.org/software/autoconf-archive/
  [Pandoc]: https://pandoc.org/
  [Doxygen]: http://www.doxygen.nl/

Bootstrapping

Bootstrapping the mptcpd source distribution is only necessary when
building a clone of the mptcpd Git repository for the first time, or
possibly after making modifications to the mptcpd build infrastructure
(e.g. configure Makefile, etc). There is no need to bootstrap
self-contained mptcpd releases generated by the canonical make dist
command.

Assuming all maintainer related build dependencies listed above are
installed, bootstrapping mptcpd simply requires running the bootstrap
script in the top-level source directory, e.g.:

    $ ./bootstrap

Move on to the common build steps below once bootstrapping is complete.

Build Steps

mptcpd shares the usual build procedure found in all Autotool enabled
software packages, i.e. running the configure script in the desired
build directory, and running make afterward:

    ./configure
    make

or for an alternate build directory:

    mkdir the_build
    cd the_build
    ../configure
    make

Run configure --help to list all command line build configuration
options. Further generic configuration and build details may be found in
the INSTALL file.

Unit Tests

Unit tests included in the mptcpd source distribution may be run like
so:

    ./configure
    make check

Once again, these steps may be performed in an alternate build
directory.

Compile-time Debugging Support

Whether or not debugging support (e.g. debug symbols) is compiled by
default into mptcpd binaries depends on how the mptcpd source was
obtained, i.e. as a cloned git repository or as a "released" tar
archive. It boils downs to the existence of a ".git" directory in the
top level mptcpd source directory. Debug symbols will be enabled and
optimization disabled by default if such a directory exists, and vice
versa if doesn't exist. The default behavior may be overriden by using
the --enable-debug configuration option:

      --enable-debug=[yes/info/profile/no]
                              compile with debugging

The usual build flags, such as CFLAGS, LDFLAGS, etc, may be provided on
the configure script command line. See the output from
./configure --help, or the INSTALL file, for additional details.

Code Coverage

To aid with identifying areas of the mptcpd code that are or are not
exercised by its unit tests or when deployed, mptcpd may be instrumented
for code coverage when it is built with GCC. Code coverage reports will
also require the tools gcov, lcov and genhtml to be installed as well.

To enable mptcpd code coverage instrumentation, and generate reports
from unit tests in the top level source directory, for example, build
mptcpd like so:

    ./configure --enable-code-coverage
    make check-code-coverage

The location of the HTML formatted code coverage results will be
displayed after the report is generated.

Documentation Generation

HTML formatted code documentaton for mptcpd may be generated if Doxygen
is installed by running the doxygen-doc make target, e.g.:

    ./configure
    make doxygen-doc

Generated documentation will be placed in the doc/html directory.
PostScript and PDF formatted documentation generation is disabled by
default but may be explicitly generated using the doxygen-ps and
doxygen-pdf make targets.

Additional Doxygen based documentation generation options are described
in the configure script help output (e.g. ./configure --help).

Installation

The mptcpd source package provides the same installation related make
targets found in most GNU style and Autotool enabled software packages.
The most basic way to install mptcpd is:

    make install

By default mptcpd will be installed in appropriate directories under the
directory /usr/local. Fine tuning of installation directories may be
done using several configure script command line options. See the help
output from ./configure --help as well as the INSTALL file for details.

Super user (root) permissions may be necessary if installing into
directories owned by root.

systemd

If systemd is detected a service file will be installed in the
appropriate location (e.g. /lib/systemd/system). That installation
directory is independendent of the default directories mentioned above.
If necessary, the systemd service file installation directory may be
changed using the following configure script command line option.

  [service file]: https://www.freedesktop.org/software/systemd/man/systemd.service.html

      --with-systemdsystemunitdir=DIR
                              Directory for systemd service files

Execution

mptcpd may be started in a number of ways depending on whether or not
systemd is used to run installed binaries, or if it is run directly from
the source tree (e.g. when debugging development versions) without
installation.

Executing an Installed mptcpd

Without systemd

mptcpd currently does not provide traditional System V "init scripts".
In general the mptcpd program may be run directly from the installed
directory, e.g.:

    /usr/bin/mptcpd

However, it may be necessary to explicitly set the library load path
through the LD_LIBRARY_PATH environment path if mptcpd is installed in a
set of directories unknown to the dynamic linker, e.g.:

    LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH /usr/local/bin/mptcpd

or:

    # Assumes Bourne shell style environment variable assignment.
    export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
    /usr/local/bin/mptcpd

Alternatively, update the dynamic linker run-time bindings by running
ldconfig after installation of mptcpd.

  [ldconfig]: https://linux.die.net/man/8/ldconfig

NOTE: mptcpd requires the CAP_NET_ADMIN capability to be fully
functional. If not using the provided systemd service file
mptcp.service, the necessary capability may be granted to mptcpd by any
of the following:

  [capability]: https://linux.die.net/man/7/capabilities
  [mptcp.service]: src/mptcp.service

-   Run as root (generally not desirable)
-   Run with a wrapper such as, capsh
-   Attach the required capabilities to the installed mptcpd executable
    through setcap

  [capsh]: https://linux.die.net/man/1/capsh
  [setcap]: https://linux.die.net/man/8/setcap

With systemd

To start mptcpd immediately after installation using systemd run the
following commands:

    systemctl daemon-reload
    systemctl start mptcp.service

These steps are not necessary if the system is rebooted after
installation of mptcpd.

Execution of mptcpd in the Source Distribution

Since mptcpd is built with libtool support it is generally best to
execute mptcpd using libtool. For example, to run mptcpd under the gdb
debugger one could do the following, assuming mptcpd was configured and
built from the top level source directory:

    ./libtool --mode=execute gdb ./src/mptcpd

Community Resources

Further help is available through the Linux kernel MPTCP community:

-   E-mail: MPTCP mailing list
-   IRC: #mptcp on Libera.Chat

  [MPTCP mailing list]: https://subspace.kernel.org/lists.linux.dev.html?highlight=mptcp
  [#mptcp]: ircs://irc.libera.chat:6697/%23mptcp
  [Libera.Chat]: https://libera.chat/