projects
/
fw
/
sdcc
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
* device/lib/libsdcc.lib: added _memmove
[fw/sdcc]
/
src
/
Makefile.in
diff --git
a/src/Makefile.in
b/src/Makefile.in
index 302309cee864246d0ed3d1b952b00e71e057ca1e..26478f8bffe4baa5070eaa035a7d786714001762 100644
(file)
--- a/
src/Makefile.in
+++ b/
src/Makefile.in
@@
-6,47
+6,65
@@
PRJDIR = ..
include $(PRJDIR)/Makefile.common
include $(PRJDIR)/Makefile.common
-PORTS = mcs51 z80
+USE_ALT_LEX = 0
+
+PORTS = $(shell cat ../ports.build)
+ALLPORTS = $(shell cat ../ports.all)
PORT_LIBS = $(PORTS:%=%/port.a)
PORT_LIBS = $(PORTS:%=%/port.a)
-LIBS = -lgc @LIBS@
-ifeq ($(HAVE_LIBGC), 1)
-else
-LIBDIRS = -L$(PRJDIR)/support/gc
-LIBGC = $(PRJDIR)/support/gc/libgc.a
+LIBS = -lm @LIBS@
+
+#CFLAGS += -Werror
+
+ifdef SDCC_SUB_VERSION
+CFLAGS += -DSDCC_SUB_VERSION_STR=\"$(SDCC_SUB_VERSION)\"
endif
endif
-OBJECTS = SDCCy.o SDCClex.o SDCCerr.o SDCChasht.o SDCCmain.o \
+SLIBOBJS = SDCCerr.o NewAlloc.o MySystem.o BuildCmd.o dbuf.o findme.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 \
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
+ 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)
+OBJECTS += altlex.o
+SPECIAL += reswords.h
+else
+OBJECTS += SDCClex.o
+endif
+
+SLIBSOURCES = $(patsubst %.o,$(SLIB)/%.c,$(SLIBOBJS))
SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
SOURCES = $(patsubst %.o,%.c,$(OBJECTS))
-TARGET = $(PRJDIR)/bin/sdcc
+TARGET = $(PRJDIR)/bin/sdcc
$(EXEEXT)
# Compiling entire program or any subproject
# ------------------------------------------
# Compiling entire program or any subproject
# ------------------------------------------
-all:
ports checkconf $(LIBGC)
$(TARGET)
+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)
$(PRJDIR)/support/gc/libgc.a:
cd $(PRJDIR)/support/gc && $(MAKE)
-
# Compiling and installing everything and runing test
# ---------------------------------------------------
install: all installdirs
# Compiling and installing everything and runing test
# ---------------------------------------------------
install: all installdirs
- $(INSTALL) -s $(TARGET) $(bindir)/sdcc
+ $(INSTALL) $(TARGET) `echo $(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
+ $(STRIP) `echo $(bindir)/sdcc$(EXEEXT)|sed '$(transform)'`
# Deleting all the installed files
# --------------------------------
uninstall:
# Deleting all the installed files
# --------------------------------
uninstall:
- rm -f $(bindir)/sdcc
-
+ rm -f $(bindir)/sdcc$(EXEEXT)
# Performing self-test
# --------------------
# Performing self-test
# --------------------
@@
-68,8
+86,8
@@
installdirs:
# ---------------------
dep: Makefile.dep
# ---------------------
dep: Makefile.dep
-Makefile.dep: $(SOURCES) *.h $(PRJDIR)/*.h
- $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES) >Makefile.dep
+Makefile.dep: $(SOURCES)
$(SLIBSOURCES) $(SPECIAL)
*.h $(PRJDIR)/*.h
+ $(CPP) $(CPPFLAGS) $(M_OR_MM) $(SOURCES)
$(SLIBSOURCES)
>Makefile.dep
include Makefile.dep
include clean.mk
include Makefile.dep
include clean.mk
@@
-77,12
+95,20
@@
include clean.mk
# My rules
# --------
# My rules
# --------
-$(TARGET): $(OBJECTS) $(PORT_LIBS)
- $(CC)
-o $@
$(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
+$(TARGET): $(
SLIBOBJS) $(
OBJECTS) $(PORT_LIBS)
+ $(CC)
$(LDFLAGS) -o $@ $(SLIBOBJS)
$(OBJECTS) $(PORT_LIBS) $(LIBDIRS) $(LIBS)
.c.o:
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $@
.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 $< > $@
+
+altlex.o: altlex.c SDCCy.h reswords.h
+
SDCCy.h: SDCCy.c
SDCCy.c: SDCC.y
SDCCy.h: SDCCy.c
SDCCy.c: SDCC.y
@@
-91,9
+117,6
@@
SDCCy.c: SDCC.y
SDCClex.c: SDCC.lex SDCCy.h
$(LEX) -t $< >$@
SDCClex.c: SDCC.lex SDCCy.h
$(LEX) -t $< >$@
-SDCCpeeph.rul: SDCCpeeph.def
- $(AWK) -f SDCCpeeph.awk SDCCpeeph.def > SDCCpeeph.rul
-
.y.c:
rm -f $*.cc $*.h
$(YACC) -d $<
.y.c:
rm -f $*.cc $*.h
$(YACC) -d $<
@@
-114,4
+137,3
@@
checkconf:
fi
# End of main_in.mk/main.mk
fi
# End of main_in.mk/main.mk
-