6 VERSIONHI = @VERSIONHI@
7 VERSIONLO = @VERSIONLO@
15 ifeq ($(shell uname -s),Linux)
21 top_builddir = @top_builddir@
22 top_srcdir = @top_srcdir@
25 INCDIR = $(top_srcdir)/device/include
27 PORTINCDIR = $(INCDIR)/mcs51
30 CC = $(top_builddir)/bin/sdcc
31 CPP = $(top_builddir)/bin/sdcpp
34 exec_prefix = @exec_prefix@
38 datarootdir = @datarootdir@
39 includedir = @includedir@
41 man1dir = $(mandir)/man1
42 man2dir = $(mandir)/man2
45 lib_dir_suffix = @lib_dir_suffix@
47 sdcc_libdir = $(DESTDIR)$(datadir)/$(lib_dir_suffix)
49 CPPFLAGS = -I$(INCDIR) -I$(PORTINCDIR)
50 CFLAGS = $(MODELFLAGS) --nostdinc --std-c99
56 PORTDIR = $(BUILDDIR)/$(PORT)
59 OPT_DISABLE_AVR = @OPT_DISABLE_AVR@
60 OPT_DISABLE_DS390 = @OPT_DISABLE_DS390@
61 OPT_DISABLE_DS400 = @OPT_DISABLE_DS400@
62 OPT_DISABLE_GBZ80 = @OPT_DISABLE_GBZ80@
63 OPT_DISABLE_HC08 = @OPT_DISABLE_HC08@
64 OPT_DISABLE_MCS51 = @OPT_DISABLE_MCS51@
65 OPT_DISABLE_PIC = @OPT_DISABLE_PIC@
66 OPT_DISABLE_PIC16 = @OPT_DISABLE_PIC16@
67 OPT_DISABLE_XA51 = @OPT_DISABLE_XA51@
68 OPT_DISABLE_Z80 = @OPT_DISABLE_Z80@
70 SOURCES = _autobaud.c _bp.c _decdptr.c \
71 _gptrget.c _gptrgetc.c _gptrput.c \
74 _atof.c _atoi.c _atol.c _itoa.c _ltoa.c \
75 _schar2fs.c _sint2fs.c _slong2fs.c \
76 _uchar2fs.c _uint2fs.c _ulong2fs.c \
77 _fs2schar.c _fs2sint.c _fs2slong.c \
78 _fs2uchar.c _fs2uint.c _fs2ulong.c \
79 _fsadd.c _fsdiv.c _fsmul.c _fssub.c \
80 _fseq.c _fsgt.c _fslt.c _fsneq.c \
81 _divsint.c _divslong.c _divuint.c _divulong.c \
82 _modsint.c _modslong.c _moduint.c _modulong.c \
83 _mulint.c _mullong.c \
85 _iscntrl.c _isdigit.c _isgraph.c \
86 _isprint.c _ispunct.c _isspace.c \
87 _islower.c _isupper.c _isxdigit.c \
89 _strcat.c _strchr.c _strcmp.c _strcpy.c \
90 _strcspn.c _strlen.c _strncat.c _strncmp.c \
91 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
93 _memcmp.c _memcpy.c _memmove.c _memset.c \
94 _heap.c calloc.c malloc.c realloc.c free.c \
95 printf_large.c sprintf.c vprintf.c puts.c gets.c \
96 printf_fast.c printf_fast_f.c printf_tiny.c printfl.c \
97 assert.c time.c bpx.c \
98 _fscmp.c _fsget1arg.c _fsget2args.c _fsnormalize.c \
99 _fsreturnval.c _fsrshift.c _fsswapargs.c _logexpf.c \
100 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
101 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
102 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
103 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
105 OBJECTS = $(patsubst %.c,$(PORTDIR)/%.rel,$(SOURCES))
108 _atof.c _atoi.c _atol.c _itoa.c _ltoa.c \
109 _schar2fs.c _sint2fs.c _slong2fs.c \
110 _uchar2fs.c _uint2fs.c _ulong2fs.c \
111 _fs2schar.c _fs2sint.c _fs2slong.c \
112 _fs2uchar.c _fs2uint.c _fs2ulong.c \
113 _fsadd.c _fsdiv.c _fsmul.c _fssub.c \
114 _fseq.c _fsgt.c _fslt.c _fsneq.c \
115 _divslong.c _divulong.c \
116 _modslong.c _modulong.c \
118 abs.c labs.c rand.c \
119 _iscntrl.c _isdigit.c _isgraph.c \
120 _isprint.c _ispunct.c _isspace.c \
121 _islower.c _isupper.c _isxdigit.c \
123 _strcat.c _strchr.c _strcmp.c _strcpy.c \
124 _strcspn.c _strlen.c _strncat.c _strncmp.c \
125 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
126 _strstr.c _strtok.c \
127 _memcmp.c _memcpy.c _memmove.c _memset.c \
128 calloc.c malloc.c realloc.c free.c \
129 printf_large.c sprintf.c vprintf.c puts.c gets.c \
131 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
132 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
133 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
134 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
136 Z80OBJECTS = $(Z80SOURCES:%.c=$(PORTDIR)/%.o)
138 XA51SOURCES = _atof.c _atoi.c _atol.c _schar2fs.c \
139 _divsint.c _divslong.c _divuint.c \
140 _divulong.c _fs2schar.c _fs2sint.c _fs2slong.c \
141 _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
142 _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
144 _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
145 _islower.c _isprint.c _ispunct.c _isspace.c \
146 _isupper.c _isxdigit.c _slong2fs.c _memcmp.c \
147 _memcpy.c _memmove.c _memset.c _modsint.c _modslong.c \
148 _moduint.c _modulong.c _mulint.c _mullong.c \
149 abs.c labs.c rand.c \
150 _strcat.c _strchr.c _strcmp.c _strcpy.c \
151 _strcspn.c _strlen.c _strncat.c _strncmp.c \
152 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
153 _strstr.c _strtok.c \
154 _uchar2fs.c _uint2fs.c _ulong2fs.c \
155 _heap.c calloc.c malloc.c realloc.c free.c \
157 printf_large.c puts.c gets.c \
159 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
160 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
161 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
162 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
164 XA51OBJECTS = $(XA51SOURCES:%.c=$(PORTDIR)/%.rel)
167 _atof.c _atoi.c _atol.c _itoa.c _ltoa.c \
168 _schar2fs.c _sint2fs.c _slong2fs.c \
169 _uchar2fs.c _uint2fs.c _ulong2fs.c \
170 _fs2schar.c _fs2sint.c _fs2slong.c \
171 _fs2uchar.c _fs2uint.c _fs2ulong.c \
172 _fsadd.c _fsdiv.c _fsmul.c _fssub.c \
173 _fseq.c _fsgt.c _fslt.c _fsneq.c \
174 _divsint.c _divslong.c \
175 _modsint.c _modslong.c _moduint.c _modulong.c \
176 abs.c labs.c rand.c \
177 _iscntrl.c _isdigit.c _isgraph.c \
178 _isprint.c _ispunct.c _isspace.c \
179 _islower.c _isupper.c _isxdigit.c \
181 _strcat.c _strchr.c _strcmp.c _strcpy.c \
182 _strcspn.c _strlen.c _strncat.c _strncmp.c \
183 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
184 _strstr.c _strtok.c \
185 _memcmp.c _memcpy.c _memmove.c _memset.c \
186 _heap.c calloc.c malloc.c realloc.c free.c \
187 printf_large.c sprintf.c vprintf.c puts.c gets.c \
189 fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
190 cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
191 asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
192 sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
194 HC08OBJECTS = $(patsubst %.c,$(PORTDIR)/%.rel,$(HC08SOURCES))
198 include $(srcdir)/incl.mk
200 ifeq ($(OPT_DISABLE_DS390), 0)
201 TARGETS += model-ds390
204 ifeq ($(OPT_DISABLE_DS400), 0)
205 TARGETS += model-ds400
208 ifeq ($(OPT_DISABLE_HC08), 0)
209 TARGETS += model-hc08
212 ifeq ($(OPT_DISABLE_MCS51), 0)
213 TARGETS += models small-mcs51-stack-auto
216 ifeq ($(OPT_DISABLE_PIC), 0)
217 TARGETS += model-pic14
220 ifeq ($(OPT_DISABLE_PIC16), 0)
221 TARGETS += model-pic16
224 ifeq ($(OPT_DISABLE_Z80), 0)
228 ifeq ($(OPT_DISABLE_GBZ80), 0)
229 TARGETS += model-gbz80
232 # Compiling entire program or any subproject
233 # ------------------------------------------
234 all: checkconf $(TARGETS)
236 objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate
239 if [ "`grep mcs51 $(top_builddir)/ports.build`" = mcs51 ]; then \
240 for model in $(MODELS); do \
241 $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model PORTINCDIR=$(INCDIR)/mcs51 objects; \
245 small-mcs51-stack-auto:
246 if [ "`grep mcs51 $(top_builddir)/ports.build`" = mcs51 ]; then \
247 $(MAKE) MODELFLAGS="--model-small --stack-auto" PORT=small PORTDIR=$(BUILDDIR)/small-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
250 model-mcs51-stack-auto:
251 if [ "`grep mcs51 $(top_builddir)/ports.build`" = mcs51 ]; then \
252 for model in $(MODELS); do \
253 $(MAKE) MODELFLAGS="--model-$$model --stack-auto" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
257 model-mcs51-xstack-auto:
258 if [ "`grep mcs51 $(top_builddir)/ports.build`" = mcs51 ]; then \
259 for model in $(MODELS); do \
260 $(MAKE) MODELFLAGS="--model-$$model --stack-auto --xstack" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-xstack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
265 if [ "`grep ds390 $(top_builddir)/ports.build`" = ds390 ]; then \
266 $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \
270 if [ "`grep ds400 $(top_builddir)/ports.build`" = ds400 ]; then \
271 $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \
275 if [ "`grep xa51 $(top_builddir)/ports.build`" = xa51 ]; then \
276 $(MAKE) MODELFLAGS="-mxa51" PORT=xa51 objects-xa51; \
279 objects-xa51: build-dir $(XA51OBJECTS) port-specific-objects
280 cd $(PORTDIR); ls *$(OEXT) > lib$(PORT).lib
283 if [ "`grep z80 $(top_builddir)/ports.build`" = z80 ]; then \
284 $(MAKE) MODELFLAGS="-mz80" PORT=z80 objects-z80 OEXT=.o; \
288 if [ "`grep z80 $(top_builddir)/ports.build`" = z80 ]; then \
289 $(MAKE) MODELFLAGS="-mgbz80" PORT=gbz80 objects-z80 OEXT=.o; \
292 objects-z80: build-dir $(Z80OBJECTS) port-specific-objects clean_intermediate
293 cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
296 if [ "`grep hc08 $(top_builddir)/ports.build`" = hc08 ]; then \
297 $(MAKE) MODELFLAGS="-mhc08" PORT=hc08 objects-hc08; \
300 objects-hc08: build-dir $(HC08OBJECTS) port-specific-objects clean_intermediate
301 cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
304 if [ "`grep pic16 $(top_builddir)/ports.build`" = pic16 ]; then \
305 $(MAKE) MODELFLAGS="-mpic16" PORT=pic16 OEXT=.lib objects-pic16; \
308 objects-pic16: build-dir port-specific-objects-pic16 clean_intermediate-pic16
309 -cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
311 # yes, we do reuse the *-pic16 rules for pic14
313 if [ "`grep pic $(top_builddir)/ports.build | grep -v pic16`" = pic ]; then \
314 $(MAKE) MODELFLAGS="-mpic14" PORT=pic OEXT=.lib objects-pic16; \
317 build-dir: $(PORTDIR)
322 port-specific-objects:
323 -if [ -f $(PORT)/Makefile ]; then \
324 $(MAKE) -C $(PORT); \
325 cp -f $(PORT)/*.lib $(PORT)/*$(OEXT) $(PORTDIR); \
328 port-specific-objects-pic16:
329 -if [ -f $(PORT)/Makefile ]; then \
330 mkdir -p $(PORT)/bin; \
331 $(MAKE) -C $(PORT); \
332 cp -f $(PORT)/bin/*.* $(PORTDIR); \
336 cp $(srcdir)/*.lib $(PORTDIR)
339 rm -f $(PORTDIR)/*.lst $(PORTDIR)/*.sym
341 clean_intermediate-pic16:
342 $(MAKE) -C $(PORT) clean-intermediate
344 # Compiling and installing everything and runing test
345 # ---------------------------------------------------
346 install: all installdirs
347 $(CP_U) -r $(BUILDDIR)/* $(sdcc_libdir)
348 $(CP_U) -r $(MODELS) $(srcdir)/mcs51 $(srcdir)/ds390 $(srcdir)/ds400 \
349 $(srcdir)/gbz80 $(srcdir)/z80 $(srcdir)/hc08 \
350 $(srcdir)/pic $(srcdir)/pic16 $(srcdir)/*.c $(sdcc_libdir)/src
351 $(CP_U) -r $(MODELS) mcs51 ds390 ds400 gbz80 z80 hc08 $(sdcc_libdir)/src
353 for src in $(MODELS) ds390 ds400 gbz80 z80 hc08 pic pic16; do \
354 find $(sdcc_libdir)/src/$$src -depth \
355 \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
356 -name '*.lst' -o -name '*.asm' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \
357 -name 'Makefile*' \) \
358 -exec rm -rf {}+ \; ; \
360 find $(sdcc_libdir)/src/mcs51 -depth \
361 \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
362 -name '*.lst' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \
363 -name 'Makefile*' \) \
366 # Deleting all the installed files
367 # --------------------------------
369 rm -rf $(sdcc_libdir)
371 # Performing self-test
372 # --------------------
376 # Performing installation test
377 # ----------------------------
381 # Creating installation directories
382 # ---------------------------------
384 [ -d $(sdcc_libdir) ] || mkdir -p $(sdcc_libdir)
385 for model in $(MODELS); do \
386 [ -d $(sdcc_libdir)/$$model ] || \
387 mkdir -p $(sdcc_libdir)/$$model; \
389 for libdir in small-stack-auto ds390 ds400 hc08 pic16 pic; do \
390 [ -d $(sdcc_libdir)/$$libdir ] || mkdir -p $(sdcc_libdir)/$$libdir; \
392 mkdir -p $(sdcc_libdir)/src
394 # Creating dependencies
395 # ---------------------
398 Makefile.dep: $(SOURCES) $(INCDIR)/*.h $(PORTINCDIR)/*.h
400 for i in $(filter %.c,$^); do \
401 $(CPP) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \
402 cat $${i}.dep >>Makefile.dep; \
406 ifeq "$(findstring $(MAKECMDGOALS),uninstall check installcheck installdirs checkconf \
407 clean distclean mostlyclean realclean)" ""
410 include $(srcdir)/clean.mk
417 $(PORTDIR)/%$(OEXT): %.c
418 $(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
420 # Remaking configuration
421 # ----------------------
423 @if [ -f $(top_builddir)/devel ]; then\
424 $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" \
428 # End of main_in.mk/main.mk