X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=Makefile.am;h=672beecad0176a848ab31d5258c97bee668e4747;hp=1589884fbc8b144bd436ea2745f18741587e601e;hb=1a186a881c195c0f240c0baa813056b0cc1eab91;hpb=0376e7b2f8d26778ebc4750b34e718c062c92764 diff --git a/Makefile.am b/Makefile.am index 1589884..672beec 100644 --- a/Makefile.am +++ b/Makefile.am @@ -1,23 +1,39 @@ -INCLUDES = -I$(top_builddir)/urcu +ACLOCAL_AMFLAGS=-I m4 -AM_LDFLAGS=-lpthread +AM_CPPFLAGS = -I$(top_builddir)/urcu + +#Add the -version-info directly here since we are only building +# library that use the version-info +AM_LDFLAGS=-version-info $(URCU_LIBRARY_VERSION) +if !LIBC_INCLUDES_PTHREAD +AM_LDFLAGS+=-lpthread +endif AM_CFLAGS=-Wall -SUBDIRS = . tests +SUBDIRS = . doc tests -include_HEADERS = urcu.h $(top_srcdir)/urcu-*.h +include_HEADERS = urcu.h urcu-bp.h urcu-call-rcu.h urcu-defer.h \ + urcu-pointer.h urcu-qsbr.h urcu-flavor.h nobase_dist_include_HEADERS = urcu/compiler.h urcu/hlist.h urcu/list.h \ - urcu/rculist.h urcu/rcuhlist.h urcu/system.h urcu/urcu-futex.h \ - urcu/uatomic_generic.h urcu/arch_generic.h urcu/wfstack.h \ + urcu/rculist.h urcu/rcuhlist.h urcu/system.h urcu/futex.h \ + urcu/uatomic/generic.h urcu/arch/generic.h urcu/wfstack.h \ urcu/wfqueue.h urcu/rculfstack.h urcu/rculfqueue.h \ - urcu/wfqueue-static.h urcu/wfstack-static.h \ - urcu/rculfqueue-static.h urcu/rculfstack-static.h \ - urcu/urcu_ref.h -nobase_nodist_include_HEADERS = urcu/arch.h urcu/uatomic_arch.h urcu/config.h + urcu/ref.h urcu/cds.h urcu/urcu_ref.h urcu/urcu-futex.h \ + urcu/uatomic_arch.h urcu/rculfhash.h urcu/wfcqueue.h \ + urcu/lfstack.h urcu/syscall-compat.h \ + $(top_srcdir)/urcu/map/*.h \ + $(top_srcdir)/urcu/static/*.h \ + urcu/rand-compat.h \ + urcu/tls-compat.h urcu/debug.h +nobase_nodist_include_HEADERS = urcu/arch.h urcu/uatomic.h urcu/config.h + +dist_noinst_HEADERS = urcu-die.h urcu-wait.h compat-getcpu.h -EXTRA_DIST = $(top_srcdir)/urcu/arch_*.h $(top_srcdir)/urcu/uatomic_arch_*.h \ +EXTRA_DIST = $(top_srcdir)/urcu/arch/*.h $(top_srcdir)/urcu/uatomic/*.h \ gpl-2.0.txt lgpl-2.1.txt lgpl-relicensing.txt \ - README LICENSE compat_arch_x86.c + LICENSE compat_arch_x86.c \ + urcu-call-rcu-impl.h urcu-defer-impl.h \ + rculfhash-internal.h if COMPAT_ARCH COMPAT=compat_arch_@ARCHTYPE@.c @@ -25,30 +41,55 @@ else COMPAT= endif -if COMPAT_FUTEX COMPAT+=compat_futex.c -endif -lib_LTLIBRARIES = liburcu.la liburcu-qsbr.la liburcu-mb.la liburcu-signal.la \ - liburcu-bp.la \ - libwfqueue.la libwfstack.la librculfqueue.la librculfstack.la +RCULFHASH = rculfhash.c rculfhash-mm-order.c rculfhash-mm-chunk.c \ + rculfhash-mm-mmap.c + +lib_LTLIBRARIES = liburcu-common.la \ + liburcu.la liburcu-qsbr.la \ + liburcu-mb.la liburcu-signal.la liburcu-bp.la \ + liburcu-cds.la + +# +# liburcu-common contains wait-free queues (needed by call_rcu) as well +# as futex fallbacks. +# +liburcu_common_la_SOURCES = wfqueue.c wfcqueue.c wfstack.c $(COMPAT) liburcu_la_SOURCES = urcu.c urcu-pointer.c $(COMPAT) +liburcu_la_LIBADD = liburcu-common.la liburcu_qsbr_la_SOURCES = urcu-qsbr.c urcu-pointer.c $(COMPAT) +liburcu_qsbr_la_LIBADD = liburcu-common.la liburcu_mb_la_SOURCES = urcu.c urcu-pointer.c $(COMPAT) liburcu_mb_la_CFLAGS = -DRCU_MB +liburcu_mb_la_LIBADD = liburcu-common.la liburcu_signal_la_SOURCES = urcu.c urcu-pointer.c $(COMPAT) liburcu_signal_la_CFLAGS = -DRCU_SIGNAL +liburcu_signal_la_LIBADD = liburcu-common.la liburcu_bp_la_SOURCES = urcu-bp.c urcu-pointer.c $(COMPAT) +liburcu_bp_la_LIBADD = liburcu-common.la -libwfqueue_la_SOURCES = wfqueue.c $(COMPAT) -libwfstack_la_SOURCES = wfstack.c $(COMPAT) -librculfqueue_la_SOURCES = rculfqueue.c $(COMPAT) -librculfstack_la_SOURCES = rculfstack.c $(COMPAT) +liburcu_cds_la_SOURCES = rculfqueue.c rculfstack.c lfstack.c \ + $(RCULFHASH) $(COMPAT) +liburcu_cds_la_LIBADD = liburcu-common.la pkgconfigdir = $(libdir)/pkgconfig -pkgconfig_DATA = liburcu.pc liburcu-bp.pc \ No newline at end of file +pkgconfig_DATA = liburcu-cds.pc liburcu.pc liburcu-bp.pc liburcu-qsbr.pc \ + liburcu-signal.pc liburcu-mb.pc + +dist_doc_DATA = README.md ChangeLog + +dist_noinst_DATA = CodingStyle + +.PHONY: short_bench long_bench regtest +short_bench: + cd tests && $(MAKE) $(AM_MAKEFLAGS) short_bench +long_bench: + cd tests && $(MAKE) $(AM_MAKEFLAGS) long_bench +regtest: + cd tests && $(MAKE) $(AM_MAKEFLAGS) regtest