X-Git-Url: http://git.liburcu.org/?p=urcu.git;a=blobdiff_plain;f=Makefile;h=658a7fb5b57b9326217232eb3b1ca07a7f6c162d;hp=093bf6619c852bfd920652bfac4929487dd28e0d;hb=7abf2d0da3b328572a17c9457b33c3890b0ba58b;hpb=af02d47e5d0712e5ccde6d8f1ee89f18de798cad diff --git a/Makefile b/Makefile index 093bf66..658a7fb 100644 --- a/Makefile +++ b/Makefile @@ -2,6 +2,36 @@ CFLAGS=-Wall -O2 -g -I. LDFLAGS=-lpthread +HOSTTYPE=$(shell uname -m) + +ifeq ("${HOSTTYPE}","x86_64") +ARCHTYPE=x86 +endif +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 #CFLAGS+=-DDEBUG_FULL_MB @@ -9,23 +39,74 @@ LDFLAGS=-lpthread #Changing the signal number used by the library. SIGUSR1 by default. #CFLAGS+=-DSIGURCU=SIGUSR2 -SRC_DEP=`echo $^ | sed 's/[^ ]*.h//g'` +SRC_DEP=`echo $^ | sed 's/[^ ]*\.h//g'` + +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 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},) + @echo "Architecture ${HOSTTYPE} is currently unsupported by liburcu" + @exit 1 +endif + +arch.h: arch_${ARCHTYPE}.h + cp -f arch_${ARCHTYPE}.h arch.h -all: test_urcu test_urcu_dynamic_link test_urcu_timing \ - test_rwlock_timing test_urcu_yield urcu-asm.S \ - urcu-asm.o urcutorture urcutorture-yield liburcu.so +api.h: ${APIHEADER} + cp -f ${APIHEADER} api.h -pthreads-x86: clean - cp api_x86.h api.h - cp arch_x86.h arch.h +arch_atomic.h: arch_atomic_${ARCHTYPE}.h + cp -f arch_atomic_${ARCHTYPE}.h arch_atomic.h -pthreads-ppc: clean - cp api_ppc.h api.h - cp arch_ppc.h arch.h +urcu.h: arch.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) @@ -35,12 +116,24 @@ test_urcu_yield: urcu-yield.o test_urcu.c urcu.h test_urcu_timing: urcu.o test_urcu_timing.c urcu.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_qsbr_timing: urcu-qsbr.o test_qsbr_timing.c urcu-qsbr.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + test_rwlock_timing: urcu.o test_rwlock_timing.c urcu.h $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) +test_perthreadlock_timing: urcu.o test_perthreadlock_timing.c urcu.h + $(CC) ${CFLAGS} $(LDFLAGS) -o $@ $(SRC_DEP) + urcu.o: urcu.c urcu.h $(CC) -fPIC ${CFLAGS} $(LDFLAGS) -c -o $@ $(SRC_DEP) +urcu-mb.o: urcu.c urcu.h + $(CC) -fPIC -DDEBUG_FULL_MB ${CFLAGS} $(LDFLAGS) -c -o $@ $(SRC_DEP) + +urcu-qsbr.o: urcu-qsbr.c urcu-qsbr.h + $(CC) -fPIC ${CFLAGS} $(LDFLAGS) -c -o $@ $(SRC_DEP) + liburcu.so: urcu.o $(CC) -fPIC -shared -o $@ $< @@ -53,19 +146,23 @@ 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 +.PHONY: clean install checkarch install: liburcu.so cp -f liburcu.so /usr/lib/ - cp -f arch.h compiler.h urcu.h urcu-static.h /usr/include/ + cp -f arch.h arch_atomic.h compiler.h urcu.h urcu-static.h /usr/include/ clean: - rm -f *.o test_urcu test_urcu_timing test_rwlock_timing urcu-asm.S \ - test_urcu_yield urcutorture urcutorture-yield liburcu.so \ - test_urcu_dynamic_link + rm -f *.o 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 urcutorture \ + urcutorture-yield liburcu.so api.h arch.h arch_atomic.h \ + test_mutex test_urcu_gc test_urcu_gc_mb +