8e91993490f4d070746af1b736d9f35acde8b96e
[fw/sdcc] / device / lib / Makefile.in
1 #
2 #
3 #
4
5 VERSION         = @VERSION@
6 VERSIONHI       = @VERSIONHI@
7 VERSIONLO       = @VERSIONLO@
8 VERSIONP        = @VERSIONP@
9
10 SHELL           = /bin/sh
11 CPP             = @CPP@
12 INSTALL         = @INSTALL@
13 CP              = @CP@
14
15 ifeq ($(shell uname -s),Linux)
16 CP_U    = $(CP) -u
17 else
18 CP_U    = $(CP)
19 endif
20
21 top_builddir    = @top_builddir@
22 top_srcdir      = @top_srcdir@
23 VPATH           = @srcdir@
24 srcdir          = @srcdir@
25 INCDIR          = $(top_srcdir)/device/include
26 ifndef PORTINCDIR
27 PORTINCDIR      = $(INCDIR)/mcs51
28 endif
29
30 CC              = $(top_builddir)/bin/sdcc
31 CPP             = $(top_builddir)/bin/sdcpp
32
33 prefix          = @prefix@
34 exec_prefix     = @exec_prefix@
35 bindir          = @bindir@
36 libdir          = @libdir@
37 datadir         = @datadir@
38 datarootdir     = @datarootdir@
39 includedir      = @includedir@
40 mandir          = @mandir@
41 man1dir         = $(mandir)/man1
42 man2dir         = $(mandir)/man2
43 infodir         = @infodir@
44
45 lib_dir_suffix  = @lib_dir_suffix@
46
47 sdcc_libdir     = $(DESTDIR)$(datadir)/$(lib_dir_suffix)
48
49 CPPFLAGS        = -I$(INCDIR) -I$(PORTINCDIR)
50 CFLAGS          = $(MODELFLAGS) --nostdinc --std-c99
51
52 BUILDDIR        = build
53 # Default
54 PORT            = z80
55 ifndef PORTDIR
56 PORTDIR         = $(BUILDDIR)/$(PORT)
57 endif
58
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@
69
70 SOURCES =       _autobaud.c _bp.c _decdptr.c \
71                 _gptrget.c _gptrgetc.c _gptrput.c \
72                 _ser.c _setjmp.c \
73                 serial.c ser_ir.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 \
84                 abs.c labs.c rand.c \
85                 _iscntrl.c _isdigit.c _isgraph.c \
86                 _isprint.c _ispunct.c _isspace.c \
87                 _islower.c _isupper.c _isxdigit.c \
88                 _spx.c _startup.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 \
92                 _strstr.c _strtok.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
104
105 OBJECTS         = $(patsubst %.c,$(PORTDIR)/%.rel,$(SOURCES))
106
107 Z80SOURCES =    \
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 \
117                 _mullong.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 \
122                 _startup.c \
123                 _strcat.c _strchr.c _strcmp.c _strcpy.c \
124                 _strcspn.c _strncat.c _strncmp.c \
125                 _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
126                 _strstr.c _strtok.c \
127                 _memcmp.c _memcpy.c _memset.c \
128                 _calloc.c _malloc.c _realloc.c _free.c \
129                 printf_large.c sprintf.c vprintf.c puts.c gets.c \
130                 assert.c time.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
135
136 Z80OBJECTS      = $(Z80SOURCES:%.c=$(PORTDIR)/%.o)
137
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 \
143                   _fsneq.c _fssub.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 \
156                   puts.c gets.c \
157                   printf_large.c puts.c gets.c \
158                   assert.c time.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
163
164 XA51OBJECTS      = $(XA51SOURCES:%.c=$(PORTDIR)/%.rel)
165
166 HC08SOURCES =   \
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 \
180                 _spx.c _startup.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 \
188                 assert.c time.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
193
194 HC08OBJECTS     = $(patsubst %.c,$(PORTDIR)/%.rel,$(HC08SOURCES))
195
196 OEXT            = .rel
197
198 include $(srcdir)/incl.mk
199
200 ifeq ($(OPT_DISABLE_DS390), 0)
201 TARGETS        += model-ds390
202 endif
203
204 ifeq ($(OPT_DISABLE_DS400), 0)
205 TARGETS        += model-ds400
206 endif
207
208 ifeq ($(OPT_DISABLE_HC08), 0)
209 TARGETS        += model-hc08
210 endif
211
212 ifeq ($(OPT_DISABLE_MCS51), 0)
213 TARGETS        += models small-mcs51-stack-auto
214 endif
215
216 ifeq ($(OPT_DISABLE_PIC), 0)
217 TARGETS        += model-pic14
218 endif
219
220 ifeq ($(OPT_DISABLE_PIC16), 0)
221 TARGETS        += model-pic16
222 endif
223
224 ifeq ($(OPT_DISABLE_Z80), 0)
225 TARGETS        += model-z80
226 endif
227
228 ifeq ($(OPT_DISABLE_GBZ80), 0)
229 TARGETS        += model-gbz80
230 endif
231
232 # Compiling entire program or any subproject
233 # ------------------------------------------
234 all: checkconf $(TARGETS)
235
236 objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate
237
238 models:
239         if grep '^mcs51\>' $(top_builddir)/ports.build > /dev/null; then \
240           for model in $(MODELS); do \
241             $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model PORTINCDIR=$(INCDIR)/mcs51 objects; \
242           done \
243         fi
244
245 small-mcs51-stack-auto:
246         if grep '^mcs51\>' $(top_builddir)/ports.build > /dev/null; then \
247           $(MAKE) MODELFLAGS="--model-small --stack-auto" PORT=small PORTDIR=$(BUILDDIR)/small-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
248         fi
249
250 model-mcs51-stack-auto:
251         if grep '^mcs51\>' $(top_builddir)/ports.build > /dev/null; 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; \
254           done \
255         fi
256
257 model-mcs51-xstack-auto:
258         if grep '^mcs51\>' $(top_builddir)/ports.build > /dev/null; 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; \
261           done \
262         fi
263
264 model-ds390:
265         if grep '^ds390\>' $(top_builddir)/ports.build > /dev/null; then \
266           $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \
267         fi
268
269 model-ds400:
270         if grep '^ds400\>' $(top_builddir)/ports.build > /dev/null; then \
271           $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \
272         fi
273
274 model-xa51:
275         if grep '^xa51\>' $(top_builddir)/ports.build > /dev/null; then \
276           $(MAKE) MODELFLAGS="-mxa51" PORT=xa51 objects-xa51; \
277         fi
278
279 objects-xa51: build-dir $(XA51OBJECTS) port-specific-objects
280         cd $(PORTDIR); ls *$(OEXT) > lib$(PORT).lib
281
282 model-z80:
283         if grep '^z80\>' $(top_builddir)/ports.build > /dev/null; then \
284           $(MAKE) MODELFLAGS="-mz80" PORT=z80 objects-z80 OEXT=.o; \
285         fi
286
287 model-gbz80:
288         if grep '^z80\>' $(top_builddir)/ports.build > /dev/null; then \
289           $(MAKE) MODELFLAGS="-mgbz80" PORT=gbz80 objects-z80 OEXT=.o; \
290         fi
291
292 objects-z80: build-dir $(Z80OBJECTS) port-specific-objects clean_intermediate
293         cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
294
295 model-hc08:
296         if grep '^hc08\>' $(top_builddir)/ports.build > /dev/null; then \
297           $(MAKE) MODELFLAGS="-mhc08" PORT=hc08 objects-hc08; \
298         fi
299
300 objects-hc08: build-dir $(HC08OBJECTS) port-specific-objects clean_intermediate
301         cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
302
303 model-pic16:
304         if grep '^pic16\>' $(top_builddir)/ports.build > /dev/null; then \
305           $(MAKE) PORT=pic16 objects-pic16; \
306         fi
307
308 objects-pic16: build-dir port-specific-objects-pic16 clean_intermediate-pic16
309
310 model-pic14:
311         if grep '^pic\>' $(top_builddir)/ports.build > /dev/null; then \
312           $(MAKE) PORT=pic objects-pic14; \
313         fi
314
315 objects-pic14: build-dir port-specific-objects-pic14 clean_intermediate-pic14
316
317 build-dir: $(PORTDIR)
318
319 $(PORTDIR):
320         mkdir -p $(PORTDIR)
321
322 port-specific-objects:
323         -if [ -f $(PORT)/Makefile ]; then \
324           $(MAKE) -C $(PORT); \
325           cp -f $(PORT)/*.lib $(PORT)/*$(OEXT) $(PORTDIR); \
326         fi
327
328 port-specific-objects-pic16:
329         -if [ -f $(PORT)/Makefile ]; then \
330           $(MAKE) -C $(PORT); \
331           for i in $(PORT)/*/lib*.a; do cp -f $$i $(PORTDIR)/$$(basename $$i .a).lib; done; \
332           cp -f $(PORT)/*/crt0*.o $(PORTDIR); \
333         fi
334
335 port-specific-objects-pic14:
336         -if [ -f $(PORT)/Makefile ]; then \
337           mkdir -p $(PORT)/bin; \
338           $(MAKE) -C $(PORT); \
339           cp -f $(PORT)/bin/*.* $(PORTDIR); \
340         fi
341
342 lib-files:
343         cp $(srcdir)/*.lib $(PORTDIR)
344
345 clean_intermediate:
346         rm -f $(PORTDIR)/*.lst $(PORTDIR)/*.sym
347
348 clean_intermediate-pic16:
349         $(MAKE) -C $(PORT) clean-intermediate
350
351 clean_intermediate-pic14:
352         $(MAKE) -C $(PORT) clean-intermediate
353
354 # Compiling and installing everything and runing test
355 # ---------------------------------------------------
356 install: all installdirs
357         $(CP_U) -r $(BUILDDIR)/* $(sdcc_libdir)
358         $(CP_U) -r $(MODELS) $(srcdir)/mcs51 $(srcdir)/ds390 $(srcdir)/ds400 \
359                              $(srcdir)/gbz80 $(srcdir)/z80 $(srcdir)/hc08 \
360                              $(srcdir)/pic $(srcdir)/pic16 $(srcdir)/*.c $(sdcc_libdir)/src
361         $(CP_U) -r $(MODELS) mcs51 ds390 ds400 gbz80 z80 hc08 $(sdcc_libdir)/src
362
363         for src in $(MODELS) ds390 ds400 gbz80 z80 hc08 pic pic16; do \
364           find $(sdcc_libdir)/src/$$src -depth \
365             \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
366             -name '*.lst' -o -name '*.asm' -o -name '.svn' -o -name 'autom4te.cache' -o \
367             -name 'build' -o -name 'bin' -o -name 'Makefile*' -o -name 'config*' -o \
368             -name 'depcomp' -o -name 'missing' -o -name 'install-sh' -o \
369             -name 'bootstrap.sh' \) \
370             -exec rm -rf {} + ; \
371         done
372         find $(sdcc_libdir)/src/mcs51 -depth \
373           \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
374           -name '*.lst' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \
375           -name 'Makefile*' \) \
376           -exec rm -rf {} +
377
378 # Deleting all the installed files
379 # --------------------------------
380 uninstall:
381         rm -rf $(sdcc_libdir)
382
383 # Performing self-test
384 # --------------------
385 check:
386
387
388 # Performing installation test
389 # ----------------------------
390 installcheck:
391
392
393 # Creating installation directories
394 # ---------------------------------
395 installdirs:
396         [ -d $(sdcc_libdir) ] || mkdir -p $(sdcc_libdir)
397         for model in $(MODELS); do \
398           [ -d $(sdcc_libdir)/$$model ] || \
399           mkdir -p $(sdcc_libdir)/$$model; \
400         done
401         for libdir in small-stack-auto ds390 ds400 hc08 pic16 pic; do \
402           [ -d $(sdcc_libdir)/$$libdir ] || mkdir -p $(sdcc_libdir)/$$libdir; \
403         done
404         mkdir -p $(sdcc_libdir)/src
405
406 # Creating dependencies
407 # ---------------------
408 dep: Makefile.dep
409
410 Makefile.dep: $(SOURCES) $(INCDIR)/*.h $(PORTINCDIR)/*.h
411         rm -f Makefile.dep
412         for i in $(filter %.c,$^); do \
413           $(CPP) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \
414           cat $${i}.dep >>Makefile.dep; \
415           rm $${i}.dep; \
416         done
417
418 ifeq "$(findstring $(MAKECMDGOALS),uninstall check installcheck installdirs checkconf \
419                                    clean distclean mostlyclean realclean)" ""
420   -include Makefile.dep
421 endif
422 include $(srcdir)/clean.mk
423
424 # My rules
425 # --------
426
427 .SUFFIXES: .rel .o
428
429 $(PORTDIR)/%$(OEXT): %.c
430         $(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
431
432 # Remaking configuration
433 # ----------------------
434 checkconf:
435         @if [ -f $(top_builddir)/devel ]; then\
436           $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" \
437           freshconf;\
438         fi
439
440 # End of main_in.mk/main.mk