Enabled VPATH feature: changed nearly all Makefiles (149 files).
[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      = $(srcdir)/$(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 includedir      = @includedir@
39 mandir          = @mandir@
40 man1dir         = $(mandir)/man1
41 man2dir         = $(mandir)/man2
42 infodir         = @infodir@
43
44 lib_dir_suffix  = @lib_dir_suffix@
45
46 sdcc_libdir     = $(DESTDIR)$(datadir)/$(lib_dir_suffix)
47
48 CPPFLAGS        = -I$(INCDIR) -I$(PORTINCDIR)
49 CFLAGS          = $(MODELFLAGS) --nostdinc --std-sdcc99
50
51 BUILDDIR        = build
52 # Default
53 PORT            = z80
54 ifndef PORTDIR
55 PORTDIR         = $(BUILDDIR)/$(PORT)
56 endif
57
58 OPT_DISABLE_AVR   = @OPT_DISABLE_AVR@
59 OPT_DISABLE_DS390 = @OPT_DISABLE_DS390@
60 OPT_DISABLE_DS400 = @OPT_DISABLE_DS400@
61 OPT_DISABLE_HC08  = @OPT_DISABLE_HC08@
62 OPT_DISABLE_MCS51 = @OPT_DISABLE_MCS51@
63 OPT_DISABLE_PIC   = @OPT_DISABLE_PIC@
64 OPT_DISABLE_PIC16 = @OPT_DISABLE_PIC16@
65 OPT_DISABLE_XA51  = @OPT_DISABLE_XA51@
66 OPT_DISABLE_Z80   = @OPT_DISABLE_Z80@
67
68 SOURCES         = _atof.c _atoi.c _atol.c _autobaud.c _bp.c _schar2fs.c \
69                   _decdptr.c _divsint.c _divslong.c _divuint.c \
70                   _divulong.c _fs2schar.c _fs2sint.c _fs2slong.c \
71                   _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
72                   _fsdiv.c _fseq.c _fsgt.c _fslt.c _fscmp.c _fsmul.c \
73                   _fsneq.c _fssub.c _gptrget.c _gptrgetc.c _gptrput.c \
74                   _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
75                   _islower.c _isprint.c _ispunct.c _isspace.c \
76                   _isupper.c _isxdigit.c _itoa.c _ltoa.c \
77                   _slong2fs.c \
78                   _memcmp.c _memcpy.c _memmove.c _memset.c \
79                   _modsint.c _modslong.c _moduint.c _modulong.c \
80                   _mulint.c _mullong.c \
81                   abs.c labs.c \
82                   _ser.c _setjmp.c \
83                   _spx.c _startup.c \
84                   _strcat.c _strchr.c _strcmp.c _strcpy.c \
85                   _strcspn.c _strlen.c _strncat.c _strncmp.c \
86                   _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
87                   _strstr.c _strtok.c \
88                   _uchar2fs.c _uint2fs.c _ulong2fs.c \
89                   calloc.c malloc.c realloc.c free.c \
90                   serial.c ser_ir.c printfl.c \
91                   printf_large.c sprintf.c vprintf.c puts.c gets.c \
92                   printf_fast.c printf_fast_f.c printf_tiny.c \
93                   assert.c time.c bpx.c \
94                   _fsget1arg.c _fsget2args.c _fsnormalize.c \
95                   _fsreturnval.c _fsrshift.c _fsswapargs.c _logexpf.c \
96                   fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
97                   cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
98                   asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
99                   sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
100
101 OBJECTS         = $(patsubst %.c,$(PORTDIR)/%.rel,$(SOURCES))
102
103 Z80SOURCES      = _atof.c _atoi.c \
104                   _iscntrl.c _isdigit.c _isgraph.c \
105                   _islower.c _isprint.c _ispunct.c _isspace.c \
106                   _isupper.c _isxdigit.c \
107                   _memcmp.c _memcpy.c _memmove.c _memset.c \
108                   _startup.c \
109                   _strcat.c _strchr.c _strcmp.c _strcpy.c \
110                   _strcspn.c _strlen.c _strncat.c _strncmp.c \
111                   _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
112                   _strstr.c _strtok.c \
113                   assert.c \
114                   _modslong.c _modulong.c \
115                   _mullong.c \
116                   abs.c labs.c \
117                   _divslong.c _divulong.c \
118                   calloc.c malloc.c realloc.c free.c \
119                   printf_large.c sprintf.c vprintf.c puts.c gets.c \
120                   _fs2schar.c _fs2sint.c _fs2slong.c \
121                   _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
122                   _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
123                   _fsneq.c _fssub.c \
124                   _uchar2fs.c _uint2fs.c \
125                   _ulong2fs.c \
126                   _slong2fs.c _sint2fs.c _schar2fs.c
127
128 Z80OBJECTS      = $(Z80SOURCES:%.c=$(PORTDIR)/%.o)
129
130 XA51SOURCES      = _atof.c _atoi.c _atol.c _schar2fs.c \
131                   _divsint.c _divslong.c _divuint.c \
132                   _divulong.c _fs2schar.c _fs2sint.c _fs2slong.c \
133                   _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
134                   _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
135                   _fsneq.c _fssub.c \
136                   _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
137                   _islower.c _isprint.c _ispunct.c _isspace.c \
138                   _isupper.c _isxdigit.c _slong2fs.c _memcmp.c \
139                   _memcpy.c _memmove.c _memset.c _modsint.c _modslong.c \
140                   _moduint.c _modulong.c _mulint.c _mullong.c \
141                   abs.c labs.c \
142                   _strcat.c _strchr.c _strcmp.c _strcpy.c \
143                   _strcspn.c _strlen.c _strncat.c _strncmp.c \
144                   _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
145                   _strstr.c _strtok.c \
146                   _uchar2fs.c _uint2fs.c _ulong2fs.c \
147                   calloc.c malloc.c realloc.c free.c \
148                   puts.c gets.c \
149                   printf_large.c puts.c gets.c \
150                   assert.c time.c \
151                   fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
152                   cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
153                   asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
154                   sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
155
156 XA51OBJECTS      = $(XA51SOURCES:%.c=$(PORTDIR)/%.rel)
157
158 HC08SOURCES     = _atof.c _atoi.c _atol.c _schar2fs.c \
159                   _divsint.c _divslong.c \
160                   _fs2schar.c _fs2sint.c _fs2slong.c \
161                   _fs2uchar.c _fs2uint.c _fs2ulong.c _fsadd.c \
162                   _fsdiv.c _fseq.c _fsgt.c _fslt.c _fsmul.c \
163                   _fsneq.c _fssub.c \
164                   _sint2fs.c _iscntrl.c _isdigit.c _isgraph.c \
165                   _islower.c _isprint.c _ispunct.c _isspace.c \
166                   _isupper.c _isxdigit.c _itoa.c _ltoa.c \
167                   _slong2fs.c \
168                   _memcmp.c _memcpy.c _memmove.c _memset.c \
169                   _modsint.c _modslong.c _moduint.c _modulong.c \
170                   abs.c labs.c \
171                   _spx.c _startup.c \
172                   _strcat.c _strchr.c _strcmp.c _strcpy.c \
173                   _strcspn.c _strlen.c _strncat.c _strncmp.c \
174                   _strncpy.c _strpbrk.c _strrchr.c _strspn.c \
175                   _strstr.c _strtok.c \
176                   _uchar2fs.c _uint2fs.c _ulong2fs.c \
177                   calloc.c malloc.c realloc.c free.c \
178                   printf_large.c sprintf.c vprintf.c \
179                   assert.c time.c \
180                   fabsf.c frexpf.c ldexpf.c expf.c powf.c sincosf.c sinf.c \
181                   cosf.c logf.c log10f.c sqrtf.c tancotf.c tanf.c cotf.c \
182                   asincosf.c asinf.c acosf.c atanf.c atan2f.c sincoshf.c \
183                   sinhf.c coshf.c tanhf.c floorf.c ceilf.c modff.c errno.c
184
185 HC08OBJECTS     = $(patsubst %.c,$(PORTDIR)/%.rel,$(HC08SOURCES))
186
187 OEXT            = .rel
188
189 include $(srcdir)/incl.mk
190
191 ifeq ($(OPT_DISABLE_DS390), 0)
192 TARGETS        += model-ds390
193 endif
194
195 ifeq ($(OPT_DISABLE_DS400), 0)
196 TARGETS        += model-ds400
197 endif
198
199 ifeq ($(OPT_DISABLE_HC08), 0)
200 TARGETS        += model-hc08
201 endif
202
203 ifeq ($(OPT_DISABLE_MCS51), 0)
204 TARGETS        += models small-mcs51-stack-auto
205 endif
206
207 ifeq ($(OPT_DISABLE_PIC), 0)
208 TARGETS        += model-pic14
209 endif
210
211 ifeq ($(OPT_DISABLE_PIC16), 0)
212 TARGETS        += model-pic16
213 endif
214
215 ifeq ($(OPT_DISABLE_Z80), 0)
216 TARGETS        += model-z80 model-gbz80
217 endif
218
219
220 # Compiling entire program or any subproject
221 # ------------------------------------------
222 all: checkconf $(TARGETS)
223
224 objects: build-dir $(OBJECTS) port-specific-objects lib-files clean_intermediate
225
226 models:
227         if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \
228           for model in $(MODELS); do \
229             $(MAKE) MODELFLAGS="--model-$$model" PORT=$$model PORTINCDIR=$(INCDIR)/mcs51 objects; \
230           done \
231         fi
232
233 small-mcs51-stack-auto:
234         if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \
235           $(MAKE) MODELFLAGS="--model-small --stack-auto" PORT=small PORTDIR=$(BUILDDIR)/small-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
236         fi
237
238 model-mcs51-stack-auto:
239         if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \
240           for model in $(MODELS); do \
241             $(MAKE) MODELFLAGS="--model-$$model --stack-auto" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-stack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
242           done \
243         fi
244
245 model-mcs51-xstack-auto:
246         if [ "`grep mcs51 $(top_builddir)ports.build`" = mcs51 ]; then \
247           for model in $(MODELS); do \
248             $(MAKE) MODELFLAGS="--model-$$model --stack-auto --xstack" PORT=$$model PORTDIR=$(BUILDDIR)/$$model-xstack-auto PORTINCDIR=$(INCDIR)/mcs51 objects; \
249           done \
250         fi
251
252 model-ds390:
253         if [ "`grep ds390 $(top_builddir)ports.build`" = ds390 ]; then \
254           $(MAKE) MODELFLAGS="-mds390" PORT=ds390 PORTINCDIR=$(INCDIR)/mcs51 objects; \
255         fi
256
257 model-ds400:
258         if [ "`grep ds400 $(top_builddir)ports.build`" = ds400 ]; then \
259           $(MAKE) MODELFLAGS="-mds400" PORT=ds400 PORTINCDIR=$(INCDIR)/mcs51 objects; \
260         fi
261
262 model-xa51:
263         if [ "`grep xa51 $(top_builddir)ports.build`" = xa51 ]; then \
264           $(MAKE) MODELFLAGS="-mxa51" PORT=xa51 objects-xa51; \
265         fi
266
267 objects-xa51: build-dir $(XA51OBJECTS) port-specific-objects
268         cd $(PORTDIR); ls *$(OEXT) > lib$(PORT).lib
269
270 model-z80:
271         if [ "`grep z80 $(top_builddir)ports.build`" = z80 ]; then \
272           $(MAKE) MODELFLAGS="-mz80" PORT=z80 objects-z80 OEXT=.o; \
273         fi
274
275 model-gbz80:
276         if [ "`grep z80 $(top_builddir)ports.build`" = z80 ]; then \
277           $(MAKE) MODELFLAGS="-mgbz80" PORT=gbz80 objects-z80 OEXT=.o; \
278         fi
279
280 objects-z80: build-dir $(Z80OBJECTS) port-specific-objects clean_intermediate
281         cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
282
283 model-hc08:
284         if [ "`grep hc08 $(top_builddir)ports.build`" = hc08 ]; then \
285           $(MAKE) MODELFLAGS="-mhc08" PORT=hc08 objects-hc08; \
286         fi
287
288 objects-hc08: build-dir $(HC08OBJECTS) port-specific-objects clean_intermediate
289         cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
290
291 model-pic16:
292         if [ "`grep pic16 $(top_builddir)ports.build`" = pic16 ]; then \
293           $(MAKE) MODELFLAGS="-mpic16" PORT=pic16 OEXT=.lib objects-pic16; \
294         fi
295
296 objects-pic16: build-dir port-specific-objects-pic16 clean_intermediate-pic16
297         -cd $(PORTDIR); ls *$(OEXT) > $(PORT).lib
298
299 # yes, we do reuse the *-pic16 rules for pic14
300 model-pic14:
301         if [ "`grep pic $(top_builddir)ports.build | grep -v pic16`" = pic ]; then \
302           $(MAKE) MODELFLAGS="-mpic14" PORT=pic OEXT=.lib objects-pic16; \
303         fi
304
305 build-dir: $(PORTDIR)
306
307 $(PORTDIR):
308         mkdir -p $(PORTDIR)
309
310 port-specific-objects:
311         if [ -f $(PORT)/Makefile ]; then \
312           $(MAKE) -C $(PORT); \
313           cp -f $(PORT)/*.lib $(PORT)/*$(OEXT) $(PORTDIR); \
314         fi
315
316 port-specific-objects-pic16:
317         -if [ -f $(PORT)/Makefile ]; then \
318           mkdir -p $(PORT)/bin; \
319           $(MAKE) -C $(PORT); \
320           cp -f $(PORT)/bin/*.* $(PORTDIR); \
321         fi
322
323 lib-files:
324         cp $(srcdir)/*.lib $(PORTDIR)
325
326 clean_intermediate:
327         rm -f $(PORTDIR)/*.lst $(PORTDIR)/*.sym
328
329 clean_intermediate-pic16:
330         $(MAKE) -C $(PORT) clean-intermediate
331
332 # Compiling and installing everything and runing test
333 # ---------------------------------------------------
334 install: all installdirs
335         $(CP_U) -r $(BUILDDIR)/* $(sdcc_libdir)
336         $(CP_U) -r $(MODELS) $(srcdir)/mcs51 $(srcdir)/ds390 $(srcdir)/ds400 \
337                              $(srcdir)/gbz80 $(srcdir)/z80 $(srcdir)/hc08 \
338                              $(srcdir)/pic $(srcdir)/pic16 $(srcdir)/*.c $(sdcc_libdir)/src
339         $(CP_U) -r $(MODELS) mcs51 ds390 ds400 gbz80 z80 hc08 $(sdcc_libdir)/src
340
341         for src in $(MODELS) ds390 ds400 gbz80 z80 hc08 pic pic16; do \
342           find $(sdcc_libdir)/src/$$src -depth \
343             \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
344             -name '*.lst' -o -name '*.asm' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \
345             -name 'Makefile*' \) \
346             -exec rm -r {} \; ; \
347         done
348         find $(sdcc_libdir)/src/mcs51 -depth \
349           \( -name '*.rel' -o -name '*.dump*' -o -name '*.sym' -o -name '*.o' -o -name '*.lib' -o \
350           -name '*.lst' -o -name '.svn' -o -name 'build' -o -name 'bin' -o \
351           -name 'Makefile*' \) \
352           -exec rm -r {} \;
353
354 # Deleting all the installed files
355 # --------------------------------
356 uninstall:
357         rm -rf $(sdcc_libdir)
358
359 # Performing self-test
360 # --------------------
361 check:
362
363
364 # Performing installation test
365 # ----------------------------
366 installcheck:
367
368
369 # Creating installation directories
370 # ---------------------------------
371 installdirs:
372         [ -d $(sdcc_libdir) ] || mkdir -p $(sdcc_libdir)
373         for model in $(MODELS); do \
374           [ -d $(sdcc_libdir)/$$model ] || \
375           mkdir -p $(sdcc_libdir)/$$model; \
376         done
377         for libdir in small-stack-auto ds390 ds400 hc08 pic16 pic; do \
378           [ -d $(sdcc_libdir)/$$libdir ] || mkdir -p $(sdcc_libdir)/$$libdir; \
379         done
380         mkdir -p $(sdcc_libdir)/src
381
382 # Creating dependencies
383 # ---------------------
384 dep: Makefile.dep
385
386 Makefile.dep: $(SOURCES) $(INCDIR)/*.h $(PORTINCDIR)/*.h
387         rm -f Makefile.dep
388         for i in $(filter %.c,$^); do \
389           $(CPP) -std=c99 -M $(CPPFLAGS) $$i >$${i}.dep; \
390           cat $${i}.dep >>Makefile.dep; \
391           rm $${i}.dep; \
392         done
393
394 ifeq "$(findstring $(MAKECMDGOALS),uninstall check installcheck installdirs checkconf \
395                                    clean distclean mostlyclean realclean)" ""
396   include Makefile.dep
397 endif
398 include $(srcdir)/clean.mk
399
400 # My rules
401 # --------
402
403 .SUFFIXES: .rel .o
404
405 $(PORTDIR)/%$(OEXT): %.c
406         $(CC) $(CPPFLAGS) $(CFLAGS) -c $< -o $@
407
408 # Remaking configuration
409 # ----------------------
410 checkconf:
411         @if [ -f $(top_builddir)devel ]; then\
412           $(MAKE) -f $(srcdir)/conf.mk srcdir="$(srcdir)" top_builddir="$(top_builddir)" \
413           freshconf;\
414         fi
415
416 # End of main_in.mk/main.mk