1 | ## Define the configuration variables.
|
---|
2 |
|
---|
3 | Build = build
|
---|
4 | Figures = img
|
---|
5 |
|
---|
6 | LaTMac = ../../../LaTeXmacros
|
---|
7 | BibRep = ../../../bibliography
|
---|
8 |
|
---|
9 | Macros = ${LaTMac}
|
---|
10 | TeXLIB = .:${Macros}:${Build}:${BibRep}:
|
---|
11 | LaTeX = TEXINPUTS=${TeXLIB} && export TEXINPUTS && latex -halt-on-error -output-directory=${Build}
|
---|
12 | BibTeX = BIBINPUTS=${TeXLIB} && export BIBINPUTS && bibtex
|
---|
13 |
|
---|
14 | MAKEFLAGS = --no-print-directory # --silent
|
---|
15 | VPATH = ${Build} ${Figures}
|
---|
16 |
|
---|
17 | ## Define the text source files.
|
---|
18 | TEXTS = ${addprefix text/, ${addsuffix .tex, \
|
---|
19 | front \
|
---|
20 | intro \
|
---|
21 | existing \
|
---|
22 | runtime \
|
---|
23 | core \
|
---|
24 | practice \
|
---|
25 | io \
|
---|
26 | eval_micro \
|
---|
27 | eval_macro \
|
---|
28 | conclusion \
|
---|
29 | }}
|
---|
30 |
|
---|
31 | FIGURES = base \
|
---|
32 | base_avg \
|
---|
33 | base_ts2 \
|
---|
34 | cache-share \
|
---|
35 | cache-noshare \
|
---|
36 | empty \
|
---|
37 | emptybit \
|
---|
38 | emptytls \
|
---|
39 | emptytree \
|
---|
40 | executionStates \
|
---|
41 | fairness \
|
---|
42 | idle \
|
---|
43 | idle1 \
|
---|
44 | idle2 \
|
---|
45 | idle_state \
|
---|
46 | io_uring \
|
---|
47 | pivot_ring \
|
---|
48 | MQMS \
|
---|
49 | MQMSG \
|
---|
50 | system \
|
---|
51 | cycle \
|
---|
52 | result.cycle.jax.ops \
|
---|
53 | result.cycle.nasus.ops \
|
---|
54 | result.yield.jax.ops \
|
---|
55 | result.yield.nasus.ops \
|
---|
56 | result.churn.jax.ops \
|
---|
57 | result.churn.nasus.ops \
|
---|
58 | result.locality.share.jax.ops \
|
---|
59 | result.locality.share.nasus.ops \
|
---|
60 | result.locality.noshare.jax.ops \
|
---|
61 | result.locality.noshare.nasus.ops \
|
---|
62 | result.cycle.jax.ns \
|
---|
63 | result.cycle.nasus.ns \
|
---|
64 | result.yield.jax.ns \
|
---|
65 | result.yield.nasus.ns \
|
---|
66 | result.churn.jax.ns \
|
---|
67 | result.churn.nasus.ns \
|
---|
68 | result.locality.share.jax.ns \
|
---|
69 | result.locality.share.nasus.ns \
|
---|
70 | result.locality.noshare.jax.ns \
|
---|
71 | result.locality.noshare.nasus.ns \
|
---|
72 | result.cycle.low.jax.ops \
|
---|
73 | result.cycle.low.nasus.ops \
|
---|
74 | result.yield.low.jax.ops \
|
---|
75 | result.yield.low.nasus.ops \
|
---|
76 | result.churn.low.jax.ops \
|
---|
77 | result.churn.low.nasus.ops \
|
---|
78 | result.cycle.low.jax.ns \
|
---|
79 | result.cycle.low.nasus.ns \
|
---|
80 | result.yield.low.jax.ns \
|
---|
81 | result.yield.low.nasus.ns \
|
---|
82 | result.churn.low.jax.ns \
|
---|
83 | result.churn.low.nasus.ns \
|
---|
84 | result.memcd.rate.qps \
|
---|
85 | result.memcd.rate.99th \
|
---|
86 | result.memcd.forall.qps \
|
---|
87 | result.memcd.forall.lat \
|
---|
88 | result.memcd.fibre.qps \
|
---|
89 | result.memcd.fibre.lat \
|
---|
90 | result.memcd.vanilla.qps \
|
---|
91 | result.memcd.vanilla.lat \
|
---|
92 | result.swbsrv.25gb \
|
---|
93 | result.swbsrv.25gb.err \
|
---|
94 | SQMS
|
---|
95 |
|
---|
96 | PICTURES = ${addsuffix .pstex, ${FIGURES} }
|
---|
97 |
|
---|
98 | PROGRAMS = ${addsuffix .tex, \
|
---|
99 | }
|
---|
100 |
|
---|
101 | GRAPHS = ${addsuffix .tex, \
|
---|
102 | }
|
---|
103 |
|
---|
104 | ## Define the documents that need to be made.
|
---|
105 | all: thesis.pdf
|
---|
106 | build/thesis.dvi: ${TEXTS} ${PICTURES} thesis.tex glossary.tex local.bib ${LaTMac}/common.tex ${LaTMac}/common.sty ${BibRep}/pl.bib
|
---|
107 |
|
---|
108 | DOCUMENT = thesis.pdf
|
---|
109 | BASE = ${basename ${DOCUMENT}}
|
---|
110 |
|
---|
111 | # Directives #
|
---|
112 |
|
---|
113 | .NOTPARALLEL: # cannot make in parallel
|
---|
114 |
|
---|
115 | .PHONY : all clean # not file names
|
---|
116 |
|
---|
117 | all : ${DOCUMENT}
|
---|
118 |
|
---|
119 | clean :
|
---|
120 | @rm -frv ${DOCUMENT} ${BASE}.ps ${Build}
|
---|
121 |
|
---|
122 | # File Dependencies #
|
---|
123 |
|
---|
124 | %.pdf : build/%.ps | ${Build}
|
---|
125 | ps2pdf $<
|
---|
126 |
|
---|
127 | build/%.ps : build/%.dvi | ${Build}
|
---|
128 | dvips $< -o $@
|
---|
129 |
|
---|
130 | build/%.dvi : %.tex Makefile | ${Build}
|
---|
131 | # Conditionally create an empty *.ind (index) file for inclusion until makeindex is run.
|
---|
132 | if [ ! -r ${basename $@}.ind ] ; then touch ${basename $@}.ind ; fi
|
---|
133 | # Must have *.aux file containing citations for bibtex
|
---|
134 | if [ ! -r ${basename $@}.aux ] ; then ${LaTeX} $< ; fi
|
---|
135 | -${BibTeX} ${basename $@}
|
---|
136 | # Some citations reference others so run again to resolve these citations
|
---|
137 | ${LaTeX} $<
|
---|
138 | -${BibTeX} ${basename $@}
|
---|
139 | # Make index from *.aux entries and input index at end of document
|
---|
140 | -makeglossaries -q -s ${basename $@}.ist ${basename $@}
|
---|
141 | # Make index from *.aux entries and input index at end of document
|
---|
142 | -makeindex ${basename $@}.idx
|
---|
143 | # Run again to finish citations
|
---|
144 | ${LaTeX} $<
|
---|
145 |
|
---|
146 | ## Define the default recipes.
|
---|
147 |
|
---|
148 | ${Build}:
|
---|
149 | mkdir -p ${Build}
|
---|
150 |
|
---|
151 | %.tex : fig/%.fig | ${Build}
|
---|
152 | fig2dev -L eepic $< > ${Build}/$@
|
---|
153 |
|
---|
154 | %.ps : fig/%.fig | ${Build}
|
---|
155 | fig2dev -L ps $< > ${Build}/$@
|
---|
156 |
|
---|
157 | %.pstex : fig/%.fig | ${Build}
|
---|
158 | fig2dev -L pstex $< > ${Build}/$@
|
---|
159 | fig2dev -L pstex_t -p ${Build}/$@ $< > ${Build}/$@_t
|
---|
160 |
|
---|
161 | %.pstex : build/%.svg | ${Build}
|
---|
162 | inkscape -z -D --file=$< --export-eps=${Build}/$@ --export-latex
|
---|
163 | mv ${Build}/$@_tex ${Build}/$@_t
|
---|
164 | echo "sed -i 's/$@/${Build}/$@/g' ${Build}/$@_t"
|
---|
165 | sed -i 's/$@/${Build}\/$@/g' ${Build}/$@_t
|
---|
166 |
|
---|
167 | build/fairness.svg : fig/fairness.py | ${Build}
|
---|
168 | python3 $< $@
|
---|
169 |
|
---|
170 | cycle_jax_ops_FLAGS = --MaxY=500000000
|
---|
171 | cycle_low_jax_ops_FLAGS = --MaxY=500000000
|
---|
172 | cycle_jax_ns_FLAGS = --MaxY=4000
|
---|
173 | cycle_low_jax_ns_FLAGS = --MaxY=4000
|
---|
174 |
|
---|
175 | cycle_nasus_ops_FLAGS = --MaxY=1250000000
|
---|
176 | cycle_low_nasus_ops_FLAGS = --MaxY=1250000000
|
---|
177 | cycle_nasus_ns_FLAGS = --MaxY=1500
|
---|
178 | cycle_low_nasus_ns_FLAGS = --MaxY=1500
|
---|
179 |
|
---|
180 | yield_jax_ops_FLAGS = --MaxY=1000000000
|
---|
181 | yield_low_jax_ops_FLAGS = --MaxY=1000000000
|
---|
182 | yield_jax_ns_FLAGS = --MaxY=4000
|
---|
183 | yield_low_jax_ns_FLAGS = --MaxY=4000
|
---|
184 |
|
---|
185 | yield_nasus_ops_FLAGS = --MaxY=1500000000
|
---|
186 | yield_low_nasus_ops_FLAGS = --MaxY=1500000000
|
---|
187 | yield_nasus_ns_FLAGS = --MaxY=1500
|
---|
188 | yield_low_nasus_ns_FLAGS = --MaxY=1500
|
---|
189 |
|
---|
190 | churn_jax_ops_FLAGS = --MaxY=50000000
|
---|
191 | churn_low_jax_ops_FLAGS = --MaxY=50000000
|
---|
192 | churn_jax_ns_FLAGS = --MaxY=20000
|
---|
193 | churn_low_jax_ns_FLAGS = --MaxY=20000
|
---|
194 |
|
---|
195 | churn_nasus_ops_FLAGS = --MaxY=75000000
|
---|
196 | churn_low_nasus_ops_FLAGS = --MaxY=75000000
|
---|
197 | churn_nasus_ns_FLAGS = --MaxY=20000
|
---|
198 | churn_low_nasus_ns_FLAGS = --MaxY=20000
|
---|
199 |
|
---|
200 | build/result.%.ns.svg : data/% Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
201 | ../../../../benchmark/plot.py -f $< -o $@ -y "ns per ops/procs" $($(subst .,_,$*)_ns_FLAGS)
|
---|
202 |
|
---|
203 | build/result.%.ops.svg : data/% Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
204 | ../../../../benchmark/plot.py -f $< -o $@ -y "Ops per second" $($(subst .,_,$*)_ops_FLAGS)
|
---|
205 |
|
---|
206 | build/result.memcd.rate.qps.svg : data/memcd.rate Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
207 | ../../../../benchmark/plot.py -f $< -o $@ -y "Actual QPS" -x "Target QPS" --MaxY=750000
|
---|
208 |
|
---|
209 | build/result.memcd.rate.99th.svg : data/memcd.rate Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
210 | ../../../../benchmark/plot.py -f $< -o $@ -y "Tail Read Latency" -x "Target QPS"
|
---|
211 |
|
---|
212 | build/result.memcd.forall.qps.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
213 | ../../../../benchmark/plot.py -f $< -o $@ -y "Actual QPS" -x "Target QPS" --filter forall --MaxY=700000
|
---|
214 |
|
---|
215 | build/result.memcd.forall.lat.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
216 | ../../../../benchmark/plot.py -f $< -o $@ -y "Tail Read Latency" -x "Target QPS" --filter forall --MaxY=1
|
---|
217 |
|
---|
218 | build/result.memcd.vanilla.qps.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
219 | ../../../../benchmark/plot.py -f $< -o $@ -y "Actual QPS" -x "Target QPS" --filter vanilla --MaxY=700000
|
---|
220 |
|
---|
221 | build/result.memcd.vanilla.lat.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
222 | ../../../../benchmark/plot.py -f $< -o $@ -y "Tail Read Latency" -x "Target QPS" --filter vanilla --MaxY=1
|
---|
223 |
|
---|
224 | build/result.memcd.fibre.qps.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
225 | ../../../../benchmark/plot.py -f $< -o $@ -y "Actual QPS" -x "Target QPS" --filter fibre --MaxY=700000
|
---|
226 |
|
---|
227 | build/result.memcd.fibre.lat.svg : data/memcd.updt Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
228 | ../../../../benchmark/plot.py -f $< -o $@ -y "Tail Read Latency" -x "Target QPS" --filter fibre --MaxY=1
|
---|
229 |
|
---|
230 | build/swbsrv.% : data/swbsrv.%.nginx data/swbsrv.%.cfa Makefile ../../../../benchmark/process-trun.py | ${Build}
|
---|
231 | ../../../../benchmark/process-trun.py --out $@ $^
|
---|
232 |
|
---|
233 | build/result.swbsrv.%.svg : build/swbsrv.% Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
234 | ../../../../benchmark/plot.py -f $< -o $@ -y "Data Rate" -x "Request Rate"
|
---|
235 |
|
---|
236 | build/result.swbsrv.%.err.svg : build/swbsrv.% Makefile ../../../../benchmark/plot.py | ${Build}
|
---|
237 | ../../../../benchmark/plot.py -f $< -o $@ -y "Errors" -x "Request Rate"
|
---|
238 |
|
---|
239 | ## pstex with inverted colors
|
---|
240 | %.dark.pstex : fig/%.fig Makefile | ${Build}
|
---|
241 | fig2dev -L pstex $< > ${Build}/$@
|
---|
242 | sed -i 's/\/col-1 {0 setgray} bind def/\/col-1 {1 setgray} bind def/g' ${Build}/$@
|
---|
243 | sed -i 's/\/col0 {0.000 0.000 0.000 srgb} bind def/\/col0 {1.000 1.000 1.000 srgb} bind def/g' ${Build}/$@
|
---|
244 | sed -i 's/\/col7 {1.000 1.000 1.000 srgb} bind def/\/col7 {0.000 0.000 0.000 srgb} bind def/g' ${Build}/$@
|
---|
245 | fig2dev -L pstex_t -p ${Build}/$@ $< > ${Build}/$@_t
|
---|
246 |
|
---|
247 | # Local Variables: #
|
---|
248 | # compile-command: "make" #
|
---|
249 | # End: #
|
---|