Page MenuHomeClusterLabs Projects

No OneTemporary

diff --git a/.gitignore b/.gitignore
index f72bee07..759e634c 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,50 +1,53 @@
*.o
*.a
*.la
*.lo
*.pc
*.tar.*
*.sha256*
stamp-h1
Makefile.in
Makefile
.deps
.libs
.version
.dirstamp
# build-aux/release.mk related litter
/.tarball-version
/tag-*
aclocal.m4
autoconf
autoheader
autom4te.cache
automake
compile
config.*
configure*
debian/changelog
debian/kronosnetd.postinst
debian/patches
depcomp
install-sh
libtoolize
ltmain.sh
m4
missing
libtool
autoscan.log
init/kronosnetd
init/kronosnetd.service
kronosnetd/kronosnetd
kronosnetd/knet-keygen
kronosnetd/kronosnetd.logrotate
kronosnet.spec
*.swp
*_test
*_bench
test-driver
*.trs
*.log
+Doxyfile
+doxyfile.stamp
+xml/
diff --git a/configure.ac b/configure.ac
index 3f7946d7..8465cacf 100644
--- a/configure.ac
+++ b/configure.ac
@@ -1,511 +1,514 @@
#
# Copyright (C) 2010-2017 Red Hat, Inc. All rights reserved.
#
# Authors: Fabio M. Di Nitto <fabbione@kronosnet.org>
# Federico Simoncelli <fsimon@kronosnet.org>
#
# This software licensed under GPL-2.0+, LGPL-2.0+
#
# -*- Autoconf -*-
# Process this file with autoconf to produce a configure script.
#
AC_PREREQ([2.63])
AC_INIT([kronosnet],
m4_esyscmd([build-aux/git-version-gen .tarball-version]),
[devel@lists.kronosnet.org])
AC_USE_SYSTEM_EXTENSIONS
AM_INIT_AUTOMAKE([1.13 dist-bzip2 dist-xz color-tests -Wno-portability subdir-objects])
LT_PREREQ([2.2.6])
LT_INIT
AC_CONFIG_MACRO_DIR([m4])
AC_CONFIG_SRCDIR([kronosnetd/main.c])
AC_CONFIG_HEADERS([config.h])
AC_CANONICAL_HOST
AC_PROG_LIBTOOL
AC_LANG([C])
systemddir=${prefix}/lib/systemd/system
if test "$prefix" = "NONE"; then
prefix="/usr"
if test "$localstatedir" = "\${prefix}/var"; then
localstatedir="/var"
fi
if test "$sysconfdir" = "\${prefix}/etc"; then
sysconfdir="/etc"
fi
if test "$systemddir" = "NONE/lib/systemd/system"; then
systemddir=/lib/systemd/system
fi
if test "$libdir" = "\${exec_prefix}/lib"; then
if test -e /usr/lib64; then
libdir="/usr/lib64"
else
libdir="/usr/lib"
fi
fi
fi
AC_PROG_AWK
AC_PROG_GREP
AC_PROG_SED
AC_PROG_CPP
AC_PROG_CC
AC_PROG_CC_C99
if test "x$ac_cv_prog_cc_c99" = "xno"; then
AC_MSG_ERROR(["C99 support is required"])
fi
AC_PROG_LN_S
AC_PROG_INSTALL
AC_PROG_MAKE_SET
PKG_PROG_PKG_CONFIG
AC_CHECK_PROGS([PUBLICAN], [publican], [:])
AC_CHECK_PROGS([DOXYGEN], [doxygen])
-if test "x$DOXYGEN" = "x"; then
- AC_MSG_ERROR(["doxygen is required to build man pages"])
-fi
AC_CHECK_PROGS([DOXY2MAN], [doxy2man])
-if test "x$DOXY2MAN" = "x"; then
- AC_MSG_ERROR(["doxy2man is required to build man pages"])
+
+manpageupdates=1
+if test "x$DOXYGEN" = "x" || test "x$DOXY2MAN" = "x"; then
+ manpageupdates=0;
fi
+
+AM_CONDITIONAL([MANPAGEUPDATES], [test $manpageupdates -gt 0])
+
AC_CHECK_PROGS([VALGRIND_EXEC], [valgrind])
AM_CONDITIONAL([HAS_VALGRIND], [test x$VALGRIND_EXEC != "x"])
AC_ARG_ENABLE([libknet-sctp],
[ --disable-libknet-sctp : disable libknet SCTP support ],,
[ enable_libknet_sctp="yes" ])
AM_CONDITIONAL([BUILDSCTP], [test x$enable_libknet_sctp = xyes])
AC_ARG_ENABLE([crypto-all],
[ --disable-crypto-all : disable libknet all crypto modules support ],,
[ enable_crypto_all="yes" ])
AC_ARG_ENABLE([crypto-nss],
[ --disable-crypto-nss : disable libknet nss support ],,
[ enable_crypto_nss="$enable_crypto_all" ])
AM_CONDITIONAL([BUILDCRYPTONSS], [test x$enable_crypto_nss = xyes])
AC_ARG_ENABLE([crypto-openssl],
[ --disable-crypto-openssl : disable libknet openssl support ],,
[ enable_crypto_openssl="$enable_crypto_all" ])
AM_CONDITIONAL([BUILDCRYPTOOPENSSL], [test x$enable_crypto_openssl = xyes])
AC_ARG_ENABLE([compress-all],
[ --disable-compress-all : disable libknet all compress modules support ],,
[ enable_compress_all="yes" ])
AC_ARG_ENABLE([compress-zlib],
[ --disable-compress-zlib : disable libknet zlib support ],,
[ enable_compress_zlib="$enable_compress_all" ])
AM_CONDITIONAL([BUILDCOMPZLIB], [test x$enable_compress_zlib = xyes])
AC_ARG_ENABLE([compress-lz4],
[ --disable-compress-lz4 : disable libknet lz4 support ],,
[ enable_compress_lz4="$enable_compress_all" ])
AM_CONDITIONAL([BUILDCOMPLZ4], [test x$enable_compress_lz4 = xyes])
AC_ARG_ENABLE([compress-lzo2],
[ --disable-compress-lzo2 : disable libknet lzo2 support ],,
[ enable_compress_lzo2="$enable_compress_all" ])
AM_CONDITIONAL([BUILDCOMPLZO2], [test x$enable_compress_lzo2 = xyes])
AC_ARG_ENABLE([compress-lzma],
[ --disable-compress-lzma : disable libknet lzma support ],,
[ enable_compress_lzma="$enable_compress_all" ])
AM_CONDITIONAL([BUILDCOMPLZMA], [test x$enable_compress_lzma = xyes])
AC_ARG_ENABLE([compress-bzip2],
[ --disable-compress-bzip2 : disable libknet bzip2 support ],,
[ enable_compress_bzip2="$enable_compress_all" ])
AM_CONDITIONAL([BUILDCOMPBZIP2], [test x$enable_compress_bzip2 = xyes])
AC_ARG_ENABLE([poc],
[ --enable-poc : enable building poc code ],,
[ enable_poc="no" ])
AM_CONDITIONAL([BUILD_POC], [test x$enable_poc = xyes])
AC_ARG_ENABLE([kronosnetd],
[ --enable-kronosnetd : Kronosnetd support ],,
[ enable_kronosnetd="no" ])
AM_CONDITIONAL([BUILD_KRONOSNETD], [test x$enable_kronosnetd = xyes])
AC_ARG_ENABLE([runautogen],
[ --enable-runautogen : run autogen.sh ],,
[ enable_runautogen="no" ])
AM_CONDITIONAL([BUILD_RUNAUTOGEN], [test x$enable_runautogen = xyes])
AC_ARG_ENABLE([libtap],
[ --enable-libtap : libtap support ],,
[ enable_libtap="no" ])
if test "x$enable_kronosnetd" = xyes; then
enable_libtap=yes
fi
AM_CONDITIONAL([BUILD_LIBTAP], [test x$enable_libtap = xyes])
## local helper functions
# this function checks if CC support options passed as
# args. Global CFLAGS are ignored during this test.
cc_supports_flag() {
saveCPPFLAGS="$CPPFLAGS"
CPPFLAGS="$@"
if echo $CC | grep -q clang; then
CPPFLAGS="-Werror $CPPFLAGS"
fi
AC_MSG_CHECKING([whether $CC supports "$@"])
AC_PREPROC_IFELSE([AC_LANG_PROGRAM([])],
[RC=0; AC_MSG_RESULT([yes])],
[RC=1; AC_MSG_RESULT([no])])
CPPFLAGS="$saveCPPFLAGS"
return $RC
}
# helper macro to check libs without adding them to LIBS
check_lib_no_libs() {
lib_no_libs_arg1=$1
shift
lib_no_libs_arg2=$1
shift
lib_no_libs_args=$@
AC_CHECK_LIB([$lib_no_libs_arg1],
[$lib_no_libs_arg2],,,
[$lib_no_libs_args])
LIBS=$ac_check_lib_save_LIBS
}
# Checks for C features
AC_C_INLINE
# Checks for libraries.
AC_CHECK_LIB([pthread], [pthread_create], [AC_SUBST([pthread_LIBS], [-lpthread])], [AC_MSG_ERROR([kronosnet requires pthread library])])
AC_CHECK_LIB([m], [ceil], [AC_SUBST([m_LIBS], [-lm])], [AC_MSG_ERROR([kronosnet requires m library])])
AC_CHECK_LIB([rt], [clock_gettime], [AC_SUBST([rt_LIBS], [-lrt])], [AC_MSG_ERROR([kronosnet requires rt library])])
AC_SEARCH_LIBS([dlopen], [dl dld], [dllibs=$ac_res], [AC_MSG_ERROR([kronosnet requires dl library])])
if test "x$dllibs" != "xnone required"; then
AC_SUBST([dl_LIBS], [$dllibs])
fi
# crypto libraries checks
if test "x$enable_crypto_nss" = xyes; then
PKG_CHECK_MODULES([nss],[nss])
AC_DEFINE_UNQUOTED([BUILDCRYPTONSS], [1], [Enable nss crypto])
fi
if test "x$enable_crypto_openssl" = xyes; then
PKG_CHECK_MODULES([openssl],[openssl < 1.1],
[AC_DEFINE_UNQUOTED([BUILDCRYPTOOPENSSL10], [1], [openssl 1.0 crypto])],
[PKG_CHECK_MODULES([openssl],[openssl >= 1.1],
[AC_DEFINE_UNQUOTED([BUILDCRYPTOOPENSSL11], [1], [openssl 1.1 crypto])])])
AC_DEFINE_UNQUOTED([BUILDCRYPTOOPENSSL], [1], [Enable openssl crypto])
fi
# compress libraries checks
if test "x$enable_compress_zlib" = xyes; then
PKG_CHECK_MODULES([zlib], [zlib])
AC_DEFINE_UNQUOTED([BUILDCOMPZLIB], [1], [Enable zlib compression])
fi
if test "x$enable_compress_lz4" = xyes; then
PKG_CHECK_MODULES([liblz4], [liblz4])
AC_DEFINE_UNQUOTED([BUILDCOMPLZ4], [1], [Enable lz4 compress])
fi
if test "x$enable_compress_lzo2" = xyes; then
PKG_CHECK_MODULES([lzo2], [lzo2],,
[AC_CHECK_HEADERS([lzo/lzo1x.h],
[AC_CHECK_LIB([lzo2], [lzo1x_decompress_safe],
[AC_SUBST([lzo2_LIBS], [-llzo2])])],
[AC_MSG_ERROR(["missing required lzo/lzo1x.h header"])])])
AC_DEFINE_UNQUOTED([BUILDCOMPLZO2], [1], [Enable lzo2 compress])
fi
if test "x$enable_compress_lzma" = xyes; then
PKG_CHECK_MODULES([liblzma], [liblzma])
AC_DEFINE_UNQUOTED([BUILDCOMPLZMA], [1], [Enable lzma compress])
fi
if test "x$enable_compress_bzip2" = xyes; then
PKG_CHECK_MODULES([bzip2], [bzip2],,
[AC_CHECK_HEADERS([bzlib.h],
[AC_CHECK_LIB([bz2], [BZ2_bzBuffToBuffCompress],
[AC_SUBST([bzip2_LIBS], [-lbz2])])],
[AC_MSG_ERROR(["missing required bzlib.h"])])])
AC_DEFINE_UNQUOTED([BUILDCOMPBZIP2], [1], [Enable bzip2 compress])
fi
# Checks for header files.
AC_CHECK_HEADERS([fcntl.h])
AC_CHECK_HEADERS([stdlib.h])
AC_CHECK_HEADERS([string.h])
AC_CHECK_HEADERS([strings.h])
AC_CHECK_HEADERS([sys/ioctl.h])
AC_CHECK_HEADERS([syslog.h])
AC_CHECK_HEADERS([unistd.h])
AC_CHECK_HEADERS([netinet/in.h])
AC_CHECK_HEADERS([sys/socket.h])
AC_CHECK_HEADERS([arpa/inet.h])
AC_CHECK_HEADERS([netdb.h])
AC_CHECK_HEADERS([limits.h])
AC_CHECK_HEADERS([stdint.h])
AC_CHECK_HEADERS([sys/epoll.h])
if test "x$enable_libknet_sctp" = xyes; then
AC_CHECK_HEADERS([netinet/sctp.h],, [AC_MSG_ERROR(["missing required SCTP headers"])])
fi
# Checks for typedefs, structures, and compiler characteristics.
AC_C_INLINE
AC_TYPE_SIZE_T
AC_TYPE_PID_T
AC_TYPE_SSIZE_T
AC_TYPE_UINT8_T
AC_TYPE_UINT16_T
AC_TYPE_UINT32_T
AC_TYPE_UINT64_T
AC_TYPE_INT32_T
# Checks for library functions.
AC_FUNC_ALLOCA
AC_FUNC_FORK
AC_FUNC_MALLOC
AC_FUNC_REALLOC
AC_CHECK_FUNCS([memset])
AC_CHECK_FUNCS([strdup])
AC_CHECK_FUNCS([strerror])
AC_CHECK_FUNCS([dup2])
AC_CHECK_FUNCS([select])
AC_CHECK_FUNCS([socket])
AC_CHECK_FUNCS([inet_ntoa])
AC_CHECK_FUNCS([memmove])
AC_CHECK_FUNCS([strchr])
AC_CHECK_FUNCS([atexit])
AC_CHECK_FUNCS([ftruncate])
AC_CHECK_FUNCS([strrchr])
AC_CHECK_FUNCS([strstr])
AC_CHECK_FUNCS([clock_gettime])
AC_CHECK_FUNCS([strcasecmp])
AC_CHECK_FUNCS([kevent])
# if neither sys/epoll.h nor kevent are present, we should fail.
if test "x$ac_cv_header_sys_epoll_h" = xno && test "x$ac_cv_func_kevent" = xno; then
AC_MSG_ERROR([Both epoll and kevent unavailable on this OS])
fi
if test "x$ac_cv_header_sys_epoll_h" = xyes && test "x$ac_cv_func_kevent" = xyes; then
AC_MSG_ERROR([Both epoll and kevent available on this OS, please contact the maintainers to fix the code])
fi
# checks (for kronosnetd)
if test "x$enable_kronosnetd" = xyes; then
AC_CHECK_HEADERS([security/pam_appl.h],
[AC_CHECK_LIB([pam], [pam_start])],
[AC_MSG_ERROR([Unable to find LinuxPAM devel files])])
AC_CHECK_HEADERS([security/pam_misc.h],
[AC_CHECK_LIB([pam_misc], [misc_conv])],
[AC_MSG_ERROR([Unable to find LinuxPAM MISC devel files])])
PKG_CHECK_MODULES([libqb], [libqb])
AC_CHECK_LIB([qb], [qb_log_thread_priority_set],
[have_qb_log_thread_priority_set="yes"],
[have_qb_log_thread_priority_set="no"])
if test "x${have_qb_log_thread_priority_set}" = xyes; then
AC_DEFINE_UNQUOTED([HAVE_QB_LOG_THREAD_PRIORITY_SET], [1], [have qb_log_thread_priority_set])
fi
fi
# local options
AC_ARG_ENABLE([debug],
[ --enable-debug enable debug build. ],
[ default="no" ])
AC_ARG_ENABLE([publicandocs],
[ --enable-publicandocs enable docs build. ],
[ default="no" ])
AC_ARG_WITH([initdefaultdir],
[ --with-initdefaultdir : path to /etc/sysconfig/.. or /etc/default dir. ],
[ INITDEFAULTDIR="$withval" ],
[ INITDEFAULTDIR="$sysconfdir/default" ])
AC_ARG_WITH([initddir],
[ --with-initddir=DIR : path to init script directory. ],
[ INITDDIR="$withval" ],
[ INITDDIR="$sysconfdir/init.d" ])
AC_ARG_WITH([systemddir],
[ --with-systemddir=DIR : path to systemd unit files directory. ],
[ SYSTEMDDIR="$withval" ],
[ SYSTEMDDIR="$systemddir" ])
AC_ARG_WITH([syslogfacility],
[ --with-syslogfacility=FACILITY
default syslog facility. ],
[ SYSLOGFACILITY="$withval" ],
[ SYSLOGFACILITY="LOG_DAEMON" ])
AC_ARG_WITH([sysloglevel],
[ --with-sysloglevel=LEVEL
default syslog level. ],
[ SYSLOGLEVEL="$withval" ],
[ SYSLOGLEVEL="LOG_INFO" ])
AC_ARG_WITH([defaultadmgroup],
[ --with-defaultadmgroup=GROUP
define PAM group. Users part of this group will be
allowed to configure kronosnet. Others will only
receive read-only rights. ],
[ DEFAULTADMGROUP="$withval" ],
[ DEFAULTADMGROUP="kronosnetadm" ])
## random vars
LOGDIR=${localstatedir}/log/
RUNDIR=${localstatedir}/run/
DEFAULT_CONFIG_DIR=${sysconfdir}/kronosnet
## do subst
AM_CONDITIONAL([BUILD_DOCS], [test "x${enable_publicandocs}" = xyes])
AM_CONDITIONAL([DEBUG], [test "x${enable_debug}" = xyes])
AC_SUBST([DEFAULT_CONFIG_DIR])
AC_SUBST([INITDEFAULTDIR])
AC_SUBST([INITDDIR])
AC_SUBST([SYSTEMDDIR])
AC_SUBST([LOGDIR])
AC_SUBST([DEFAULTADMGROUP])
AC_DEFINE_UNQUOTED([DEFAULT_CONFIG_DIR],
["$(eval echo ${DEFAULT_CONFIG_DIR})"],
[Default config directory])
AC_DEFINE_UNQUOTED([DEFAULT_CONFIG_FILE],
["$(eval echo ${DEFAULT_CONFIG_DIR}/kronosnetd.conf)"],
[Default config file])
AC_DEFINE_UNQUOTED([LOGDIR],
["$(eval echo ${LOGDIR})"],
[Default logging directory])
AC_DEFINE_UNQUOTED([DEFAULT_LOG_FILE],
["$(eval echo ${LOGDIR}/kronosnetd.log)"],
[Default log file])
AC_DEFINE_UNQUOTED([RUNDIR],
["$(eval echo ${RUNDIR})"],
[Default run directory])
AC_DEFINE_UNQUOTED([SYSLOGFACILITY],
[$(eval echo ${SYSLOGFACILITY})],
[Default syslog facility])
AC_DEFINE_UNQUOTED([SYSLOGLEVEL],
[$(eval echo ${SYSLOGLEVEL})],
[Default syslog level])
AC_DEFINE_UNQUOTED([DEFAULTADMGROUP],
["$(eval echo ${DEFAULTADMGROUP})"],
[Default admin group])
## *FLAGS handling
ENV_CFLAGS="$CFLAGS"
ENV_CPPFLAGS="$CPPFLAGS"
ENV_LDFLAGS="$LDFLAGS"
# debug build stuff
if test "x${enable_debug}" = xyes; then
AC_DEFINE_UNQUOTED([DEBUG], [1], [Compiling Debugging code])
OPT_CFLAGS="-O0"
else
OPT_CFLAGS="-O3"
fi
# gdb flags
if test "x${GCC}" = xyes; then
GDB_FLAGS="-ggdb3"
else
GDB_FLAGS="-g"
fi
# extra warnings
EXTRA_WARNINGS=""
WARNLIST="
all
extra
unused
shadow
missing-prototypes
missing-declarations
suggest-attribute=noreturn
suggest-attribute=format
strict-prototypes
declaration-after-statement
pointer-arith
write-strings
cast-align
bad-function-cast
missing-format-attribute
float-equal
format=2
format-signedness
format-security
format-nonliteral
no-long-long
unsigned-char
gnu89-inline
no-strict-aliasing
error
address
cpp
overflow
parentheses
sequence-point
switch
shift-overflow=2
overlength-strings
retundent-decls
init-self
uninitialized
unused-but-set-variable
unused-function
unused-result
unused-value
unused-variable
unknown-pragmas
no-unused-parameter
"
for j in $WARNLIST; do
if cc_supports_flag -W$j; then
EXTRA_WARNINGS="$EXTRA_WARNINGS -W$j";
fi
done
CFLAGS="$ENV_CFLAGS $lt_prog_compiler_pic $OPT_CFLAGS $GDB_FLAGS \
$EXTRA_WARNINGS $WERROR_CFLAGS"
CPPFLAGS="$ENV_CPPFLAGS"
LDFLAGS="$ENV_LDFLAGS $lt_prog_compiler_pic -Wl,--as-needed"
AC_CONFIG_FILES([
Makefile
init/Makefile
libtap/Makefile
libtap/libtap.pc
kronosnetd/Makefile
kronosnetd/kronosnetd.logrotate
libknet/Makefile
- libknet/Doxyfile
libknet/libknet.pc
libknet/tests/Makefile
+ libknet/man/Doxyfile
+ libknet/man/Makefile
docs/Makefile
poc-code/Makefile
poc-code/iov-hash/Makefile
poc-code/access-list/Makefile
])
AC_OUTPUT
diff --git a/kronosnet.spec.in b/kronosnet.spec.in
index 9d7d6ea4..497d380a 100644
--- a/kronosnet.spec.in
+++ b/kronosnet.spec.in
@@ -1,362 +1,363 @@
###############################################################################
###############################################################################
##
## Copyright (C) 2010-2017 Red Hat, Inc. All rights reserved.
##
## This copyrighted material is made available to anyone wishing to use,
## modify, copy, or redistribute it subject to the terms and conditions
## of the GNU General Public License v.2 or higher
##
###############################################################################
###############################################################################
# keep around ready for later user
%global alphatag @alphatag@
%global numcomm @numcomm@
%global dirty @dirty@
# set defaults from ./configure invokation
%@sctp@ sctp
%@nss@ nss
%@openssl@ openssl
%@zlib@ zlib
%@lz4@ lz4
%@lzo2@ lzo2
%@lzma@ lzma
%@bzip2@ bzip2
%@kronosnetd@ kronosnetd
%@libtap@ libtap
%@runautogen@ runautogen
%if %{with sctp}
%global buildsctp 1
%endif
%if %{with nss}
%global buildcryptonss 1
%endif
%if %{with openssl}
%global buildcryptoopenssl 1
%endif
%if %{with zlib}
%global buildcompresszlib 1
%endif
%if %{with lz4}
%global buildcompresslz4 1
%endif
%if %{with lzo2}
%global buildcompresslzo2 1
%endif
%if %{with lzma}
%global buildcompresslzma 1
%endif
%if %{with bzip2}
%global buildcompressbzip2 1
%endif
%if %{with libtap}
%global buildlibtap 1
%endif
%if %{with kronosnetd}
%global buildlibtap 1
%global buildkronosnetd 1
%endif
%if %{with runautogen}
%global buildautogen 1
%endif
# main (empty) package
# http://www.rpm.org/max-rpm/s1-rpm-subpack-spec-file-changes.html
Name: kronosnet
Summary: Multipoint-to-Multipoint VPN daemon
Version: @version@
Release: 1%{?numcomm:.%{numcomm}}%{?alphatag:.%{alphatag}}%{?dirty:.%{dirty}}%{?dist}
License: GPLv2+ and LGPLv2+
Group: System Environment/Base
URL: https://github.com/fabbione/kronosnet/
Source0: https://github.com/fabbione/kronosnet/archive/%{name}-%{version}%{?numcomm:.%{numcomm}}%{?alphatag:-%{alphatag}}%{?dirty:-%{dirty}}.tar.gz
## Setup/build bits
BuildRoot: %(mktemp -ud %{_tmppath}/%{name}-%{version}-%{release}-XXXXXX)
# Build dependencies
BuildRequires: gcc
%if %{defined buildsctp}
BuildRequires: lksctp-tools-devel
%endif
%if %{defined buildcryptonss}
BuildRequires: nss-devel
%endif
%if %{defined buildcryptoopenssl}
BuildRequires: openssl-devel
%endif
%if %{defined buildcompresszlib}
BuildRequires: zlib-devel
%endif
%if %{defined buildcompresslz4}
BuildRequires: lz4-devel
%endif
%if %{defined buildcompresslzo2}
BuildRequires: lzo-devel
%endif
%if %{defined buildcompresslzma}
BuildRequires: xz-devel
%endif
%if %{defined buildcompressbzip2}
BuildRequires: bzip2-devel
%endif
%if %{defined buildkronosnetd}
BuildRequires: libqb-devel pam-devel
%endif
%if %{defined buildautogen}
BuildRequires: autoconf
BuildRequires: automake
BuildRequires: libtool
%endif
%prep
%setup -q -n %{name}-%{version}%{?numcomm:.%{numcomm}}%{?alphatag:-%{alphatag}}%{?dirty:-%{dirty}}
%build
%if %{with runautogen}
./autogen.sh
%endif
%{configure} \
%if %{defined buildsctp}
--enable-libknet-sctp \
%else
--disable-libknet-sctp \
%endif
%if %{defined buildcryptonss}
--enable-crypto-nss \
%else
--disable-crypto-nss \
%endif
%if %{defined buildcryptoopenssl}
--enable-crypto-openssl \
%else
--disable-crypto-openssl \
%endif
%if %{defined buildcompresszlib}
--enable-compress-zlib \
%else
--disable-compress-zlib \
%endif
%if %{defined buildcompresslz4}
--enable-compress-lz4 \
%else
--disable-compress-lz4 \
%endif
%if %{defined buildcompresslzo2}
--enable-compress-lzo2 \
%else
--disable-compress-lzo2 \
%endif
%if %{defined buildcompresslzma}
--enable-compress-lzma \
%else
--disable-compress-lzma \
%endif
%if %{defined buildcompressbzip2}
--enable-compress-bzip2 \
%else
--disable-compress-bzip2 \
%endif
%if %{defined buildkronosnetd}
--enable-kronosnetd \
%endif
%if %{defined buildlibtap}
--enable-libtap \
%endif
--with-initdefaultdir=%{_sysconfdir}/sysconfig/ \
%if %{defined _unitdir}
--with-systemddir=%{_unitdir}
%else
--with-initddir=%{_sysconfdir}/rc.d/init.d/
%endif
make %{_smp_mflags}
%install
rm -rf %{buildroot}
make install DESTDIR=%{buildroot}
# tree cleanup
# remove static libraries
find %{buildroot} -name "*.a" -exec rm {} \;
# remove libtools leftovers
find %{buildroot} -name "*.la" -exec rm {} \;
# handle systemd vs init script
%if %{defined _unitdir}
# remove init scripts
rm -rf %{buildroot}/etc/init.d
%else
# remove systemd specific bits
find %{buildroot} -name "*.service" -exec rm {} \;
%endif
# remove docs
rm -rf %{buildroot}/usr/share/doc/kronosnet
%clean
rm -rf %{buildroot}
# main empty package
%description
kronosnet source
%if %{defined buildkronosnetd}
## Runtime and subpackages section
%package -n kronosnetd
Group: System Environment/Base
Summary: Multipoint-to-Multipoint VPN daemon
%if %{defined _unitdir}
# Needed for systemd unit
Requires(post): systemd-sysv
Requires(post): systemd-units
Requires(preun): systemd-units
Requires(postun): systemd-units
%else
Requires(post): chkconfig
Requires(preun): chkconfig, initscripts
%endif
Requires(post): shadow-utils
Requires(preun): shadow-utils
Requires: pam, /etc/pam.d/passwd
%description -n kronosnetd
The kronosnet daemon is a bridge between kronosnet switching engine
and kernel network tap devices, to create and administer a
distributed LAN over multipoint-to-multipoint VPNs.
The daemon does a poor attempt to provide a configure UI similar
to other known network devices/tools (Cisco, quagga).
Beside looking horrific, it allows runtime changes and
reconfiguration of the kronosnet(s) without daemon reload
or service disruption.
%post -n kronosnetd
%if %{defined _unitdir}
%if 0%{?systemd_post:1}
%systemd_post kronosnetd.service
%else
/bin/systemctl daemon-reload >/dev/null 2>&1 || :
%endif
%else
/sbin/chkconfig --add kronosnetd
%endif
/usr/sbin/groupadd --force --system @defaultadmgroup@
%preun -n kronosnetd
%if %{defined _unitdir}
%if 0%{?systemd_preun:1}
%systemd_preun kronosnetd.service
%else
if [ "$1" -eq 0 ]; then
/bin/systemctl --no-reload disable kronosnetd.service
/bin/systemctl stop kronosnetd.service >/dev/null 2>&1
fi
%endif
%else
if [ "$1" = 0 ]; then
/sbin/service kronosnetd stop >/dev/null 2>&1
/sbin/chkconfig --del kronosnetd
fi
%endif
%files -n kronosnetd
%defattr(-,root,root,-)
%doc COPYING.* COPYRIGHT
%dir %{_sysconfdir}/kronosnet
%dir %{_sysconfdir}/kronosnet/*
%config(noreplace) %{_sysconfdir}/sysconfig/kronosnetd
%config(noreplace) %{_sysconfdir}/pam.d/kronosnetd
%config(noreplace) %{_sysconfdir}/logrotate.d/kronosnetd
%if %{defined _unitdir}
%{_unitdir}/kronosnetd.service
%else
%config(noreplace) %{_sysconfdir}/rc.d/init.d/kronosnetd
%endif
%{_sbindir}/*
%{_mandir}/man8/*
%endif
%if %{defined buildlibtap}
%package -n libtap1
Group: System Environment/Libraries
Summary: Simple userland wrapper around kernel tap devices
%description -n libtap1
This is an over-engineered commodity library to manage a pool
of tap devices and provides the basic
pre-up.d/up.d/down.d/post-down.d infrastructure.
%files -n libtap1
%defattr(-,root,root,-)
%doc COPYING.* COPYRIGHT
%{_libdir}/libtap.so.*
%post -n libtap1 -p /sbin/ldconfig
%postun -n libtap1 -p /sbin/ldconfig
%package -n libtap1-devel
Group: Development/Libraries
Summary: Simple userland wrapper around kernel tap devices (developer files)
Requires: libtap1 = %{version}-%{release}
Requires: pkgconfig
%description -n libtap1-devel
This is an over-engineered commodity library to manage a pool
of tap devices and provides the basic
pre-up.d/up.d/down.d/post-down.d infrastructure.
%files -n libtap1-devel
%defattr(-,root,root,-)
%doc COPYING.* COPYRIGHT
%{_libdir}/libtap.so
%{_includedir}/libtap.h
%{_libdir}/pkgconfig/libtap.pc
%endif
%package -n libknet1
Group: System Environment/Libraries
Summary: Kronosnet core switching implementation
%description -n libknet1
The whole kronosnet core is implemented in this library.
Please refer to the not-yet-existing documentation for further
information.
%files -n libknet1
%defattr(-,root,root,-)
%doc COPYING.* COPYRIGHT
%{_libdir}/libknet.so.*
%post -n libknet1 -p /sbin/ldconfig
%postun -n libknet1 -p /sbin/ldconfig
%package -n libknet1-devel
Group: Development/Libraries
Summary: Kronosnet core switching implementation (developer files)
Requires: libknet1 = %{version}-%{release}
Requires: pkgconfig
%description -n libknet1-devel
The whole kronosnet core is implemented in this library.
Please refer to the not-yet-existing documentation for further
information.
%files -n libknet1-devel
%defattr(-,root,root,-)
%doc COPYING.* COPYRIGHT
%{_libdir}/libknet.so
%{_includedir}/libknet.h
%{_libdir}/pkgconfig/libknet.pc
+%{_mandir}/man3/*.3.gz
%changelog
* @date@ Autotools generated version <nobody@nowhere.org> - @version@-1-@numcomm@.@alphatag@.@dirty@
- These aren't the droids you're looking for.
diff --git a/libknet/Makefile.am b/libknet/Makefile.am
index a3927b3a..f8ed648b 100644
--- a/libknet/Makefile.am
+++ b/libknet/Makefile.am
@@ -1,112 +1,114 @@
#
# Copyright (C) 2010-2015 Red Hat, Inc. All rights reserved.
#
# Authors: Fabio M. Di Nitto <fabbione@kronosnet.org>
# Federico Simoncelli <fsimon@kronosnet.org>
#
# This software licensed under GPL-2.0+, LGPL-2.0+
#
MAINTAINERCLEANFILES = Makefile.in
include $(top_srcdir)/build-aux/check.mk
SYMFILE = libknet_exported_syms
EXTRA_DIST = $(SYMFILE)
-SUBDIRS = . tests
+SUBDIRS = . tests man
libversion = 1:0:0
# override global LIBS that pulls in lots of craft we don't need here
LIBS =
sources = \
common.c \
compat.c \
compress.c \
compress_zlib.c \
compress_lz4.c \
compress_lzo2.c \
compress_lzma.c \
compress_bzip2.c \
crypto.c \
crypto_nss.c \
crypto_openssl.c \
handle.c \
host.c \
links.c \
logging.c \
netutils.c \
threads_common.c \
threads_dsthandler.c \
threads_heartbeat.c \
threads_pmtud.c \
threads_rx.c \
threads_tx.c \
transport_udp.c \
transport_sctp.c \
transport_loopback.c \
transport_common.c
include_HEADERS = libknet.h
pkgconfigdir = $(libdir)/pkgconfig
pkgconfig_DATA = libknet.pc
noinst_HEADERS = \
common.h \
compat.h \
compress.h \
compress_zlib.h \
compress_lz4.h \
compress_lzo2.h \
compress_lzma.h \
compress_bzip2.h \
crypto.h \
crypto_nss.h \
crypto_openssl.h \
host.h \
internals.h \
links.h \
logging.h \
netutils.h \
onwire.h \
threads_common.h \
threads_dsthandler.h \
threads_heartbeat.h \
threads_pmtud.h \
threads_rx.h \
threads_tx.h \
transports.h
lib_LTLIBRARIES = libknet.la
libknet_la_SOURCES = $(sources)
libknet_la_CFLAGS = $(nss_CFLAGS) $(openssl_CFLAGS) \
$(zlib_CFLAGS) $(liblz4_CFLAGS) $(lzo2_CFLAGS) $(liblzma_CFLAGS) $(bzip2_CFLAGS)
EXTRA_libknet_la_DEPENDENCIES = $(SYMFILE)
libknet_la_LDFLAGS = -Wl,--version-script=$(srcdir)/$(SYMFILE) \
--export-dynamic \
-version-number $(libversion)
libknet_la_LIBADD = $(dl_LIBS) $(pthread_LIBS) $(rt_LIBS) $(m_LIBS)
-directory = $(builddir)/man
+dist_man_MANS = man
-dist_man_MANS = $(directory)/*.3
-
-$(directory)/*.3: doxyfile.stamp
+update-man-pages: doxyfile.stamp
doxyfile.stamp: Doxyfile
+if MANPAGEUPDATES
$(DOXYGEN) Doxyfile
- $(DOXY2MAN) -o man -s 3 --short-pkg @PACKAGE_NAME@ --pkg "Kronosnet Programmer's Manual" $(builddir)/xml/libknet_8h.xml
+ $(DOXY2MAN) -o $(abs_srcdir)/man -s 3 --short-pkg @PACKAGE_NAME@ --pkg "Kronosnet Programmer's Manual" $(builddir)/xml/libknet_8h.xml
+else
+ @echo this system does not have doxy2man or doxygen installed. Unable to update man pages automatically.
+endif
touch doxyfile.stamp
clean-local:
- rm -rf doxyfile.stamp xml man
+ rm -rf doxyfile.stamp xml
diff --git a/libknet/Doxyfile.in b/libknet/man/Doxyfile.in
similarity index 70%
rename from libknet/Doxyfile.in
rename to libknet/man/Doxyfile.in
index 4a03555c..aa02f138 100644
--- a/libknet/Doxyfile.in
+++ b/libknet/man/Doxyfile.in
@@ -1,9 +1,9 @@
+PROJECT_NAME = @PACKAGE_NAME@
+PROJECT_NUMBER = @PACKAGE_VERSION@
+INPUT = @srcdir@/../libknet.h
+XML_OUTPUT = @abs_builddir@/xml
GENERATE_XML = YES
-XML_OUTPUT = xml
XML_PROGRAMLISTING = NO
-INPUT = @srcdir@/libknet.h
AUTOLINK_SUPPORT = NO
GENERATE_HTML = NO
GENERATE_LATEX = NO
-PROJECT_NAME = @PACKAGE_NAME@
-PROJECT_NUMBER = @PACKAGE_VERSION@
diff --git a/libknet/man/Makefile.am b/libknet/man/Makefile.am
new file mode 100644
index 00000000..8f826f64
--- /dev/null
+++ b/libknet/man/Makefile.am
@@ -0,0 +1,87 @@
+#
+# Copyright (C) 2017 Red Hat, Inc. All rights reserved.
+#
+# Authors: Fabio M. Di Nitto <fabbione@kronosnet.org>
+# Federico Simoncelli <fsimon@kronosnet.org>
+#
+# This software licensed under GPL-2.0+, LGPL-2.0+
+#
+
+MAINTAINERCLEANFILES = Makefile.in
+
+include $(top_srcdir)/build-aux/check.mk
+
+dist_man_MANS = \
+ knet_addrtostr.3 \
+ knet_handle_add_datafd.3 \
+ knet_handle_clear_stats.3 \
+ knet_handle_compress.3 \
+ knet_handle_crypto.3 \
+ knet_handle_enable_filter.3 \
+ knet_handle_enable_pmtud_notify.3 \
+ knet_handle_enable_sock_notify.3 \
+ knet_handle_free.3 \
+ knet_handle_get_channel.3 \
+ knet_handle_get_compress_list.3 \
+ knet_handle_get_crypto_list.3 \
+ knet_handle_get_datafd.3 \
+ knet_handle_get_stats.3 \
+ knet_handle_get_transport_id_by_name.3 \
+ knet_handle_get_transport_list.3 \
+ knet_handle_get_transport_name_by_id.3 \
+ knet_handle_get_transport_reconnect_interval.3 \
+ knet_handle_new.3 \
+ knet_handle_pmtud_get.3 \
+ knet_handle_pmtud_getfreq.3 \
+ knet_handle_pmtud_setfreq.3 \
+ knet_handle_remove_datafd.3 \
+ knet_handle_setfwd.3 \
+ knet_handle_set_transport_reconnect_interval.3 \
+ knet_host_add.3 \
+ knet_host_enable_status_change_notify.3 \
+ knet_host_get_host_list.3 \
+ knet_host_get_id_by_host_name.3 \
+ knet_host_get_name_by_host_id.3 \
+ knet_host_get_policy.3 \
+ knet_host_get_status.3 \
+ knet_host_remove.3 \
+ knet_host_set_name.3 \
+ knet_host_set_policy.3 \
+ knet_link_clear_config.3 \
+ knet_link_get_config.3 \
+ knet_link_get_enable.3 \
+ knet_link_get_link_list.3 \
+ knet_link_get_ping_timers.3 \
+ knet_link_get_pong_count.3 \
+ knet_link_get_priority.3 \
+ knet_link_get_status.3 \
+ knet_link_set_config.3 \
+ knet_link_set_enable.3 \
+ knet_link_set_ping_timers.3 \
+ knet_link_set_pong_count.3 \
+ knet_link_set_priority.3 \
+ knet_log_get_loglevel.3 \
+ knet_log_get_loglevel_id.3 \
+ knet_log_get_loglevel_name.3 \
+ knet_log_get_subsystem_id.3 \
+ knet_log_get_subsystem_name.3 \
+ knet_log_set_loglevel.3 \
+ knet_recv.3 \
+ knet_send.3 \
+ knet_send_sync.3 \
+ knet_strtoaddr.3 \
+ libknet.h.3
+
+update-man-pages: doxyfile.stamp
+
+doxyfile.stamp: Doxyfile
+if MANPAGEUPDATES
+ $(DOXYGEN) Doxyfile
+ $(DOXY2MAN) -o $(abs_srcdir) -s 3 --short-pkg @PACKAGE_NAME@ --pkg "Kronosnet Programmer's Manual" $(builddir)/xml/libknet_8h.xml
+else
+ @echo this system does not have doxy2man or doxygen installed. Unable to update man pages automatically.
+endif
+ touch doxyfile.stamp
+
+clean-local:
+ rm -rf doxyfile.stamp xml
diff --git a/libknet/man/knet_addrtostr.3 b/libknet/man/knet_addrtostr.3
new file mode 100644
index 00000000..0af08d2b
--- /dev/null
+++ b/libknet/man/knet_addrtostr.3
@@ -0,0 +1,39 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_addrtostr 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_addrtostr \- Convert an address to a host name.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_addrtostr\fP(
+ \fBconst struct sockaddr_storage *\fP\fIss\fP,
+ \fBsocklen_t \fP\fIsslen\fP,
+ \fBchar *\fP\fIaddr_buf\fP,
+ \fBsize_t \fP\fIaddr_buf_size\fP,
+ \fBchar *\fP\fIport_buf\fP,
+ \fBsize_t \fP\fIport_buf_size\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_addrtostr
+.PP
+ss - sockaddr_storage to convert
+.PP
+sslen - len of the sockaddr_storage
+.PP
+host - IPaddr/hostname where to store data (recommended size: KNET_MAX_HOST_LEN)
+.PP
+port - port buffer where to store data (recommended size: KNET_MAX_PORT_LEN)
+.SH RETURN VALUE
+.PP
+knet_strtoaddr returns same error codes as getnameinfo
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_add_datafd.3 b/libknet/man/knet_handle_add_datafd.3
new file mode 100644
index 00000000..8b9be8c5
--- /dev/null
+++ b/libknet/man/knet_handle_add_datafd.3
@@ -0,0 +1,58 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_add_datafd 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_add_datafd \- Install a file descriptor for communication.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_add_datafd\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBint *\fP\fIdatafd\fP,
+ \fBint8_t *\fP\fIchannel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_add_datafd
+.PP
+IMPORTANT: In order to add datafd to knet, knet_handle_enable_sock_notify MUST be set and be able to handle both errors (-1) and 0 bytes read / write from the provided datafd. On read error (< 0) from datafd, the socket is automatically removed from polling to avoid spinning on dead sockets. It is safe to call knet_handle_remove_datafd even on sockets that have been removed.
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+*datafd - read/write file descriptor. knet will read data here to send to the other hosts and will write data received from the network. Each data packet can be of max size KNET_MAX_PACKET_SIZE! Applications using knet_send/knet_recv will receive a proper error if the packet size is not within boundaries. Applications using their own functions to write to the datafd should NOT write more than KNET_MAX_PACKET_SIZE.
+.PP
+Please refer to handle.c on how to set up a socketpair.
+.PP
+datafd can be 0, and knet_handle_add_datafd will create a properly populated socket pair the same way as ping_test, or a value higher than 0. A negative number will return an error. On exit knet_handle_free will take care to cleanup the socketpair only if they have been created by knet_handle_add_datafd.
+.PP
+It is possible to pass either sockets or normal fds. User provided datafd will be marked as non-blocking and close-on-exit.
+.PP
+*channel - This value has the same effect of VLAN tagging. A negative value will auto-allocate a channel. Setting a value between 0 and 31 will try to allocate that specific channel (unless already in use).
+.PP
+It is possible to add up to 32 datafds but be aware that each one of them must have a receiving end on the other host.
+.PP
+Example: hostA channel 0 will be delivered to datafd on hostB channel 0 hostA channel 1 to hostB channel 1.
+.PP
+Each channel must have a unique file descriptor.
+.PP
+If your application could have 2 channels on one host and one channel on another host, then you can use dst_host_filter to manipulate channel values on TX and RX.
+.SH RETURN VALUE
+.PP
+knet_handle_add_datafd returns
+.TP
+.B 0
+on success, *datafd will be populated with a socket if the original value was 0 or if a specific fd was set, the value is untouched. *channel will be populated with a channel number if the original value was negative or the value is untouched if a specific channel was requested.
+
+.TP
+.B -1
+on error and errno is set. *datafd and *channel are untouched or empty.
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_clear_stats.3 b/libknet/man/knet_handle_clear_stats.3
new file mode 100644
index 00000000..324a0e6e
--- /dev/null
+++ b/libknet/man/knet_handle_clear_stats.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_clear_stats 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_clear_stats \- Clear knet stats - link and/or handle.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_clear_stats\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBint \fP\fIclear_option\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_clear_stats
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+clear_option Which stats to clear (see below)
+.SH RETURN VALUE
+.PP
+0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_compress.3 b/libknet/man/knet_handle_compress.3
new file mode 100644
index 00000000..8985a1b5
--- /dev/null
+++ b/libknet/man/knet_handle_compress.3
@@ -0,0 +1,55 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_compress 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_compress \- Set up packet compression.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_compress\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBstruct knet_handle_compress_cfg *\fP\fIknet_handle_compress_cfg\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_compress
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+knet_handle_compress_cfg - pointer to a knet_handle_compress_cfg structure
+.PP
+compress_model should contain the mode name. Currently only "zlib" and "lz4" are supported. Setting to "none" will disable compression.
+.PP
+compress_threshold tells the transmission thread to NOT compress any packets that are smaller than the value indicated. Default 100 bytes. Set to 0 to reset to the default. Set to 1 to compress everything. Max accepted value is KNET_MAX_PACKET_SIZE.
+.PP
+compress_level some compression libraries allow tuning of compression parameters. For example zlib value ranges from 0 to 9 where 0 is no compression and 9 is max compression. This value is passed pristine to the compression library. zlib: 0 (no compression), 1 (minimal) .. 9 (max compression). lz4: 1 (max compression)... 9 (fastest compression). lz4hc: 1 (min compression) ... LZ4HC_MAX_CLEVEL (16) or LZ4HC_CLEVEL_MAX (12) depends on the installed version of lz4hc. libknet can detects the max value and will print an appropriate warning. lzo2: accepts only some specific values depending on the requested algorithm: 1 : lzo1x_1_compress (default) 11 : lzo1x_1_11_compress 12 : lzo1x_1_12_compress 15 : lzo1x_1_15_compress 999: lzo1x_999_compress every other values will use default lzma: 0 (minimal) .. 9 (max compression) bzip2: 1 (minimal) .. 9 (max compression) Please refer to the library man pages on how to be set this value, as it is passed unmodified to the compression algorithm where supported.
+.PP
+knet does NOT implement the compression algorithm directly. it relies on external libraries for this functionality. Please read the libraries man pages to figure out which algorithm/compression level is best for the data you are planning to transmit.
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_compress_cfg {
+ char \fIcompress_model\fP;
+ uint32_t \fIcompress_threshold\fP;
+ int \fIcompress_level\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+knet_handle_compress returns 0 on success -1 on error and errno is set. EINVAL means that either the model or the level are not supported.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_crypto.3 b/libknet/man/knet_handle_crypto.3
new file mode 100644
index 00000000..5391ea55
--- /dev/null
+++ b/libknet/man/knet_handle_crypto.3
@@ -0,0 +1,73 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_crypto 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_crypto \- set up packet cryptographic signing & encryption
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_crypto\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBstruct knet_handle_crypto_cfg *\fP\fIknet_handle_crypto_cfg\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_crypto
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+knet_handle_crypto_cfg - pointer to a knet_handle_crypto_cfg structure
+.PP
+crypto_model should contain the model name. Currently only "openssl" and "nss" are supported. Setting to "none" will disable crypto.
+.PP
+crypto_cipher_type should contain the cipher algo name. It can be set to "none" to disable encryption. Currently supported by "nss" model: "3des", "aes128", "aes192" and "aes256". "openssl" model supports more modes and it strictly depends on the openssl build. See: EVP_get_cipherbyname openssl API call for details.
+.PP
+crypto_hash_type should contain the hashing algo name. It can be set to "none" to disable hashing. Currently supported by "nss" model: "md5", "sha1", "sha256", "sha384" and "sha512". "openssl" model supports more modes and it strictly depends on the openssl build. See: EVP_get_digestbyname openssl API call for details.
+.PP
+private_key will contain the private shared key. It has to be at least KNET_MIN_KEY_LEN long.
+.PP
+private_key_len length of the provided private_key.
+.PP
+it is safe to call knet_handle_crypto multiple times at runtime. The last config will be used. IMPORTANT: a call to knet_handle_crypto can fail due to: 1) failure to obtain locking 2) errors to initializing the crypto level. This can happen even in subsequent calls to knet_handle_crypto. A failure in crypto init, might leave your traffic unencrypted! It's best to stop data forwarding (see knet_handle_setfwd(3)), change crypto config, start forward again.
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_crypto_cfg {
+ char \fIcrypto_model\fP;
+ char \fIcrypto_cipher_type\fP;
+ char \fIcrypto_hash_type\fP;
+ unsigned char \fIprivate_key\fP;
+ unsigned int \fIprivate_key_len\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+knet_handle_crypto returns:
+.TP
+.B 0
+on success
+
+.TP
+.B -1
+on error and errno is set.
+
+.TP
+.B -2
+on crypto subsystem initialization error. No errno is provided at the moment (yet).
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_enable_filter.3 b/libknet/man/knet_handle_enable_filter.3
new file mode 100644
index 00000000..eb87829a
--- /dev/null
+++ b/libknet/man/knet_handle_enable_filter.3
@@ -0,0 +1,38 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_enable_filter 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_enable_filter \- install a filter to route packets
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_enable_filter\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBvoid *\fP\fIdst_host_filter_fn_private_data\fP,
+ \fBint(*)(void *private_data, const unsigned char *outdata, ssize_t outdata_len, uint8_t tx_rx, knet_node_id_t this_host_id, knet_node_id_t src_host_id, int8_t *channel, knet_node_id_t *dst_host_ids, size_t *dst_host_ids_entries) \fP\fIdst_host_filter_fn\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_enable_filter
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+dst_host_filter_fn_private_data void pointer to data that can be used to identify the callback.
+.PP
+dst_host_filter_fn - is a callback function that is invoked every time a packet hits datafd (see knet_handle_new(3)). the function allows users to tell libknet where the packet has to be delivered.
+.PP
+const unsigned char *outdata - is a pointer to the current packet ssize_t outdata_len - lenght of the above data uint8_t tx_rx - filter is called on tx or rx (see defines below) knet_node_id_t this_host_id - host_id processing the packet knet_node_id_t src_host_id - host_id that generated the packet knet_node_id_t *dst_host_ids - array of KNET_MAX_HOST knet_node_id_t where to store the destinations size_t *dst_host_ids_entries - number of hosts to send the message
+.PP
+dst_host_filter_fn should return -1 on error, packet is discarded. 0 packet is unicast and should be sent to dst_host_ids and there are dst_host_ids_entries in the buffer. 1 packet is broadcast/multicast and is sent all hosts. contents of dst_host_ids and dst_host_ids_entries are ignored. (see also kronosnetd/etherfilter.* for an example that filters based on ether protocol)
+.SH RETURN VALUE
+.PP
+knet_handle_enable_filter returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_enable_pmtud_notify.3 b/libknet/man/knet_handle_enable_pmtud_notify.3
new file mode 100644
index 00000000..40929d7d
--- /dev/null
+++ b/libknet/man/knet_handle_enable_pmtud_notify.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_enable_pmtud_notify 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_enable_pmtud_notify \- install a callback to receive PMTUd changes
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_enable_pmtud_notify\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBvoid *\fP\fIpmtud_notify_fn_private_data\fP,
+ \fBvoid(*)(void *private_data, unsigned int data_mtu) \fP\fIpmtud_notify_fn\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_enable_pmtud_notify
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+pmtud_notify_fn_private_data void pointer to data that can be used to identify the callback.
+.PP
+pmtud_notify_fn is a callback function that is invoked every time a path MTU size change is detected. The function allows libknet to notify the user of data MTU, that's the max value that can be send onwire without fragmentation. The data MTU will always be lower than real link MTU because it accounts for protocol overhead, knet packet header and (if configured) crypto overhead, This function MUST NEVER block or add substantial delays.
+.SH RETURN VALUE
+.PP
+knet_handle_enable_pmtud_notify returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_enable_sock_notify.3 b/libknet/man/knet_handle_enable_sock_notify.3
new file mode 100644
index 00000000..4d0ab2ab
--- /dev/null
+++ b/libknet/man/knet_handle_enable_sock_notify.3
@@ -0,0 +1,32 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_enable_sock_notify 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_enable_sock_notify \- Register a callback to receive socket events.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_enable_sock_notify\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBvoid *\fP\fIsock_notify_fn_private_data\fP,
+ \fBvoid(*)(void *private_data, int datafd, int8_t channel, uint8_t tx_rx, int error, int errorno) \fP\fIsock_notify_fn\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_enable_sock_notify knet_h - pointer to knet_handle_t
+.PP
+sock_notify_fn_private_data void pointer to data that can be used to identify the callback.
+.PP
+sock_notify_fn A callback function that is invoked every time a socket in the datafd pool will report an error (-1) or an end of read (0) (see socket.7). This function MUST NEVER block or add substantial delays. The callback is invoked in an internal unlocked area to allow calls to knet_handle_add_datafd/knet_handle_remove_datafd to swap/replace the bad fd. if both err and errno are 0, it means that the socket has received a 0 byte packet (EOF?). The callback function must either remove the fd from knet (by calling knet_handle_remove_fd()) or dup a new fd in its place. Failure to do this can cause problems.
+.SH RETURN VALUE
+.PP
+knet_handle_enable_sock_notify returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_free.3 b/libknet/man/knet_handle_free.3
new file mode 100644
index 00000000..6d09972e
--- /dev/null
+++ b/libknet/man/knet_handle_free.3
@@ -0,0 +1,26 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_free 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_free \- Destroy a knet handle, free all resources.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_free\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_free knet_h - pointer to knet_handle_t
+.SH RETURN VALUE
+.PP
+knet_handle_free returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_channel.3 b/libknet/man/knet_handle_get_channel.3
new file mode 100644
index 00000000..f06322f0
--- /dev/null
+++ b/libknet/man/knet_handle_get_channel.3
@@ -0,0 +1,40 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_channel 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_channel \- Get the channel associated with a file descriptor.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_channel\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst int \fP\fIdatafd\fP,
+ \fBint8_t *\fP\fIchannel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_channel knet_h - pointer to knet_handle_t
+.PP
+datafd - get the channel associated to this datafd
+.PP
+*channel - will contain the result
+.SH RETURN VALUE
+.PP
+knet_handle_get_channel returns
+.TP
+.B 0
+on success and *channel will contain the result
+
+.TP
+.B -1
+on error and errno is set. and *channel content is meaningless
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_compress_list.3 b/libknet/man/knet_handle_get_compress_list.3
new file mode 100644
index 00000000..4741bf86
--- /dev/null
+++ b/libknet/man/knet_handle_get_compress_list.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_compress_list 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_compress_list \- Get a list of support compression types.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_compress_list\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char **\fP\fIcompress_names\fP,
+ \fBsize_t *\fP\fInum_names\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_compress_list
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+compress_names - array of char * If NULL then only the number of names is returned in num_names to to allow the caller to allocate sufficient space.
+.PP
+num_names - returns the number of strings in compres_names
+.SH RETURN VALUE
+.PP
+knet_host_add returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_crypto_list.3 b/libknet/man/knet_handle_get_crypto_list.3
new file mode 100644
index 00000000..24f63afc
--- /dev/null
+++ b/libknet/man/knet_handle_get_crypto_list.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_crypto_list 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_crypto_list \- Get a list of supported crypto libraries.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_crypto_list\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char **\fP\fIcrypto_names\fP,
+ \fBsize_t *\fP\fInum_names\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_crypto_list
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+crypto_names - array of char * If NULL then only the number of names is returned in num_names to to allow the caller to allocate sufficient space.
+.PP
+num_names - returns the number of strings in crypto_names
+.SH RETURN VALUE
+.PP
+knet_host_add returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_datafd.3 b/libknet/man/knet_handle_get_datafd.3
new file mode 100644
index 00000000..11b063b4
--- /dev/null
+++ b/libknet/man/knet_handle_get_datafd.3
@@ -0,0 +1,40 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_datafd 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_datafd \- Get the file descriptor associated with a channel.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_datafd\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst int8_t \fP\fIchannel\fP,
+ \fBint *\fP\fIdatafd\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_datafd knet_h - pointer to knet_handle_t
+.PP
+channel - get the datafd associated to this channel
+.PP
+*datafd - will contain the result
+.SH RETURN VALUE
+.PP
+knet_handle_get_datafd returns
+.TP
+.B 0
+on success and *datafd will contain the results
+
+.TP
+.B -1
+on error and errno is set. and *datafd content is meaningless
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_stats.3 b/libknet/man/knet_handle_get_stats.3
new file mode 100644
index 00000000..2674641c
--- /dev/null
+++ b/libknet/man/knet_handle_get_stats.3
@@ -0,0 +1,70 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_stats 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_stats \- Get statistics for compression & crypto.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_stats\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBstruct knet_handle_stats *\fP\fIstats\fP,
+ \fBsize_t \fP\fIstruct_size\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_stats
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+knet_handle_stats pointer to a knet_handle_stats structure
+.PP
+struct_size size of knet_handle_stats structure to allow for backwards compatibility. libknet will only copy this much data into the stats structure so that older callers will not get overflowed if new fields are added.
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_stats {
+ size_t \fIsize\fP;
+ uint64_t \fItx_uncompressed_packets\fP;
+ uint64_t \fItx_compressed_packets\fP;
+ uint64_t \fItx_compressed_original_bytes\fP;
+ uint64_t \fItx_compressed_size_bytes\fP;
+ uint64_t \fItx_compress_time_ave\fP;
+ uint64_t \fItx_compress_time_min\fP;
+ uint64_t \fItx_compress_time_max\fP;
+ uint64_t \fIrx_compressed_packets\fP;
+ uint64_t \fIrx_compressed_original_bytes\fP;
+ uint64_t \fIrx_compressed_size_bytes\fP;
+ uint64_t \fIrx_compress_time_ave\fP;
+ uint64_t \fIrx_compress_time_min\fP;
+ uint64_t \fIrx_compress_time_max\fP;
+ uint64_t \fItx_crypt_packets\fP;
+ uint64_t \fItx_crypt_byte_overhead\fP;
+ uint64_t \fItx_crypt_time_ave\fP;
+ uint64_t \fItx_crypt_time_min\fP;
+ uint64_t \fItx_crypt_time_max\fP;
+ uint64_t \fIrx_crypt_packets\fP;
+ uint64_t \fIrx_crypt_time_ave\fP;
+ uint64_t \fIrx_crypt_time_min\fP;
+ uint64_t \fIrx_crypt_time_max\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_transport_id_by_name.3 b/libknet/man/knet_handle_get_transport_id_by_name.3
new file mode 100644
index 00000000..4cbbe7f7
--- /dev/null
+++ b/libknet/man/knet_handle_get_transport_id_by_name.3
@@ -0,0 +1,39 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_transport_id_by_name 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_transport_id_by_name \- Get a transport ID from its name.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBuint8_t knet_handle_get_transport_id_by_name\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char *\fP\fIname\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_transport_id_by_name
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+name - transport name (UDP/SCTP/etc)
+.SH RETURN VALUE
+.PP
+knet_handle_get_transport_name_by_id returns:
+.TP
+.B KNET_MAX_TRANSPORTS
+on error and errno is set accordingly
+
+.TP
+.B KNET_TRANSPORT_xxx
+on success.
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_transport_list.3 b/libknet/man/knet_handle_get_transport_list.3
new file mode 100644
index 00000000..00eb53ef
--- /dev/null
+++ b/libknet/man/knet_handle_get_transport_list.3
@@ -0,0 +1,50 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_transport_list 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_transport_list \- Get a list of the transports support by this build of knet.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_transport_list\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBstruct transport_info *\fP\fItransport_list\fP,
+ \fBsize_t *\fP\fItransport_list_entries\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_transport_list
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+transport_list - an array of struct transport_info that must be at least of size struct transport_info * KNET_MAX_TRANSPORTS
+.PP
+transport_list_entries - pointer to a size_t where to store how many transports are available in this build of libknet.
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct transport_info {
+ const char *\fIname\fP;
+ uint8_t \fIid\fP;
+ uint8_t \fIproperties\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+knet_handle_get_transport_list returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_transport_name_by_id.3 b/libknet/man/knet_handle_get_transport_name_by_id.3
new file mode 100644
index 00000000..70f2743e
--- /dev/null
+++ b/libknet/man/knet_handle_get_transport_name_by_id.3
@@ -0,0 +1,39 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_transport_name_by_id 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_transport_name_by_id \- Get a transport name from its ID number.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBconst char * knet_handle_get_transport_name_by_id\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBuint8_t \fP\fItransport\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_transport_name_by_id
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+transport - one of the above KNET_TRANSPORT_xxx constants
+.SH RETURN VALUE
+.PP
+knet_handle_get_transport_name_by_id returns:
+.TP
+.B pointer
+to the name on success or
+
+.TP
+.B NULL
+on error and errno is set.
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_get_transport_reconnect_interval.3 b/libknet/man/knet_handle_get_transport_reconnect_interval.3
new file mode 100644
index 00000000..d3201584
--- /dev/null
+++ b/libknet/man/knet_handle_get_transport_reconnect_interval.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_get_transport_reconnect_interval 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_get_transport_reconnect_interval \- Get the interval between transport attempts to reconnect a failed link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_get_transport_reconnect_interval\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBuint32_t *\fP\fImsecs\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_get_transport_reconnect_interval
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+msecs - milliseconds
+.SH RETURN VALUE
+.PP
+knet_handle_get_transport_reconnect_interval returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_new.3 b/libknet/man/knet_handle_new.3
new file mode 100644
index 00000000..aafe301c
--- /dev/null
+++ b/libknet/man/knet_handle_new.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_new 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_new \- create a new instance of a knet handle
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBknet_handle_t knet_handle_new\fP(
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBint \fP\fIlog_fd\fP,
+ \fBuint8_t \fP\fIdefault_log_level\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_new
+.PP
+host_id - Each host in a knet is identified with a unique ID. when creating a new handle local host_id must be specified (0 to UINT16T_MAX are all valid). It is the user's responsibility to check that the value is unique, or bad things might happen.
+.PP
+log_fd - Write file descriptor. If set to a value > 0, it will be used to write log packets (see below) from libknet to the application. Setting to 0 will disable logging from libknet. It is possible to enable logging at any given time (see logging API below). Make sure to either read from this filedescriptor properly and/or mark it O_NONBLOCK, otherwise if the fd becomes full, libknet could block.
+.PP
+default_log_level - If logfd is specified, it will initialize all subsystems to log at default_log_level value. (see logging API below)
+.SH RETURN VALUE
+.PP
+on success, a new knet_handle_t is returned. on failure, NULL is returned and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_pmtud_get.3 b/libknet/man/knet_handle_pmtud_get.3
new file mode 100644
index 00000000..22167faa
--- /dev/null
+++ b/libknet/man/knet_handle_pmtud_get.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_pmtud_get 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_pmtud_get \- Get the current data MTU.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_pmtud_get\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBunsigned int *\fP\fIdata_mtu\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_pmtud_get
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+data_mtu - pointer where to store data_mtu
+.SH RETURN VALUE
+.PP
+knet_handle_pmtud_get returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_pmtud_getfreq.3 b/libknet/man/knet_handle_pmtud_getfreq.3
new file mode 100644
index 00000000..ff4a6c6c
--- /dev/null
+++ b/libknet/man/knet_handle_pmtud_getfreq.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_pmtud_getfreq 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_pmtud_getfreq \- Get the interval between PMTUd scans.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_pmtud_getfreq\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBunsigned int *\fP\fIinterval\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_pmtud_getfreq
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+interval - pointer where to store the current interval value
+.SH RETURN VALUE
+.PP
+knet_handle_pmtud_setfreq returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_pmtud_setfreq.3 b/libknet/man/knet_handle_pmtud_setfreq.3
new file mode 100644
index 00000000..8bcc158f
--- /dev/null
+++ b/libknet/man/knet_handle_pmtud_setfreq.3
@@ -0,0 +1,33 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_pmtud_setfreq 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_pmtud_setfreq \- Set the interval between PMTUd scans.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_pmtud_setfreq\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBunsigned int \fP\fIinterval\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_pmtud_setfreq
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+interval - define the interval in seconds between PMTUd scans range from 1 to 86400 (24h)
+.PP
+default interval is 60.
+.SH RETURN VALUE
+.PP
+knet_handle_pmtud_setfreq returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_remove_datafd.3 b/libknet/man/knet_handle_remove_datafd.3
new file mode 100644
index 00000000..f616733b
--- /dev/null
+++ b/libknet/man/knet_handle_remove_datafd.3
@@ -0,0 +1,29 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_remove_datafd 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_remove_datafd \- Remove a file descriptor from knet.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_remove_datafd\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBint \fP\fIdatafd\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_remove_datafd knet_h - pointer to knet_handle_t
+.PP
+datafd - file descriptor to remove. NOTE that if the socket/fd was created by knet_handle_add_datafd, the socket will be closed by libknet.
+.SH RETURN VALUE
+.PP
+knet_handle_remove_datafd returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_set_transport_reconnect_interval.3 b/libknet/man/knet_handle_set_transport_reconnect_interval.3
new file mode 100644
index 00000000..f27ed340
--- /dev/null
+++ b/libknet/man/knet_handle_set_transport_reconnect_interval.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_set_transport_reconnect_interval 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_set_transport_reconnect_interval \- Set the interval between transport attempts to reconnect a failed link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_set_transport_reconnect_interval\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBuint32_t \fP\fImsecs\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_set_transport_reconnect_interval
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+msecs - milliseconds
+.SH RETURN VALUE
+.PP
+knet_handle_set_transport_reconnect_interval returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_handle_setfwd.3 b/libknet/man/knet_handle_setfwd.3
new file mode 100644
index 00000000..a09f7fe6
--- /dev/null
+++ b/libknet/man/knet_handle_setfwd.3
@@ -0,0 +1,33 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_handle_setfwd 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_handle_setfwd \- Start packet forwarding.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_handle_setfwd\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBunsigned int \fP\fIenabled\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_handle_setfwd
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+enable - set to 1 to allow data forwarding, 0 to disable data forwarding.
+.PP
+By default data forwarding is off and no traffic will pass through knet until it is set on.
+.SH RETURN VALUE
+.PP
+knet_handle_setfwd returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_add.3 b/libknet/man/knet_host_add.3
new file mode 100644
index 00000000..7133f6e2
--- /dev/null
+++ b/libknet/man/knet_host_add.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_add 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_add \- Add a new host ID to knet.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_add\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_add
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - each host in a knet is identified with a unique ID (see also knet_handle_new(3))
+.SH RETURN VALUE
+.PP
+knet_host_add returns: 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_enable_status_change_notify.3 b/libknet/man/knet_host_enable_status_change_notify.3
new file mode 100644
index 00000000..1121c63b
--- /dev/null
+++ b/libknet/man/knet_host_enable_status_change_notify.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_enable_status_change_notify 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_enable_status_change_notify \- Install a callback to get host status change events.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_enable_status_change_notify\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBvoid *\fP\fIhost_status_change_notify_fn_private_data\fP,
+ \fBvoid(*)(void *private_data, knet_node_id_t host_id, uint8_t reachable, uint8_t remote, uint8_t external) \fP\fIhost_status_change_notify_fn\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_enable_status_change_notify
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_status_change_notify_fn_private_data void pointer to data that can be used to identify the callback.
+.PP
+external, 0 if the host_id is configured locally or 1 if it has been added from remote nodes config. NOTE: dynamic topology is NOT currently implemented, but this is ready for future and can avoid an API/ABI breakage later on. This function MUST NEVER block or add substantial delays.
+.SH RETURN VALUE
+.PP
+knet_host_status_change_notify returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_get_host_list.3 b/libknet/man/knet_host_get_host_list.3
new file mode 100644
index 00000000..299a0d12
--- /dev/null
+++ b/libknet/man/knet_host_get_host_list.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_get_host_list 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_get_host_list \- Get a list of hosts known to knet.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_get_host_list\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t *\fP\fIhost_ids\fP,
+ \fBsize_t *\fP\fIhost_ids_entries\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_get_host_list
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_ids - array of at lest KNET_MAX_HOST size
+.PP
+host_ids_entries - number of entries writted in host_ids
+.SH RETURN VALUE
+.PP
+knet_host_get_host_list returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_get_id_by_host_name.3 b/libknet/man/knet_host_get_id_by_host_name.3
new file mode 100644
index 00000000..bfa706c1
--- /dev/null
+++ b/libknet/man/knet_host_get_id_by_host_name.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_get_id_by_host_name 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_get_id_by_host_name \- Get the ID of a host given its name.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_get_id_by_host_name\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char *\fP\fIname\fP,
+ \fBknet_node_id_t *\fP\fIhost_id\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_get_id_by_host_name
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+name - name to lookup, max len KNET_MAX_HOST_LEN
+.PP
+host_id - where to store the result
+.SH RETURN VALUE
+.PP
+knet_host_get_id_by_host_name returns: 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_get_name_by_host_id.3 b/libknet/man/knet_host_get_name_by_host_id.3
new file mode 100644
index 00000000..85998fb5
--- /dev/null
+++ b/libknet/man/knet_host_get_name_by_host_id.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_get_name_by_host_id 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_get_name_by_host_id \- Get the name of a host given its ID.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_get_name_by_host_id\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBchar *\fP\fIname\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_get_name_by_host_id
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see knet_host_add(3)
+.PP
+name - pointer to a preallocated buffer of at least size KNET_MAX_HOST_LEN where the current host name will be stored (as set by knet_host_set_name or default by knet_host_add)
+.SH RETURN VALUE
+.PP
+knet_host_get_name_by_host_id returns: 0 on success -1 on error and errno is set (name is left untouched)
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_get_policy.3 b/libknet/man/knet_host_get_policy.3
new file mode 100644
index 00000000..bc16cb8c
--- /dev/null
+++ b/libknet/man/knet_host_get_policy.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_get_policy 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_get_policy \- Get the switching policy for a host's links.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_get_policy\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t *\fP\fIpolicy\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_get_policy
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see knet_host_add(3)
+.PP
+policy - will contain the current configured switching policy. Default is passive when creating a new host.
+.SH RETURN VALUE
+.PP
+knet_host_get_policy returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_get_status.3 b/libknet/man/knet_host_get_status.3
new file mode 100644
index 00000000..1b3ebe7e
--- /dev/null
+++ b/libknet/man/knet_host_get_status.3
@@ -0,0 +1,48 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_get_status 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_get_status \- Get the status of a host.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_get_status\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBstruct knet_host_status *\fP\fIstatus\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_status_get
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+status - pointer to knet_host_status struct
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_host_status {
+ uint8_t \fIreachable\fP;
+ uint8_t \fIremote\fP;
+ uint8_t \fIexternal\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+knet_handle_pmtud_get returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_remove.3 b/libknet/man/knet_host_remove.3
new file mode 100644
index 00000000..44a61eb6
--- /dev/null
+++ b/libknet/man/knet_host_remove.3
@@ -0,0 +1,31 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_remove 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_remove \- Remove a host ID from knet.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_remove\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_remove
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - each host in a knet is identified with a unique ID (see also knet_handle_new(3))
+.SH RETURN VALUE
+.PP
+knet_host_remove returns: 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_set_name.3 b/libknet/man/knet_host_set_name.3
new file mode 100644
index 00000000..27e81bec
--- /dev/null
+++ b/libknet/man/knet_host_set_name.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_set_name 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_set_name \- Set the name of a knet host.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_set_name\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBconst char *\fP\fIname\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_set_name
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+name - this name will be used for pretty logging and eventually search for hosts (see also knet_handle_host_get_name(2) and knet_handle_host_get_id(3)). Only up to KNET_MAX_HOST_LEN - 1 bytes will be accepted and name has to be unique for each host.
+.SH RETURN VALUE
+.PP
+knet_host_set_name returns: 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_host_set_policy.3 b/libknet/man/knet_host_set_policy.3
new file mode 100644
index 00000000..39b42f1a
--- /dev/null
+++ b/libknet/man/knet_host_set_policy.3
@@ -0,0 +1,38 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_host_set_policy 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_host_set_policy \- Set the switching policy for a host's links.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_host_set_policy\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIpolicy\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_host_set_policy
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see knet_host_add(3)
+.PP
+policy - there are currently 3 kind of simple switching policies as defined above, based on link configuration. KNET_LINK_POLICY_PASSIVE - the active link with the lowest priority will be used. if one or more active links share the same priority, the one with lowest link_id will be used.
+.PP
+KNET_LINK_POLICY_ACTIVE - all active links will be used simultaneously to send traffic. link priority is ignored.
+.PP
+KNET_LINK_POLICY_RR - round-robin policy, every packet will be send on a different active link.
+.SH RETURN VALUE
+.PP
+knet_host_set_policy returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_clear_config.3 b/libknet/man/knet_link_clear_config.3
new file mode 100644
index 00000000..94557543
--- /dev/null
+++ b/libknet/man/knet_link_clear_config.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_clear_config 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_clear_config \- Clear link information and disconnect the link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_clear_config\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_clear_config
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.SH RETURN VALUE
+.PP
+knet_link_clear_config returns 0 on success. -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_config.3 b/libknet/man/knet_link_get_config.3
new file mode 100644
index 00000000..ed2c33d5
--- /dev/null
+++ b/libknet/man/knet_link_get_config.3
@@ -0,0 +1,49 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_config 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_config \- Get the link configutation information.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_config\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t *\fP\fItransport\fP,
+ \fBstruct sockaddr_storage *\fP\fIsrc_addr\fP,
+ \fBstruct sockaddr_storage *\fP\fIdst_addr\fP,
+ \fBuint8_t *\fP\fIdynamic\fP,
+ \fBuint64_t *\fP\fIflags\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_config
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see knet_host_add(3)
+.PP
+link_id - see knet_link_set_config(3)
+.PP
+transport - see knet_link_set_config(3)
+.PP
+src_addr - sockaddr_storage that can be either IPv4 or IPv6
+.PP
+dst_addr - sockaddr_storage that can be either IPv4 or IPv6
+.PP
+dynamic - 0 if dst_addr is static or 1 if dst_addr is dynamic. In case of 1, dst_addr can be NULL and it will be left untouched.
+.PP
+flags - KNET_LINK_FLAG_*
+.SH RETURN VALUE
+.PP
+knet_link_get_config returns 0 on success. -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_enable.3 b/libknet/man/knet_link_get_enable.3
new file mode 100644
index 00000000..655a2fc0
--- /dev/null
+++ b/libknet/man/knet_link_get_enable.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_enable 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_enable \- Find out whether a link is enabled or not.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_enable\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBunsigned int *\fP\fIenabled\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_enable
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+enabled - 0 disable the link, 1 enable the link
+.SH RETURN VALUE
+.PP
+knet_link_get_enable returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_link_list.3 b/libknet/man/knet_link_get_link_list.3
new file mode 100644
index 00000000..bac91dd0
--- /dev/null
+++ b/libknet/man/knet_link_get_link_list.3
@@ -0,0 +1,35 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_link_list 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_link_list \- Get a list of links connecting a host.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_link_list\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t *\fP\fIlink_ids\fP,
+ \fBsize_t *\fP\fIlink_ids_entries\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_link_list
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+link_ids - array of at lest KNET_MAX_LINK size with the list of configured links for a certain host.
+.PP
+link_ids_entries - number of entries contained in link_ids
+.SH RETURN VALUE
+.PP
+knet_link_get_link_list returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_ping_timers.3 b/libknet/man/knet_link_get_ping_timers.3
new file mode 100644
index 00000000..8e4ad8d1
--- /dev/null
+++ b/libknet/man/knet_link_get_ping_timers.3
@@ -0,0 +1,43 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_ping_timers 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_ping_timers \- Get the ping timers for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_ping_timers\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBtime_t *\fP\fIinterval\fP,
+ \fBtime_t *\fP\fItimeout\fP,
+ \fBunsigned int *\fP\fIprecision\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_ping_timers
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+interval - ping intervall
+.PP
+timeout - if no pong is received within this time, the link is declared dead
+.PP
+precision - how many values of latency are used to calculate the average link latency (see also get_status below)
+.SH RETURN VALUE
+.PP
+knet_link_get_ping_timers returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_pong_count.3 b/libknet/man/knet_link_get_pong_count.3
new file mode 100644
index 00000000..01d71d77
--- /dev/null
+++ b/libknet/man/knet_link_get_pong_count.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_pong_count 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_pong_count \- Get the poing count for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_pong_count\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t *\fP\fIpong_count\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_pong_count
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+pong_count - see above
+.SH RETURN VALUE
+.PP
+knet_link_get_pong_count returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_priority.3 b/libknet/man/knet_link_get_priority.3
new file mode 100644
index 00000000..81652d99
--- /dev/null
+++ b/libknet/man/knet_link_get_priority.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_priority 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_priority \- Get the priority for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_priority\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t *\fP\fIpriority\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_priority
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+priority - gather the switching priority for this link see also knet_host_set_policy
+.SH RETURN VALUE
+.PP
+knet_link_get_priority returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_get_status.3 b/libknet/man/knet_link_get_status.3
new file mode 100644
index 00000000..cbc29937
--- /dev/null
+++ b/libknet/man/knet_link_get_status.3
@@ -0,0 +1,66 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_get_status 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_get_status \- Get the status (and statistics) for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_get_status\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBstruct knet_link_status *\fP\fIstatus\fP,
+ \fBsize_t \fP\fIstruct_size\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_get_status
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+status - pointer to knet_link_status struct (see above)
+.PP
+struct_size - max size of knet_link_status - allows library to add fields without ABI change. Returned structure will be truncated to this length and .size member indicates the full size.
+.SH STRUCTURES
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_link_status {
+ size_t \fIsize\fP;
+ char \fIsrc_ipaddr\fP;
+ char \fIsrc_port\fP;
+ char \fIdst_ipaddr\fP;
+ char \fIdst_port\fP;
+ uint8_t \fIenabled\fP;
+ uint8_t \fIconnected\fP;
+ uint8_t \fIdynconnected\fP;
+ unsigned long long \fIlatency\fP;
+ struct timespec \fIpong_last\fP;
+ unsigned int \fImtu\fP;
+ unsigned int \fIproto_overhead\fP;
+ struct knet_link_stats \fIstats\fP;
+};
+\fP
+.fi
+.RE
+.SH RETURN VALUE
+.PP
+knet_link_get_status returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_set_config.3 b/libknet/man/knet_link_set_config.3
new file mode 100644
index 00000000..1333ed46
--- /dev/null
+++ b/libknet/man/knet_link_set_config.3
@@ -0,0 +1,46 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_set_config 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_set_config \- Configure the link to a host.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_set_config\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t \fP\fItransport\fP,
+ \fBstruct sockaddr_storage *\fP\fIsrc_addr\fP,
+ \fBstruct sockaddr_storage *\fP\fIdst_addr\fP,
+ \fBuint64_t \fP\fIflags\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_set_config
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see knet_host_add(3)
+.PP
+link_id - see knet_link_set_config(3)
+.PP
+transport - one of the above KNET_TRANSPORT_xxx constants
+.PP
+src_addr - sockaddr_storage that can be either IPv4 or IPv6
+.PP
+dst_addr - sockaddr_storage that can be either IPv4 or IPv6 this can be null if we don't know the incoming IP address/port and the link will remain quiet till the node on the other end will initiate a connection
+.PP
+flags - KNET_LINK_FLAG_*
+.SH RETURN VALUE
+.PP
+knet_link_set_config returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_set_enable.3 b/libknet/man/knet_link_set_enable.3
new file mode 100644
index 00000000..05343ee6
--- /dev/null
+++ b/libknet/man/knet_link_set_enable.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_set_enable 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_set_enable \- Enable traffic on a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_set_enable\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBunsigned int \fP\fIenabled\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_set_enable
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+enabled - 0 disable the link, 1 enable the link
+.SH RETURN VALUE
+.PP
+knet_link_set_enable returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_set_ping_timers.3 b/libknet/man/knet_link_set_ping_timers.3
new file mode 100644
index 00000000..cb0db803
--- /dev/null
+++ b/libknet/man/knet_link_set_ping_timers.3
@@ -0,0 +1,43 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_set_ping_timers 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_set_ping_timers \- Set the ping timers for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_set_ping_timers\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBtime_t \fP\fIinterval\fP,
+ \fBtime_t \fP\fItimeout\fP,
+ \fBunsigned int \fP\fIprecision\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_set_ping_timers
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+interval - specify the ping interval
+.PP
+timeout - if no pong is received within this time, the link is declared dead
+.PP
+precision - how many values of latency are used to calculate the average link latency (see also get_status below)
+.SH RETURN VALUE
+.PP
+knet_link_set_ping_timers returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_set_pong_count.3 b/libknet/man/knet_link_set_pong_count.3
new file mode 100644
index 00000000..ae97b643
--- /dev/null
+++ b/libknet/man/knet_link_set_pong_count.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_set_pong_count 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_set_pong_count \- Set the poing count for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_set_pong_count\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t \fP\fIpong_count\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_set_pong_count
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+pong_count - how many valid ping/pongs before a link is marked UP. default: 5, value should be > 0
+.SH RETURN VALUE
+.PP
+knet_link_set_pong_count returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_link_set_priority.3 b/libknet/man/knet_link_set_priority.3
new file mode 100644
index 00000000..fe3081df
--- /dev/null
+++ b/libknet/man/knet_link_set_priority.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_link_set_priority 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_link_set_priority \- Set the priority for a link.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_link_set_priority\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBknet_node_id_t \fP\fIhost_id\fP,
+ \fBuint8_t \fP\fIlink_id\fP,
+ \fBuint8_t \fP\fIpriority\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_link_set_priority
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+host_id - see above
+.PP
+link_id - see above
+.PP
+priority - specify the switching priority for this link see also knet_host_set_policy
+.SH RETURN VALUE
+.PP
+knet_link_set_priority returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_get_loglevel.3 b/libknet/man/knet_log_get_loglevel.3
new file mode 100644
index 00000000..74f1d703
--- /dev/null
+++ b/libknet/man/knet_log_get_loglevel.3
@@ -0,0 +1,34 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_get_loglevel 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_get_loglevel \- Get the logging level for a subsystem.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_log_get_loglevel\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBuint8_t \fP\fIsubsystem\fP,
+ \fBuint8_t *\fP\fIlevel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_get_log_level
+.PP
+knet_h - same as above
+.PP
+subsystem - same as above
+.PP
+level - same as above
+.SH RETURN VALUE
+.PP
+knet_log_get_loglevel returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_get_loglevel_id.3 b/libknet/man/knet_log_get_loglevel_id.3
new file mode 100644
index 00000000..7bc54825
--- /dev/null
+++ b/libknet/man/knet_log_get_loglevel_id.3
@@ -0,0 +1,26 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_get_loglevel_id 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_get_loglevel_id \- Get a logging level ID from its name.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBuint8_t knet_log_get_loglevel_id\fP(
+ \fBconst char *\fP\fIname\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_get_loglevel_id
+.SH RETURN VALUE
+.PP
+returns internal log level ID or KNET_LOG_ERR for invalid names
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_get_loglevel_name.3 b/libknet/man/knet_log_get_loglevel_name.3
new file mode 100644
index 00000000..3ae9dfa9
--- /dev/null
+++ b/libknet/man/knet_log_get_loglevel_name.3
@@ -0,0 +1,26 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_get_loglevel_name 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_get_loglevel_name \- Get a logging level name from its numeric ID.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBconst char * knet_log_get_loglevel_name\fP(
+ \fBuint8_t \fP\fIlevel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_get_loglevel_name
+.SH RETURN VALUE
+.PP
+returns internal name of the log level or "ERROR" for unknown values
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_get_subsystem_id.3 b/libknet/man/knet_log_get_subsystem_id.3
new file mode 100644
index 00000000..3ddbcad5
--- /dev/null
+++ b/libknet/man/knet_log_get_subsystem_id.3
@@ -0,0 +1,26 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_get_subsystem_id 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_get_subsystem_id \- Get a logging system ID from its name.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBuint8_t knet_log_get_subsystem_id\fP(
+ \fBconst char *\fP\fIname\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_get_subsystem_id
+.SH RETURN VALUE
+.PP
+returns internal ID of the subsystem or KNET_SUB_COMMON
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_get_subsystem_name.3 b/libknet/man/knet_log_get_subsystem_name.3
new file mode 100644
index 00000000..e707b76e
--- /dev/null
+++ b/libknet/man/knet_log_get_subsystem_name.3
@@ -0,0 +1,26 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_get_subsystem_name 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_get_subsystem_name \- Get a logging system name from its numeric ID.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBconst char * knet_log_get_subsystem_name\fP(
+ \fBuint8_t \fP\fIsubsystem\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_get_subsystem_name
+.SH RETURN VALUE
+.PP
+returns internal name of the subsystem or "common"
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_log_set_loglevel.3 b/libknet/man/knet_log_set_loglevel.3
new file mode 100644
index 00000000..8147f9e2
--- /dev/null
+++ b/libknet/man/knet_log_set_loglevel.3
@@ -0,0 +1,36 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_log_set_loglevel 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_log_set_loglevel \- Set the logging level for a subsystem.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_log_set_loglevel\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBuint8_t \fP\fIsubsystem\fP,
+ \fBuint8_t \fP\fIlevel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_log_set_log_level
+.PP
+knet_h - same as above
+.PP
+subsystem - same as above
+.PP
+level - same as above
+.PP
+knet_log_set_loglevel allows fine control of log levels by subsystem. See also knet_handle_new for defaults.
+.SH RETURN VALUE
+.PP
+knet_log_set_loglevel returns 0 on success -1 on error and errno is set.
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_recv.3 b/libknet/man/knet_recv.3
new file mode 100644
index 00000000..0805d4fc
--- /dev/null
+++ b/libknet/man/knet_recv.3
@@ -0,0 +1,33 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_recv 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_recv \- Receive data from knet nodes.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBssize_t knet_recv\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBchar *\fP\fIbuff\fP,
+ \fBconst size_t \fP\fIbuff_len\fP,
+ \fBconst int8_t \fP\fIchannel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_recv knet_h - pointer to knet_handle_t
+.PP
+buff - pointer to buffer to store the received data
+.PP
+buff_len - buffer length
+.SH RETURN VALUE
+.PP
+knet_recv is a commodity function to wrap iovec operations around a socket. It returns a call to readv(2).
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_send.3 b/libknet/man/knet_send.3
new file mode 100644
index 00000000..f6e27b0c
--- /dev/null
+++ b/libknet/man/knet_send.3
@@ -0,0 +1,33 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_send 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_send \- Send data to knet nodes.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBssize_t knet_send\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char *\fP\fIbuff\fP,
+ \fBconst size_t \fP\fIbuff_len\fP,
+ \fBconst int8_t \fP\fIchannel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_send knet_h - pointer to knet_handle_t
+.PP
+buff - pointer to the buffer of data to send
+.PP
+buff_len - length of data to send
+.SH RETURN VALUE
+.PP
+knet_send is a commodity function to wrap iovec operations around a socket. It returns a call to writev(2).
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_send_sync.3 b/libknet/man/knet_send_sync.3
new file mode 100644
index 00000000..0be7172b
--- /dev/null
+++ b/libknet/man/knet_send_sync.3
@@ -0,0 +1,71 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_send_sync 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_send_sync \- Synchronously send data to knet nodes.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_send_sync\fP(
+ \fBknet_handle_t \fP\fIknet_h\fP,
+ \fBconst char *\fP\fIbuff\fP,
+ \fBconst size_t \fP\fIbuff_len\fP,
+ \fBconst int8_t \fP\fIchannel\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_send_sync
+.PP
+knet_h - pointer to knet_handle_t
+.PP
+buff - pointer to the buffer of data to send
+.PP
+buff_len - length of data to send
+.PP
+channel - data channel to use (see knet_handle_add_datafd(3))
+.PP
+All knet RX/TX operations are async for performance reasons. There are applications that might need a sync version of data transmission and receive errors in case of failure to deliver to another host. knet_send_sync bypasses the whole TX async layer and delivers data directly to the link layer, and returns errors accordingly. knet_send_sync allows to send only one packet to one host at a time. It does NOT support multiple destinations or multicast packets. Decision is still based on dst_host_filter_fn.
+.SH RETURN VALUE
+.PP
+knet_send_sync returns 0 on success and -1 on error. In addition to normal sendmmsg errors, knet_send_sync can fail due to:
+.TP
+.B ECANCELED
+- data forward is disabled
+
+.TP
+.B EFAULT
+- dst_host_filter fatal error
+
+.TP
+.B EINVAL
+- dst_host_filter did not provide dst_host_ids_entries on unicast pckts
+
+.TP
+.B E2BIG
+- dst_host_filter did return more than one dst_host_ids_entries on unicast pckts
+
+.TP
+.B ENOMSG
+- received unknown message type
+
+.TP
+.B EHOSTDOWN
+- unicast pckt cannot be delivered because dest host is not connected yet
+
+.TP
+.B ECHILD
+- crypto failed
+
+.TP
+.B EAGAIN
+- sendmmsg was unable to send all messages and there was no progress during retry
+
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/knet_strtoaddr.3 b/libknet/man/knet_strtoaddr.3
new file mode 100644
index 00000000..dffcb92c
--- /dev/null
+++ b/libknet/man/knet_strtoaddr.3
@@ -0,0 +1,37 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH knet_strtoaddr 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+knet_strtoaddr \- Convert a hostname string to an address.
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.sp
+\fBint knet_strtoaddr\fP(
+ \fBconst char *\fP\fIhost\fP,
+ \fBconst char *\fP\fIport\fP,
+ \fBstruct sockaddr_storage *\fP\fIss\fP,
+ \fBsocklen_t \fP\fIsslen\fP
+);
+.fi
+.SH DESCRIPTION
+.PP
+knet_strtoaddr
+.PP
+host - IPaddr/hostname to convert be aware only the first IP address will be returned in case a hostname resolves to multiple IP
+.PP
+port - port to connect to
+.PP
+ss - sockaddr_storage where to store the converted data
+.PP
+sslen - len of the sockaddr_storage
+.SH RETURN VALUE
+.PP
+knet_strtoaddr returns same error codes as getaddrinfo
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIlibknet.h\fP(3), \fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy
diff --git a/libknet/man/libknet.h.3 b/libknet/man/libknet.h.3
new file mode 100644
index 00000000..afc1c925
--- /dev/null
+++ b/libknet/man/libknet.h.3
@@ -0,0 +1,207 @@
+.\" File automatically generated by doxy2man0.2
+.\" Generation date: Mon Oct 30 2017
+.TH libknet.h 3 2017-10-30 "kronosnet" "Kronosnet Programmer's Manual"
+.SH "NAME"
+libknet.h \- kronosnet API include file
+.SH SYNOPSIS
+.nf
+.B #include <libknet.h>
+.fi
+.SH DESCRIPTION
+.PP
+Kronosnet is an advanced VPN system for High Availability applications.
+.PP
+.sp
+.RS
+.nf
+\fB
+int knet_addrtostr(const struct sockaddr_storage *, socklen_t, char *, size_t, char *, size_t);
+int knet_handle_add_datafd(knet_handle_t, int *, int8_t *);
+int knet_handle_clear_stats(knet_handle_t, int);
+int knet_handle_compress(knet_handle_t, struct knet_handle_compress_cfg *);
+int knet_handle_crypto(knet_handle_t, struct knet_handle_crypto_cfg *);
+int knet_handle_enable_filter(knet_handle_t, void *, int(*)(void *private_data, const unsigned char *outdata, ssize_t outdata_len, uint8_t tx_rx, knet_node_id_t this_host_id, knet_node_id_t src_host_id, int8_t *channel, knet_node_id_t *dst_host_ids, size_t *dst_host_ids_entries));
+int knet_handle_enable_pmtud_notify(knet_handle_t, void *, void(*)(void *private_data, unsigned int data_mtu));
+int knet_handle_enable_sock_notify(knet_handle_t, void *, void(*)(void *private_data, int datafd, int8_t channel, uint8_t tx_rx, int error, int errorno));
+int knet_handle_free(knet_handle_t);
+int knet_handle_get_channel(knet_handle_t, const int, int8_t *);
+int knet_handle_get_compress_list(knet_handle_t, const char **, size_t *);
+int knet_handle_get_crypto_list(knet_handle_t, const char **, size_t *);
+int knet_handle_get_datafd(knet_handle_t, const int8_t, int *);
+int knet_handle_get_stats(knet_handle_t, struct knet_handle_stats *, size_t);
+uint8_t knet_handle_get_transport_id_by_name(knet_handle_t, const char *);
+int knet_handle_get_transport_list(knet_handle_t, struct transport_info *, size_t *);
+const char *knet_handle_get_transport_name_by_id(knet_handle_t, uint8_t);
+int knet_handle_get_transport_reconnect_interval(knet_handle_t, uint32_t *);
+knet_handle_t knet_handle_new(knet_node_id_t, int, uint8_t);
+int knet_handle_pmtud_get(knet_handle_t, unsigned int *);
+int knet_handle_pmtud_getfreq(knet_handle_t, unsigned int *);
+int knet_handle_pmtud_setfreq(knet_handle_t, unsigned int);
+int knet_handle_remove_datafd(knet_handle_t, int);
+int knet_handle_set_transport_reconnect_interval(knet_handle_t, uint32_t);
+int knet_handle_setfwd(knet_handle_t, unsigned int);
+int knet_host_add(knet_handle_t, knet_node_id_t);
+int knet_host_enable_status_change_notify(knet_handle_t, void *, void(*)(void *private_data, knet_node_id_t host_id, uint8_t reachable, uint8_t remote, uint8_t external));
+int knet_host_get_host_list(knet_handle_t, knet_node_id_t *, size_t *);
+int knet_host_get_id_by_host_name(knet_handle_t, const char *, knet_node_id_t *);
+int knet_host_get_name_by_host_id(knet_handle_t, knet_node_id_t, char *);
+int knet_host_get_policy(knet_handle_t, knet_node_id_t, uint8_t *);
+int knet_host_get_status(knet_handle_t, knet_node_id_t, struct knet_host_status *);
+int knet_host_remove(knet_handle_t, knet_node_id_t);
+int knet_host_set_name(knet_handle_t, knet_node_id_t, const char *);
+int knet_host_set_policy(knet_handle_t, knet_node_id_t, uint8_t);
+int knet_link_clear_config(knet_handle_t, knet_node_id_t, uint8_t);
+int knet_link_get_config(knet_handle_t, knet_node_id_t, uint8_t, uint8_t *, struct sockaddr_storage *, struct sockaddr_storage *, uint8_t *, uint64_t *);
+int knet_link_get_enable(knet_handle_t, knet_node_id_t, uint8_t, unsigned int *);
+int knet_link_get_link_list(knet_handle_t, knet_node_id_t, uint8_t *, size_t *);
+int knet_link_get_ping_timers(knet_handle_t, knet_node_id_t, uint8_t, time_t *, time_t *, unsigned int *);
+int knet_link_get_pong_count(knet_handle_t, knet_node_id_t, uint8_t, uint8_t *);
+int knet_link_get_priority(knet_handle_t, knet_node_id_t, uint8_t, uint8_t *);
+int knet_link_get_status(knet_handle_t, knet_node_id_t, uint8_t, struct knet_link_status *, size_t);
+int knet_link_set_config(knet_handle_t, knet_node_id_t, uint8_t, uint8_t, struct sockaddr_storage *, struct sockaddr_storage *, uint64_t);
+int knet_link_set_enable(knet_handle_t, knet_node_id_t, uint8_t, unsigned int);
+int knet_link_set_ping_timers(knet_handle_t, knet_node_id_t, uint8_t, time_t, time_t, unsigned int);
+int knet_link_set_pong_count(knet_handle_t, knet_node_id_t, uint8_t, uint8_t);
+int knet_link_set_priority(knet_handle_t, knet_node_id_t, uint8_t, uint8_t);
+int knet_log_get_loglevel(knet_handle_t, uint8_t, uint8_t *);
+uint8_t knet_log_get_loglevel_id(const char *);
+const char *knet_log_get_loglevel_name(uint8_t);
+uint8_t knet_log_get_subsystem_id(const char *);
+const char *knet_log_get_subsystem_name(uint8_t);
+int knet_log_set_loglevel(knet_handle_t, uint8_t, uint8_t);
+ssize_t knet_recv(knet_handle_t, char *, const size_t, const int8_t);
+ssize_t knet_send(knet_handle_t, const char *, const size_t, const int8_t);
+int knet_send_sync(knet_handle_t, const char *, const size_t, const int8_t);
+int knet_strtoaddr(const char *, const char *, struct sockaddr_storage *, socklen_t);
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_host_status {
+ uint8_t \fIreachable\fP;
+ uint8_t \fIremote\fP;
+ uint8_t \fIexternal\fP;
+};
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct transport_info {
+ const char *\fIname\fP;
+ uint8_t \fIid\fP;
+ uint8_t \fIproperties\fP;
+};
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_crypto_cfg {
+ char \fIcrypto_model\fP;
+ char \fIcrypto_cipher_type\fP;
+ char \fIcrypto_hash_type\fP;
+ unsigned char \fIprivate_key\fP;
+ unsigned int \fIprivate_key_len\fP;
+};
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_compress_cfg {
+ char \fIcompress_model\fP;
+ uint32_t \fIcompress_threshold\fP;
+ int \fIcompress_level\fP;
+};
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_handle_stats {
+ size_t \fIsize\fP;
+ uint64_t \fItx_uncompressed_packets\fP;
+ uint64_t \fItx_compressed_packets\fP;
+ uint64_t \fItx_compressed_original_bytes\fP;
+ uint64_t \fItx_compressed_size_bytes\fP;
+ uint64_t \fItx_compress_time_ave\fP;
+ uint64_t \fItx_compress_time_min\fP;
+ uint64_t \fItx_compress_time_max\fP;
+ uint64_t \fIrx_compressed_packets\fP;
+ uint64_t \fIrx_compressed_original_bytes\fP;
+ uint64_t \fIrx_compressed_size_bytes\fP;
+ uint64_t \fIrx_compress_time_ave\fP;
+ uint64_t \fIrx_compress_time_min\fP;
+ uint64_t \fIrx_compress_time_max\fP;
+ uint64_t \fItx_crypt_packets\fP;
+ uint64_t \fItx_crypt_byte_overhead\fP;
+ uint64_t \fItx_crypt_time_ave\fP;
+ uint64_t \fItx_crypt_time_min\fP;
+ uint64_t \fItx_crypt_time_max\fP;
+ uint64_t \fIrx_crypt_packets\fP;
+ uint64_t \fIrx_crypt_time_ave\fP;
+ uint64_t \fIrx_crypt_time_min\fP;
+ uint64_t \fIrx_crypt_time_max\fP;
+};
+\fP
+.fi
+.RE
+.SS ""
+.PP
+.sp
+.sp
+.RS
+.nf
+\fB
+struct knet_link_status {
+ size_t \fIsize\fP;
+ char \fIsrc_ipaddr\fP;
+ char \fIsrc_port\fP;
+ char \fIdst_ipaddr\fP;
+ char \fIdst_port\fP;
+ uint8_t \fIenabled\fP;
+ uint8_t \fIconnected\fP;
+ uint8_t \fIdynconnected\fP;
+ unsigned long long \fIlatency\fP;
+ struct timespec \fIpong_last\fP;
+ unsigned int \fImtu\fP;
+ unsigned int \fIproto_overhead\fP;
+ struct knet_link_stats \fIstats\fP;
+};
+\fP
+.fi
+.RE
+.SH SEE ALSO
+.PP
+.nh
+.ad l
+\fIknet_addrtostr\fP(3), \fIknet_handle_add_datafd\fP(3), \fIknet_handle_clear_stats\fP(3), \fIknet_handle_compress\fP(3), \fIknet_handle_crypto\fP(3), \fIknet_handle_enable_filter\fP(3), \fIknet_handle_enable_pmtud_notify\fP(3), \fIknet_handle_enable_sock_notify\fP(3), \fIknet_handle_free\fP(3), \fIknet_handle_get_channel\fP(3), \fIknet_handle_get_compress_list\fP(3), \fIknet_handle_get_crypto_list\fP(3), \fIknet_handle_get_datafd\fP(3), \fIknet_handle_get_stats\fP(3), \fIknet_handle_get_transport_id_by_name\fP(3), \fIknet_handle_get_transport_list\fP(3), \fIknet_handle_get_transport_name_by_id\fP(3), \fIknet_handle_get_transport_reconnect_interval\fP(3), \fIknet_handle_new\fP(3), \fIknet_handle_pmtud_get\fP(3), \fIknet_handle_pmtud_getfreq\fP(3), \fIknet_handle_pmtud_setfreq\fP(3), \fIknet_handle_remove_datafd\fP(3), \fIknet_handle_set_transport_reconnect_interval\fP(3), \fIknet_handle_setfwd\fP(3), \fIknet_host_add\fP(3), \fIknet_host_enable_status_change_notify\fP(3), \fIknet_host_get_host_list\fP(3), \fIknet_host_get_id_by_host_name\fP(3), \fIknet_host_get_name_by_host_id\fP(3), \fIknet_host_get_policy\fP(3), \fIknet_host_get_status\fP(3), \fIknet_host_remove\fP(3), \fIknet_host_set_name\fP(3), \fIknet_host_set_policy\fP(3), \fIknet_link_clear_config\fP(3), \fIknet_link_get_config\fP(3), \fIknet_link_get_enable\fP(3), \fIknet_link_get_link_list\fP(3), \fIknet_link_get_ping_timers\fP(3), \fIknet_link_get_pong_count\fP(3), \fIknet_link_get_priority\fP(3), \fIknet_link_get_status\fP(3), \fIknet_link_set_config\fP(3), \fIknet_link_set_enable\fP(3), \fIknet_link_set_ping_timers\fP(3), \fIknet_link_set_pong_count\fP(3), \fIknet_link_set_priority\fP(3), \fIknet_log_get_loglevel\fP(3), \fIknet_log_get_loglevel_id\fP(3), \fIknet_log_get_loglevel_name\fP(3), \fIknet_log_get_subsystem_id\fP(3), \fIknet_log_get_subsystem_name\fP(3), \fIknet_log_set_loglevel\fP(3), \fIknet_recv\fP(3), \fIknet_send\fP(3), \fIknet_send_sync\fP(3), \fIknet_strtoaddr\fP(3)
+.ad
+.hy

File Metadata

Mime Type
text/x-diff
Expires
Wed, Feb 26, 11:23 AM (20 h, 11 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
1465294
Default Alt Text
(228 KB)

Event Timeline