X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=device%2Flib%2FMakefile.in;h=ca53e7139334616b8da136de8304a79d3f223786;hb=c42e9051755428d14eb620abc9eda86d43479a1a;hp=424d841fc9281ead67d4e0fb5d3884eca89ec6c7;hpb=5979bbd157a5f3cd8018aed666e4dd41a3e08edf;p=fw%2Fsdcc diff --git a/device/lib/Makefile.in b/device/lib/Makefile.in index 424d841f..ca53e713 100644 --- a/device/lib/Makefile.in +++ b/device/lib/Makefile.in @@ -18,14 +18,17 @@ else CP_U = $(CP) endif -PRJDIR = ../.. -INCDIR = $(PRJDIR)/device/include +top_builddir = @top_builddir@ +top_srcdir = @top_srcdir@ +VPATH = @srcdir@ +srcdir = @srcdir@ +INCDIR = $(top_srcdir)/device/include ifndef PORTINCDIR -PORTINCDIR = $(INCDIR)/mcs51 +PORTINCDIR = $(srcdir)/$(INCDIR)/mcs51 endif -CC = $(PRJDIR)/bin/sdcc -CPP = $(PRJDIR)/bin/sdcpp +CC = $(top_builddir)bin/sdcc +CPP = $(top_builddir)bin/sdcpp prefix = @prefix@ exec_prefix = @exec_prefix@ @@ -37,7 +40,6 @@ mandir = @mandir@ man1dir = $(mandir)/man1 man2dir = $(mandir)/man2 infodir = @infodir@ -srcdir = @srcdir@ lib_dir_suffix = @lib_dir_suffix@ @@ -53,6 +55,16 @@ ifndef PORTDIR PORTDIR = $(BUILDDIR)/$(PORT) endif +OPT_DISABLE_AVR = @OPT_DISABLE_AVR@ +OPT_DISABLE_DS390 = @OPT_DISABLE_DS390@ +OPT_DISABLE_DS400 = @OPT_DISABLE_DS400@ +OPT_DISABLE_HC08 = @OPT_DISABLE_HC08@ +OPT_DISABLE_MCS51 = @OPT_DISABLE_MCS51@ +OPT_DISABLE_PIC = @OPT_DISABLE_PIC@ +OPT_DISABLE_PIC16 = @OPT_DISABLE_PIC16@ +OPT_DISABLE_XA51 = @OPT_DISABLE_XA51@ +OPT_DISABLE_Z80 = @OPT_DISABLE_Z80@ + SOURCES = _atof.c _atoi.c _atol.c _autobaud.c _bp.c _schar2fs.c \ _decdptr.c _divsint.c _divslong.c _divuint.c \ _divulong.c _fs2schar.c _fs2sint.c _fs2slong.c \ @@ -174,52 +186,81 @@ HC08OBJECTS = $(patsubst %.c,$(PORTDIR)/%.rel,$(HC08SOURCES)) OEXT = .rel -include incl.mk +include $(srcdir)/incl.mk + +ifeq ($(OPT_DISABLE_DS390), 0) +TARGETS += model-ds390 +endif + +ifeq ($(OPT_DISABLE_DS400), 0) +TARGETS += model-ds400 +endif + +ifeq ($(OPT_DISABLE_HC08), 0) +TARGETS += model-hc08 +endif + +ifeq ($(OPT_DISABLE_MCS51), 0) +TARGETS += models small-mcs51-stack-auto +endif + +ifeq ($(OPT_DISABLE_PIC), 0) +TARGETS += model-pic14 +endif + +ifeq ($(OPT_DISABLE_PIC16), 0) +TARGETS += model-pic16 +endif + +ifeq ($(OPT_DISABLE_Z80), 0) +TARGETS += model-z80 model-gbz80 +endif + # Compiling entire program or any subproject # ------------------------------------------ -all: checkconf models small-mcs51-stack-auto model-ds390 model-ds400 model-z80 model-gbz80 model-hc08 model-pic16 model-pic14 +all: checkconf $(TARGETS) objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate models: - if [ "`grep mcs51 ../../ports.build`" = mcs51 ]; then \ + if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \ for model in $(MODELS); do \ $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model PORTINCDIR=$(INCDIR)/mcs51 objects; \ done \ fi small-mcs51-stack-auto: - if [ "`grep mcs51 ../../ports.build`" = mcs51 ]; then \ + if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \ $(MAKE) MODELFLAGS="--model-small --stack-auto" PORT=small PORTDIR=$(BUILDDIR)/small-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \ fi model-mcs51-stack-auto: - if [ "`grep mcs51 ../../ports.build`" = mcs51 ]; then \ + if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \ for model in $(MODELS); do \ $(MAKE) MODELFLAGS="--model-$$model --stack-auto" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \ done \ fi model-mcs51-xstack-auto: - if [ "`grep mcs51 ../../ports.build`" = mcs51 ]; then \ + if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \ for model in $(MODELS); do \ $(MAKE) MODELFLAGS="--model-$$model --stack-auto --xstack" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-xstack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \ done \ fi model-ds390: - if [ "`grep ds390 ../../ports.build`" = ds390 ]; then \ + if [ "`grep ds390 $(top_builddir)ports.build`" = ds390 ]; then \ $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \ fi model-ds400: - if [ "`grep ds400 ../../ports.build`" = ds400 ]; then \ + if [ "`grep ds400 $(top_builddir)ports.build`" = ds400 ]; then \ $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \ fi model-xa51: - if [ "`grep xa51 ../../ports.build`" = xa51 ]; then \ + if [ "`grep xa51 $(top_builddir)ports.build`" = xa51 ]; then \ $(MAKE) MODELFLAGS="-mxa51" PORT=xa51 objects-xa51; \ fi @@ -227,12 +268,12 @@ objects-xa51: build-dir $(XA51OBJECTS) port-specific-objects cd $(PORTDIR); ls *$(OEXT) > lib$(PORT).lib model-z80: - if [ "`grep z80 ../../ports.build`" = z80 ]; then \ + if [ "`grep z80 $(top_builddir)ports.build`" = z80 ]; then \ $(MAKE) MODELFLAGS="-mz80" PORT=z80 objects-z80 OEXT=.o; \ fi model-gbz80: - if [ "`grep z80 ../../ports.build`" = z80 ]; then \ + if [ "`grep z80 $(top_builddir)ports.build`" = z80 ]; then \ $(MAKE) MODELFLAGS="-mgbz80" PORT=gbz80 objects-z80 OEXT=.o; \ fi @@ -240,7 +281,7 @@ objects-z80: build-dir $(Z80OBJECTS) port-specific-objects clean_intermediate cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib model-hc08: - if [ "`grep hc08 ../../ports.build`" = hc08 ]; then \ + if [ "`grep hc08 $(top_builddir)ports.build`" = hc08 ]; then \ $(MAKE) MODELFLAGS="-mhc08" PORT=hc08 objects-hc08; \ fi @@ -248,7 +289,7 @@ objects-hc08: build-dir $(HC08OBJECTS) port-specific-objects clean_intermediate cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib model-pic16: - if [ "`grep pic16 ../../ports.build`" = pic16 ]; then \ + if [ "`grep pic16 $(top_builddir)ports.build`" = pic16 ]; then \ $(MAKE) MODELFLAGS="-mpic16" PORT=pic16 OEXT=.lib objects-pic16; \ fi @@ -257,7 +298,7 @@ objects-pic16: build-dir port-specific-objects-pic16 clean_intermediate-pic16 # yes, we do reuse the *-pic16 rules for pic14 model-pic14: - if [ "`grep pic ../../ports.build | grep -v pic16`" = pic ]; then \ + if [ "`grep pic $(top_builddir)ports.build | grep -v pic16`" = pic ]; then \ $(MAKE) MODELFLAGS="-mpic14" PORT=pic OEXT=.lib objects-pic16; \ fi @@ -267,20 +308,20 @@ $(PORTDIR): mkdir -p $(PORTDIR) port-specific-objects: - if [ -d $(PORT) ]; then \ + if [ -f $(PORT)/Makefile ]; then \ $(MAKE) -C $(PORT); \ cp -f $(PORT)/*.lib $(PORT)/*$(OEXT) $(PORTDIR); \ fi port-specific-objects-pic16: - -if [ -d $(PORT) ]; then \ + -if [ -f $(PORT)/Makefile ]; then \ mkdir -p $(PORT)/bin; \ $(MAKE) -C $(PORT); \ cp -f $(PORT)/bin/*.* $(PORTDIR); \ fi lib-files: - cp *.lib $(PORTDIR) + cp $(srcdir)/*.lib $(PORTDIR) clean_intermediate: rm -f $(PORTDIR)/*.lst $(PORTDIR)/*.sym @@ -292,16 +333,22 @@ clean_intermediate-pic16: # --------------------------------------------------- install: all installdirs $(CP_U) -r $(BUILDDIR)/* $(sdcc_libdir) - $(CP_U) -r $(MODELS) mcs51 ds390 ds400 gbz80 z80 hc08 pic pic16 *.c $(sdcc_libdir)/src - for srcdir in $(MODELS) ds390 ds400 gbz80 z80 hc08 pic pic16; do \ - find $(sdcc_libdir)/src/$$srcdir -depth \ + $(CP_U) -r $(MODELS) $(srcdir)/mcs51 $(srcdir)/ds390 $(srcdir)/ds400 \ + $(srcdir)/gbz80 $(srcdir)/z80 $(srcdir)/hc08 \ + $(srcdir)/pic $(srcdir)/pic16 $(srcdir)/*.c $(sdcc_libdir)/src + $(CP_U) -r $(MODELS) mcs51 ds390 ds400 gbz80 z80 hc08 $(sdcc_libdir)/src + + for src in $(MODELS) ds390 ds400 gbz80 z80 hc08 pic pic16; do \ + find $(sdcc_libdir)/src/$$src -depth \ \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \ - -name '*.lst' -o -name '*.asm' -o -name '.svn' -o -name 'build' -o -name 'bin' \) \ + -name '*.lst' -o -name '*.asm' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \ + -name 'Makefile*' \) \ -exec rm -r {} \; ; \ done find $(sdcc_libdir)/src/mcs51 -depth \ \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \ - -name '*.lst' -o -name '.svn' -o -name 'build' -o -name 'bin' \) \ + -name '*.lst' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \ + -name 'Makefile*' \) \ -exec rm -r {} \; # Deleting all the installed files @@ -338,14 +385,17 @@ dep: Makefile.dep Makefile.dep: $(SOURCES) $(INCDIR)/*.h $(PORTINCDIR)/*.h rm -f Makefile.dep - for i in $(SOURCES); do \ + for i in $(filter %.c,$^); do \ $(CPP) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \ cat $${i}.dep >>Makefile.dep; \ rm $${i}.dep; \ done -include Makefile.dep -include clean.mk +ifeq "$(findstring $(MAKECMDGOALS),uninstall check installcheck installdirs checkconf \ + clean distclean mostlyclean realclean)" "" + include Makefile.dep +endif +include $(srcdir)/clean.mk # My rules # -------- @@ -358,8 +408,8 @@ $(PORTDIR)/%$(OEXT): %.c # Remaking configuration # ---------------------- checkconf: - @if [ -f $(PRJDIR)/devel ]; then\ - $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" PRJDIR="$(PRJDIR)" \ + @if [ -f $(top_builddir)devel ]; then\ + $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" \ freshconf;\ fi