-CC=gcc
-CXX=g++
-
-LIB_NAME=model
-LIB_SO=lib$(LIB_NAME).so
-
+include common.mk
MODEL_CC=libthreads.cc schedule.cc model.cc threads.cc librace.cc action.cc nodestack.cc clockvector.cc main.cc snapshot-interface.cc cyclegraph.cc datarace.cc impatomic.cc cmodelint.cc promise.cc
MODEL_O=libthreads.o schedule.o model.o threads.o librace.o action.o nodestack.o clockvector.o main.o snapshot-interface.o cyclegraph.o datarace.o impatomic.o cmodelint.o promise.o
SHMEM_CC=snapshot.cc malloc.c mymemory.cc
SHMEM_O=snapshot.o malloc.o mymemory.o
-SHMEM_H=snapshot.h snapshotimp.h mymemory.h
+SHMEM_H=snapshot.h snapshotimp.h mymemory.h config.h
-CPPFLAGS=-Wall -g -O0 -Iinclude -I.
+CPPFLAGS += -Iinclude -I.
LDFLAGS=-ldl -lrt
SHARED=-shared
-all: $(LIB_SO)
+TESTS=test
+
+all: $(LIB_SO) tests
debug: CPPFLAGS += -DCONFIG_DEBUG
debug: all
malloc.o: malloc.c
$(CC) -fPIC -c malloc.c -DMSPACES -DONLY_MSPACES $(CPPFLAGS)
-mymemory.o: mymemory.h snapshotimp.h snapshot.h mymemory.cc
+mymemory.o: mymemory.h snapshotimp.h snapshot.h mymemory.cc config.h
$(CXX) -fPIC -c mymemory.cc $(CPPFLAGS)
-snapshot.o: mymemory.h snapshot.h snapshotimp.h snapshot.cc
+snapshot.o: mymemory.h snapshot.h snapshotimp.h snapshot.cc config.h
$(CXX) -fPIC -c snapshot.cc $(CPPFLAGS)
%.o: %.cc $(MODEL_H)
clean:
rm -f *.o *.so
+ $(MAKE) -C $(TESTS) clean
mrclean: clean
rm -rf docs
tags::
ctags -R
+
+tests:: $(LIB_SO)
+ $(MAKE) -C $(TESTS)