update license
[urcu.git] / Makefile
index e03d50936d4b9ce81dd6077f5deef02ba70767c1..658a7fb5b57b9326217232eb3b1ca07a7f6c162d 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -19,6 +19,18 @@ 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
@@ -33,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 test_mutex
+       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},)
@@ -44,25 +58,46 @@ 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)
 
@@ -111,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
@@ -129,5 +164,5 @@ clean:
        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_mutex test_urcu_gc test_urcu_gc_mb
 
This page took 0.023748 seconds and 4 git commands to generate.