|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH v12 2/7] remus: add libnl3 dependency for network buffering support
On Fri, Jun 20, 2014 at 03:04:27PM +0800, Yang Hongyang wrote:
> Libnl3 is required for controlling Remus network buffering.
> This patch adds dependency on libnl3 (>= 3.2.8) to autoconf scripts.
> Also provide ability to configure tools without libnl3 support, that
> is without network buffering support.
>
> when there's no network buffering support,libxl__netbuffer_enabled()
> returns 0, otherwise returns 1. The callers of this api will be
> introduced in the rest of the series.
>
> NOTE: This patch changes tools/configure.ac, please rerun
> autogen.sh while apply the patch.
> Signed-off-by: Shriram Rajagopalan <rshriram@xxxxxxxxx>
> Signed-off-by: Lai Jiangshan <laijs@xxxxxxxxxxxxxx>
> Signed-off-by: Yang Hongyang <yanghy@xxxxxxxxxxxxxx>
> Reviewed-by: Wen Congyang <wency@xxxxxxxxxxxxxx>
> ---
> README | 4 ++++
> config/Tools.mk.in | 4 ++++
> tools/configure.ac | 16 ++++++++++++++++
> tools/libxl/Makefile | 13 +++++++++++++
> tools/libxl/libxl_internal.h | 1 +
> tools/libxl/libxl_netbuffer.c | 31 +++++++++++++++++++++++++++++++
> tools/libxl/libxl_nonetbuffer.c | 31 +++++++++++++++++++++++++++++++
> tools/remus/README | 6 ++++++
> 8 files changed, 106 insertions(+)
> create mode 100644 tools/libxl/libxl_netbuffer.c
> create mode 100644 tools/libxl/libxl_nonetbuffer.c
>
> diff --git a/README b/README
> index 9bbe734..e770932 100644
> --- a/README
> +++ b/README
> @@ -72,6 +72,10 @@ disabled at compile time:
> * cmake (if building vtpm stub domains)
> * markdown
> * figlet (for generating the traditional Xen start of day banner)
> + * Development install of libnl3 (e.g., libnl-3-200,
> + libnl-3-dev, etc). Required if network buffering is desired
> + when using Remus with libxl. See tools/remus/README for detailed
> + information.
>
> Second, you need to acquire a suitable kernel for use in domain 0. If
> possible you should use a kernel provided by your OS distributor. If
> diff --git a/config/Tools.mk.in b/config/Tools.mk.in
> index 84b2612..06c9d25 100644
> --- a/config/Tools.mk.in
> +++ b/config/Tools.mk.in
> @@ -38,6 +38,9 @@ PTHREAD_LIBS := @PTHREAD_LIBS@
>
> PTYFUNCS_LIBS := @PTYFUNCS_LIBS@
>
> +LIBNL3_LIBS := @LIBNL3_LIBS@
> +LIBNL3_CFLAGS := @LIBNL3_CFLAGS@
> +
> # Download GIT repositories via HTTP or GIT's own protocol?
> # GIT's protocol is faster and more robust, when it works at all (firewalls
> # may block it). We make it the default, but if your GIT repository downloads
> @@ -56,6 +59,7 @@ CONFIG_QEMU_XEN := @qemu_xen@
> CONFIG_BLKTAP1 := @blktap1@
> CONFIG_VTPM := @vtpm@
> CONFIG_QEMUU_EXTRA_ARGS:= @EXTRA_QEMUU_CONFIGURE_ARGS@
> +CONFIG_REMUS_NETBUF := @remus_netbuf@
>
> #System options
> ZLIB := @zlib@
> diff --git a/tools/configure.ac b/tools/configure.ac
> index 9db798b..6deed8f 100644
> --- a/tools/configure.ac
> +++ b/tools/configure.ac
> @@ -267,5 +267,21 @@ esac
> # Checks for header files.
> AC_CHECK_HEADERS([yajl/yajl_version.h sys/eventfd.h valgrind/memcheck.h
> utmp.h])
>
> +# Check for libnl3 >=3.2.8. If present enable remus network buffering.
> +PKG_CHECK_MODULES(LIBNL3, [libnl-3.0 >= 3.2.8 libnl-route-3.0 >= 3.2.8],
> + [libnl3_lib="y"], [libnl3_lib="n"])
> +
> +AS_IF([test "x$libnl3_lib" = "xn" ], [
> + AC_MSG_WARN([Disabling support for Remus network buffering.
> + Please install libnl3 libraries, command line tools and devel
> + headers - version 3.2.8 or higher])
> + AC_SUBST(remus_netbuf, [n])
> + ],[
> + AC_SUBST(remus_netbuf, [y])
> +])
> +
> +AC_SUBST(LIBNL3_LIBS)
> +AC_SUBST(LIBNL3_CFLAGS)
> +
> AC_OUTPUT()
>
> diff --git a/tools/libxl/Makefile b/tools/libxl/Makefile
> index 7fc42c8..fdffff3 100644
> --- a/tools/libxl/Makefile
> +++ b/tools/libxl/Makefile
> @@ -21,11 +21,17 @@ endif
>
> LIBXL_LIBS =
> LIBXL_LIBS = $(LDLIBS_libxenctrl) $(LDLIBS_libxenguest)
> $(LDLIBS_libxenstore) $(LDLIBS_libblktapctl) $(PTYFUNCS_LIBS) $(LIBUUID_LIBS)
> +ifeq ($(CONFIG_REMUS_NETBUF),y)
> +LIBXL_LIBS += $(LIBNL3_LIBS)
> +endif
>
> CFLAGS_LIBXL += $(CFLAGS_libxenctrl)
> CFLAGS_LIBXL += $(CFLAGS_libxenguest)
> CFLAGS_LIBXL += $(CFLAGS_libxenstore)
> CFLAGS_LIBXL += $(CFLAGS_libblktapctl)
> +ifeq ($(CONFIG_REMUS_NETBUF),y)
> +CFLAGS_LIBXL += $(LIBNL3_CFLAGS)
> +endif
> CFLAGS_LIBXL += -Wshadow
>
> LIBXL_LIBS-$(CONFIG_ARM) += -lfdt
> @@ -43,6 +49,13 @@ LIBXL_OBJS-y += libxl_blktap2.o
> else
> LIBXL_OBJS-y += libxl_noblktap2.o
> endif
> +
> +ifeq ($(CONFIG_REMUS_NETBUF),y)
> +LIBXL_OBJS-y += libxl_netbuffer.o
> +else
> +LIBXL_OBJS-y += libxl_nonetbuffer.o
> +endif
> +
> LIBXL_OBJS-$(CONFIG_X86) += libxl_cpuid.o libxl_x86.o
> LIBXL_OBJS-$(CONFIG_ARM) += libxl_nocpuid.o libxl_arm.o
>
> diff --git a/tools/libxl/libxl_internal.h b/tools/libxl/libxl_internal.h
> index a0d4f24..3fc90e2 100644
> --- a/tools/libxl/libxl_internal.h
> +++ b/tools/libxl/libxl_internal.h
> @@ -2470,6 +2470,7 @@ typedef struct libxl__save_helper_state {
> * marshalling and xc callback functions */
> } libxl__save_helper_state;
>
> +_hidden int libxl__netbuffer_enabled(libxl__gc *gc);
>
> /*----- Domain suspend (save) state structure -----*/
>
> diff --git a/tools/libxl/libxl_netbuffer.c b/tools/libxl/libxl_netbuffer.c
> new file mode 100644
> index 0000000..8e23d75
> --- /dev/null
> +++ b/tools/libxl/libxl_netbuffer.c
> @@ -0,0 +1,31 @@
> +/*
> + * Copyright (C) 2013
.. There should be something past 2013. And you can just make
it 2014
> + * Author Shriram Rajagopalan <rshriram@xxxxxxxxx>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU Lesser General Public License as published
> + * by the Free Software Foundation; version 2.1 only. with the special
> + * exception on linking described in file LICENSE.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU Lesser General Public License for more details.
> + */
> +
> +#include "libxl_osdeps.h" /* must come before any other headers */
> +
> +#include "libxl_internal.h"
> +
> +int libxl__netbuffer_enabled(libxl__gc *gc)
> +{
> + return 1;
> +}
> +
> +/*
> + * Local variables:
> + * mode: C
> + * c-basic-offset: 4
> + * indent-tabs-mode: nil
> + * End:
> + */
> diff --git a/tools/libxl/libxl_nonetbuffer.c b/tools/libxl/libxl_nonetbuffer.c
> new file mode 100644
> index 0000000..6aa4bf1
> --- /dev/null
> +++ b/tools/libxl/libxl_nonetbuffer.c
> @@ -0,0 +1,31 @@
> +/*
> + * Copyright (C) 2013
Ditto.
> + * Author Shriram Rajagopalan <rshriram@xxxxxxxxx>
> + *
> + * This program is free software; you can redistribute it and/or modify
> + * it under the terms of the GNU Lesser General Public License as published
> + * by the Free Software Foundation; version 2.1 only. with the special
> + * exception on linking described in file LICENSE.
> + *
> + * This program is distributed in the hope that it will be useful,
> + * but WITHOUT ANY WARRANTY; without even the implied warranty of
> + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
> + * GNU Lesser General Public License for more details.
> + */
> +
> +#include "libxl_osdeps.h" /* must come before any other headers */
> +
> +#include "libxl_internal.h"
> +
> +int libxl__netbuffer_enabled(libxl__gc *gc)
> +{
> + return 0;
> +}
> +
> +/*
> + * Local variables:
> + * mode: C
> + * c-basic-offset: 4
> + * indent-tabs-mode: nil
> + * End:
> + */
> diff --git a/tools/remus/README b/tools/remus/README
> index 9e8140b..4736252 100644
> --- a/tools/remus/README
> +++ b/tools/remus/README
> @@ -2,3 +2,9 @@ Remus provides fault tolerance for virtual machines by
> sending continuous
> checkpoints to a backup, which will activate if the target VM fails.
>
> See the website at http://nss.cs.ubc.ca/remus/ for details.
> +
> +Using Remus with libxl on Xen 4.4 and higher:
Might want to say Xen 4.5 and higher since this is for Xen 4.5
> + To enable network buffering, you need libnl 3.2.8
> + or higher along with the development headers and command line utilities.
> + If your distro does not have the appropriate libnl3 version, you can find
> + the latest source tarball of libnl3 at
> http://www.carisma.slowglass.com/~tgr/libnl/
> --
> 1.9.1
>
>
> _______________________________________________
> Xen-devel mailing list
> Xen-devel@xxxxxxxxxxxxx
> http://lists.xen.org/xen-devel
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |