Fix snapshot code
[model-checker.git] / Makefile
1 include common.mk
2
3 SCFENCE_DIR := scfence
4
5 OBJECTS := libthreads.o schedule.o model.o threads.o librace.o action.o \
6            nodestack.o clockvector.o main.o snapshot-interface.o cyclegraph.o \
7            datarace.o impatomic.o cmodelint.o \
8            snapshot.o malloc.o mymemory.o common.o mutex.o promise.o conditionvariable.o \
9            context.o scanalysis.o execution.o plugins.o libannotate.o
10
11 CPPFLAGS += -Iinclude -I. -I$(SCFENCE_DIR)
12 LDFLAGS := -ldl -lrt -rdynamic
13 SHARED := -shared
14
15 # Mac OSX options
16 ifeq ($(UNAME), Darwin)
17 LDFLAGS := -ldl
18 SHARED := -Wl,-undefined,dynamic_lookup -dynamiclib
19 endif
20
21 TESTS_DIR := test
22
23 MARKDOWN := doc/Markdown/Markdown.pl
24
25 all: $(LIB_SO) tests README.html
26
27 debug: CPPFLAGS += -DCONFIG_DEBUG
28 debug: all
29
30 PHONY += docs
31 docs: *.c *.cc *.h README.html
32         doxygen
33
34 README.html: README.md
35         $(MARKDOWN) $< > $@
36
37
38 malloc.o: malloc.c
39         $(CC) -fPIC -c malloc.c -DMSPACES -DONLY_MSPACES -DHAVE_MMAP=0 $(CPPFLAGS) -Wno-unused-variable
40
41 %.o : %.cc
42         $(CXX) -MMD -MF .$@.d -fPIC -c $< $(CPPFLAGS)
43
44 include $(SCFENCE_DIR)/Makefile
45
46 -include $(wildcard $(SCFENCE_DIR)/.*.d)
47
48 $(LIB_SO): $(OBJECTS)
49         $(CXX) $(SHARED) -o $(LIB_SO) $+ $(LDFLAGS)
50
51 %.pdf: %.dot
52         dot -Tpdf $< -o $@
53
54 -include $(OBJECTS:%=.%.d)
55
56 PHONY += clean
57 clean:
58         rm -f *.o *.so .*.d *.pdf *.dot $(SCFENCE_DIR)/.*.d $(SCFENCE_DIR)/*.o
59         $(MAKE) -C $(TESTS_DIR) clean
60
61 PHONY += mrclean
62 mrclean: clean
63         rm -rf docs
64
65 PHONY += tags
66 tags:
67         ctags -R
68
69 PHONY += tests
70 tests: $(LIB_SO)
71         $(MAKE) -C $(TESTS_DIR)
72
73 BENCH_DIR := benchmarks
74
75 PHONY += benchmarks
76 benchmarks: $(LIB_SO)
77         @if ! test -d $(BENCH_DIR); then \
78                 echo "Directory $(BENCH_DIR) does not exist" && \
79                 echo "Please clone the benchmarks repository" && \
80                 echo && \
81                 exit 1; \
82         fi
83         $(MAKE) -C $(BENCH_DIR)
84
85 PHONY += pdfs
86 pdfs: $(patsubst %.dot,%.pdf,$(wildcard *.dot))
87
88 .PHONY: $(PHONY)
89
90 # A 1-inch margin PDF generated by 'pandoc'
91 %.pdf: %.md
92         pandoc -o $@ $< -V header-includes='\usepackage[margin=1in]{geometry}'