7 include $(PRJDIR)/Makefile.common
11 PORTS = mcs51 z80 avr ds390
12 PORT_LIBS = $(PORTS:%=%/port.a)
14 LIBS = -lgc -lm @LIBS@
15 ifeq ($(HAVE_LIBGC), 1)
17 LIBDIRS = -L$(PRJDIR)/support/gc
18 LIBGC = $(PRJDIR)/support/gc/libgc.a
23 ifdef SDCC_SUB_VERSION
24 CFLAGS += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
27 OBJECTS = SDCCy.o SDCCerr.o SDCChasht.o SDCCmain.o \
28 SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
29 SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
30 SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
31 SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o spawn.o \
35 ifeq ($(USE_ALT_LEX), 1)
42 SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
44 TARGET = $(PRJDIR)/bin/sdcc
45 PACKIHX = $(PRJDIR)/bin/packihx
47 # Compiling entire program or any subproject
48 # ------------------------------------------
49 all: ports checkconf $(LIBGC) $(TARGET) $(PACKIHX)
52 for i in $(PORTS); do $(MAKE) -C $$i; done
54 $(PRJDIR)/support/gc/libgc.a:
55 cd $(PRJDIR)/support/gc && $(MAKE)
57 # Compiling and installing everything and runing test
58 # ---------------------------------------------------
59 install: all installdirs
60 $(INSTALL) -s $(TARGET) $(bindir)/sdcc
61 $(INSTALL) $(PACKIHX) $(bindir)/packihx
64 # Deleting all the installed files
65 # --------------------------------
68 rm -f $(bindir)/packihx
70 # Performing self-test
71 # --------------------
75 # Performing installation test
76 # ----------------------------
80 # Creating installation directories
81 # ---------------------------------
83 $(INSTALL) -d $(bindir)
86 # Creating dependencies
87 # ---------------------
90 Makefile.dep: $(SOURCES) $(SPECIAL) *.h $(PRJDIR)/*.h
91 $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
99 $(TARGET): $(OBJECTS) $(PORT_LIBS)
100 $(CC) -o $@ $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
103 $(INSTALL) packihx $(PACKIHX)
106 $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
108 reswords.h: reswords.gperf Makefile
109 gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
111 altlex.o: altlex.c SDCCy.h reswords.h
116 $(YACC) -d -v -o $@ $<
118 SDCClex.c: SDCC.lex SDCCy.h
132 # Remaking configuration
133 # ----------------------
135 @if [ -f $(PRJDIR)/devel ]; then\
136 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \
140 # End of main_in.mk/main.mk