| |
| # used to create vbcc, vc and ucpp |
| CC = gcc -std=c99 -g #-fsanitize=address #-DHAVE_ECPP -DHAVE_MISRA |
| LDFLAGS = |
| |
| # native version; used to create dtgen |
| NCC = $(CC) |
| NLDFLAGS = $(LDFLAGS) |
| |
| all: bin/vc bin/vprof bin/vbcc$(TARGET) #bin/vcpp |
| |
| vbccs: bin/vbccs$(TARGET) |
| |
| bin/vc: frontend/vc.c |
| $(CC) frontend/vc.c -o bin/vc $(LDFLAGS) |
| |
| bin/vprof: vprof/vprof.c |
| $(CC) vprof/vprof.c -o bin/vprof $(LDFLAGS) |
| |
| doc/vbcc.pdf: |
| texi2dvi --pdf doc/vbcc.texi |
| rm -f vbcc.cp vbcc.fn vbcc.vr vbcc.tp vbcc.ky vbcc.pg vbcc.toc \ |
| vbcc.aux vbcc.log |
| |
| doc/vbcc.html: |
| (cd doc;texi2html -split=chapter -nosec_nav -frames vbcc.texi) |
| sed -e s/vbcc_13/vbcc_1/ <doc/vbcc_frame.html >doc/vbcc.html |
| |
| vcppobjs = vcpp/cpp.o vcpp/eval.o vcpp/getopt.o vcpp/hideset.o vcpp/include.o \ |
| vcpp/lex.o vcpp/macro.o vcpp/nlist.o vcpp/tokens.o vcpp/unix.o |
| |
| _vbcc.tar.gz: |
| -(cd ..;tar zcvf vbcc.tar.gz --exclude=*/dt.c --exclude=*/dt.h vbcc/Makefile vbcc/bin/.dummy vbcc/*.[ch] vbcc/datatypes/*.[ch] vbcc/doc/*.texi vbcc/frontend/vc.c vbcc/machines/*/*.[ch] vbcc/machines/*/machine.dt vbcc/machines/*/schedule.[ch] vbcc/machines/*/compress.[ch] vbcc/ucpp/*.[ch] vbcc/ucpp/README vbcc/vprof/vprof.c vbcc/vsc/vsc.[ch] vbcc/vcpr/vcpr.[ch]) |
| |
| bin/osekrm: osekrm.c |
| $(CC) osekrm.c -o bin/osekrm |
| |
| dist: bin/osekrm |
| mv supp.h t1 |
| mv supp.c t2 |
| mv main.c t3 |
| mv machines/ppc/machine.c t4 |
| mv declaration.c t5 |
| mv flow.c t6 |
| mv ic.c t7 |
| mv parse_expr.c t8 |
| mv statements.c t9 |
| mv rd.c t10 |
| mv type_expr.c t11 |
| bin/osekrm <t1 >supp.h |
| bin/osekrm <t2 >supp.c |
| bin/osekrm <t3 >main.c |
| bin/osekrm <t4 >machines/ppc/machine.c |
| bin/osekrm <t5 >declaration.c |
| bin/osekrm <t6 >flow.c |
| bin/osekrm <t7 >ic.c |
| bin/osekrm <t8 >parse_expr.c |
| bin/osekrm <t9 >statements.c |
| bin/osekrm <t10 >rd.c |
| bin/osekrm <t11 >type_expr.c |
| make _vbcc.tar.gz |
| mv t1 supp.h |
| mv t2 supp.c |
| mv t3 main.c |
| mv t4 machines/ppc/machine.c |
| mv t5 declaration.c |
| mv t6 flow.c |
| mv t7 ic.c |
| mv t8 parse_expr.c |
| mv t9 statements.c |
| mv t10 rd.c |
| mv t11 type_expr.c |
| |
| bin/vcpp: $(vcppobjs) |
| $(CC) $(LDFLAGS) $(vcppobjs) -o bin/vcpp |
| |
| vcpp/cpp.o: vcpp/cpp.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/cpp.c -o vcpp/cpp.o |
| |
| vcpp/eval.o: vcpp/eval.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/eval.c -o vcpp/eval.o |
| |
| vcpp/getopt.o: vcpp/getopt.c |
| $(CC) -c -Ivcpp vcpp/getopt.c -o vcpp/getopt.o |
| |
| vcpp/hideset.o: vcpp/hideset.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/hideset.c -o vcpp/hideset.o |
| |
| vcpp/include.o: vcpp/include.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/include.c -o vcpp/include.o |
| |
| vcpp/lex.o: vcpp/lex.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/lex.c -o vcpp/lex.o |
| |
| vcpp/macro.o: vcpp/macro.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/macro.c -o vcpp/macro.o |
| |
| vcpp/nlist.o: vcpp/nlist.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/nlist.c -o vcpp/nlist.o |
| |
| vcpp/tokens.o: vcpp/tokens.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/tokens.c -o vcpp/tokens.o |
| |
| vcpp/unix.o: vcpp/unix.c vcpp/cpp.h |
| $(CC) -c -Ivcpp vcpp/unix.c -o vcpp/unix.o |
| |
| TRGDIR = machines/$(TARGET) |
| |
| bobjects = $(TRGDIR)/main.o $(TRGDIR)/vars.o $(TRGDIR)/declaration.o \ |
| $(TRGDIR)/parse_expr.o $(TRGDIR)/type_expr.o $(TRGDIR)/ic.o \ |
| $(TRGDIR)/machine.o $(TRGDIR)/statements.o \ |
| $(TRGDIR)/supp.o $(TRGDIR)/dt.o \ |
| $(TRGDIR)/assert.o $(TRGDIR)/cpp.o $(TRGDIR)/hash.o \ |
| $(TRGDIR)/lexer.o $(TRGDIR)/macro.o $(TRGDIR)/mem.o \ |
| $(TRGDIR)/eval.o |
| # $(TRGDIR)/AdjList.o $(TRGDIR)/DUChain.o \ |
| # $(TRGDIR)/ICodeInsertion.o $(TRGDIR)/NodeList.o \ |
| # $(TRGDIR)/RAllocMain.o $(TRGDIR)/Web.o |
| |
| fobjects = $(TRGDIR)/opt.o $(TRGDIR)/av.o $(TRGDIR)/rd.o $(TRGDIR)/regs.o \ |
| $(TRGDIR)/flow.o $(TRGDIR)/cse.o $(TRGDIR)/cp.o $(TRGDIR)/loop.o \ |
| $(TRGDIR)/alias.o $(TRGDIR)/range.o $(bobjects) |
| |
| sobjects = $(TRGDIR)/opts.o $(TRGDIR)/regss.o $(bobjects) |
| |
| tasm = $(TRGDIR)/supp.o $(TRGDIR)/tasm.o $(TRGDIR)/dt.o \ |
| $(TRGDIR)/opt.o $(TRGDIR)/av.o $(TRGDIR)/rd.o $(TRGDIR)/regs.o \ |
| $(TRGDIR)/flow.o $(TRGDIR)/cse.o $(TRGDIR)/cp.o $(TRGDIR)/loop.o \ |
| $(TRGDIR)/alias.o $(TRGDIR)/machine.o |
| |
| mbasic = $(TRGDIR)/supp.o $(TRGDIR)/mbasic.o $(TRGDIR)/dt.o \ |
| $(TRGDIR)/opt.o $(TRGDIR)/av.o $(TRGDIR)/rd.o $(TRGDIR)/regs.o \ |
| $(TRGDIR)/flow.o $(TRGDIR)/cse.o $(TRGDIR)/cp.o $(TRGDIR)/loop.o \ |
| $(TRGDIR)/alias.o $(TRGDIR)/machine.o |
| |
| minicomp = $(TRGDIR)/supp.o $(TRGDIR)/minicompg.tab.o $(TRGDIR)/minicomp.o $(TRGDIR)/dt.o \ |
| $(TRGDIR)/opt.o $(TRGDIR)/av.o $(TRGDIR)/rd.o $(TRGDIR)/regs.o \ |
| $(TRGDIR)/flow.o $(TRGDIR)/cse.o $(TRGDIR)/cp.o $(TRGDIR)/loop.o \ |
| $(TRGDIR)/alias.o $(TRGDIR)/machine.o |
| |
| vscobjects = $(TRGDIR)/vsc.o $(TRGDIR)/schedule.o |
| |
| vcprobjects = $(TRGDIR)/vcpr.o $(TRGDIR)/compress.o |
| |
| bin/vbcc$(TARGET): $(fobjects) |
| $(CC) $(LDFLAGS) $(fobjects) -o bin/vbcc$(TARGET) |
| |
| bin/vbccs$(TARGET): $(sobjects) |
| $(CC) $(LDFLAGS) $(sobjects) -o bin/vbccs$(TARGET) |
| |
| bin/vsc$(TARGET): $(vscobjects) |
| $(CC) $(LDFLAGS) $(vscobjects) -o bin/vsc$(TARGET) |
| |
| bin/vcpr$(TARGET): $(vcprobjects) |
| $(CC) $(LDFLAGS) $(vcprobjects) -o bin/vcpr$(TARGET) |
| |
| bin/tasm$(TARGET): $(tasm) |
| $(CC) $(LDFLAGS) $(tasm) -o bin/tasm$(TARGET) |
| |
| bin/mbasic$(TARGET): $(mbasic) |
| $(CC) $(LDFLAGS) $(mbasic) -o bin/mbasic$(TARGET) |
| |
| bin/minicomp$(TARGET): $(minicomp) |
| $(CC) $(LDFLAGS) $(minicomp) -o bin/minicomp$(TARGET) |
| |
| bin/dtgen: datatypes/dtgen.c datatypes/datatypes.h datatypes/dtconv.h |
| $(NCC) datatypes/dtgen.c -o bin/dtgen -Idatatypes $(NLDFLAGS) |
| |
| $(TRGDIR)/dt.h: bin/dtgen $(TRGDIR)/machine.dt |
| bin/dtgen $(TRGDIR)/machine.dt $(TRGDIR)/dt.h $(TRGDIR)/dt.c |
| |
| $(TRGDIR)/dt.c: bin/dtgen $(TRGDIR)/machine.dt |
| bin/dtgen $(TRGDIR)/machine.dt $(TRGDIR)/dt.h $(TRGDIR)/dt.c |
| |
| $(TRGDIR)/dt.o: $(TRGDIR)/dt.h $(TRGDIR)/dt.c |
| $(CC) -c $(TRGDIR)/dt.c -o $(TRGDIR)/dt.o -I$(TRGDIR) -Idatatypes |
| |
| $(TRGDIR)/tasm.o: tasm.c supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c tasm.c -o $(TRGDIR)/tasm.o -I$(TRGDIR) |
| |
| $(TRGDIR)/mbasic.o: mbasic.c supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c mbasic.c -o $(TRGDIR)/mbasic.o -I$(TRGDIR) |
| |
| $(TRGDIR)/minicomp.o: minicomp.c minicomp.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c minicomp.c -o $(TRGDIR)/minicomp.o -I$(TRGDIR) |
| |
| $(TRGDIR)/minicompg.tab.o: minicompg.y minicomplexer.c minicomp.h supp.h |
| bison minicompg.y |
| $(CC) -c minicompg.tab.c -o $(TRGDIR)/minicompg.tab.o -I$(TRGDIR) |
| |
| $(TRGDIR)/supp.o: supp.c supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c supp.c -o $(TRGDIR)/supp.o -I$(TRGDIR) |
| |
| $(TRGDIR)/main.o: main.c vbc.h supp.h vbcc_cpp.h ucpp/cpp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c main.c -o $(TRGDIR)/main.o -I$(TRGDIR) |
| |
| $(TRGDIR)/vars.o: vars.c vbc.h supp.h $(TRGDIR)/machine.h errors.h $(TRGDIR)/dt.h |
| $(CC) -c vars.c -o $(TRGDIR)/vars.o -I$(TRGDIR) |
| |
| $(TRGDIR)/declaration.o: declaration.c vbc.h supp.h vbcc_cpp.h ucpp/cpp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c declaration.c -o $(TRGDIR)/declaration.o -I$(TRGDIR) |
| |
| $(TRGDIR)/parse_expr.o: parse_expr.c vbc.h supp.h vbcc_cpp.h ucpp/cpp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c parse_expr.c -o $(TRGDIR)/parse_expr.o -I$(TRGDIR) |
| |
| $(TRGDIR)/type_expr.o: type_expr.c vbc.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c type_expr.c -o $(TRGDIR)/type_expr.o -I$(TRGDIR) |
| |
| $(TRGDIR)/ic.o: ic.c vbc.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c ic.c -o $(TRGDIR)/ic.o -I$(TRGDIR) |
| |
| $(TRGDIR)/statements.o: statements.c vbc.h supp.h vbcc_cpp.h ucpp/cpp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c statements.c -o $(TRGDIR)/statements.o -I$(TRGDIR) |
| |
| $(TRGDIR)/opt.o: opt.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c opt.c -o $(TRGDIR)/opt.o -I$(TRGDIR) |
| |
| $(TRGDIR)/av.o: av.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c av.c -o $(TRGDIR)/av.o -I$(TRGDIR) |
| |
| $(TRGDIR)/rd.o: rd.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c rd.c -o $(TRGDIR)/rd.o -I$(TRGDIR) |
| |
| $(TRGDIR)/regs.o: regs.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c regs.c -o $(TRGDIR)/regs.o -I$(TRGDIR) |
| |
| $(TRGDIR)/flow.o: flow.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c flow.c -o $(TRGDIR)/flow.o -I$(TRGDIR) |
| |
| $(TRGDIR)/cse.o: cse.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c cse.c -o $(TRGDIR)/cse.o -I$(TRGDIR) |
| |
| $(TRGDIR)/cp.o: cp.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c cp.c -o $(TRGDIR)/cp.o -I$(TRGDIR) |
| |
| $(TRGDIR)/loop.o: loop.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c loop.c -o $(TRGDIR)/loop.o -I$(TRGDIR) |
| |
| $(TRGDIR)/alias.o: alias.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c alias.c -o $(TRGDIR)/alias.o -I$(TRGDIR) |
| |
| $(TRGDIR)/range.o: range.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c range.c -o $(TRGDIR)/range.o -I$(TRGDIR) |
| |
| $(TRGDIR)/preproc.o: preproc.c vbpp.h supp.h vbc.h $(TRGDIR)/dt.h |
| $(CC) -c preproc.c -o $(TRGDIR)/preproc.o -I$(TRGDIR) |
| |
| $(TRGDIR)/assert.o: ucpp/assert.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/assert.c -o $(TRGDIR)/assert.o -I$(TRGDIR) |
| |
| $(TRGDIR)/cpp.o: ucpp/cpp.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/cpp.c -o $(TRGDIR)/cpp.o -I$(TRGDIR) |
| |
| $(TRGDIR)/hash.o: ucpp/hash.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/hash.c -o $(TRGDIR)/hash.o -I$(TRGDIR) |
| |
| $(TRGDIR)/lexer.o: ucpp/lexer.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/lexer.c -o $(TRGDIR)/lexer.o -I$(TRGDIR) |
| |
| $(TRGDIR)/macro.o: ucpp/macro.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/macro.c -o $(TRGDIR)/macro.o -I$(TRGDIR) |
| |
| $(TRGDIR)/mem.o: ucpp/mem.c ucpp/cpp.h ucpp/mem.h ucpp/hash.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/mem.c -o $(TRGDIR)/mem.o -I$(TRGDIR) |
| |
| $(TRGDIR)/eval.o: ucpp/eval.c ucpp/cpp.h ucpp/mem.h ucpp/tune.h $(TRGDIR)/dt.h |
| $(CC) -DNO_UCPP_ERROR_FUNCTIONS -c ucpp/eval.c -o $(TRGDIR)/eval.o -I$(TRGDIR) |
| |
| $(TRGDIR)/machine.o: $(TRGDIR)/machine.c supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h dwarf2.c |
| $(CC) -c $(TRGDIR)/machine.c -o $(TRGDIR)/machine.o -I$(TRGDIR) -I. |
| |
| $(TRGDIR)/opts.o: opt.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c -DNO_OPTIMIZER opt.c -o $(TRGDIR)/opts.o -I$(TRGDIR) |
| |
| $(TRGDIR)/regss.o: regs.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c -DNO_OPTIMIZER regs.c -o $(TRGDIR)/regss.o -I$(TRGDIR) |
| |
| $(TRGDIR)/vsc.o: vsc/vsc.h vsc/vsc.c $(TRGDIR)/schedule.h |
| $(CC) -c vsc/vsc.c -o $(TRGDIR)/vsc.o -I$(TRGDIR) |
| |
| $(TRGDIR)/schedule.o: vsc/vsc.h $(TRGDIR)/schedule.h $(TRGDIR)/schedule.c |
| $(CC) -c $(TRGDIR)/schedule.c -o $(TRGDIR)/schedule.o -I$(TRGDIR) -Ivsc |
| |
| $(TRGDIR)/vcpr.o: vcpr/vcpr.h vcpr/vcpr.c |
| $(CC) -c vcpr/vcpr.c -o $(TRGDIR)/vcpr.o -I$(TRGDIR) |
| |
| $(TRGDIR)/compress.o: vcpr/vcpr.h $(TRGDIR)/compress.c |
| $(CC) -c $(TRGDIR)/compress.c -o $(TRGDIR)/compress.o -I$(TRGDIR) -Ivcpr |
| |
| |
| |
| # Graph coloring register allocator by Alex |
| $(TRGDIR)/AdjList.o: GCRegAlloc/AdjList.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/AdjList.c -o $(TRGDIR)/AdjList.o -IGCRegAlloc -I$(TRGDIR) |
| |
| $(TRGDIR)/DUChain.o: GCRegAlloc/DUChain.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/DUChain.c -o $(TRGDIR)/DUChain.o -IGCRegAlloc -I$(TRGDIR) |
| |
| $(TRGDIR)/ICodeInsertion.o: GCRegAlloc/ICodeInsertion.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/ICodeInsertion.c -o $(TRGDIR)/ICodeInsertion.o -IGCRegAlloc -I$(TRGDIR) |
| |
| $(TRGDIR)/NodeList.o: GCRegAlloc/NodeList.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/NodeList.c -o $(TRGDIR)/NodeList.o -IGCRegAlloc -I$(TRGDIR) |
| |
| $(TRGDIR)/RAllocMain.o: GCRegAlloc/RAllocMain.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/RAllocMain.c -o $(TRGDIR)/RAllocMain.o -IGCRegAlloc -I$(TRGDIR) |
| |
| $(TRGDIR)/Web.o: GCRegAlloc/Web.c opt.h supp.h $(TRGDIR)/machine.h $(TRGDIR)/dt.h |
| $(CC) -c GCRegAlloc/Web.c -o $(TRGDIR)/Web.o -IGCRegAlloc -I$(TRGDIR) |