git-svn-id: https://sdcc.svn.sourceforge.net/svnroot/sdcc/trunk/sdcc@4106 4a8a32a2...
[fw/sdcc] / device / lib / Makefile.in
index 31e8d875ede38ec46637bb6f753c2decfc8d43a7..424d841fc9281ead67d4e0fb5d3884eca89ec6c7 100644 (file)
@@ -12,8 +12,17 @@ CPP          = @CPP@
 INSTALL                = @INSTALL@
 CP              = @CP@
 
+ifeq ($(shell uname -s),Linux)
+CP_U   = $(CP) -u
+else
+CP_U   = $(CP)
+endif
+
 PRJDIR         = ../..
 INCDIR         = $(PRJDIR)/device/include
+ifndef PORTINCDIR
+PORTINCDIR     = $(INCDIR)/mcs51
+endif
 
 CC             = $(PRJDIR)/bin/sdcc
 CPP            = $(PRJDIR)/bin/sdcpp
@@ -30,79 +39,275 @@ man2dir         = $(mandir)/man2
 infodir         = @infodir@
 srcdir          = @srcdir@
 
-CPPFLAGS        = -I$(INCDIR) 
-CFLAGS         = 
-
-OBJECTS                = _atoi.rel _atol.rel _autobaud.rel _bp.rel _schar2fs.rel \
-                 _decdptr.rel _divsint.rel _divslong.rel _divuint.rel \
-                 _divulong.rel _fs2schar.rel _fs2sint.rel _fs2slong.rel \
-                 _fs2uchar.rel _fs2uint.rel _fs2ulong.rel _fsadd.rel \
-                 _fsdiv.rel _fseq.rel _fsgt.rel _fslt.rel _fsmul.rel \
-                 _fsneq.rel _fssub.rel _gptrget.rel _gptrput.rel \
-                 _sint2fs.rel _iscntrl.rel _isdigit.rel _isgraph.rel \
-                 _islower.rel _isprint.rel _ispunct.rel _isspace.rel \
-                 _isupper.rel _isxdigit.rel _slong2fs.rel _memcmp.rel \
-                 _memcpy.rel _memset.rel _modsint.rel _modslong.rel \
-                 _moduint.rel _modulong.rel _mulsint.rel _muluint.rel \
-                 _mululong.rel _muslong.rel _ser.rel _setjmp.rel \
-                 _spx.rel _startup.rel _strchr.rel _strcmp.rel _strcpy.rel \
-                 _strcspn.rel _strlen.rel _strncat.rel _strncmp.rel \
-                 _strncpy.rel _strpbrk.rel _strrchr.rel _strspn.rel \
-                 _strstr.rel _strtok.rel _uchar2fs.rel _uint2fs.rel \
-                 _ulong2fs.rel malloc.rel serial.rel ser_ir.rel printfl.rel \
-                 printf_large.rel vprintf.rel puts.rel gets.rel \
-                 assert.rel _strcat.rel
-SOURCES                = $(patsubst %.rel,%.c,$(OBJECTS))
+lib_dir_suffix  = @lib_dir_suffix@
+
+sdcc_libdir     = $(DESTDIR)$(datadir)/$(lib_dir_suffix)
+
+CPPFLAGS        = -I$(INCDIR) -I$(PORTINCDIR)
+CFLAGS         = $(MODELFLAGS) --nostdinc --std-sdcc99
+
+BUILDDIR        = build
+# Default
+PORT            = z80
+ifndef PORTDIR
+PORTDIR         = $(BUILDDIR)/$(PORT)
+endif
+
+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 \
+                 _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
+                 _fsdiv.c _fseq.c _fsgt.c _fslt.c _fscmp.c _fsmul.c \
+                 _fsneq.c _fssub.c _gptrget.c _gptrgetc.c _gptrput.c \
+                 _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
+                 _islower.c _isprint.c _ispunct.c _isspace.c \
+                 _isupper.c _isxdigit.c _itoa.c _ltoa.c \
+                 _slong2fs.c \
+                 _memcmp.c _memcpy.c _memmove.c _memset.c \
+                 _modsint.c _modslong.c _moduint.c _modulong.c \
+                 _mulint.c _mullong.c \
+                 abs.c labs.c \
+                 _ser.c _setjmp.c \
+                 _spx.c _startup.c \
+                 _strcat.c _strchr.c _strcmp.c _strcpy.c \
+                 _strcspn.c _strlen.c _strncat.c _strncmp.c \
+                 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
+                 _strstr.c _strtok.c \
+                 _uchar2fs.c _uint2fs.c _ulong2fs.c \
+                 calloc.c malloc.c realloc.c free.c \
+                 serial.c ser_ir.c printfl.c \
+                 printf_large.c sprintf.c vprintf.c puts.c gets.c \
+                 printf_fast.c printf_fast_f.c printf_tiny.c \
+                 assert.c time.c bpx.c \
+                 _fsget1arg.c _fsget2args.c _fsnormalize.c \
+                 _fsreturnval.c _fsrshift.c _fsswapargs.c _logexpf.c \
+                 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
+                 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
+                 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
+                 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
+
+OBJECTS                = $(patsubst %.c,$(PORTDIR)/%.rel,$(SOURCES))
+
+Z80SOURCES      = _atof.c _atoi.c \
+                 _iscntrl.c _isdigit.c _isgraph.c \
+                 _islower.c _isprint.c _ispunct.c _isspace.c \
+                 _isupper.c _isxdigit.c \
+                 _memcmp.c _memcpy.c _memmove.c _memset.c \
+                 _startup.c \
+                 _strcat.c _strchr.c _strcmp.c _strcpy.c \
+                 _strcspn.c _strlen.c _strncat.c _strncmp.c \
+                 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
+                 _strstr.c _strtok.c \
+                 assert.c \
+                 _modslong.c _modulong.c \
+                 _mullong.c \
+                 abs.c labs.c \
+                 _divslong.c _divulong.c \
+                 calloc.c malloc.c realloc.c free.c \
+                 printf_large.c sprintf.c vprintf.c puts.c gets.c \
+                 _fs2schar.c _fs2sint.c _fs2slong.c \
+                 _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
+                 _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
+                 _fsneq.c _fssub.c \
+                 _uchar2fs.c _uint2fs.c \
+                 _ulong2fs.c \
+                 _slong2fs.c _sint2fs.c _schar2fs.c
+
+Z80OBJECTS      = $(Z80SOURCES:%.c=$(PORTDIR)/%.o)
+
+XA51SOURCES      = _atof.c _atoi.c _atol.c _schar2fs.c \
+                 _divsint.c _divslong.c _divuint.c \
+                 _divulong.c _fs2schar.c _fs2sint.c _fs2slong.c \
+                 _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
+                 _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
+                 _fsneq.c _fssub.c \
+                 _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
+                 _islower.c _isprint.c _ispunct.c _isspace.c \
+                 _isupper.c _isxdigit.c _slong2fs.c _memcmp.c \
+                 _memcpy.c _memmove.c _memset.c _modsint.c _modslong.c \
+                 _moduint.c _modulong.c _mulint.c _mullong.c \
+                 abs.c labs.c \
+                 _strcat.c _strchr.c _strcmp.c _strcpy.c \
+                 _strcspn.c _strlen.c _strncat.c _strncmp.c \
+                 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
+                 _strstr.c _strtok.c \
+                 _uchar2fs.c _uint2fs.c _ulong2fs.c \
+                 calloc.c malloc.c realloc.c free.c \
+                 puts.c gets.c \
+                 printf_large.c puts.c gets.c \
+                 assert.c time.c \
+                 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
+                 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
+                 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
+                 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
+
+XA51OBJECTS      = $(XA51SOURCES:%.c=$(PORTDIR)/%.rel)
+
+HC08SOURCES    = _atof.c _atoi.c _atol.c _schar2fs.c \
+                 _divsint.c _divslong.c \
+                 _fs2schar.c _fs2sint.c _fs2slong.c \
+                 _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
+                 _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
+                 _fsneq.c _fssub.c \
+                 _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
+                 _islower.c _isprint.c _ispunct.c _isspace.c \
+                 _isupper.c _isxdigit.c _itoa.c _ltoa.c \
+                 _slong2fs.c \
+                 _memcmp.c _memcpy.c _memmove.c _memset.c \
+                 _modsint.c _modslong.c _moduint.c _modulong.c \
+                 abs.c labs.c \
+                 _spx.c _startup.c \
+                 _strcat.c _strchr.c _strcmp.c _strcpy.c \
+                 _strcspn.c _strlen.c _strncat.c _strncmp.c \
+                 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
+                 _strstr.c _strtok.c \
+                 _uchar2fs.c _uint2fs.c _ulong2fs.c \
+                 calloc.c malloc.c realloc.c free.c \
+                 printf_large.c sprintf.c vprintf.c \
+                 assert.c time.c \
+                 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
+                 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
+                 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
+                 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
+
+HC08OBJECTS    = $(patsubst %.c,$(PORTDIR)/%.rel,$(HC08SOURCES))
+
+OEXT            = .rel
 
 include incl.mk
 
 # Compiling entire program or any subproject
 # ------------------------------------------
