fairness changes...
[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 mutex.o
7
8 CPPFLAGS += -Iinclude -I. -rdynamic
9 LDFLAGS = -ldl -lrt
10 SHARED = -shared
11
12 # Mac OSX options
13 ifeq ($(UNAME), Darwin)
14 LDFLAGS = -ldl
15 SHARED = -Wl,-undefined,dynamic_lookup -dynamiclib
16 endif
17
18 TESTS_DIR = test
19
20 program_H_SRCS := $(wildcard *.h) $(wildcard include/*.h)
21 program_C_SRCS := $(wildcard *.c) $(wildcard *.cc)
22 DEPS = make.deps
23
24 all: $(LIB_SO) $(DEPS) tests
25
26 $(DEPS): $(program_C_SRCS) $(program_H_SRCS)
27         $(CXX) -MM $(program_C_SRCS) $(CPPFLAGS) > $(DEPS)
28
29 include $(DEPS)
30
31 debug: CPPFLAGS += -DCONFIG_DEBUG
32 debug: all
33
34 docs: *.c *.cc *.h
35         doxygen
36
37 $(LIB_SO): $(OBJECTS)
38         $(CXX) $(SHARED) -o $(LIB_SO) $(OBJECTS) $(LDFLAGS)
39
40 malloc.o: malloc.c
41         $(CC) -fPIC -c malloc.c -DMSPACES -DONLY_MSPACES $(CPPFLAGS)
42
43 %.o: %.cc
44         $(CXX) -fPIC -c $< $(CPPFLAGS)
45
46 PHONY += clean
47 clean:
48         rm -f *.o *.so
49         $(MAKE) -C $(TESTS_DIR) clean
50
51 PHONY += mrclean
52 mrclean: clean
53         rm -rf docs
54
55 PHONY += tags
56 tags:
57         ctags -R
58
59 PHONY += tests
60 tests: $(LIB_SO)
61         $(MAKE) -C $(TESTS_DIR)
62
63 .PHONY: $(PHONY)