diff --git a/configure.ac b/configure.ac
index 84bfd96..3f6f81d 100644
--- a/configure.ac
+++ b/configure.ac
@@ -2,6 +2,7 @@ AC_INIT([nftlb], [1.0], [netfilter-devel@vger.kernel.org])
AC_CONFIG_AUX_DIR([build-aux])
AC_CONFIG_MACRO_DIR([m4])
+AC_CONFIG_HEADERS([config.h])
AM_INIT_AUTOMAKE([-Wall foreign subdir-objects
tar-pax no-dist-gzip dist-bzip2 1.6])
@@ -25,5 +26,7 @@ AC_CHECK_HEADER([ev.h], [EVENTINC="-include ev.h"],
[EVENTINC="-include libev/ev.h"],
[AC_MSG_ERROR([ev.h not found])])])
+AC_CHECK_HEADERS([execinfo.h])
+
AC_CONFIG_FILES([Makefile src/Makefile])
AC_OUTPUT
diff --git a/src/main.c b/src/main.c
index 9854f95..8e7df1d 100644
--- a/src/main.c
+++ b/src/main.c
@@ -18,6 +18,7 @@
* along with this program. If not, see .
*
*/
+#include "config.h"
#include
#include
@@ -25,7 +26,10 @@
#include
#include
#include
+
+#ifdef HAVE_EXECINFO_H
#include
+#endif /* HAVE_EXECINFO_H */
#include "config.h"
#include "objects.h"
@@ -88,6 +92,7 @@ static void nftlb_sighandler(int signo)
exit(EXIT_SUCCESS);
}
+#ifdef HAVE_EXECINFO_H
static void nftlb_trace() {
void *buffer[255];
char **str;
@@ -109,6 +114,7 @@ static void nftlb_trace() {
exit(EXIT_FAILURE);
}
+#endif /* HAVE_EXECINFO_H */
int main(int argc, char *argv[])
{
@@ -166,9 +172,13 @@ int main(int argc, char *argv[])
if (signal(SIGINT, nftlb_sighandler) == SIG_ERR ||
signal(SIGTERM, nftlb_sighandler) == SIG_ERR ||
+#ifdef HAVE_EXECINFO_H
signal(SIGPIPE, SIG_IGN) == SIG_ERR ||
signal(SIGABRT, nftlb_trace) == SIG_ERR ||
signal(SIGSEGV, nftlb_trace) == SIG_ERR) {
+#else
+ signal(SIGPIPE, SIG_IGN) == SIG_ERR) {
+#endif /* HAVE_EXECINFO_H */
tools_printlog(LOG_ERR, "Error assigning signals");
return EXIT_FAILURE;
}