Makefile: automate adding headers for new load balancers
[charm.git] / src / scripts / Makefile
1 #############################################################################"
2 #
3 # This one Makefile serves all of converse and charm.  It includes
4 # rules for building:
5 #
6 #     * The CONVERSE libraries
7 #     * Charm++ runtime
8 #     * ITC++ Translator
9 #     * Languages
10 #     * Documentation
11 #
12 # This Makefile is common to all machines.  This works because the charmc
13 # is smart enough to "conceal" the differences between machines.  charmc
14 # gets its smarts by reading the conv-mach.sh configuration file.
15 #
16 # If you wish to compile with debugging, optimization, or some other charm
17 # option, you can do so by setting OPTS.  For example, if you need a lot
18 # of debugging information, you could type:
19 #
20 #     make charm++ OPTS="-g -save -verbose"
21 #
22 ###############################################################################
23
24 SHELL=/bin/sh
25 L=../lib
26 INC=../include
27
28 all: charm++ bigsim LIBS AMPI f90charm TSM SM PVM doc
29
30 all-test: bigsim AMPI
31         cd ../tests ; $(MAKE) all OPTS='$(OPTS)'
32         cd ../examples ; $(MAKE) all OPTS='$(OPTS)'
33
34 charm++: charm-target
35         @echo "$(OPTS)" > OPTS
36         touch charm++
37
38 bgampi: bigsim AMPI
39
40 TSM: converse $(L)/libtsm.a
41
42 SM: converse $(L)/libsm.a
43
44 PVM: converse $(L)/libpvmc.a
45
46 AMR: charm++ LIBS
47         cd libs/ck-libs/amr; make all OPTS='$(OPTS)'
48
49 FEM: charm++ LIBS
50 FEMC: FEM
51 FEMF: FEM
52 ParFUM: FEM
53
54 MBLOCK: AMPI MBLOCKC MBLOCKF
55
56 MBLOCKC: charm++ LIBS
57
58 MBLOCKF: MBLOCKC
59
60 AMPI:  charm++ LIBS
61 AMPIC AMPIF: AMPI
62
63 ARMCI: charm++ LIBS
64
65
66 f90charm: charm++ $(L)/libf90charm.a
67
68 default_libs: multicast pythonCCS
69
70 ChaNGa: charm++ cache liveViz
71
72 cache: charm++
73         cd libs/ck-libs/cache && $(MAKE)
74
75 liveViz: charm++
76         cd libs/ck-libs/liveViz && $(MAKE)
77
78 multicast: charmxi
79         cd libs/ck-libs/multicast && $(MAKE)
80
81 pythonCCS: charmxi
82         cd libs/ck-libs/pythonCCS && $(MAKE)
83
84 translators: charmxi conv-cpm
85
86 pose:  charm++
87         cd libs/ck-libs/pose && $(MAKE)
88
89 msa: charm++
90         cd libs/ck-libs/multiphaseSharedArrays && $(MAKE)
91
92 jade: charm++ msa
93 #       make the lib, include
94         cd langs/jade && $(MAKE)
95
96 fftlib: charm++
97         cd libs/ck-libs/fftlib && $(MAKE)
98
99 # This should be done offline, since the user does not need to compile
100 # parser files, etc.  All they need is the libjade + include files,
101 # antlr.jar, jade.jar, and a few scripts which the jade target takes
102 # care of.
103 #jadeall: jade
104 #       make parser.g -> .java files
105 #       cd langs/jade && $(MAKE) p
106 #       make the jade.jar file
107 #       cd ../java/charm/jade && $(MAKE)
108
109 #include TAU defs
110 TAU_MAKEFILE=Make.tau
111 include $(TAU_MAKEFILE) #stub-makefile
112
113 #builds TAU's trace library
114 Tau: 
115         echo "buliding charm trace library with support for TAU."
116         $(MAKE) $(L)/libtrace-Tau.a $(L)/libtrace-all.a TAU_TRACE_OBJ=libtrace-Tau.o
117
118 LIBS: CONVLIBS CHARMLIBS
119         cd libs; $(MAKE) otherlibs
120         echo "Built LIBS Successfully"
121
122 bgtest: bigsim AMPI
123         cd ../tests ; $(MAKE) bgtest OPTS='$(OPTS)'
124         cd ../examples ; $(MAKE) bgtest OPTS='$(OPTS)'
125
126 test: bigsim AMPI
127         cd ../tests ; $(MAKE) test OPTS='$(OPTS)'
128         cd ../examples ; $(MAKE) test OPTS='$(OPTS)'
129
130 test-converse: converse
131         cd ../tests ; $(MAKE) test-converse  OPTS='$(OPTS)'
132
133 test-charm: charm++ METIS
134         cd ../tests ; $(MAKE) test-charm  OPTS='$(OPTS)'
135
136 test-AMPI: AMPI
137         cd ../tests ; $(MAKE) test-AMPI  OPTS='$(OPTS)'
138
139 test-fem: FEM
140         cd ../tests ; $(MAKE) test-fem  OPTS='$(OPTS)'
141
142 ps-doc: basics
143         cd ../doc ; make ps
144
145 pdf-doc: basics
146         cd ../doc ; make pdf
147
148 html-doc: basics
149         cd ../doc ; make html
150
151 doc: basics
152         cd ../doc ; make doc
153
154 CHARMC=../bin/charmc $(CHARMOPTS) $(OPTS)
155
156 SEQCHARMC=../bin/charmc -seq $(CHARMOPTS)
157
158 NATIVECHARMC=../bin/charmc -host $(CHARMOPTS)
159
160 CHARMXI=../bin/charmc -intrinsic $(OPTS)
161
162 DEPENDFILE = Make.depends
163
164 include $(DEPENDFILE)
165
166 CIFILES = $(wildcard *.ci)
167
168 %.di: %.ci ../bin/charmxi
169         @echo "Generating module dependencies from $<"
170         $(CHARMXI) -M $< > $@
171
172 %.ci.stamp: %.ci ../bin/charmxi
173         $(CHARMXI) $< && touch $@
174
175 include $(CIFILES:.ci=.di)
176
177 ###############################################################################
178 #
179 # The basics (bin, lib, include, headers, charmc, conv-mach.sh)
180 #
181 ###############################################################################
182
183 CVHEADERS=cpthreads.h converse.h conv-trace.h conv-random.h conv-qd.h \
184       queueing.h conv-cpath.h conv-cpm.h persistent.h\
185       trace.h trace-common.h trace-bluegene.h trace-projections.h  \
186       trace-simple.h trace-controlPoints.h charm-api.h \
187       conv-ccs.h ccs-client.c ccs-client.h \
188       ccs-server.h ccs-auth.c ccs-auth.h \
189       memory-isomalloc.h debug-conv.h debug-charm.h conv-autoconfig.h \
190       conv-common.h conv-config.sh conv-config.h conv-mach.h conv-mach.sh \
191       blue.h blue-conv.h bgconverse.h \
192         3dgridrouter.h hypercuberouter.h hypercubetopology.h    \
193         routerstrategy.h convcomlibstrategy.h  convcomlib.h dummyconversestrategy.h  treerouter.h \
194         convcomlibmanager.h graphrouter.h petable.h gridrouter.h router.h \
195         prefixrouter.h pipebroadcastconverse.h pipelinestrategy.h cmipool.h \
196       comlib.h cmidirect.h cmidirectmanytomany.h \
197       controlPoints.h controlPointsf.h arrayRedistributor.h cp_effects.h register.h stats.h
198
199 # The .c files are there to be #included by clients whole
200 # This is a bit unusual, but makes client linking simpler.
201 UTILHEADERS=pup.h pupf.h pup_c.h pup_stl.h pup_mpi.h pup_toNetwork.h pup_toNetwork4.h pup_paged.h pup_cmialloc.h\
202         ckimage.h ckdll.h ckhashtable.h ckbitvector.h cklists.h ckliststring.h \
203         ckstatistics.h ckvector3d.h conv-lists.h RTH.h ckcomplex.h \
204         sockRoutines.h sockRoutines.c ckpool.h BGLTorus.h BGPTorus.h \
205         TopoManager.h XT3Torus.h XT4Torus.h cmimemcpy.h simd.h SSE-Double.h SSE-Float.h crc32.h
206
207 CKHEADERS=ck.h ckstream.h envelope.h init.h qd.h charm.h charm++.h \
208           ckfutures.h ckIgetControl.h cktiming.h \
209           ckcallback.h CkCallback.decl.h ckcallback-ccs.h       \
210           ckarrayreductionmgr.h cknodegroupreduction.h cksection.h \
211           ckarray.h cklocation.h ckreduction.h ckcheckpoint.h ckmemcheckpoint.h ckevacuation.h\
212                 ckmessagelogging.h ckobjid.h\
213           ckobjQ.h readonly.h charisma.h ComlibArrayListener.h ComlibStrategy.h \
214           ComlibLearner.h $(UTILHEADERS) \
215           tempo.h waitqd.h LBDatabase.h lbdb.h lbdb++.h LBProfit.h $(LBHEADERS) \
216           LBDBManager.h LBComm.h LBOM.h LBObj.h LBMachineUtil.h LBAgent.h \
217           Refiner.h RefinerApprox.h RefinerComm.h ObjGraph.h ckheap.h \
218           elements.h CommLBHeap.h topology.h manager.h \
219           BaseLB.h CentralLB.h CentralLBMsg.h \
220           NborBaseLB.h HybridBaseLB.h HybridLBMsg.h \
221           NeighborLBMsg.h \
222           BlueGene.h middle.h middle-conv.h middle-blue.h \
223           CkMarshall.decl.h CkArray.decl.h CkLocation.decl.h    \
224           CkReduction.decl.h CkArrayReductionMgr.decl.h\
225           tempo.decl.h waitqd.decl.h \
226           CkFutures.decl.h CkCheckpoint.decl.h CkMemCheckpoint.decl.h \
227           LBDatabase.decl.h CentralLB.decl.h NullLB.decl.h \
228           BaseLB.decl.h \
229           NborBaseLB.decl.h \
230           HybridBaseLB.decl.h EveryLB.decl.h \
231           charisma.decl.h TraceSummary.decl.h TraceProjections.decl.h \
232           TraceSimple.decl.h TraceControlPoints.decl.h TraceTau.decl.h \
233           TraceUtilization.decl.h BlueGene.decl.h \
234           comlib.decl.h ComlibManager.h DummyStrategy.h \
235           MulticastStrategy.h DirectMulticastStrategy.h RingMulticastStrategy.h \
236           ChunkMulticastStrategy.h OneTimeMulticastStrategy.h MultiRingMulticast.h \
237           EachToManyMulticastStrategy.h MsgPacker.h StreamingStrategy.h \
238           NodeMulticast.h PipeBroadcastStrategy.h MeshStreamingStrategy.h \
239           PrioStreaming.h MPIStrategy.h MsgPacker.h StreamingStrategy.h \
240           BroadcastStrategy.h ComlibSectionInfo.h AAPLearner.h \
241           AAMLearner.h ComlibStats.h \
242           RectMulticastStrategy.h ckdirect.h \
243           ControlPoints.decl.h PathHistory.decl.h \
244           pathHistory.h envelope-path.h \
245           $(CVHEADERS)
246
247 ALLHEADERS=$(CKHEADERS) \
248     simplemsg.h sm.h pvmc.h pvm3.h sdag.h \
249         graph.h bitvecset.h ckset.h LBSimulation.h  \
250         $(BLUE_HEADERS)
251
252 basics: headers
253         touch basics
254
255 # Headers is used only for the dependencies
256 headers: dirs+sources
257         $(MAKE) charmxi
258         $(MAKE) headerlinks
259
260 conv-autoconfig.h: configure config_opts.sh
261         @. ./config_opts.sh; echo ./configure $(QUIET) $$CONFIG_OPTS;  \
262         ./configure $(QUIET) $$CONFIG_OPTS
263
264 headerlinks: dirs+sources Makefile $(ALLHEADERS)
265         @[ "x$QUIET" = "x--quiet" ] || echo "Soft-linking headers..."
266         -@for hdr in $(ALLHEADERS) ; do test ! -f "../include/$$hdr" && ./system_ln "../tmp/$$hdr" ../include ; done
267         touch headerlinks
268
269 dirs+sources:
270 #       rm -f .gdir
271 #       (cd .. ; basename "`pwd`" | sed -e 's@-.*@@')   > .gdir
272         pwd
273         find . -type l -exec rm {} \;
274         rm -rf QuickThreads
275         rm -rf libs
276         rm -rf ../bin ; mkdir ../bin
277         rm -rf ../lib ; mkdir ../lib
278         rm -rf ../lib_so ; mkdir ../lib_so; touch ../lib_so/.charmso
279         rm -rf ../examples
280         rm -rf ../tests
281         rm -rf ../doc ; ln -s ../doc ../doc
282         ../../src/scripts/gatherflat ../../src/scripts .
283         ./gatherflat ../../src/conv-core        .
284         ./gatherflat ../../src/conv-ldb         .
285         ./gatherflat ../../src/conv-ccs         .
286         ./gatherflat ../../src/conv-perf        .
287         ./gatherflat ../../src/ck-core          .
288         ./gatherflat ../../src/util             .
289         ./gatherflat ../../src/ck-perf          .
290         ./gatherflat ../../src/ck-ldb           .
291         ./gatherflat ../../src/ck-com           .
292         ./gatherflat ../../src/ck-cp           .
293         ./gatherflat ../../src/conv-com           .
294         ./gatherflat ../../src/langs/simplemsg  .
295         ./gatherflat ../../src/langs/pvmc       .
296         ./gatherflat ../../src/langs/bluegene   .
297         ./gatherflat ../../src/langs/f90charm   .
298         ./gatherflat ../../src/xlat-i           .
299         ./gatherflat ../../src/xlatcpm          .
300         ./gathertree ../../src/QuickThreads QuickThreads
301         ./gathertree ../../src/libs libs
302         ./gathertree ../../src/arch/util      .
303         ./gathertree ../../src/langs langs
304         ./gathertree ../../src/langs/jade langs/jade
305         ./gathertree ../../src/arch/common           .
306         ./gathertree ../../src/arch/`cat .gdir`      .
307         test -f ../../src/arch/`cat .gdir`/gdir_link && cat ../../src/arch/`cat .gdir`/gdir_link > .gdir.new && ./gathertree ../../src/arch/`cat .gdir.new`      . || true
308         ./gatherflat ../../src/arch/`cat .vdir`      .
309         ./gathertree ../../examples ../examples
310         ./gathertree ../../tests ../tests
311         rm -f ../bin/dep.pl ; cp dep.pl ../bin/
312         chmod +x charmc
313         -./system_ln  ../tmp/charmc ../bin/
314 #       -ln -s ../../java/bin charmjavabin
315 #       -ln -s ../../java/bin ../bin/charmjavabin
316 #       -ln -s charmjavabin/* ../bin/
317 #       -ln -s ../java ..
318 #       rm -f .gdir
319         rm -rf ../include ; mkdir ../include
320         -./system_ln  ../tmp/conv-*.*h ../include
321         -./system_ln  ../tmp/cc-*.*h ../include
322         if [ -x ./special.sh ] ; then ./special.sh ; fi
323         if [ ! -f conv-common.h ] ; then ( touch conv-common.h ) ; fi
324         touch dirs+sources
325
326 ###############################################################################
327 #
328 # Converse Libraries
329
330 ###############################################################################
331 CLBLIBS=$(L)/libldb-rand.o $(L)/libldb-spray.o   $(L)/libldb-workstealing.o  $(L)/libldb-neighbor.o $(L)/libldb-none.o $(L)/libldb-test.o $(L)/libldb-bluegene.o
332 TRACELIBS=$(L)/libtrace-projections.a  $(L)/libtrace-summary.a   $(L)/libtrace-utilization.a \
333           $(L)/libtrace-simple.a \
334           $(L)/libtrace-counter.a $(L)/libtrace-bluegene.a \
335           $(L)/libtrace-projector.a $(L)/libtrace-all.a $(L)/libtrace-converse.a \
336           $(L)/libtracef_f.a $(L)/libtrace-memory.a
337 MEMLIBS=$(L)/libmemory-default.o $(L)/libmemory-os.o $(L)/libmemory-gnu.o \
338           $(L)/libmemory-gnuold.o $(L)/libmemory-verbose.o      \
339           $(L)/libmemory-paranoid.o \
340           $(L)/libmemory-leak.o $(L)/libmemory-isomalloc.o \
341           $(L)/libmemory-charmdebug.o $(L)/libmemory-charmdebug-mmap.o \
342           $(L)/libmemory-charmdebug-slot.o $(L)/libmemory-charmdebug-mmap-slot.o \
343           $(L)/libmemory-os-verbose.o $(L)/libmemory-os-isomalloc.o \
344           $(L)/libmemory-os-leak.o $(L)/libmemory-os-paranoid.o \
345           $(L)/libmemory-os-lock.o \
346           $(L)/libmemory-os-charmdebug.o $(L)/libmemory-os-wrapper.o \
347           $(L)/libmemory-hooks-charmdebug.o
348 THREADLIBS=$(L)/libthreads-default.o $(L)/libthreads-qt.o       \
349           $(L)/libthreads-context.o $(L)/libthreads-uJcontext.o \
350           $(L)/libthreads-context-tls.o  $(L)/libthreads-qt-tls.o  \
351           $(L)/libthreads-pthreads.o $(L)/libthreads-fibers.o \
352           $(L)/libthreads-stackcopy.o $(L)/libthreads-memoryalias.o \
353           $(L)/libthreads-qt-memoryalias.o      \
354           $(L)/libthreads-context-memoryalias.o \
355           $(L)/libthreads-uJcontext-memoryalias.o
356
357 CVLIBS=$(L)/libconv-core.a \
358         $(L)/libconv-cplus-y.a $(L)/libconv-cplus-n.a \
359         $(L)/libconv-util.a $(L)/libconv-utilf.a \
360         $(CLBLIBS) $(TRACELIBS) $(MEMLIBS) $(THREADLIBS) \
361         $(L)/libccs-client.a
362
363 LIBCONV_CORE= convcore.o conv-conds.o queueing.o msgmgr.o \
364         cpm.o cpthreads.o futures.o cldb.o topology.o random.o \
365         debug-conv.o generate.o edgelist.o conv-ccs.o ccs-builtins.o middle-ccs.o \
366         traceCore.o traceCoreCommon.o \
367         converseProjections.o machineProjections.o \
368         quiescence.o isomalloc.o mem-arena.o conv-counter.o \
369         global-nop.o cmipool.o cpuaffinity.o cputopology.o  \
370         cmitls.o memoryaffinity.o
371
372 #############################################
373 #Comlib Core objects that go into libck.a
374 COMLIB_CORE_OBJS = ComlibModuleInterface.o 
375 ##############################################
376
377 LIBCONV_UTIL=pup_util.o pup_toNetwork.o pup_toNetwork4.o                \
378         pup_xlater.o pup_c.o pup_paged.o pup_cmialloc.o                 \
379         ckimage.o ckdll.o ckhashtable.o sockRoutines.o                  \
380         conv-lists.o RTH.o persist-comm.o \
381         ckbitvector.o TopoManager.o CrayNid.o crc32.o
382
383 LIBCONV_UTILF=pup_f.o
384
385 converse: fmain-ok charmrun-target swapglobal-target conv-cpm
386
387 charmrun-target: sockRoutines.c sockRoutines.h ccs-server.c ccs-server.h sockRoutines-seq.o $(L)/libck.a $(CVLIBS)
388         if [ -d charmrun ] ; then ( cd charmrun ; $(MAKE) OPTS='$(OPTS)' -j1 ) ; fi
389         if [ -f charmrun ] ; then ( cp -f charmrun ../bin ) ; fi
390
391 fmain-ok: fmain.f90
392         -@$(CHARMC) -c fmain.f90
393         -@cp fmain.o ../lib
394         -@touch fmain-ok
395
396 QUICK_THREADS: $(CVHEADERS)
397         -( cd QuickThreads && $(MAKE) clean )
398         ( cd QuickThreads;./configure )
399         ( cd QuickThreads ; $(MAKE) qt  OPTS='$(OPTS)' ) || ( echo "Did you try to build net-linux on a 64-bit system? Try net-linux-x86_64" && false )
400         cp -f QuickThreads/libqt.a ../lib/libckqt.a
401         -(CHARMINC=.; . ./conv-config.sh; \
402           test -d ../lib_so && \
403           cp -f QuickThreads/libqt.$$CMK_SHARED_SUF ../lib_so && \
404           cp -f QuickThreads/libqt.$$CMK_SHARED_SUF ../lib_so/libckqt.$$CMK_SHARED_SUF)
405         touch QUICK_THREADS
406
407 METIS:  charm++
408         cd libs/ck-libs/parmetis/METISLib && $(MAKE) OPTS='$(OPTS)'
409
410 CONVLIBS: converse
411         cd libs; $(MAKE) convlibs OPTS='$(OPTS)'
412
413 $(L)/libconv-core.a: $(LIBCONV_CORE)
414         $(CHARMC) $(TAU_LIBS) -o $@ $(LIBCONV_CORE) 
415
416 $(L)/libconv-cplus-y.a: $(L)/libconv-cplus-n.a
417
418 include Makefile.machine
419
420 $(L)/libconv-cplus-n.a: machine.c $(CVHEADERS)
421         @-test -f $(INC)/mpi.h && mv -f $(INC)/mpi.h $(INC)/mpi.BAK || true
422         $(CHARMC) -o machine.o  -DFOR_CPLUS=1 machine.c
423         @-test -f ./bglmachine.C && $(CHARMC) -o machine.o  -DFOR_CPLUS=1 bglmachine.C || true
424         $(CHARMC) -o $(L)/libconv-cplus-y.a machine.o
425         $(CHARMC) -o $(L)/libconv-cplus-n.a -DFOR_CPLUS=0 machine.c
426         @-test -f $(INC)/mpi.BAK && mv -f $(INC)/mpi.BAK $(INC)/mpi.h || true
427
428 $(L)/libconv-util.a: $(LIBCONV_UTIL)
429         $(CHARMC) -o $@ $(LIBCONV_UTIL)
430
431 $(L)/libconv-utilf.a: $(LIBCONV_UTILF)
432         -$(CHARMC) -o $@ $(LIBCONV_UTILF) || touch $@
433
434 $(L)/libccs-client.a: ccs-client.o
435         $(CHARMC) -o $@ ccs-client.o
436
437 ccs-client.o: ccs-client.c $(CVHEADERS)
438         $(CHARMC) ccs-client.c
439
440 sockRoutines.o: sockRoutines.c $(CVHEADERS) $(UTILHEADERS)
441         $(CHARMC) -DCMK_USE_CONVERSE=1 sockRoutines.c
442
443 sockRoutines-seq.o: sockRoutines.c $(CVHEADERS) $(UTILHEADERS)
444         $(SEQCHARMC) -o sockRoutines-seq.o sockRoutines.c
445
446 pup_util.o: pup_util.C $(CVHEADERS) $(UTILHEADERS)
447         $(CHARMC) -o pup_util.o pup_util.C
448
449 pup_toNetwork.o: pup_toNetwork.C $(CVHEADERS) $(UTILHEADERS)
450         $(CHARMC) -I. -o pup_toNetwork.o pup_toNetwork.C
451
452 pup_toNetwork4.o: pup_toNetwork4.C $(CVHEADERS) $(UTILHEADERS)
453         $(CHARMC) -I. -o pup_toNetwork4.o pup_toNetwork4.C
454
455 pup_xlater.o: pup_xlater.C $(CVHEADERS) $(UTILHEADERS)
456         $(CHARMC) -I. -o pup_xlater.o pup_xlater.C
457
458 pup_c.o: pup_c.C $(CVHEADERS) $(UTILHEADERS)
459         $(CHARMC) -o pup_c.o pup_c.C
460
461 pup_paged.o: pup_paged.C $(CVHEADERS) $(UTILHEADERS)
462         $(CHARMC) -o pup_paged.o pup_paged.C
463
464 pup_f.f90: pup_f.f90.sh
465         ./pup_f.f90.sh
466
467 pup_f.o: pup_f.f90 $(CVHEADERS)
468         -$(CHARMC) -c pup_f.f90 && $(CHARMC) -cpmod ../include pupmod.M || touch pup_f.o
469
470 pup_cmialloc.o: pup_cmialloc.C $(CVHEADERS) $(UTILHEADERS)
471         $(CHARMC) -o pup_cmialloc.o pup_cmialloc.C
472
473 ckhashtable.o: ckhashtable.C ckhashtable.h $(CVHEADERS)
474         $(CHARMC) -o ckhashtable.o ckhashtable.C
475
476 TopoManager.o: TopoManager.C TopoManager.h BGLTorus.h BGPTorus.h XT3Torus.h XT4Torus.h CrayNid.c $(CVHEADERS) $(UTILHEADERS)
477         $(CHARMC) -o TopoManager.o TopoManager.C
478
479 CrayNid.o: CrayNid.c $(CVHEADERS) $(UTILHEADERS)
480         $(CHARMC) -c -o CrayNid.o CrayNid.c
481
482 ckbitvector.o: ckbitvector.C ckbitvector.h $(CVHEADERS)
483         $(CHARMC) -I. -o ckbitvector.o ckbitvector.C
484
485 ckdll.o: ckdll.C ckdll.h $(CVHEADERS)
486         $(CHARMC) -o ckdll.o ckdll.C
487
488 ckimage.o: ckimage.C ckimage.h $(CVHEADERS)
489         $(CHARMC) -o ckimage.o ckimage.C
490
491 RTH.o: RTH.C RTH.h $(CVHEADERS)
492         $(CHARMC) -o RTH.o RTH.C
493
494 persist-comm.o: persist-comm.c persist_impl.h $(CVHEADERS)
495         $(CHARMC) -o persist-comm.o persist-comm.c
496
497 conv-lists.o: conv-lists.C $(UTILHEADERS) $(CVHEADERS)
498         $(CHARMC) -o conv-lists.o conv-lists.C
499         
500 crc32.o: crc32.c crc32.h
501         $(CHARMC) -optimize -o crc32.o crc32.c
502
503 ## Converse load balancers (seed balancers, -balance)
504 $(L)/libldb-none.o: cldb.none.c $(CVHEADERS)
505         $(CHARMC) -o $@ cldb.none.c
506
507 $(L)/libldb-rand.o: cldb.rand.c cldb.h $(CVHEADERS)
508         $(CHARMC) -o $@ cldb.rand.c
509
510 $(L)/libldb-neighbor.o: cldb.neighbor.c cldb.neighbor.h graph.h $(CVHEADERS)
511         $(CHARMC) -o $@ cldb.neighbor.c
512
513 $(L)/libldb-workstealing.o: cldb.workstealing.c cldb.workstealing.h graph.h $(CVHEADERS)
514         $(CHARMC) -o $@ cldb.workstealing.c
515
516 $(L)/libldb-spray.o: cldb.spray.c $(CVHEADERS)
517         $(CHARMC) -o $@ cldb.spray.c
518
519
520 #$(L)/libldb-prioritycentralized.o: cldb.prioritycentralized.c cldb.prioritycentralized.h  $(CVHEADERS)
521 #       $(CHARMC) -o $@ cldb.prioritycentralized.c 
522
523 #//$(L)/libldb-prioritycentralizedopt.o: cldb.prioritycentralizedopt.c cldb.prioritycentralizedopt.h  $(CVHEADERS)
524 #//     $(CHARMC) -o $@ cldb.prioritycentralizedopt.c 
525
526 $(L)/libldb-test.o: cldb.test.c $(CVHEADERS)
527         $(CHARMC) -o $@ cldb.test.c
528
529 $(L)/libldb-bluegene.o: cldb.bluegene.c $(CVHEADERS)
530         $(CHARMC) -o $@ cldb.bluegene.c
531
532 ## Memory allocation libraries (-memory)
533 MEM_DEPS=memory.c memory-gnu.c memory-gnuold.c converse.h conv-mach.h $(CVHEADERS)
534 $(L)/libmemory-default.o: $(MEM_DEPS)
535         $(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_DEFAULT memory.c
536
537 $(L)/libmemory-os.o: $(MEM_DEPS)
538         $(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_OS memory.c
539
540 $(L)/libmemory-os-verbose.o: memory-verbose.c $(MEM_DEPS)
541         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_VERBOSE memory.c || touch $@
542
543 $(L)/libmemory-os-paranoid.o: memory-paranoid.c $(MEM_DEPS)
544         -$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_PARANOID memory.c || touch $@
545
546 $(L)/libmemory-os-leak.o: $(MEM_DEPS)
547         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_LEAK memory.c || touch $@
548
549 $(L)/libmemory-os-isomalloc.o: memory-isomalloc.c $(MEM_DEPS)
550         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_ISOMALLOC memory.c || touch $@
551
552 $(L)/libmemory-os-lock.o: memory-lock.c $(MEM_DEPS)
553         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_LOCK memory.c || touch $@
554
555 $(L)/libmemory-os-charmdebug.o: memory-charmdebug.c $(MEM_DEPS)
556         -$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_OS_WRAPPED -DCMK_MEMORY_BUILD_CHARMDEBUG memory.c || touch $@
557
558 $(L)/libmemory-os-wrapper.o: memory-os-wrapper.C $(MEM_DEPS)
559         -$(CHARMC) -o $@ memory-os-wrapper.C || touch $@
560
561 $(L)/libmemory-hooks-charmdebug.o: memory-charmdebug.c $(MEM_DEPS)
562         -$(CHARMC) -o $@ -DCMK_MEMORY_BUILD_GNU_HOOKS -DCMK_MEMORY_BUILD_CHARMDEBUG memory.c || touch $@
563
564 # If the system doesn't have sbrk, these compilations may fail.
565 #  This is OK, but then we can't use "-memory gnu" or friends.
566 $(L)/libmemory-gnu.o: $(MEM_DEPS)
567         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_GNU memory.c || touch $@
568
569 $(L)/libmemory-gnuold.o: $(MEM_DEPS)
570         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_GNUOLD memory.c || touch $@
571
572 $(L)/libmemory-verbose.o: memory-verbose.c $(MEM_DEPS)
573         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_VERBOSE memory.c || touch $@
574
575 $(L)/libmemory-paranoid.o: memory-paranoid.c $(MEM_DEPS)
576         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_PARANOID memory.c || touch $@
577
578 $(L)/libmemory-leak.o: memory-leak.c $(MEM_DEPS)
579         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_LEAK memory.c || touch $@
580
581 $(L)/libmemory-cache.o: memory-cache.c $(MEM_DEPS)
582         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_CACHE memory.c || touch $@
583
584 $(L)/libmemory-isomalloc.o: memory-isomalloc.c $(MEM_DEPS)
585         -$(CHARMC) -I. -o $@ -DCMK_MEMORY_BUILD_ISOMALLOC memory.c || touch $@
586
587 $(L)/libmemory-charmdebug.o: memory-charmdebug.c $(MEM_DEPS)
588         -$(CHARMC) -I. -optimize -o $@ -DCMK_MEMORY_BUILD_CHARMDEBUG memory.c || touch $@
589
590 $(L)/libmemory-charmdebug-slot.o: memory-charmdebug.c $(MEM_DEPS)
591         -$(CHARMC) -I. -optimize -o $@ -DCMK_MEMORY_BUILD_CHARMDEBUG -DCMK_SEPARATE_SLOT memory.c || touch $@
592
593 $(L)/libmemory-charmdebug-mmap.o: memory-charmdebug.c $(MEM_DEPS)
594         -$(CHARMC) -I. -optimize -o $@ -DCMK_MEMORY_BUILD_CHARMDEBUG -DCPD_USE_MMAP memory.c || touch $@
595
596 $(L)/libmemory-charmdebug-mmap-slot.o: memory-charmdebug.c $(MEM_DEPS)
597         -$(CHARMC) -I. -optimize -o $@ -DCMK_MEMORY_BUILD_CHARMDEBUG -DCPD_USE_MMAP -DCMK_SEPARATE_SLOT memory.c || touch $@
598
599 ## Thread libraries (-thread)
600
601 LIBTHREADSDEPS = threads.c $(CVHEADERS) QUICK_THREADS
602
603 $(L)/libthreads-default.o: $(LIBTHREADSDEPS)
604         $(CHARMC) -o $@ -DCMK_THREADS_BUILD_DEFAULT=1 -IQuickThreads -I. threads.c
605
606 $(L)/libthreads-qt.o: $(LIBTHREADSDEPS) 
607         $(CHARMC) -o $@ -DCMK_THREADS_BUILD_QT=1 -IQuickThreads threads.c
608
609 $(L)/libthreads-qt-tls.o: $(LIBTHREADSDEPS) 
610         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_QT=1 -DCMK_THREADS_BUILD_TLS=1 -IQuickThreads threads.c 2> /dev/null || touch $@
611
612 $(L)/libthreads-context.o: $(LIBTHREADSDEPS) 
613         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_CONTEXT=1 -IQuickThreads threads.c || touch $@
614
615 $(L)/libthreads-context-tls.o: $(LIBTHREADSDEPS) 
616         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_CONTEXT=1 -DCMK_THREADS_BUILD_TLS=1 -IQuickThreads threads.c 2> /dev/null || touch $@
617
618 $(L)/libthreads-uJcontext.o: $(LIBTHREADSDEPS) uJcontext.c
619         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_JCONTEXT=1 -IQuickThreads -I. threads.c || touch $@
620
621 $(L)/libthreads-pthreads.o: $(LIBTHREADSDEPS) 
622         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_PTHREADS=1 -IQuickThreads threads.c || touch $@
623
624 $(L)/libthreads-fibers.o: $(LIBTHREADSDEPS)
625         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_FIBERS=1 -IQuickThreads threads.c 2> /dev/null || touch $@
626
627 $(L)/libthreads-stackcopy.o: $(LIBTHREADSDEPS) 
628         -$(CHARMC) -o $@ -DCMK_THREADS_BUILD_STACKCOPY=1 -IQuickThreads threads.c || touch $@
629
630 $(L)/libthreads-memoryalias.o: $(LIBTHREADSDEPS) 
631         -$(CHARMC) -o $@ -DCMK_THREADS_ALIAS_STACK=1 -DCMK_THREADS_BUILD_DEFAULT=1 -IQuickThreads threads.c || touch $@
632
633 $(L)/libthreads-qt-memoryalias.o: $(LIBTHREADSDEPS) 
634         -$(CHARMC) -o $@ -DCMK_THREADS_ALIAS_STACK=1 -DCMK_THREADS_BUILD_QT=1 -IQuickThreads threads.c || touch $@
635
636 $(L)/libthreads-context-memoryalias.o: $(LIBTHREADSDEPS) 
637         -$(CHARMC) -o $@ -DCMK_THREADS_ALIAS_STACK=1 -DCMK_THREADS_BUILD_CONTEXT=1 -IQuickThreads threads.c || touch $@
638
639 $(L)/libthreads-uJcontext-memoryalias.o: $(LIBTHREADSDEPS) 
640         -$(CHARMC) -o $@ -DCMK_THREADS_ALIAS_STACK=1 -DCMK_THREADS_BUILD_JCONTEXT=1 -IQuickThreads -I. threads.c || touch $@
641
642 ## Global swapping (-swapglobal)
643 swapglobal-target: $(L)/libglobal-swap.o $(L)/libglobal-copy.o $(L)/loadsym.o
644
645 $(L)/libglobal-swap.o: global-elfgot.C $(CVHEADERS)
646         -$(CHARMC) -c global-elfgot.C -o $@ || touch $@
647
648 $(L)/libglobal-copy.o: global-elfcopy.C  $(CVHEADERS)
649         -$(CHARMC) -c global-elfcopy.C -o $@ || touch $@
650
651 $(L)/loadsym.o: loadsym.c  $(CVHEADERS)
652         -$(CHARMC) -c loadsym.c -o $@ || touch $@
653
654 ###############################################################################
655 #
656 # Charm Libraries
657 #
658 ###############################################################################
659
660 CK_LIBS_CORE=$(L)/libck.a
661
662 LIBCK_CORE=trace-common.o tracec.o tracef.o init.o register.o qd.o ck.o main.o  \
663            msgalloc.o ckfutures.o ckIgetControl.o debug-message.o debug-charm.o ckcallback.o \
664            cklocation.o ckarray.o ckreduction.o ckarrayreductionmgr.o\
665            tempo.o waitqd.o LBDatabase.o lbdb.o lbdbf.o charisma.o ckobjQ.o  \
666            LBAgent.o LBProfit.o ckcheckpoint.o ckmemcheckpoint.o ckevacuation.o ckmessagelogging.o\
667            LBDBManager.o LBComm.o LBObj.o LBMachineUtil.o CentralPredictor.o \
668            BaseLB.o CentralLB.o HybridBaseLB.o NborBaseLB.o WSLB.o \
669            ObjGraph.o graph.o LButil.o Refiner.o RefinerApprox.o  \
670            RefinerComm.o bitvecset.o ckset.o ckheap.o CommLBHeap.o \
671            NullLB.o LBSimulation.o $(COMLIB_CORE_OBJS) modifyScheduler.o \
672            charmProjections.o cktiming.o pathHistory.o controlPoints.o arrayRedistributor.o cp_effects.o trace-controlPoints.o
673
674 charm-target: converse $(L)/libck.a $(L)/libckf.a loadbalancers default_libs comlib_objs 
675
676 CHARMLIBS: charm++ CONVLIBS
677         cd libs; $(MAKE) charmlibs OPTS='$(OPTS)'
678
679 $(L)/libck.a: $(LIBCK_CORE)
680         $(CHARMC) -o $@ $(LIBCK_CORE)
681
682 ## Charm fortran AMPI
683
684 CK_FOR_LIBS_CORE=$(L)/libckf.a
685
686 LIBCKF_CORE=charmf.o charmmod.o
687
688 $(L)/libckf.a: $(LIBCKF_CORE)
689         -$(CHARMC) -o $@ $(LIBCKF_CORE) || touch $@
690
691 charmf.o:  charmf.C $(CKHEADERS) charmf.h
692         $(CHARMC) -c -I. charmf.C
693
694 charmmod.o: charmmod.f90
695         -$(CHARMC) -c charmmod.f90 || touch $@
696         -$(CHARMC) -cpmod ../include charm.M
697
698 ## Tracing libraries (profiling, -tracemode)
699 LIBTRACE_PROJ=trace-projections.o
700 $(L)/libtrace-projections.a: $(LIBTRACE_PROJ)
701         $(CHARMC) -o $@ $(LIBTRACE_PROJ)
702
703 LIBTRACE_SUMM=trace-summary.o
704 $(L)/libtrace-summary.a: $(LIBTRACE_SUMM)
705         $(CHARMC) -o $@ $(LIBTRACE_SUMM)
706  
707 LIBTRACE_UTIL=trace-utilization.o
708 $(L)/libtrace-utilization.a: $(LIBTRACE_UTIL)
709         $(CHARMC) -o $@ $(LIBTRACE_UTIL)
710
711 LIBTRACE_SIMPLE=trace-simple.o
712 $(L)/libtrace-simple.a: $(LIBTRACE_SIMPLE)
713         $(CHARMC) -o $@ $(LIBTRACE_SIMPLE)
714
715 libtrace-Tau.o: trace-Tau.C charm++.h charm.h converse.h conv-config.h \
716   conv-autoconfig.h conv-common.h conv-mach.h conv-mach-opt.h \
717   conv-mach-ifort.h pup_c.h conv-cpm.h conv-cpath.h conv-qd.h \
718   conv-random.h conv-lists.h conv-trace.h persistent.h debug-conv.h pup.h \
719   middle.h middle-conv.h cklists.h ckbitvector.h ckstream.h init.h \
720   ckhashtable.h debug-charm.h CkMarshall.decl.h cksection.h ckcallback.h \
721   conv-ccs.h sockRoutines.h ccs-server.h ckobjQ.h ckreduction.h \
722   CkReduction.decl.h cknodegroupreduction.h CkArrayReductionMgr.decl.h \
723   ckmemcheckpoint.h CkMemCheckpoint.decl.h readonly.h ckarray.h \
724   cklocation.h LBDatabase.h lbdb.h LBDBManager.h LBObj.h LBOM.h LBComm.h \
725   LBMachineUtil.h lbdb++.h LBDatabase.decl.h NullLB.decl.h BaseLB.decl.h \
726   CkLocation.decl.h CkArray.decl.h ComlibArrayListener.h ComlibStrategy.h \
727   convcomlibstrategy.h ComlibLearner.h envelope.h envelope-path.h CkFutures.decl.h \
728   charisma.h charisma.decl.h tempo.h tempo.decl.h waitqd.h waitqd.decl.h \
729   sdag.h ckcheckpoint.h CkCheckpoint.decl.h ckevacuation.h \
730   ckarrayreductionmgr.h trace.h trace-bluegene.h trace-simple.h \
731   register.h trace-common.h trace-simpleBOC.h TraceSimple.decl.h \
732   TraceSimple.def.h
733         $(CHARMC) -c -I. $(TAU_INCLUDE) $(TAU_DEFS) trace-Tau.C -o libtrace-Tau.o
734
735 tau_selective.o: $(TAUROOT)/utils/tau_selective.cpp 
736         $(CHARMC) -I$(TAUROOT)/utils -DTAU_DYNINST $(TAUROOT)/utils/tau_selective.cpp
737
738 $(L)/libtrace-Tau.a: $(TAU_TRACE_OBJ) tau_selective.o
739         $(CHARMC) $(TAU_LIBS) -o $@ $(TAU_TRACE_OBJ) tau_selective.o $(TAU_TRACE_OBJ)
740
741 LIBTRACE_COUNT=trace-counter.o
742 $(L)/libtrace-counter.a: $(LIBTRACE_COUNT)
743         $(CHARMC) -o $@ $(LIBTRACE_COUNT)
744
745 LIBTRACE_BG=trace-bluegene.o
746 $(L)/libtrace-bluegene.a:$(LIBTRACE_BG)
747         $(CHARMC) -o $@ $(LIBTRACE_BG)
748
749 LIBTRACE_MEMORY=trace-memory.o
750 $(L)/libtrace-memory.a: $(LIBTRACE_MEMORY)
751         $(CHARMC) -o $@ $(LIBTRACE_MEMORY)
752
753 LIBTRACE_ALL=trace-all.o trace-projections.o trace-summary.o trace-simple.o \
754 $(TAU_TRACE_OBJ) trace-projector.o traceCore.o traceCoreCommon.o charmProjections.o converseProjections.o machineProjections.o trace-memory.o trace-utilization.o
755
756 $(L)/libtrace-all.a: $(LIBTRACE_ALL)
757         $(CHARMC) -o $@ $(LIBTRACE_ALL)
758
759 LIBTRACE_PROJECTOR=trace-projector.o traceCore.o traceCoreCommon.o charmProjections.o converseProjections.o machineProjections.o
760 $(L)/libtrace-projector.a: $(LIBTRACE_PROJECTOR)
761         $(CHARMC) -o  $@ $(LIBTRACE_PROJECTOR)
762
763 LIBTRACE_CONVERSE=trace-converse.o
764 $(L)/libtrace-converse.a: $(LIBTRACE_CONVERSE)
765         $(CHARMC) -o  $@ $(LIBTRACE_CONVERSE)
766
767 LIBTRACE_FOR=tracef_f.o
768 $(L)/libtracef_f.a: $(LIBTRACE_FOR)
769         -$(CHARMC) -o $@ $(LIBTRACE_FOR) || touch $@
770
771 tracef_f.o: tracef_f.f90
772         -$(CHARMC) -o $@ -c tracef_f.f90 && $(CHARMC) -cpmod ../include tracemod.M  || touch $@
773
774 # used for make depends
775 TRACE_OBJS =  trace-projections.o  trace-summary.o  trace-simple.o \
776               trace-counter.o trace-utilization.o       \
777               trace-bluegene.o trace-projector.o trace-converse.o trace-all.o \
778           trace-memory.o
779
780
781 ###############################################################################
782 #
783 # Dynamic Load Balancers
784 #
785 ###############################################################################
786
787
788 # Automatically generated by script Makefile_lb.sh
789 include Make.lb
790
791 loadbalancers: $(LOADBALANCERS) $(L)/libmoduleEveryLB.a
792 ######################################################################
793 #
794 #Communication Optimization Library
795 #
796 ######################################################################
797
798 STRATEGY_OBJS = MPIStrategy.o StreamingStrategy.o \
799                 DummyStrategy.o NodeMulticast.o ChunkMulticastStrategy.o OneTimeMulticastStrategy.o \
800                 EachToManyMulticastStrategy.o ComlibSectionInfo.o \
801                 AAPLearner.o ComlibStats.o AAMLearner.o \
802                 MsgPacker.o MulticastStrategy.o DirectMulticastStrategy.o \
803                 RingMulticastStrategy.o MultiRingMulticast.o\
804                 PipeBroadcastStrategy.o MeshStreamingStrategy.o \
805                 PrioStreaming.o BroadcastStrategy.o RectMulticastStrategy.o \
806                 convcomlibstrategy.o ComlibManager.o ComlibStrategy.o 
807
808 CONVERSE_COM_OBJS = gridrouter.o hypercuberouter.o treerouter.o petable.o \
809                 3dgridrouter.o graphrouter.o hypercubetopology.o \
810                 routerstrategy.o convcomlibmanager.o pipebroadcastconverse.o \
811                 pipelinestrategy.o prefixrouter.o
812
813 COMLIB_OBJS = $(STRATEGY_OBJS) $(CONVERSE_COM_OBJS)
814
815 comlib_objs: $(L)/libmodulecomlib.a $(L)/libconvcom.a
816
817 $(L)/libconvcom.a: $(COMLIB_OBJS)
818         $(CHARMC) -o $(L)/libconvcom.a $(CONVERSE_COM_OBJS)
819
820 #for backward compatibility, keep libmodulecommlib.a with double m.
821 $(L)/libmodulecomlib.a: $(COMLIB_OBJS)
822         $(CHARMC) -o $(L)/libmodulecomlib.a $(COMLIB_OBJS)
823         cp -f $(L)/libmodulecomlib.a $(L)/libmodulecommlib.a
824
825
826 ###############################################################################
827 #
828 # BlueGene Emulator
829 #
830 ###############################################################################
831
832 bigsim:  bigsim-target
833
834 bigemulator: bigsim
835
836 bigsim-target: charm++ $(L)/libconv-bigsim.a $(L)/libconv-bigsim-logs.a $(L)/libconv-bluegene-stub.a $(L)/libblue-standalone.a METIS
837
838 $(L)/libbluegene.a: BlueGene.C BlueGene.h BlueGene.decl.h BlueGene.def.h
839         $(CHARMC) -c BlueGene.C
840         $(CHARMC) -o $@ BlueGene.o
841
842 # (Converse) Blue Gene emulator
843 BLUE_HEADERS = blue_types.h bigsim_timing.h blue_defs.h bigsim_logs.h blue.h blue_impl.h bigsim_network.h bigsim_record.h bigsim_ooc.h bigsim_debug.h shared-alloc.h
844 BLUE_OBJS = blue.o bigsim_node.o bigsim_proc.o bigsim_init.o bigsim_timing.o bigsim_record.o bigsim_ooc.o shared_alloc.o
845 BIGSIM_IO_OBJS = bigsim_read.o bigsim_logs.o bigsim_api.o
846
847 LIBBLUE_OBJS = $(BLUE_OBJS) $(BIGSIM_IO_OBJS) blue_stub.o blue_standalone.o
848
849 $(L)/libconv-bigsim.a: $(BLUE_OBJS)
850         $(CHARMC) -o $@  $(BLUE_OBJS)
851
852 $(L)/libconv-bigsim-logs.a: $(BIGSIM_IO_OBJS)
853         $(CHARMC) -o $@  $(BIGSIM_IO_OBJS)
854
855 $(L)/libconv-bluegene-stub.a:  blue_stub.o
856         $(CHARMC) -o $@  blue_stub.o
857
858 $(L)/libblue-standalone.a: blue_standalone.o
859         $(CHARMC) -o $@  blue_standalone.o
860
861 ###############################################################################
862 #
863 # The CPM scanner
864 #
865 ###############################################################################
866
867 conv-cpm: conv-cpm.o
868         $(NATIVECHARMC) -language c -o conv-cpm -cp ../bin/ conv-cpm.o
869
870 conv-cpm.o: conv-cpm.c $(CVHEADERS)
871         $(NATIVECHARMC) conv-cpm.c
872
873 ###############################################################################
874 #
875 # The interface translator
876 #
877 ###############################################################################
878
879 XIHEADERS=conv-autoconfig.h xi-symbol.h xi-util.h xi-grammar.tab.h
880 CHARMXIOBJ=xi-main.o xi-symbol.o xi-grammar.tab.o xi-scan.o xi-util.o
881 SDAGOBJ=sdag-globals.o CSdagConstruct.o CEntry.o
882 SDAGHEADERS= CToken.h EToken.h CParsedFile.h \
883         sdag-globals.h CEntry.h
884
885 charmxi: ../bin/charmxi
886
887 ../bin/charmxi: $(CHARMXIOBJ) $(SDAGOBJ)
888         $(NATIVECHARMC) -language c++ -cp ../bin/ -o charmxi $(CHARMXIOBJ) $(SDAGOBJ)
889
890 xi-main.o: xi-main.C $(XIHEADERS) $(SDAGHEADERS)
891         $(NATIVECHARMC) xi-main.C
892
893 xi-symbol.o: xi-symbol.C $(XIHEADERS) $(SDAGHEADERS)
894         $(NATIVECHARMC) xi-symbol.C
895
896 xi-util.o: xi-util.C $(XIHEADERS) $(SDAGHEADERS)
897         $(NATIVECHARMC) xi-util.C
898
899 xi-grammar.tab.o: xi-grammar.tab.C $(XIHEADERS) $(SDAGHEADERS)
900         $(NATIVECHARMC) xi-grammar.tab.C
901
902 xi-scan.o: xi-scan.C $(XIHEADERS) $(SDAGHEADERS)
903         $(NATIVECHARMC) -I. -DYY_NEVER_INTERACTIVE xi-scan.C
904
905 sdag-globals.o: sdag-globals.C $(XIHEADERS) $(SDAGHEADERS)
906         $(NATIVECHARMC) -c sdag-globals.C
907
908 CSdagConstruct.o: CSdagConstruct.C $(XIHEADERS) $(SDAGHEADERS)
909         $(NATIVECHARMC) -c CSdagConstruct.C
910
911 CEntry.o: CEntry.C $(XIHEADERS) $(SDAGHEADERS)
912         $(NATIVECHARMC) -c CEntry.C
913
914 ###############################################################################
915 #
916 # Simple Messaging
917 #
918 ###############################################################################
919
920 $(L)/libtsm.a: converse simplemsg.c simplemsg.h
921         $(CHARMC) -o $@ simplemsg.c
922
923 $(L)/libsm.a: converse sm.c sm.h
924         $(CHARMC) -o $@ sm.c
925
926 ###############################################################################
927 #
928 # PVM
929 #
930 ###############################################################################
931
932 PVMC=pvmc_buf.o pvmc_comm.o pvmc_conv.o pvmc_main.o pvmc_pack.o pvmc_groups.o
933
934 $(L)/libpvmc.a: $(PVMC)
935         $(CHARMC) -o $@ $(PVMC)
936
937 pvmc_buf.o: pvmc_buf.c pvmc.h pvm3.h converse.h
938         $(CHARMC) -o $@ pvmc_buf.c
939
940 pvmc_conv.o: pvmc_conv.c pvmc.h pvm3.h converse.h
941         $(CHARMC) -o $@ pvmc_conv.c
942
943 pvmc_pack.o: pvmc_pack.c pvmc.h pvm3.h converse.h
944         $(CHARMC) -o $@ pvmc_pack.c
945
946 pvmc_comm.o: pvmc_comm.c pvmc.h pvm3.h converse.h
947         $(CHARMC) -o $@ pvmc_comm.c
948
949 pvmc_groups.o: pvmc_groups.c pvmc.h pvm3.h converse.h
950         $(CHARMC) -o $@ pvmc_groups.c
951
952 pvmc_main.o: pvmc_main.c pvmc.h pvm3.h converse.h
953         $(CHARMC) -o $@ pvmc_main.c
954
955 $(L)/libf90charm.a: charmxi f90main.ci f90main.h f90main.C futil.f90
956         $(CHARMC) f90main.ci
957         $(CHARMC) -c -DAMPI_FORTRAN=1 f90main.C
958         -$(CHARMC) -c futil.f90
959         -$(CHARMC) -o $@ f90main.o futil.o
960
961 ###############################################################################
962 #
963 # Make clean
964 #
965 ###############################################################################
966
967 install:
968         @test ! -d $(DESTDIR)/include && mkdir -p $(DESTDIR)/include || true
969         @test ! -d $(DESTDIR)/lib && mkdir -p $(DESTDIR)/lib || true
970         @test ! -d $(DESTDIR)/lib_so && mkdir -p $(DESTDIR)/lib_so || true
971         @test ! -d $(DESTDIR)/bin && mkdir -p $(DESTDIR)/bin || true
972         cp -f ../include/*   $(DESTDIR)/include
973         cp -f ../lib/*       $(DESTDIR)/lib
974         cp -f ../lib_so/*    $(DESTDIR)/lib_so
975 #       cp -f ../bin/*       $(DESTDIR)/bin
976         for f in ../bin/*; do if test -f $$f; then cp -f $$f $(DESTDIR)/bin; fi; done
977
978
979 clean:
980         rm -f conv-autoconfig.h config.cache
981         rm -f QuickThreads/libqt.a
982         rm -f charmxi conv-cpm
983         rm -f TAGS basics cmk_extras core
984         rm -f core *.a
985         rm -f core *.o
986         rm -f core #*#
987         rm -f core *~
988         rm -f *.stamp
989         if [ -d charmrun ] ; then ( cd charmrun; make clean ) ; fi
990         -( cd doc && $(MAKE) clean )
991         ( cd libs; $(MAKE) clean )
992         ( cd ../examples && $(MAKE) clean )
993         ( cd ../tests && $(MAKE) clean )
994
995 veryclean:
996         rm -rf ../bin
997         rm -rf ../lib
998         rm -rf ../src
999         rm -rf ../examples
1000         rm -rf ../tests
1001         rm -rf ../include
1002         rm -rf ../doc
1003         mv Makefile .Makefile
1004         mv Make.depends .Make.depends
1005         rm -rf [a-z]* [A-Z]*
1006         mv .Make.depends Make.depends
1007         rm -rf .[a-z]* .[A-Z]*
1008
1009
1010 config: configure.in
1011         autoconf && autoheader
1012
1013 depends: basics $(CIFILES:.ci=.ci.stamp)
1014         echo "Creating " $(DEPENDFILE) " ...";
1015         if [ -f $(DEPENDFILE) ]; then \
1016            /bin/cp -f $(DEPENDFILE) $(DEPENDFILE).old; \
1017         fi; \
1018         echo '#generated by make depends' > $(DEPENDFILE); \
1019         processFiles='';        \
1020         for i in $(LIBCONV_CORE) $(TRACE_OBJS) $(LIBCK_CORE) $(LB_OBJ) $(LIBBLUE_OBJS) $(COMLIB_OBJS) ; do \
1021               processed='false';        \
1022               for f in $$processFiles; do       \
1023                 if test $$i = $$f ; then        \
1024                   processed=true;  break;       \
1025                 fi;     \
1026               done;     \
1027               test $$processed = 'true'  && continue;   \
1028               processFiles="$$processFiles $$i";        \
1029               SRCFILE=`basename $$i .o`.C ; \
1030               [ ! -f $$SRCFILE ] && SRCFILE=`basename $$i .o`.c ;       \
1031               echo "checking dependencies for $$SRCFILE" ; \
1032               if g++ -MM -Wno-deprecated -I. -I$(INC) $$SRCFILE  >> $(DEPENDFILE); then   echo '        $$(CHARMC) -c -I. '$$SRCFILE >> $(DEPENDFILE) ; else echo '' ; echo "Compilation of '$$SRCFILE' failed, please fix it first!!!!" ; exit; fi;  \
1033               echo '' >> $(DEPENDFILE) ; \
1034         done;
1035
1036 dependsCaseSensitive: basics $(CIFILES:.ci=.ci.stamp)
1037         @echo "Creating " $(DEPENDFILE) " ...";
1038         if [ -f $(DEPENDFILE) ]; then \
1039            /bin/cp -f $(DEPENDFILE) $(DEPENDFILE).old; \
1040         fi; \
1041         echo '#generated by make depends' > $(DEPENDFILE); \
1042         processFiles='';        \
1043         for i in $(LIBCONV_CORE) $(TRACE_OBJS) $(LIBCK_CORE) $(LB_OBJ) $(LIBBLUE_OBJS) $(COMLIB_OBJS); do \
1044               processed='false';        \
1045               for f in $$processFiles; do       \
1046                 if test $$i = $$f ; then        \
1047                   processed=true;  break;       \
1048                 fi;     \
1049               done;     \
1050               test $$processed = 'true'  && continue;   \
1051               processFiles="$$processFiles $$i";        \
1052               SRCFILE=`basename $$i .o`.C ; \
1053               SRCDIR=`dirname $$i` ; \
1054               found=`/usr/bin/find $$SRCDIR -depth 1 -name $$SRCFILE`; \
1055               [ ! $$found ] && SRCFILE=`basename $$i .o`.c ; \
1056               echo "checking dependencies for $$SRCFILE" ; \
1057               if g++ -MM -Wno-deprecated -I. -I$(INC) $$SRCFILE  >> $(DEPENDFILE); then   echo '        $$(CHARMC) -c -I. '$$SRCFILE >> $(DEPENDFILE) ; else echo '' ; echo "Compilation of '$$SRCFILE' failed, please fix it first!!!!" ; exit; fi;  \
1058               echo '' >> $(DEPENDFILE) ; \
1059         done;
1060
1061
1062