AC_FUNC_MALLOC
AC_CHECK_FUNCS([gettimeofday munmap socket strerror strtol])
-AC_ARG_WITH(urcu, [ --with-urcu=path Path to userspace RCU library source], URCU_PATH="$withval", AC_MSG_ERROR([Must specify liburcu path.]))
-AC_CHECK_FILE("$URCU_PATH/urcu.h", , AC_MSG_ERROR([Cannot find urcu.h in liburcu directory]))
-AC_ARG_WITH(kcompat, [ --with-kcompat=path Path to libkcompat source], KCOMPAT_PATH="$withval", AC_MSG_ERROR([Must specify libkcompat path.]))
-AC_CHECK_FILE("$KCOMPAT_PATH/kcompat.h", , AC_MSG_ERROR([Cannot find kcompat.h in libkcompat directory]))
-AC_SUBST(URCU_PATH)
+KCOMPAT_PATH=
+AC_ARG_WITH(kcompat, [ --with-kcompat path Path to userspace kcompat source], [
+ AC_CHECK_FILE(["$withval/kcompat.h"], KCOMPAT_PATH="$withval", [
+ AC_MSG_ERROR([Cannot find kcompat.h in kcompat directory])
+ ])
+])
+if test -n "${KCOMPAT_PATH}" ; then
+ CPPFLAGS="-I$KCOMPAT_PATH/ $CPPFLAGS"
+ AC_SUBST(CPPFLAGS)
+fi
+AC_CHECK_HEADER([kcompat.h], , AC_MSG_ERROR([Must specify kcompat path.]))
AC_SUBST(KCOMPAT_PATH)
+URCU_LIB=
+AC_CHECK_HEADER([urcu.h], [
+ AC_CHECK_LIB(urcu, synchronize_rcu, [
+ URCU_PATH=
+ URCU_LIB="-lurcu"
+ ])
+])
+AC_ARG_WITH(urcu, [ --with-urcu path Path to userspace RCU source], [
+ AC_CHECK_FILE(["$withval/urcu.h"], [
+ URCU_PATH="$withval"
+ URCU_LIB="/liburcu.la" ],
+ AC_MSG_ERROR([Cannot find urcu.h in urcu directory]))
+])
+if test -z "${URCU_LIB}" ; then
+ AC_MSG_ERROR([Must specify urcu path.])
+fi
+AC_SUBST(URCU_PATH)
+AC_SUBST(URCU_LIB)
+
#AC_CONFIG_FILES([Makefile
# hello/Makefile
# libmallocwrap/Makefile
lib_LTLIBRARIES = libust.la
libust_la_SOURCES = marker.c marker.h tracepoint.c tracepoint.h immediate.h channels.c channels.h marker-control.c marker-control.h relay.c relay.h tracer.c tracer.h tracercore.c tracercore.h serialize.c tracectl.c $(top_builddir)/libustcomm/ustcomm.c $(top_builddir)/share/kref.c $(top_builddir)/share/usterr.c
-libust_la_LIBADD = @URCU_PATH@/liburcu.so
-libust_la_LDFLAGS = -lpthread
+libust_la_LDFLAGS = -no-undefined -version-info 0:0:0
+libust_la_LIBADD = @URCU_PATH@@URCU_LIB@ -lpthread
INCLUDES = -I$(top_builddir)/share
INCLUDES += -I$(top_builddir)/libustcomm