X-Git-Url: https://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=Makefile;h=658a7fb5b57b9326217232eb3b1ca07a7f6c162d;hp=917aa1a31b6be0d90b974da8d1759f55123cd239;hb=98dcc5ca0ba740c56ecbc1f1c9d2977ef1b2a969;hpb=60fe0c90c4f70d12487235f750f21561da5e455b diff --git a/Makefile b/Makefile index 917aa1a..658a7fb 100644 --- a/Makefile +++ b/Makefile @@ -7,12 +7,30 @@ HOSTTYPE=$(shell uname -m) ifeq ("${HOSTTYPE}","x86_64") ARCHTYPE=x86 endif -ifeq ("${HOSTTYPE}","i486") +ifeq ("${HOSTTYPE}","i586") +ARCHTYPE=x86 +endif +ifeq ("${HOSTTYPE}","i686") ARCHTYPE=x86 endif ifeq ("${HOSTTYPE}","powerpc") ARCHTYPE=ppc endif +ifeq ("${HOSTTYPE}","ppc64") +ARCHTYPE=ppc +endif +ifeq ("${HOSTTYPE}","s390") +ARCHTYPE=s390 +endif +ifeq ("${HOSTTYPE}","s390x") +ARCHTYPE=s390 +endif + +ifeq ($(findstring ${ARCHTYPE},"x86 ppc"),) +APIHEADER=api_gcc.h +else +APIHEADER=api_${ARCHTYPE}.h +endif #debug #CFLAGS=-Wall -g @@ -27,7 +45,9 @@ all: checkarch test_urcu test_urcu_dynamic_link test_urcu_timing \ test_rwlock_timing test_rwlock test_perthreadlock_timing \ test_perthreadlock test_urcu_yield test_urcu_mb \ urcu-asm.S test_qsbr_timing test_qsbr urcu-asm.o urcutorture \ - urcutorture-yield liburcu.so + urcutorture-yield liburcu.so test_mutex test_looplen test_urcu_gc \ + test_urcu_gc_mb test_qsbr_gc test_qsbr_lgc test_urcu_lgc \ + test_urcu_lgc_mb checkarch: ifeq (${ARCHTYPE},) @@ -38,31 +58,55 @@ endif arch.h: arch_${ARCHTYPE}.h cp -f arch_${ARCHTYPE}.h arch.h -api.h: api_${ARCHTYPE}.h - cp -f api_${ARCHTYPE}.h api.h +api.h: ${APIHEADER} + cp -f ${APIHEADER} api.h arch_atomic.h: arch_atomic_${ARCHTYPE}.h cp -f arch_atomic_${ARCHTYPE}.h arch_atomic.h -urcu.h: arch.h api.h arch_atomic.h +urcu.h: arch.h arch_atomic.h -urcu-qsbr.h: arch.h api.h arch_atomic.h +urcu-qsbr.h: arch.h arch_atomic.h test_urcu: urcu.o test_urcu.c urcu.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_looplen: test_looplen.c urcu.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + test_urcu_mb: urcu-mb.o test_urcu.c urcu.h $(CC) -DDEBUG_FULL_MB ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_urcu_gc: urcu.o test_urcu_gc.c urcu.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + +test_urcu_gc_mb: urcu-mb.o test_urcu_gc.c urcu.h + $(CC) -DDEBUG_FULL_MB ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + +test_urcu_lgc: urcu.o test_urcu_gc.c urcu.h + $(CC) -DTEST_LOCAL_GC ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + +test_urcu_lgc_mb: urcu-mb.o test_urcu_gc.c urcu.h + $(CC) -DTEST_LOCAL_GC -DDEBUG_FULL_MB ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + test_qsbr: urcu-qsbr.o test_qsbr.c urcu-qsbr.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_qsbr_gc: urcu-qsbr.o test_qsbr_gc.c urcu-qsbr.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + +test_qsbr_lgc: urcu-qsbr.o test_qsbr_gc.c urcu-qsbr.h + $(CC) -DTEST_LOCAL_GC ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + test_rwlock: urcu.o test_rwlock.c urcu.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) test_perthreadlock: urcu.o test_perthreadlock.c urcu.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_mutex: urcu.o test_mutex.c urcu.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + test_urcu_dynamic_link: urcu.o test_urcu.c urcu.h $(CC) ${CFLAGS} -DDYNAMIC_LINK_TEST $(LDFLAGS) -o $@ $(SRC_DEP) @@ -102,10 +146,10 @@ urcu-asm.S: urcu-asm.c urcu.h urcu-asm.o: urcu-asm.c urcu.h $(CC) ${CFLAGS} -c -o $@ $(SRC_DEP) -urcutorture: urcutorture.c urcu.o urcu.h rcutorture.h +urcutorture: urcutorture.c urcu.o urcu.h rcutorture.h api.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) -urcutorture-yield: urcutorture.c urcu-yield.o urcu.h rcutorture.h +urcutorture-yield: urcutorture.c urcu-yield.o urcu.h rcutorture.h api.h $(CC) -DDEBUG_YIELD ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) .PHONY: clean install checkarch @@ -119,5 +163,6 @@ clean: test_rwlock_timing test_rwlock test_perthreadlock_timing \ test_perthreadlock test_urcu_yield test_urcu_mb \ urcu-asm.S test_qsbr_timing test_qsbr urcutorture \ - urcutorture-yield liburcu.so api.h arch.h arch_atomic.h + urcutorture-yield liburcu.so api.h arch.h arch_atomic.h \ + test_mutex test_urcu_gc test_urcu_gc_mb