Blame SOURCES/0002-fix-libnl-libnl-3-logic-in-configure-script.patch

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