53b0331f2a250f7a18af120f87929b4cee605fdd
[model-checker.git] / Makefile
1 include common.mk
2
3 OBJECTS = libthreads.o schedule.o model.o threads.o librace.o action.o \
4           nodestack.o clockvector.o main.o snapshot-interface.o cyclegraph.o \
5           datarace.o impatomic.o cmodelint.o \
6           snapshot.o malloc.o mymemory.o common.o
7
8 CPPFLAGS += -Iinclude -I. -rdynamic
9 LDFLAGS = -ldl -lrt
10 SHARED = -shared
11
12 # Mac OSX options
13 ifeq ($(UNAME), Darwin)
14 CPPFLAGS += -D_XOPEN_SOURCE -DMAC
15 LDFLAGS = -ldl
16 SHARED = -Wl,-undefined,dynamic_lookup -dynamiclib
17 endif
18
19 TESTS_DIR = test
20
21 program_H_SRCS := $(wildcard *.h) $(wildcard include/*.h)
22 program_C_SRCS := $(wildcard *.c) $(wildcard *.cc)
23 DEPS = make.deps
24
25 all: $(LIB_SO) $(DEPS) tests
26
27 $(DEPS): $(program_C_SRCS) $(program_H_SRCS)
28         $(CXX) -MM $(program_C_SRCS) $(CPPFLAGS) > $(DEPS)
29
30 include $(DEPS)
31
32 debug: CPPFLAGS += -DCONFIG_DEBUG
33 debug: all
34
35 docs: *.c *.cc *.h
36         doxygen
37
38 $(LIB_SO): $(OBJECTS)
39         $(CXX) $(SHARED) -o $(LIB_SO) $(OBJECTS) $(LDFLAGS)
40
41 malloc.o: malloc.c
42         $(CC) -fPIC -c malloc.c -DMSPACES -DONLY_MSPACES $(CPPFLAGS)
43
44 %.o: %.cc
45         $(CXX) -fPIC -c $< $(CPPFLAGS)
46
47 PHONY += clean
48 clean:
49         rm -f *.o *.so
50         $(MAKE) -C $(TESTS_DIR) clean
51
52 PHONY += mrclean
53 mrclean: clean
54         rm -rf docs
55
56 PHONY += tags
57 tags:
58         ctags -R
59
60 PHONY += tests
61 tests: $(LIB_SO)
62         $(MAKE) -C $(TESTS_DIR)
63
64 .PHONY: $(PHONY)