dnl ** Additional Autoconf tests for BIRD configure script
dnl ** (c) 1999 Martin Mares <mj@ucw.cz>
-AC_DEFUN(BIRD_CHECK_INTEGERS,
-[AC_CHECK_SIZEOF(char, 0)
-AC_CHECK_SIZEOF(short int, 0)
-AC_CHECK_SIZEOF(int, 0)
-AC_CHECK_SIZEOF(long int, 0)
-for size in 1 2 4 ; do
- bits=`expr $size "*" 8`
- AC_MSG_CHECKING([for $bits-bit type])
- if test $ac_cv_sizeof_int = $size ; then
- res=int
- elif test $ac_cv_sizeof_char = $size ; then
- res=char
- elif test $ac_cv_sizeof_short_int = $size ; then
- res="short int"
- elif test $ac_cv_sizeof_long_int = $size ; then
- res="long int"
- else
- AC_MSG_RESULT([not found])
- AC_MSG_ERROR([Cannot find $bits-bit integer type.])
- fi
- AC_MSG_RESULT($res)
- AC_DEFINE_UNQUOTED(INTEGER_$bits, $res)
- done
+AC_DEFUN([BIRD_CHECK_PTHREADS],
+[
+ bird_tmp_cflags="$CFLAGS"
+ CFLAGS="$CFLAGS -pthread"
+
+ AC_CACHE_CHECK(
+ [whether POSIX threads are available],
+ [bird_cv_lib_pthreads],
+ [
+ AC_LINK_IFELSE(
+ [
+ AC_LANG_PROGRAM(
+ [ #include <pthread.h> ],
+ [
+ pthread_t pt;
+ pthread_create(&pt, NULL, NULL, NULL);
+ pthread_spinlock_t lock;
+ pthread_spin_lock(&lock);
+ ]
+ )
+ ],
+ [bird_cv_lib_pthreads=yes],
+ [bird_cv_lib_pthreads=no]
+ )
+ ]
+ )
+
+ CFLAGS="$bird_tmp_cflags"
+])
+
+AC_DEFUN([BIRD_CHECK_MPLS_KERNEL],
+[
+ AC_CACHE_CHECK(
+ [for Linux MPLS headers],
+ [bird_cv_mpls_kernel],
+ [
+ AC_COMPILE_IFELSE(
+ [
+ AC_LANG_PROGRAM(
+ [
+ #include <linux/lwtunnel.h>
+ #include <linux/netlink.h>
+ #include <linux/rtnetlink.h>
+ #include <sys/socket.h>
+ void t(int arg);
+ ],
+ [
+ t(AF_MPLS);
+ t(RTA_VIA);
+ t(RTA_NEWDST);
+ t(RTA_ENCAP_TYPE);
+ t(RTA_ENCAP);
+ struct rtvia rtvia;
+ t(LWTUNNEL_ENCAP_MPLS);
+ ]
+ )
+ ],
+ [bird_cv_mpls_kernel=yes],
+ [bird_cv_mpls_kernel=no]
+ )
+ ]
+ )
])
-AC_DEFUN(BIRD_CHECK_ENDIAN,
-[AC_CACHE_CHECK([CPU endianity], bird_cv_c_endian,[
-AC_TRY_RUN([
-#include <stdio.h>
-
-unsigned int x = 0x12345678;
-unsigned char *z = (unsigned char *) &x;
-
-int main(void)
-{
- FILE *f = fopen("conftestresult", "w");
- if (!f) return 10;
- fprintf(f, "%02x %02x %02x %02x", *z, *(z+1), *(z+2), *(z+3));
- fclose(f);
- exit(0);
-}
-],[
- endian=`cat conftestresult`
- if test "$endian" = "12 34 56 78" ; then
- bird_cv_c_endian=big-endian
- elif test "$endian" = "78 56 34 12" ; then
- bird_cv_c_endian=little-endian
- fi
-],[endian="test program failed"],[endian="not available, we're cross compiling"])
-if test -z "$bird_cv_c_endian" ; then
- AC_MSG_RESULT($endian)
- AC_MSG_ERROR([Cannot determine CPU endianity.])
- fi
+AC_DEFUN([BIRD_CHECK_ANDROID_GLOB],
+[
+ AC_CACHE_CHECK(
+ [for glob.h],
+ [bird_cv_lib_glob],
+ AC_LINK_IFELSE([
+ AC_LANG_PROGRAM(
+ [
+ #include <glob.h>
+ #include <stdlib.h>
+ ],
+ [ glob(NULL, 0, NULL, NULL); ]
+ )
+ ],
+ [bird_cv_lib_glob=yes],
+ [
+ bird_tmp_libs="$LIBS"
+ LIBS="$LIBS -landroid-glob"
+ AC_LINK_IFELSE([
+ AC_LANG_PROGRAM(
+ [
+ #include <glob.h>
+ #include <stdlib.h>
+ ],
+ [ glob(NULL, 0, NULL, NULL); ]
+ )
+ ],
+ [bird_cv_lib_glob=-landroid-glob],
+ [bird_cv_lib_glob=no]
+ )
+ LIBS="$bird_tmp_libs"
+ ]
+ )
+ )
])
-case $bird_cv_c_endian in
- big-endian) AC_DEFINE(CPU_BIG_ENDIAN) ;;
- little-endian) AC_DEFINE(CPU_LITTLE_ENDIAN) ;;
- esac
+
+AC_DEFUN([BIRD_CHECK_ANDROID_LOG],
+[
+ AC_CACHE_CHECK(
+ [for syslog lib flags],
+ [bird_cv_lib_log],
+ AC_LINK_IFELSE([
+ AC_LANG_PROGRAM(
+ [ #include <sys/syslog.h> ],
+ [ syslog(0, ""); ]
+ )
+ ],
+ [bird_cv_lib_log=yes],
+ [
+ bird_tmp_libs="$LIBS"
+ LIBS="$LIBS -llog"
+ AC_LINK_IFELSE([
+ AC_LANG_PROGRAM(
+ [ #include <sys/syslog.h> ],
+ [ syslog(0, ""); ]
+ )
+ ],
+ [bird_cv_lib_log=-llog],
+ [bird_cv_lib_log=no]
+ )
+ LIBS="$bird_tmp_libs"
+ ]
+ )
+ )
+])
+
+AC_DEFUN([BIRD_CHECK_LTO],
+[
+ bird_tmp_cflags="$CFLAGS"
+ bird_tmp_ldflags="$CFLAGS"
+ CFLAGS="-flto"
+ LDFLAGS="-flto"
+
+ AC_CACHE_CHECK(
+ [whether link time optimizer is available],
+ [bird_cv_c_lto],
+ [
+ AC_LINK_IFELSE(
+ [AC_LANG_PROGRAM()],
+ [bird_cv_c_lto=yes],
+ [bird_cv_c_lto=no]
+ )
+ ]
+ )
+
+ CFLAGS="$bird_tmp_cflags"
+ LDFLAGS="$bird_tmp_ldflags"
])
-AC_DEFUN(BIRD_CHECK_STRUCT_ALIGN,
-[AC_CACHE_CHECK([usual alignment of structures],bird_cv_c_struct_align,[
-AC_TRY_RUN([
-#include <stdio.h>
-
-struct { char x; long int y; } ary[2];
-
-int main(void)
-{
- FILE *f = fopen("conftestresult", "w");
- if (!f) return 10;
- fprintf(f, "%d", sizeof(ary)/2);
- fclose(f);
- exit(0);
-}
-],[
-bird_cv_c_struct_align=`cat conftestresult`
-],[
-AC_MSG_RESULT([test program failed])
-AC_MSG_ERROR([Cannot determine structure alignment])
-],[bird_cv_c_struct_align=16])
+
+AC_DEFUN([BIRD_CHECK_GCC_OPTION],
+[
+ bird_tmp_cflags="$CFLAGS"
+ CFLAGS="$3 $2"
+
+ AC_CACHE_CHECK(
+ [whether CC supports $2],
+ [$1],
+ [
+ AC_COMPILE_IFELSE(
+ [AC_LANG_PROGRAM()],
+ [$1=yes],
+ [$1=no]
+ )
+ ]
+ )
+
+ CFLAGS="$bird_tmp_cflags"
])
-AC_DEFINE_UNQUOTED(CPU_STRUCT_ALIGN, $bird_cv_c_struct_align)
+
+AC_DEFUN([BIRD_ADD_GCC_OPTION],
+[
+ if test "$$1" = yes ; then
+ CFLAGS="$CFLAGS $2"
+ fi
])
-AC_DEFUN(BIRD_CHECK_TIME_T,
-[AC_CACHE_CHECK([characteristics of time_t], bird_cv_type_time_t, [
-AC_TRY_RUN([
-#include <stdio.h>
-#include <sys/time.h>
-#include <limits.h>
-
-int main(void)
-{
- FILE *f = fopen("conftestresult", "w");
- if (!f) return 10;
- fprintf(f, "%d-bit ", sizeof(time_t)*CHAR_BIT);
- if ((time_t) -1 > 0) fprintf(f, "un");
- fprintf(f, "signed");
- fclose(f);
- exit(0);
-}
-],[bird_cv_type_time_t=`cat conftestresult`
-],[ AC_MSG_RESULT([test program failed])
- AC_MSG_ERROR([Cannot determine time_t size and signedness.])
-],[bird_cv_type_time_t="32-bit signed"])
+# BIRD_CHECK_PROG_FLAVOR_GNU(PROGRAM-PATH, IF-SUCCESS, [IF-FAILURE])
+# copied from autoconf internal _AC_PATH_PROG_FLAVOR_GNU
+AC_DEFUN([BIRD_CHECK_PROG_FLAVOR_GNU],
+[
+ # Check for GNU $1
+ case `"$1" --version 2>&1` in
+ *GNU*)
+ $2
+ ;;
+ m4_ifval([$3],
+ [*)
+ $3
+ ;;
+ ]
+ )
+ esac
])
-case "$bird_cv_type_time_t" in
- *64-bit*) AC_DEFINE(TIME_T_IS_64BIT) ;;
- esac
-case "$bird_cv_type_time_t" in
- *unsigned*) ;;
- *) AC_DEFINE(TIME_T_IS_SIGNED) ;;
- esac
+
+AC_DEFUN([BIRD_CHECK_BISON_VERSION],
+[
+ $1=`bison --version | ( read line; echo ${line##* } )`
+ case "$$1" in
+ 1.* | 2.0* | 2.1* | 2.2* | 2.3*)
+ AC_MSG_ERROR([Provided Bison version $$1 is too old, need at least 2.4])
+ ;;
+ 2.*)
+ bird_bison_synclines=no
+ bird_bison_enhanced_error=no
+ ;;
+ 3.* | 4.* | 5.* | 6.* | 7.* | 8.* | 9.*)
+ bird_bison_synclines=yes
+ bird_bison_enhanced_error=yes
+ ;;
+ *)
+ AC_MSG_ERROR([Couldn't parse Bison version $$1. Call the developers for help.])
+ ;;
+ esac
])