-
Notifications
You must be signed in to change notification settings - Fork 0
/
GNUmakefile
149 lines (125 loc) · 5.06 KB
/
GNUmakefile
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
LAB=8
SOL=0
RPC=./rpc
LAB2GE=$(shell expr $(LAB) \>\= 2)
LAB3GE=$(shell expr $(LAB) \>\= 3)
LAB4GE=$(shell expr $(LAB) \>\= 4)
LAB5GE=$(shell expr $(LAB) \>\= 5)
LAB6GE=$(shell expr $(LAB) \>\= 6)
LAB7GE=$(shell expr $(LAB) \>\= 7)
LAB8GE=$(shell expr $(LAB) \>\= 8)
CXXFLAGS = -g -MMD -Wall -I. -I$(RPC) -I./map_reduce -DLAB=$(LAB) -DSOL=$(SOL) -D_FILE_OFFSET_BITS=64
FUSEFLAGS= -D_FILE_OFFSET_BITS=64 -DFUSE_USE_VERSION=25 -I/usr/local/include/fuse -I/usr/include/fuse
ifeq ($(shell uname -s),Darwin)
MACFLAGS= -D__FreeBSD__=10
else
MACFLAGS=
endif
LDFLAGS = -L. -L/usr/local/lib
LDLIBS = -lpthread
ifeq ($(LAB2GE),1)
ifeq ($(shell uname -s),Darwin)
ifeq ($(shell sw_vers -productVersion | sed -e "s/.*\(10\.[0-9]\).*/\1/"),10.6)
LDLIBS += -lfuse_ino64
else
LDLIBS += -lfuse
endif
else
LDLIBS += -lfuse
endif
endif
LDLIBS += $(shell test -f `gcc -print-file-name=librt.so` && echo -lrt)
LDLIBS += $(shell test -f `gcc -print-file-name=libdl.so` && echo -ldl)
CC = g++
CXX = g++
lab: lab$(LAB)
lab1: rpc/rpctest lock_server lock_tester lock_demo
lab2: rpc/rpctest lock_server lock_tester lock_demo yfs_client extent_server
lab3: yfs_client extent_server lock_server test-lab-3-b test-lab-3-c
lab4: yfs_client extent_server lock_server lock_tester test-lab-3-b\
test-lab-3-c
lab5: yfs_client extent_server lock_server test-lab-3-b test-lab-3-c
lab6: lock_server rsm_tester
lab7: lock_tester lock_server rsm_tester
lab8: extent_server lock_server yfs_client map_reduce/node map_reduce/job_main
hfiles1=rpc/fifo.h rpc/connection.h rpc/rpc.h rpc/marshall.h rpc/method_thread.h\
rpc/thr_pool.h rpc/pollmgr.h rpc/jsl_log.h rpc/slock.h rpc/rpctest.cc\
lock_protocol.h lock_server.h lock_client.h gettime.h gettime.cc lang/verify.h \
lang/algorithm.h
hfiles2=yfs_client.h extent_client.h extent_protocol.h extent_server.h
hfiles3=lock_client_cache.h lock_server_cache.h handle.h tprintf.h
hfiles4=log.h rsm.h rsm_protocol.h config.h paxos.h paxos_protocol.h rsm_state_transfer.h rsmtest_client.h tprintf.h
hfiles5=rsm_state_transfer.h rsm_client.h
rsm_files = rsm.cc paxos.cc config.cc log.cc handle.cc
rpclib=rpc/rpc.cc rpc/connection.cc rpc/pollmgr.cc rpc/thr_pool.cc rpc/jsl_log.cc gettime.cc
rpc/librpc.a: $(patsubst %.cc,%.o,$(rpclib))
rm -f $@
ar cq $@ $^
ranlib rpc/librpc.a
rpc/rpctest=rpc/rpctest.cc
rpc/rpctest: $(patsubst %.cc,%.o,$(rpctest)) rpc/librpc.a
lock_demo=lock_demo.cc lock_client.cc
lock_demo : $(patsubst %.cc,%.o,$(lock_demo)) rpc/librpc.a
lock_tester=lock_tester.cc lock_client.cc
ifeq ($(LAB4GE),1)
lock_tester += lock_client_cache.cc
endif
ifeq ($(LAB7GE),1)
lock_tester+=rsm_client.cc handle.cc lock_client_cache_rsm.cc
endif
lock_tester : $(patsubst %.cc,%.o,$(lock_tester)) rpc/librpc.a
lock_server=lock_server.cc lock_smain.cc
ifeq ($(LAB4GE),1)
lock_server+=lock_server_cache.cc handle.cc
endif
#ifeq ($(LAB6GE),1)
#lock_server+= $(rsm_files)
#endif
#ifeq ($(LAB7GE),1)
#lock_server+= lock_server_cache_rsm.cc
#endif
lock_server : $(patsubst %.cc,%.o,$(lock_server)) rpc/librpc.a
yfs_client=yfs_client.cc extent_client.cc fuse.cc
ifeq ($(LAB3GE),1)
yfs_client += lock_client.cc
endif
#ifeq ($(LAB7GE),1)
#yfs_client += rsm_client.cc lock_client_cache_rsm.cc
#endif
ifeq ($(LAB4GE),1)
yfs_client += lock_client_cache.cc
endif
yfs_client : $(patsubst %.cc,%.o,$(yfs_client)) rpc/librpc.a
extent_server=extent_server.cc extent_smain.cc
extent_server : $(patsubst %.cc,%.o,$(extent_server)) rpc/librpc.a
test-lab-3-b=test-lab-3-b.c
test-lab-3-b: $(patsubst %.c,%.o,$(test_lab_4-b)) rpc/librpc.a
test-lab-3-c=test-lab-3-c.c
test-lab-4-c: $(patsubst %.c,%.o,$(test_lab_4-c)) rpc/librpc.a
rsm_tester=rsm_tester.cc rsmtest_client.cc
rsm_tester: $(patsubst %.cc,%.o,$(rsm_tester)) rpc/librpc.a
node = map_reduce/node_main.cc map_reduce/node.cc map_reduce/mapper.cc map_reduce/reducer.cc map_reduce/master.cc handle.cc config.cc paxos.cc log.cc
map_reduce/node : $(patsubst %.cc,%.o,$(node)) rpc/librpc.a
job_main = map_reduce/job_main.cc map_reduce/node.cc handle.cc map_reduce/mapper.cc map_reduce/reducer.cc map_reduce/master.cc config.cc paxos.cc log.cc
#map_reduce_tester = map_reduce/node_main.cc map_reduce/node.cc handle.cc
map_reduce/job_main : $(patsubst %.cc,%.o,$(job_main)) rpc/librpc.a
%.o: %.cc
$(CXX) $(CXXFLAGS) -c $< -o $@
fuse.o: fuse.cc
$(CXX) -c $(CXXFLAGS) $(FUSEFLAGS) $(MACFLAGS) $<
# mklab.inc is needed by 6.824 staff only. Just ignore it.
-include mklab.inc
-include *.d
-include rpc/*.d
clean_files=rpc/rpctest rpc/*.o rpc/*.d rpc/librpc.a *.o *.d yfs_client extent_server lock_server lock_tester lock_demo rpctest test-lab-3-b test-lab-3-c rsm_tester map_reduce/node map_reduce/job_main map_reduce/*.o map_reduce/*.d
.PHONY: clean handin
clean:
rm $(clean_files) -rf
handin_ignore=$(clean_files) core* *log
handin_file=$(shell whoami)-lab$(LAB).tgz
labdir=$(shell basename $(PWD))
handin:
@if test -f stop.sh; then ./stop.sh > /dev/null 2>&1 | echo ""; fi
@bash -c "cd ../; tar -X <(tr ' ' '\n' < <(echo '$(handin_ignore)')) -czvf $(handin_file) $(labdir); mv $(handin_file) $(labdir); cd $(labdir)"
@echo Please email $(handin_file) to 6.824-submit@pdos.csail.mit.edu
@echo Thanks!