USE_ALT_LEX = 0
-PORTS = mcs51 z80 avr ds390
+PORTS = $(shell cat ../ports.build)
+ALLPORTS = $(shell cat ../ports.all)
PORT_LIBS = $(PORTS:%=%/port.a)
-LIBS = -lgc -lm @LIBS@
-ifeq ($(HAVE_LIBGC), 1)
-else
-LIBDIRS = -L$(PRJDIR)/support/gc
-LIBGC = $(PRJDIR)/support/gc/libgc.a
-endif
+LIBS = -lm @LIBS@
+
+#CFLAGS += -Werror
ifdef SDCC_SUB_VERSION
CFLAGS += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
endif
-OBJECTS = SDCCy.o SDCCerr.o SDCChasht.o SDCCmain.o \
+SLIBOBJS = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o
+
+OBJECTS = SDCCy.o SDCChasht.o SDCCmain.o \
SDCCsymt.o SDCCopt.o SDCCast.o SDCCmem.o SDCCval.o \
SDCCicode.o SDCCbitv.o SDCCset.o SDCClabel.o \
SDCCBBlock.o SDCCloop.o SDCCcse.o SDCCcflow.o SDCCdflow.o \
- SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o spawn.o \
- asm.o
+ SDCClrange.o SDCCptropt.o SDCCpeeph.o SDCCglue.o \
+ asm.o SDCCmacro.o SDCCutil.o SDCCdebug.o cdbFile.o
SPECIAL = SDCCy.h
ifeq ($(USE_ALT_LEX), 1)
SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
-TARGET = $(PRJDIR)/bin/sdcc
-PACKIHX = $(PRJDIR)/bin/packihx
+TARGET = $(PRJDIR)/bin/sdcc$(EXEEXT)
# Compiling entire program or any subproject
# ------------------------------------------
-all: ports checkconf $(LIBGC) $(TARGET) $(PACKIHX)
+all: checkconf $(TARGET)
-ports:
- for i in $(PORTS); do $(MAKE) -C $$i; done
+$(PORT_LIBS): FORCE
+ $(MAKE) -C `dirname $@`
+
+FORCE:
$(PRJDIR)/support/gc/libgc.a:
cd $(PRJDIR)/support/gc && $(MAKE)
# Compiling and installing everything and runing test
# ---------------------------------------------------
install: all installdirs
- $(INSTALL) -s $(TARGET) $(bindir)/sdcc
- $(INSTALL) $(PACKIHX) $(bindir)/packihx
+ $(INSTALL) $(TARGET) `echo $(bindir)/sdcc|sed '$(transform)'`
+ $(STRIP) `echo $(bindir)/sdcc|sed '$(transform)'`
# Deleting all the installed files
uninstall:
rm -f $(bindir)/sdcc
-
# Performing self-test
# --------------------
check:
# My rules
# --------
-$(TARGET): $(OBJECTS) $(PORT_LIBS)
- $(CC) -o $@ $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
-
-$(PACKIHX): packihx
- $(INSTALL) packihx $(PACKIHX)
-
+$(TARGET): $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS)
+ $(CC) -o $@ $(SLIBOBJS) $(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
.c.o:
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
+$(SLIBOBJS):%.o:$(SLIB)/%.c
+ $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
+
reswords.h: reswords.gperf Makefile
gperf -o -k1,2,4 -t -C -N is_reserved_word $< > $@
fi
# End of main_in.mk/main.mk
-