-all: checkconf models modelDS390
+all: checkconf models small-mcs51-stack-auto model-ds390 model-ds400 model-z80 model-gbz80 model-hc08 model-pic16 model-pic14
 
-objects: $(OBJECTS)
+objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate
 
 models:
-       for model in $(MODELS); do \
-         test -d $$model || mkdir $$model; \
-         $(MAKE) CFLAGS="$(CFLAGS) --model-$$model" objects; \
-         mv *.rel $$model; \
-         mv *.asm $$model; \
-         mv *.cdb $$model; \
-       done
+       if [ "`grep mcs51 ../../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 \
+         $(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 \
+         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 \
+         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
 
-modelDS390:
-       test -d ds390 || mkdir ds390
-       $(MAKE) CFLAGS="$(CFLAGS) -mds390 --model-flat24 \
-               --stack-10bit" objects
-       cd ds390; $(MAKE)
-       cp *.lib ds390
-       mv *.rel *.asm *.cdb ds390
+model-ds390:
+       if [ "`grep ds390 ../../ports.build`" = ds390 ]; then \
+         $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \
+       fi
+
+model-ds400:
+       if [ "`grep ds400 ../../ports.build`" = ds400 ]; then \
+         $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \
+       fi
+
+model-xa51:
+       if [ "`grep xa51 ../../ports.build`" = xa51 ]; then \
+         $(MAKE) MODELFLAGS="-mxa51" PORT=xa51 objects-xa51; \
+       fi
+
+objects-xa51: build-dir $(XA51OBJECTS) port-specific-objects
+       cd $(PORTDIR); ls *$(OEXT) > lib$(PORT).lib
+
+model-z80:
+       if [ "`grep z80 ../../ports.build`" = z80 ]; then \
+         $(MAKE) MODELFLAGS="-mz80" PORT=z80 objects-z80 OEXT=.o; \
+       fi
+
+model-gbz80:
+       if [ "`grep z80 ../../ports.build`" = z80 ]; then \
+         $(MAKE) MODELFLAGS="-mgbz80" PORT=gbz80 objects-z80 OEXT=.o; \
+       fi
+
+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 \
+         $(MAKE) MODELFLAGS="-mhc08" PORT=hc08 objects-hc08; \
+       fi
+
+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 \
+         $(MAKE) MODELFLAGS="-mpic16" PORT=pic16 OEXT=.lib objects-pic16; \
+       fi
+
+objects-pic16: build-dir port-specific-objects-pic16 clean_intermediate-pic16
+       -cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
+
+# yes, we do reuse the *-pic16 rules for pic14
+model-pic14:
+       if [ "`grep pic ../../ports.build | grep -v pic16`" = pic ]; then \
+         $(MAKE) MODELFLAGS="-mpic14" PORT=pic OEXT=.lib objects-pic16; \
+       fi
+
+build-dir: $(PORTDIR)
+
+$(PORTDIR):
+       mkdir -p $(PORTDIR)
+
+port-specific-objects:
+       if [ -d $(PORT) ]; then \
+         $(MAKE) -C $(PORT); \
+         cp -f $(PORT)/*.lib $(PORT)/*$(OEXT) $(PORTDIR); \
+       fi
+
+port-specific-objects-pic16:
+       -if [ -d $(PORT) ]; then \
+         mkdir -p $(PORT)/bin; \
+         $(MAKE) -C $(PORT); \
+         cp -f $(PORT)/bin/*.* $(PORTDIR); \
+       fi
+
+lib-files:
+       cp *.lib $(PORTDIR)
+
+clean_intermediate:
+       rm -f $(PORTDIR)/*.lst $(PORTDIR)/*.sym
+
+clean_intermediate-pic16:
+       $(MAKE) -C $(PORT) clean-intermediate
 
 # Compiling and installing everything and runing test
 # ---------------------------------------------------
-install: installDS390
-       $(CP) *.c $(datadir)/lib/
-       for model in $(MODELS); do \
-        [ -d $$model ] || $(MAKE) all; \
-        $(CP) $$model/*.rel *.lib $(datadir)/lib/$$model/; \
-        $(CP) $$model/*.asm $(datadir)/lib/$$model/; \
-        $(CP) $$model/*.cdb $(datadir)/lib/$$model/; \
+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 \
+           \( -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' \) \
+           -exec rm -r {} \; ; \
        done
-
-installDS390: installdirs
-       $(CP) ds390/*.lib ds390/*.rel ds390/*.asm ds390/*.cdb $(datadir)/lib/ds390
+       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' \) \
+         -exec rm -r {} \;
 
 # Deleting all the installed files
 # --------------------------------
 uninstall:
-       for hdr in ../include/*.h; do rm -f $(datadir)/include/$$hdr; done
-       for cfl in *.c; do rm -f $(datadir)/lib/$$cfl; done
-       for model in $(MODELS); do \
-         rm -rf $(datadir)/lib/$$model; \
-       done
-       rm -rf $(datadir)/lib/ds390
-
+       rm -rf $(sdcc_libdir)
 
 # Performing self-test
 # --------------------
@@ -117,21 +322,24 @@ installcheck:
 # Creating installation directories
 # ---------------------------------
 installdirs:
-       [ -d $(datadir)/lib ] || mkdir -p $(datadir)/lib
+       [ -d $(sdcc_libdir) ] || mkdir -p $(sdcc_libdir)
        for model in $(MODELS); do \
-        [ -d $(datadir)/lib/$$model ] || \
-        mkdir -p $(datadir)/lib/$$model; \
+         [ -d $(sdcc_libdir)/$$model ] || \
+         mkdir -p $(sdcc_libdir)/$$model; \
+       done
+       for libdir in small-stack-auto ds390 ds400 hc08 pic16 pic; do \
+         [ -d $(sdcc_libdir)/$$libdir ] || mkdir -p $(sdcc_libdir)/$$libdir; \
        done
-       [ -d $(datadir)/lib/ds390 ] || mkdir -p $(datadir)/lib/ds390
+       mkdir -p $(sdcc_libdir)/src
 
 # Creating dependencies
 # ---------------------
 dep: Makefile.dep
 
-Makefile.dep: $(SOURCES) $(INCDIR)/*.h
+Makefile.dep: $(SOURCES) $(INCDIR)/*.h $(PORTINCDIR)/*.h
        rm -f Makefile.dep
        for i in $(SOURCES); do \
-         $(CPP) -M $(CPPFLAGS) $$i >$${i}.dep; \
+         $(CPP) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \
          cat $${i}.dep >>Makefile.dep; \
          rm $${i}.dep; \
        done
@@ -142,11 +350,10 @@ include clean.mk
 # My rules
 # --------
 
-.SUFFIXES: .rel
-
-.c.rel:
-       $(CC) $(CPPFLAGS) $(CFLAGS) -c $<
+.SUFFIXES: .rel .o
 
+$(PORTDIR)/%$(OEXT): %.c
+       $(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
 
 # Remaking configuration
 # ----------------------