X-Git-Url: https://git.liburcu.org/?a=blobdiff_plain;f=Makefile;h=3d1c18f6a723b6277c8a55c4c421c413b6d24907;hb=d98c5f2fcaf4863a36d9523831d516e1d3c65651;hp=5842b26872fae87e71681c4e67a6c0bcb8ae8dd0;hpb=121a5d44c8cc7197116df73854cb94c6cfbad0b0;p=urcu.git diff --git a/Makefile b/Makefile index 5842b26..3d1c18f 100644 --- a/Makefile +++ b/Makefile @@ -2,6 +2,24 @@ 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 + #debug #CFLAGS=-Wall -g #CFLAGS+=-DDEBUG_FULL_MB @@ -9,23 +27,64 @@ 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 + +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: api_${ARCHTYPE}.h + cp -f api_${ARCHTYPE}.h 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 api.h arch_atomic.h + +urcu-qsbr.h: arch.h api.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-mb.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_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_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 +94,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 $@ $< @@ -59,12 +130,17 @@ urcutorture: urcutorture.c urcu.o urcu.h rcutorture.h urcutorture-yield: urcutorture.c urcu-yield.o urcu.h rcutorture.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 + 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 +