X-Git-Url: https://git.gag.com/?a=blobdiff_plain;f=device%2Flib%2FMakefile.in;h=4e192d87ea40a41e05b09377a522852b546ee3c5;hb=eb93c35b1ca7e48282e20bb8835bb779ce67dd83;hp=c7e81a73d07ad56bed3bbdf6f61330b93f24fb50;hpb=60be79b8345ea79c08d15e96329c65f1e548bf68;p=fw%2Fsdcc diff --git a/device/lib/Makefile.in b/device/lib/Makefile.in index c7e81a73..4e192d87 100644 --- a/device/lib/Makefile.in +++ b/device/lib/Makefile.in @@ -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 @@ -32,9 +41,9 @@ srcdir = @srcdir@ lib_dir_suffix = @lib_dir_suffix@ -sdcc_libdir = $(datadir)/$(lib_dir_suffix) +sdcc_libdir = $(DESTDIR)$(datadir)/$(lib_dir_suffix) -CPPFLAGS = -I$(INCDIR) +CPPFLAGS = -I$(INCDIR) -I$(PORTINCDIR) CFLAGS = $(MODELFLAGS) --nostdinc BUILDDIR = build @@ -46,22 +55,30 @@ 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 _fsmul.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 \ + _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 _strchr.c _strcmp.c _strcpy.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 malloc.c serial.c ser_ir.c printfl.c \ - printf_large.c vprintf.c puts.c gets.c \ - assert.c _strcat.c time.c printf_fast.c bpx.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 \ @@ -72,25 +89,27 @@ 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 _strchr.c _strcmp.c _strcpy.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 \ - puts.c gets.c \ - assert.c _strcat.c \ + assert.c \ _modslong.c _modulong.c \ _mullong.c \ + abs.c labs.c \ _divslong.c _divulong.c \ - malloc.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 + _slong2fs.c _sint2fs.c _schar2fs.c Z80OBJECTS = $(Z80SOURCES:%.c=$(PORTDIR)/%.o) @@ -105,13 +124,16 @@ XA51SOURCES = _atof.c _atoi.c _atol.c _schar2fs.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 \ - _strchr.c _strcmp.c _strcpy.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 malloc.c puts.c gets.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 _strcat.c time.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 \ @@ -119,32 +141,75 @@ XA51SOURCES = _atof.c _atoi.c _atol.c _schar2fs.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 model-ds390 model-ds400 model-z80 model-gbz80 +all: checkconf models model-ds390 model-ds400 model-z80 model-gbz80 model-hc08 model-pic16 objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate models: if [ "`grep mcs51 ../../ports.build`" = mcs51 ]; then \ for model in $(MODELS); do \ - $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model objects; \ + $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model PORTINCDIR=$(INCDIR)/mcs51 objects; \ + done \ + 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-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-xstack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \ done \ fi model-ds390: if [ "`grep ds390 ../../ports.build`" = ds390 ]; then \ - $(MAKE) MODELFLAGS="-mds390" PORT=ds390 objects; \ + $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \ fi - + model-ds400: if [ "`grep ds400 ../../ports.build`" = ds400 ]; then \ - $(MAKE) MODELFLAGS="-mds400" PORT=ds400 objects; \ - fi + $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \ + fi model-xa51: if [ "`grep xa51 ../../ports.build`" = xa51 ]; then \ @@ -167,6 +232,23 @@ model-gbz80: 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 + + build-dir: $(PORTDIR) $(PORTDIR): @@ -178,18 +260,28 @@ port-specific-objects: 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: all installdirs - cp -r $(BUILDDIR)/* $(sdcc_libdir) - cp -r ds390 ds400 gbz80 z80 *.c $(sdcc_libdir)/src - rm `find $(sdcc_libdir)/src -name '*.rel' -or -name '*.dump*' -or -name '*.sym' -or -name '*.o' -or -name '*.lst' -or -name '*.asm'` + $(CP_U) -r $(BUILDDIR)/* $(sdcc_libdir) + $(CP_U) -r ds390 ds400 gbz80 z80 hc08 *.c $(sdcc_libdir)/src + rm -r `find $(sdcc_libdir)/src -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lst' -o -name '*.asm' -o -name 'CVS'` # Deleting all the installed files # -------------------------------- @@ -215,14 +307,16 @@ installdirs: mkdir -p $(sdcc_libdir)/$$model; \ done [ -d $(sdcc_libdir)/ds390 ] || mkdir -p $(sdcc_libdir)/ds390 - [ -d $(sdcc_libdir)/ds400 ] || mkdir -p $(sdcc_libdir)/ds400 + [ -d $(sdcc_libdir)/ds400 ] || mkdir -p $(sdcc_libdir)/ds400 + [ -d $(sdcc_libdir)/hc08 ] || mkdir -p $(sdcc_libdir)/hc08 + [ -d $(sdcc_libdir)/pic16 ] || mkdir -p $(sdcc_libdir)/pic16 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) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \