|
|
7f924d |
From b14b99adf4132eab1ecf8d1d4e83fadf5ada1076 Mon Sep 17 00:00:00 2001
|
|
|
7f924d |
From: Ryan O'Hara <rohara@redhat.com>
|
|
|
7f924d |
Date: Mon, 6 Jan 2014 11:21:03 -0600
|
|
|
7f924d |
Subject: [PATCH 2/7] Fix libnl/libnl-3 logic in configure script
|
|
|
7f924d |
|
|
|
7f924d |
This patch causes the configure script to prefer libnl-3 over
|
|
|
7f924d |
libnl(1). The configure script will first check for libnl-3 and
|
|
|
7f924d |
libnl-genl-3. If both are found, use them. If not, check for
|
|
|
7f924d |
libnl(1). This is useful when building on systems that have both
|
|
|
7f924d |
libnl-3 and libnl(1) installed. It also fixes some redundant libraries
|
|
|
7f924d |
in LIBS.
|
|
|
7f924d |
---
|
|
|
7f924d |
configure | 103 ++++++++++++++++++++++++++++++-----------------------------
|
|
|
7f924d |
configure.in | 43 +++++++++++++------------
|
|
|
7f924d |
2 files changed, 74 insertions(+), 72 deletions(-)
|
|
|
7f924d |
|
|
|
7f924d |
diff --git a/configure b/configure
|
|
|
7f924d |
index b35331f..be6574e 100755
|
|
|
7f924d |
--- a/configure
|
|
|
7f924d |
+++ b/configure
|
|
|
7f924d |
@@ -3896,50 +3896,8 @@ else
|
|
|
7f924d |
as_fn_error $? "OpenSSL libraries are required" "$LINENO" 5
|
|
|
7f924d |
fi
|
|
|
7f924d |
|
|
|
7f924d |
-{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for nl_socket_modify_cb in -lnl" >&5
|
|
|
7f924d |
-$as_echo_n "checking for nl_socket_modify_cb in -lnl... " >&6; }
|
|
|
7f924d |
-if ${ac_cv_lib_nl_nl_socket_modify_cb+:} false; then :
|
|
|
7f924d |
- $as_echo_n "(cached) " >&6
|
|
|
7f924d |
-else
|
|
|
7f924d |
- ac_check_lib_save_LIBS=$LIBS
|
|
|
7f924d |
-LIBS="-lnl $LIBS"
|
|
|
7f924d |
-cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
|
|
7f924d |
-/* end confdefs.h. */
|
|
|
7f924d |
|
|
|
7f924d |
-/* Override any GCC internal prototype to avoid an error.
|
|
|
7f924d |
- Use char because int might match the return type of a GCC
|
|
|
7f924d |
- builtin and then its argument prototype would still apply. */
|
|
|
7f924d |
-#ifdef __cplusplus
|
|
|
7f924d |
-extern "C"
|
|
|
7f924d |
-#endif
|
|
|
7f924d |
-char nl_socket_modify_cb ();
|
|
|
7f924d |
-int
|
|
|
7f924d |
-main ()
|
|
|
7f924d |
-{
|
|
|
7f924d |
-return nl_socket_modify_cb ();
|
|
|
7f924d |
- ;
|
|
|
7f924d |
- return 0;
|
|
|
7f924d |
-}
|
|
|
7f924d |
-_ACEOF
|
|
|
7f924d |
-if ac_fn_c_try_link "$LINENO"; then :
|
|
|
7f924d |
- ac_cv_lib_nl_nl_socket_modify_cb=yes
|
|
|
7f924d |
-else
|
|
|
7f924d |
- ac_cv_lib_nl_nl_socket_modify_cb=no
|
|
|
7f924d |
-fi
|
|
|
7f924d |
-rm -f core conftest.err conftest.$ac_objext \
|
|
|
7f924d |
- conftest$ac_exeext conftest.$ac_ext
|
|
|
7f924d |
-LIBS=$ac_check_lib_save_LIBS
|
|
|
7f924d |
-fi
|
|
|
7f924d |
-{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nl_nl_socket_modify_cb" >&5
|
|
|
7f924d |
-$as_echo "$ac_cv_lib_nl_nl_socket_modify_cb" >&6; }
|
|
|
7f924d |
-if test "x$ac_cv_lib_nl_nl_socket_modify_cb" = xyes; then :
|
|
|
7f924d |
-
|
|
|
7f924d |
- USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
- CFLAGS="$CFLAGS -DFALLBACK_LIBNL1"
|
|
|
7f924d |
- LIBS="$LIBS -lnl"
|
|
|
7f924d |
-
|
|
|
7f924d |
-else
|
|
|
7f924d |
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking for nl_socket_alloc in -lnl-3" >&5
|
|
|
7f924d |
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for nl_socket_alloc in -lnl-3" >&5
|
|
|
7f924d |
$as_echo_n "checking for nl_socket_alloc in -lnl-3... " >&6; }
|
|
|
7f924d |
if ${ac_cv_lib_nl_3_nl_socket_alloc+:} false; then :
|
|
|
7f924d |
$as_echo_n "(cached) " >&6
|
|
|
7f924d |
@@ -3977,10 +3935,7 @@ fi
|
|
|
7f924d |
$as_echo "$ac_cv_lib_nl_3_nl_socket_alloc" >&6; }
|
|
|
7f924d |
if test "x$ac_cv_lib_nl_3_nl_socket_alloc" = xyes; then :
|
|
|
7f924d |
|
|
|
7f924d |
- USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
- CFLAGS="$CFLAGS $(pkg-config --libs --cflags libnl-3.0)"
|
|
|
7f924d |
- LIBS="$LIBS -lnl-3"
|
|
|
7f924d |
- { $as_echo "$as_me:${as_lineno-$LINENO}: checking for genl_connect in -lnl-genl-3" >&5
|
|
|
7f924d |
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking for genl_connect in -lnl-genl-3" >&5
|
|
|
7f924d |
$as_echo_n "checking for genl_connect in -lnl-genl-3... " >&6; }
|
|
|
7f924d |
if ${ac_cv_lib_nl_genl_3_genl_connect+:} false; then :
|
|
|
7f924d |
$as_echo_n "(cached) " >&6
|
|
|
7f924d |
@@ -4018,19 +3973,65 @@ fi
|
|
|
7f924d |
$as_echo "$ac_cv_lib_nl_genl_3_genl_connect" >&6; }
|
|
|
7f924d |
if test "x$ac_cv_lib_nl_genl_3_genl_connect" = xyes; then :
|
|
|
7f924d |
|
|
|
7f924d |
- LIBS="$LIBS -lnl-3 -lnl-genl-3"
|
|
|
7f924d |
+ USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
+ CFLAGS="$CFLAGS $(pkg-config libnl-genl-3.0)"
|
|
|
7f924d |
+ LIBS="$LIBS $(pkg-config --libs libnl-genl-3.0)"
|
|
|
7f924d |
+
|
|
|
7f924d |
+else
|
|
|
7f924d |
+
|
|
|
7f924d |
+ as_fn_error $? "libnl-3 is installed but not libnl-gen-3. Please, install libnl-gen-3." "$LINENO" 5
|
|
|
7f924d |
+
|
|
|
7f924d |
+fi
|
|
|
7f924d |
+
|
|
|
7f924d |
|
|
|
7f924d |
else
|
|
|
7f924d |
|
|
|
7f924d |
- as_fn_error $? "libnl-3 is installed but not libnl-gen-3. Please, install libnl-gen-3." "$LINENO" 5
|
|
|
7f924d |
+ { $as_echo "$as_me:${as_lineno-$LINENO}: checking for nl_socket_modify_cb in -lnl" >&5
|
|
|
7f924d |
+$as_echo_n "checking for nl_socket_modify_cb in -lnl... " >&6; }
|
|
|
7f924d |
+if ${ac_cv_lib_nl_nl_socket_modify_cb+:} false; then :
|
|
|
7f924d |
+ $as_echo_n "(cached) " >&6
|
|
|
7f924d |
+else
|
|
|
7f924d |
+ ac_check_lib_save_LIBS=$LIBS
|
|
|
7f924d |
+LIBS="-lnl $LIBS"
|
|
|
7f924d |
+cat confdefs.h - <<_ACEOF >conftest.$ac_ext
|
|
|
7f924d |
+/* end confdefs.h. */
|
|
|
7f924d |
|
|
|
7f924d |
+/* Override any GCC internal prototype to avoid an error.
|
|
|
7f924d |
+ Use char because int might match the return type of a GCC
|
|
|
7f924d |
+ builtin and then its argument prototype would still apply. */
|
|
|
7f924d |
+#ifdef __cplusplus
|
|
|
7f924d |
+extern "C"
|
|
|
7f924d |
+#endif
|
|
|
7f924d |
+char nl_socket_modify_cb ();
|
|
|
7f924d |
+int
|
|
|
7f924d |
+main ()
|
|
|
7f924d |
+{
|
|
|
7f924d |
+return nl_socket_modify_cb ();
|
|
|
7f924d |
+ ;
|
|
|
7f924d |
+ return 0;
|
|
|
7f924d |
+}
|
|
|
7f924d |
+_ACEOF
|
|
|
7f924d |
+if ac_fn_c_try_link "$LINENO"; then :
|
|
|
7f924d |
+ ac_cv_lib_nl_nl_socket_modify_cb=yes
|
|
|
7f924d |
+else
|
|
|
7f924d |
+ ac_cv_lib_nl_nl_socket_modify_cb=no
|
|
|
7f924d |
fi
|
|
|
7f924d |
+rm -f core conftest.err conftest.$ac_objext \
|
|
|
7f924d |
+ conftest$ac_exeext conftest.$ac_ext
|
|
|
7f924d |
+LIBS=$ac_check_lib_save_LIBS
|
|
|
7f924d |
+fi
|
|
|
7f924d |
+{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_nl_nl_socket_modify_cb" >&5
|
|
|
7f924d |
+$as_echo "$ac_cv_lib_nl_nl_socket_modify_cb" >&6; }
|
|
|
7f924d |
+if test "x$ac_cv_lib_nl_nl_socket_modify_cb" = xyes; then :
|
|
|
7f924d |
|
|
|
7f924d |
+ USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
+ CFLAGS="$CFLAGS -DFALLBACK_LIBNL1"
|
|
|
7f924d |
+ LIBS="$LIBS $(pkg-config --libs libnl-1)"
|
|
|
7f924d |
|
|
|
7f924d |
else
|
|
|
7f924d |
|
|
|
7f924d |
- USE_NL="LIBIPVS_DONTUSE_NL"
|
|
|
7f924d |
- { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: keepalived will be built without libnl support." >&5
|
|
|
7f924d |
+ USE_NL="LIBIPVS_DONTUSE_NL"
|
|
|
7f924d |
+ { $as_echo "$as_me:${as_lineno-$LINENO}: WARNING: keepalived will be built without libnl support." >&5
|
|
|
7f924d |
$as_echo "$as_me: WARNING: keepalived will be built without libnl support." >&2;}
|
|
|
7f924d |
|
|
|
7f924d |
fi
|
|
|
7f924d |
diff --git a/configure.in b/configure.in
|
|
|
7f924d |
index 3daf3ee..3d4a191 100644
|
|
|
7f924d |
--- a/configure.in
|
|
|
7f924d |
+++ b/configure.in
|
|
|
7f924d |
@@ -55,29 +55,30 @@ dnl ----[ Checks for libraries ]----
|
|
|
7f924d |
AC_CHECK_LIB(crypt, crypt,,AC_MSG_ERROR([crypt() function is required]))
|
|
|
7f924d |
AC_CHECK_LIB(crypto, MD5_Init,,AC_MSG_ERROR([OpenSSL libraries are required]))
|
|
|
7f924d |
AC_CHECK_LIB(ssl, SSL_CTX_new,,AC_MSG_ERROR([OpenSSL libraries are required]))
|
|
|
7f924d |
-AC_CHECK_LIB(nl, nl_socket_modify_cb,
|
|
|
7f924d |
+
|
|
|
7f924d |
+AC_CHECK_LIB(nl-3, nl_socket_alloc,
|
|
|
7f924d |
[
|
|
|
7f924d |
- USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
- CFLAGS="$CFLAGS -DFALLBACK_LIBNL1"
|
|
|
7f924d |
- LIBS="$LIBS -lnl"
|
|
|
7f924d |
+ AC_CHECK_LIB(nl-genl-3, genl_connect,
|
|
|
7f924d |
+ [
|
|
|
7f924d |
+ USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
+ CFLAGS="$CFLAGS $(pkg-config libnl-genl-3.0)"
|
|
|
7f924d |
+ LIBS="$LIBS $(pkg-config --libs libnl-genl-3.0)"
|
|
|
7f924d |
+ ],
|
|
|
7f924d |
+ [
|
|
|
7f924d |
+ AC_MSG_ERROR([libnl-3 is installed but not libnl-gen-3. Please, install libnl-gen-3.])
|
|
|
7f924d |
+ ])
|
|
|
7f924d |
],
|
|
|
7f924d |
- [AC_CHECK_LIB(nl-3, nl_socket_alloc,
|
|
|
7f924d |
- [
|
|
|
7f924d |
- USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
- CFLAGS="$CFLAGS $(pkg-config --libs --cflags libnl-3.0)"
|
|
|
7f924d |
- LIBS="$LIBS -lnl-3"
|
|
|
7f924d |
- AC_CHECK_LIB(nl-genl-3, genl_connect,
|
|
|
7f924d |
- [
|
|
|
7f924d |
- LIBS="$LIBS -lnl-3 -lnl-genl-3"
|
|
|
7f924d |
- ],
|
|
|
7f924d |
- [
|
|
|
7f924d |
- AC_MSG_ERROR([libnl-3 is installed but not libnl-gen-3. Please, install libnl-gen-3.])
|
|
|
7f924d |
- ])
|
|
|
7f924d |
- ],
|
|
|
7f924d |
- [
|
|
|
7f924d |
- USE_NL="LIBIPVS_DONTUSE_NL"
|
|
|
7f924d |
- AC_MSG_WARN([keepalived will be built without libnl support.])
|
|
|
7f924d |
- ])
|
|
|
7f924d |
+ [
|
|
|
7f924d |
+ AC_CHECK_LIB(nl, nl_socket_modify_cb,
|
|
|
7f924d |
+ [
|
|
|
7f924d |
+ USE_NL="LIBIPVS_USE_NL"
|
|
|
7f924d |
+ CFLAGS="$CFLAGS -DFALLBACK_LIBNL1"
|
|
|
7f924d |
+ LIBS="$LIBS $(pkg-config --libs libnl-1)"
|
|
|
7f924d |
+ ],
|
|
|
7f924d |
+ [
|
|
|
7f924d |
+ USE_NL="LIBIPVS_DONTUSE_NL"
|
|
|
7f924d |
+ AC_MSG_WARN([keepalived will be built without libnl support.])
|
|
|
7f924d |
+ ])
|
|
|
7f924d |
])
|
|
|
7f924d |
|
|
|
7f924d |
dnl ----[ Kernel version check ]----
|
|
|
7f924d |
--
|
|
|
7f924d |
1.8.1.4
|
|
|
7f924d |
|