-if !LIBC_INCLUDES_PTHREAD
-AM_LDFLAGS=-lpthread
-endif
-AM_CFLAGS=-I$(top_srcdir) -I$(top_builddir) -I$(top_srcdir)/tests/utils -I$(top_srcdir)/tests/common -g
+AM_CPPFLAGS += -I$(top_srcdir)/src -I$(top_srcdir)/tests/utils -I$(top_srcdir)/tests/common
-noinst_PROGRAMS = test_urcu_fork \
- rcutorture_urcu \
+TEST_EXTENSIONS = .tap
+TAP_LOG_DRIVER_FLAGS = --merge --comments
+TAP_LOG_DRIVER = env AM_TAP_AWK='$(AWK)' $(SHELL) \
+ $(top_srcdir)/tests/utils/tap-driver.sh
+
+noinst_PROGRAMS = test_urcu_fork.tap \
+ rcutorture_urcu_membarrier \
rcutorture_urcu_signal \
rcutorture_urcu_mb \
rcutorture_urcu_bp \
noinst_HEADERS = rcutorture.h
-URCU_COMMON_LIB=$(top_builddir)/liburcu-common.la
-URCU_LIB=$(top_builddir)/liburcu.la
-URCU_QSBR_LIB=$(top_builddir)/liburcu-qsbr.la
-URCU_MB_LIB=$(top_builddir)/liburcu-mb.la
-URCU_SIGNAL_LIB=$(top_builddir)/liburcu-signal.la
-URCU_BP_LIB=$(top_builddir)/liburcu-bp.la
-URCU_CDS_LIB=$(top_builddir)/liburcu-cds.la
+URCU_COMMON_LIB=$(top_builddir)/src/liburcu-common.la
+URCU_LIB=$(top_builddir)/src/liburcu.la
+URCU_QSBR_LIB=$(top_builddir)/src/liburcu-qsbr.la
+URCU_MB_LIB=$(top_builddir)/src/liburcu-mb.la
+URCU_SIGNAL_LIB=$(top_builddir)/src/liburcu-signal.la
+URCU_BP_LIB=$(top_builddir)/src/liburcu-bp.la
+URCU_CDS_LIB=$(top_builddir)/src/liburcu-cds.la
TAP_LIB=$(top_builddir)/tests/utils/libtap.a
-test_urcu_fork_SOURCES = test_urcu_fork.c
-test_urcu_fork_LDADD = $(URCU_LIB) $(TAP_LIB)
+test_urcu_fork_tap_SOURCES = test_urcu_fork.c
+test_urcu_fork_tap_LDADD = $(URCU_LIB) $(TAP_LIB)
-rcutorture_urcu_SOURCES = urcutorture.c
-rcutorture_urcu_CFLAGS = -DRCU_MEMBARRIER $(AM_CFLAGS)
-rcutorture_urcu_LDADD = $(URCU_LIB) $(TAP_LIB)
+rcutorture_urcu_membarrier_SOURCES = urcutorture.c
+rcutorture_urcu_membarrier_CFLAGS = -DRCU_MEMBARRIER $(AM_CFLAGS)
+rcutorture_urcu_membarrier_LDADD = $(URCU_LIB) $(TAP_LIB)
rcutorture_urcu_mb_SOURCES = urcutorture.c
rcutorture_urcu_mb_CFLAGS = -DRCU_MB $(AM_CFLAGS)
urcutorture.c: ../common/api.h
-all-local:
- @if [ x"$(srcdir)" != x"$(builddir)" ]; then \
- for script in $(SCRIPT_LIST); do \
- cp -f $(srcdir)/$$script $(builddir); \
- done; \
- fi
+.PHONY: regtest
-clean-local:
- @if [ x"$(srcdir)" != x"$(builddir)" ]; then \
- for script in $(SCRIPT_LIST); do \
- rm -f $(builddir)/$$script; \
- done; \
- fi
+# This empty variable is required to enable the TAP test suite for custom
+# targets like 'regtest' while keeping the default 'check' a noop.
+TESTS =
-.PHONY: regtest
+REGTEST_TESTS = test_urcu_fork.tap \
+ rcutorture_urcu_bp_perf_global.tap \
+ rcutorture_urcu_bp_perf_percpu.tap \
+ rcutorture_urcu_bp_perf_perthread.tap \
+ rcutorture_urcu_bp_rperf_global.tap \
+ rcutorture_urcu_bp_rperf_percpu.tap \
+ rcutorture_urcu_bp_rperf_perthread.tap \
+ rcutorture_urcu_bp_stress_global.tap \
+ rcutorture_urcu_bp_stress_percpu.tap \
+ rcutorture_urcu_bp_stress_perthread.tap \
+ rcutorture_urcu_bp_uperf_global.tap \
+ rcutorture_urcu_bp_uperf_percpu.tap \
+ rcutorture_urcu_bp_uperf_perthread.tap \
+ rcutorture_urcu_mb_perf_global.tap \
+ rcutorture_urcu_mb_perf_percpu.tap \
+ rcutorture_urcu_mb_perf_perthread.tap \
+ rcutorture_urcu_mb_rperf_global.tap \
+ rcutorture_urcu_mb_rperf_percpu.tap \
+ rcutorture_urcu_mb_rperf_perthread.tap \
+ rcutorture_urcu_mb_stress_global.tap \
+ rcutorture_urcu_mb_stress_percpu.tap \
+ rcutorture_urcu_mb_stress_perthread.tap \
+ rcutorture_urcu_mb_uperf_global.tap \
+ rcutorture_urcu_mb_uperf_percpu.tap \
+ rcutorture_urcu_mb_uperf_perthread.tap \
+ rcutorture_urcu_membarrier_perf_global.tap \
+ rcutorture_urcu_membarrier_perf_percpu.tap \
+ rcutorture_urcu_membarrier_perf_perthread.tap \
+ rcutorture_urcu_membarrier_rperf_global.tap \
+ rcutorture_urcu_membarrier_rperf_percpu.tap \
+ rcutorture_urcu_membarrier_rperf_perthread.tap \
+ rcutorture_urcu_membarrier_stress_global.tap \
+ rcutorture_urcu_membarrier_stress_percpu.tap \
+ rcutorture_urcu_membarrier_stress_perthread.tap \
+ rcutorture_urcu_membarrier_uperf_global.tap \
+ rcutorture_urcu_membarrier_uperf_percpu.tap \
+ rcutorture_urcu_membarrier_uperf_perthread.tap \
+ rcutorture_urcu_qsbr_perf_global.tap \
+ rcutorture_urcu_qsbr_perf_percpu.tap \
+ rcutorture_urcu_qsbr_perf_perthread.tap \
+ rcutorture_urcu_qsbr_rperf_global.tap \
+ rcutorture_urcu_qsbr_rperf_percpu.tap \
+ rcutorture_urcu_qsbr_rperf_perthread.tap \
+ rcutorture_urcu_qsbr_stress_global.tap \
+ rcutorture_urcu_qsbr_stress_percpu.tap \
+ rcutorture_urcu_qsbr_stress_perthread.tap \
+ rcutorture_urcu_qsbr_uperf_global.tap \
+ rcutorture_urcu_qsbr_uperf_percpu.tap \
+ rcutorture_urcu_qsbr_uperf_perthread.tap \
+ rcutorture_urcu_signal_perf_global.tap \
+ rcutorture_urcu_signal_perf_percpu.tap \
+ rcutorture_urcu_signal_perf_perthread.tap \
+ rcutorture_urcu_signal_rperf_global.tap \
+ rcutorture_urcu_signal_rperf_percpu.tap \
+ rcutorture_urcu_signal_rperf_perthread.tap \
+ rcutorture_urcu_signal_stress_global.tap \
+ rcutorture_urcu_signal_stress_percpu.tap \
+ rcutorture_urcu_signal_stress_perthread.tap \
+ rcutorture_urcu_signal_uperf_global.tap \
+ rcutorture_urcu_signal_uperf_percpu.tap \
+ rcutorture_urcu_signal_uperf_perthread.tap
regtest:
- ./run.sh regression_tests
+ $(MAKE) $(AM_MAKEFLAGS) check TESTS="$(REGTEST_TESTS)"