* configure.in: Don't set files and links. Don't call
[external/binutils.git] / gas / Makefile.in
1 # Makefile for GNU Assembler
2 #   Copyright (C) 1987, 88, 89, 90, 91, 92, 93, 94, 95, 96, 1997
3 #   Free Software Foundation, Inc.
4
5 # This file is part of GNU GAS.
6
7 # GNU GAS is free software; you can redistribute it and/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation; either version 2, or (at your option)
10 # any later version.
11
12 # GNU GAS is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 # GNU General Public License for more details.
16
17 # You should have received a copy of the GNU General Public License
18 # along with GNU GAS; see the file COPYING.  If not, write to the Free
19 # Software Foundation, 59 Temple Place - Suite 330, Boston, MA
20 # 02111-1307, USA.
21
22 # The targets for external use include:
23 # all, doc, proto, install, uninstall, includes, TAGS,
24 # clean, mostlyclean, distclean, realclean, stage1, stage2, stage3, stage4.
25
26 # Variables that exist for you to override.
27 # See below for how to change them for certain systems.
28
29 VPATH = @srcdir@
30 srcdir = @srcdir@
31 srcroot = $(srcdir)/..
32
33 target_alias = @target_alias@
34 prefix = @prefix@
35
36 program_transform_name = @program_transform_name@
37 exec_prefix = @exec_prefix@
38 bindir = @bindir@
39 libdir = @libdir@
40 tooldir = $(exec_prefix)/$(target_alias)
41
42 datadir = @datadir@
43 mandir = @mandir@
44 man1dir = $(mandir)/man1
45 man2dir = $(mandir)/man2
46 man3dir = $(mandir)/man3
47 man4dir = $(mandir)/man4
48 man5dir = $(mandir)/man5
49 man6dir = $(mandir)/man6
50 man7dir = $(mandir)/man7
51 man8dir = $(mandir)/man8
52 man9dir = $(mandir)/man9
53 infodir = @infodir@
54 includedir = @includedir@
55
56 VERSION=cygnus-2.7.1
57
58 SHELL = /bin/sh
59
60 INSTALL = $${srcroot}/install.sh -c
61 INSTALL_PROGRAM = @INSTALL_PROGRAM@
62 INSTALL_DATA = @INSTALL_DATA@
63 INSTALL_XFORM = $(INSTALL) -t='$(program_transform_name)'
64 INSTALL_XFORM1= $(INSTALL_XFORM) -b=.1
65
66 DISTSTUFF= make-gas.com m68k-parse.c itbl-parse.c itbl-lex.c
67
68 AR = ar
69 AR_FLAGS = qv
70 BISON = `if [ -f ../bison/bison ] ; then echo ../bison/bison -y -L../bison/bison ; else echo bison -y ; fi`
71 BISONFLAGS =
72 LEX = `if [ -f ../flex/flex ] ; then echo ../flex/flex ;  else echo flex ; fi`
73 LEXFLAGS =
74 MAKEINFO = makeinfo
75 TEXI2DVI = texi2dvi
76 RANLIB = ranlib
77 CC = @CC@
78 HLDFLAGS = @HLDFLAGS@
79 HLDENV = @HLDENV@
80 RPATH_ENVVAR = @RPATH_ENVVAR@
81 CFLAGS = -g
82 LDFLAGS =
83
84 MAKEOVERRIDES=
85
86 EXPECT = `if [ -f $${rootme}/../expect/expect ] ; then \
87           echo $${rootme}/../expect/expect ; \
88           else echo expect ; fi`
89
90 FLAGS_TO_PASS = \
91         "prefix=$(prefix)" \
92         "exec_prefix=$(exec_prefix)" \
93         "tooldir=$(tooldir)" \
94         "AR=$(AR)" \
95         "AR_FLAGS=$(AR_FLAGS)" \
96         "CC=$(CC)" \
97         "CFLAGS=$(CFLAGS)" \
98         "RANLIB=$(RANLIB)" \
99         "LOADLIBES=$(LOADLIBES)" \
100         "LDFLAGS=$(LDFLAGS)" \
101         "BISON=$(BISON)" \
102         "LEX=$(LEX)" \
103         "MAKEINFO=$(MAKEINFO)" \
104         "INSTALL=$(INSTALL)" \
105         "INSTALL_DATA=$(INSTALL_DATA)" \
106         "INSTALL_PROGRAM=$(INSTALL_PROGRAM)"
107
108 RUNTEST = `if [ -f $${srcdir}/../dejagnu/runtest ] ; then \
109                 echo $${srcdir}/../dejagnu/runtest ; else echo runtest; \
110            fi`
111 RUNTESTFLAGS=
112
113 TARG_CPU_C = $(srcdir)/config/tc-@target_cpu_type@.c
114 TARG_CPU_O = tc-@target_cpu_type@.o
115 TARG_CPU_H = $(srcdir)/config/tc-@target_cpu_type@.h
116 OBJ_FORMAT_C = $(srcdir)/config/obj-@obj_format@.c
117 OBJ_FORMAT_O = obj-@obj_format@.o
118 OBJ_FORMAT_H = $(srcdir)/config/obj-@obj_format@.h
119 TARG_ENV_H = $(srcdir)/config/te-@te_file@.h
120 ATOF_TARG_C = $(srcdir)/config/atof-@atof@.c
121 ATOF_TARG_O = atof-@atof@.o
122
123 # use @target_cpu_type@ for refering to configured target name
124 IT_HDRS=itbl-parse.h $(srcdir)/itbl-ops.h 
125 IT_SRCS=itbl-parse.c itbl-lex.c $(srcdir)/itbl-ops.c
126 IT_DEPS=$(srcdir)/itbl-parse.y $(srcdir)/itbl-lex.l $(srcdir)/config/itbl-@target_cpu_type@.h
127 IT_OBJS=itbl-parse.o itbl-lex.o itbl-ops.o
128
129 # Lists of files for various purposes.
130
131 SOURCES = \
132         $(srcdir)/app.c \
133         $(srcdir)/as.c \
134         $(srcdir)/atof-generic.c \
135         $(srcdir)/bignum-copy.c \
136         $(srcdir)/cond.c \
137         $(srcdir)/expr.c \
138         $(srcdir)/flonum-konst.c \
139         $(srcdir)/flonum-copy.c \
140         $(srcdir)/flonum-mult.c \
141         $(srcdir)/frags.c \
142         $(srcdir)/hash.c \
143         $(srcdir)/input-file.c \
144         $(srcdir)/input-scrub.c \
145         $(srcdir)/itbl-ops.c \
146         $(srcdir)/literal.c \
147         $(srcdir)/messages.c \
148         $(srcdir)/output-file.c \
149         $(srcdir)/read.c \
150         $(srcdir)/subsegs.c \
151         $(srcdir)/symbols.c \
152         $(srcdir)/write.c \
153         $(srcdir)/listing.c \
154         $(srcdir)/ecoff.c \
155         $(srcdir)/stabs.c
156
157 HEADERS = \
158         $(srcdir)/as.h \
159         $(srcdir)/bignum.h \
160         $(srcdir)/expr.h \
161         $(srcdir)/flonum.h \
162         $(srcdir)/frags.h \
163         $(srcdir)/hash.h \
164         $(srcdir)/input-file.h \
165         $(srcdir)/itbl-ops.h \
166         $(srcdir)/listing.h \
167         $(srcdir)/tc.h \
168         $(srcdir)/obj.h \
169         $(srcdir)/read.h \
170         $(srcdir)/struc-symbol.h \
171         $(srcdir)/subsegs.h \
172         $(srcdir)/symbols.h \
173         $(srcdir)/write.h \
174         $(srcdir)/ecoff.h
175
176 TE_OBJS=
177
178 # @target_frag@
179
180 OBJS = \
181         $(TARG_CPU_O) \
182         $(OBJ_FORMAT_O) \
183         $(ATOF_TARG_O) \
184         app.o \
185         as.o \
186         atof-generic.o \
187         bignum-copy.o \
188         cond.o \
189         expr.o \
190         flonum-konst.o \
191         flonum-copy.o \
192         flonum-mult.o \
193         frags.o \
194         hash.o \
195         input-file.o \
196         input-scrub.o \
197         literal.o \
198         messages.o \
199         output-file.o \
200         read.o \
201         subsegs.o \
202         symbols.o \
203         write.o \
204         listing.o \
205         ecoff.o \
206         stabs.o \
207         sb.o \
208         macro.o \
209         @extra_objects@ \
210         $(TE_OBJS)
211
212 GASPOBJS = \
213         gasp.o \
214         macro.o \
215         sb.o \
216         hash.o
217
218 all: .gdbinit as.new gasp.new
219         @srcroot=`cd $(srcroot); pwd`; export srcroot; \
220         (cd doc ; $(MAKE) $(FLAGS_TO_PASS) all)
221
222 dvi info install-info clean-info:
223         @srcroot=`cd $(srcroot); pwd`; export srcroot; \
224         (cd doc ; $(MAKE) $(FLAGS_TO_PASS) $@)
225
226 make-gas.com: stamp-mk.com
227 stamp-mk.com: vmsconf.sh Makefile
228         sh $(srcdir)/vmsconf.sh $(OBJS) > new-make.com
229         $(srcdir)/../move-if-change new-make.com $(srcdir)/make-gas.com
230         touch stamp-mk.com
231
232 # Now figure out from those variables how to compile and link.
233
234 # This is the variable actually used when we compile.
235 ALL_CFLAGS = -D_GNU_SOURCE $(INTERNAL_CFLAGS) $(CROSS) $(CFLAGS) $(HDEFINES) $(TDEFINES)
236
237 # How to link with both our special library facilities
238 # and the system's installed libraries.
239
240 LIBDEPS = @OPCODES_DEP@ @BFDDEP@ $(LOCAL_LOADLIBES) ../libiberty/libiberty.a
241 LIBS = @OPCODES_LIB@ @BFDLIB@ $(LOCAL_LOADLIBES) ../libiberty/libiberty.a
242
243 # Specify the directories to be searched for header files.
244 # Both . and srcdir are used, in that order,
245 # so that tm.h and config.h will be found in the compilation
246 # subdirectory rather than in the source directory.
247 INCLUDES = -I. -I$(srcdir) -I../bfd -I$(srcdir)/config -I$(srcdir)/../include -I$(srcdir)/.. -I$(srcdir)/../bfd
248
249 # Always use -I$(srcdir)/config when compiling.
250 .c.o:
251         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $<
252
253 # This tells GNU make version 3 not to export all the variables
254 # defined in this file into the environment.
255 .NOEXPORT:
256
257 # Files to be copied away after each stage in building.
258 STAGESTUFF = *.o as.new gasp.new
259
260 $(OBJS): @ALL_OBJ_DEPS@
261
262 as.new: $(OBJS) $(LIBDEPS)
263         $(HLDENV) $(CC) $(HLDFLAGS) $(ALL_CFLAGS) $(LDFLAGS) -o as.new $(OBJS) $(LIBS) $(LOADLIBES)
264
265 $(OBJS): config.h as.h $(TARG_ENV_H) $(OBJ_FORMAT_H) $(TARG_CPU_H) flonum.h \
266         expr.h struc-symbol.h write.h frags.h hash.h read.h symbols.h tc.h \
267         obj.h listing.h bignum.h $(srcdir)/../include/libiberty.h
268
269 gasp.new: $(GASPOBJS) ../libiberty/libiberty.a
270         $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o gasp.new $(GASPOBJS) ../libiberty/libiberty.a $(LOADLIBES)
271
272 installcheck:
273         @echo No installcheck target is available yet for the GNU assembler.
274
275 site.exp: ./Makefile
276         @echo "Making a new config file..."
277         -@rm -f ./tmp?
278         @touch site.exp
279         -@mv site.exp site.bak
280         @echo "## these variables are automatically generated by make ##" > ./tmp0
281         @echo "# Do not edit here. If you wish to override these values," >> ./tmp0
282         @echo "# do so in the last section."                    >> ./tmp0
283         @echo set host_os @host_os@                             >> ./tmp0
284         @echo set host_alias @host_alias@                       >> ./tmp0
285         @echo set host_cpu @host_cpu@                           >> ./tmp0
286         @echo set host_vendor @host_vendor@                     >> ./tmp0
287         @echo set target_os @target_os@                         >> ./tmp0
288         @echo set target_alias @target_alias@                   >> ./tmp0
289         @echo set target_cpu @target_cpu@                       >> ./tmp0
290         @echo set target_vendor @target_vendor@                 >> ./tmp0
291         @echo set host_triplet @host@                           >> ./tmp0
292         @echo set target_triplet @target@                       >> ./tmp0
293         @echo set target_canonical @target@                     >> ./tmp0
294         @echo set srcdir ${srcdir}/testsuite                    >> ./tmp0
295         @echo set exec_prefix ${exec_prefix}                    >> ./tmp0
296         @echo set objdir `pwd`                                  >> ./tmp0
297         @echo "## All variables above are generated by configure. Do Not Edit ##" >> ./tmp0
298         @sed -e '1,/^## All variables above are.*##/ d' < site.bak >> ./tmp0
299         @mv -f ./tmp0 site.exp
300
301 check:  site.exp
302         if [ -d testsuite ]; then \
303           true; \
304         else \
305           mkdir testsuite; \
306         fi
307         rm -f testsuite/site.exp
308         cp site.exp testsuite/site.exp
309         rootme=`pwd`; export rootme; \
310         srcdir=`cd ${srcdir}; pwd` ; export srcdir ; \
311         $(RPATH_ENVVAR)=$$rootme/../bfd:$$rootme/../opcodes:$$$(RPATH_ENVVAR); \
312         export $(RPATH_ENVVAR); \
313         cd testsuite; \
314         EXPECT=${EXPECT} ; export EXPECT ; \
315         if [ -f $${rootme}/../expect/expect ] ; then  \
316            TCL_LIBRARY=$${srcdir}/../tcl/library ; \
317            export TCL_LIBRARY ; fi ; \
318         $(RUNTEST) --tool gas --srcdir $${srcdir}/testsuite $(RUNTESTFLAGS)
319
320 config.status: configure
321         $(SHELL) config.status --recheck
322
323 config.h: config-stamp ; @true
324 config-stamp: Makefile conf
325         -rm -f config.new config-stamp
326         echo '/* config.h.  Generated automatically by make.  */' > config.new
327         echo '#ifndef GAS_VERSION'                      >> config.new
328         echo '#define GAS_VERSION "$(VERSION)"'         >> config.new
329         echo ''                                         >> config.new
330         cat conf                                        >> config.new
331         echo '#endif /* GAS_VERSION */'                 >> config.new
332         $(srcdir)/../move-if-change config.new config.h
333         touch config-stamp
334
335 # Compiling object files from source files.
336
337 TARG_CPU_DEP_a29k    =
338 TARG_CPU_DEP_alpha   = $(srcdir)/../include/opcode/alpha.h subsegs.h \
339                         $(srcdir)/../include/obstack.h
340 # start-sanitize-arc
341 TARG_CPU_DEP_arc     = $(srcdir)/../include/opcode/arc.h subsegs.h \
342                         $(srcdir)/../include/obstack.h
343 # end-sanitize-arc
344 TARG_CPU_DEP_arm     = subsegs.h $(srcdir)/../include/obstack.h
345 TARG_CPU_DEP_generic =
346 TARG_CPU_DEP_h8300   = $(srcdir)/../include/opcode/h8300.h
347 TARG_CPU_DEP_h8500   = $(srcdir)/../opcodes/h8500-opc.h subsegs.h \
348                         $(srcdir)/../include/obstack.h
349 TARG_CPU_DEP_hppa    = subsegs.h $(srcdir)/../include/obstack.h
350 TARG_CPU_DEP_i386    = $(srcdir)/../include/opcode/i386.h subsegs.h \
351                         $(srcdir)/../include/obstack.h
352 TARG_CPU_DEP_i860    =
353 TARG_CPU_DEP_i960    =
354 TARG_CPU_DEP_m68k    = $(srcdir)/../include/opcode/m68k.h \
355                         $(srcdir)/config/m68k-parse.h subsegs.h \
356                         $(srcdir)/../include/obstack.h
357 TARG_CPU_DEP_m88k    = $(srcdir)/config/m88k-opcode.h subsegs.h \
358                         $(srcdir)/../include/obstack.h
359 TARG_CPU_DEP_mips    = $(srcdir)/../include/opcode/mips.h subsegs.h \
360                         $(srcdir)/../include/obstack.h \
361                         $(srcdir)/config/itbl-mips.h $(srcdir)/itbl-ops.h
362 TARG_CPU_DEP_ns32k   =
363 TARG_CPU_DEP_ppc     = subsegs.h $(srcdir)/../include/obstack.h
364 TARG_CPU_DEP_sh      = $(srcdir)/../opcodes/sh-opc.h subsegs.h \
365                         $(srcdir)/../include/obstack.h
366 TARG_CPU_DEP_sparc   = subsegs.h $(srcdir)/../include/opcode/sparc.h \
367                         $(srcdir)/../include/obstack.h
368 TARG_CPU_DEP_tahoe   =
369 TARG_CPU_DEP_vax     =
370 TARG_CPU_DEP_w65     = $(srcdir)/../opcodes/w65-opc.h subsegs.h \
371                         $(srcdir)/../include/obstack.h
372 TARG_CPU_DEP_z8k     = $(srcdir)/../opcodes/z8k-opc.h
373
374 # The implicit .c.o rule doesn't work here, perhaps because of the
375 # variables, or perhaps because the sources are not on vpath.
376 $(TARG_CPU_O): $(TARG_CPU_C) $(TARG_CPU_DEP_@target_cpu_type@)
377         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(TARG_CPU_C)
378 $(OBJ_FORMAT_O): $(OBJ_FORMAT_C)
379         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(OBJ_FORMAT_C)
380 $(ATOF_TARG_O): $(ATOF_TARG_C)
381         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(ATOF_TARG_C)
382
383 gasp.o : gasp.c sb.h macro.h config.h
384 sb.o : sb.c sb.h config.h
385 macro.o : macro.c macro.h sb.h hash.h config.h
386 app.o : app.c write.h
387 as.o : as.c output-file.h write.h subsegs.h sb.h macro.h \
388         $(srcdir)/../include/obstack.h
389 atof-generic.o : atof-generic.c
390 bignum-copy.o : bignum-copy.c
391 cond.o : cond.c $(srcdir)/../include/obstack.h
392 debug.o : debug.c subsegs.h $(srcdir)/../include/obstack.h
393 expr.o : expr.c $(srcdir)/../include/obstack.h
394 flonum-konst.o : flonum-konst.c
395 flonum-copy.o : flonum-copy.c
396 flonum-mult.o : flonum-mult.c
397 frags.o : frags.c subsegs.h $(srcdir)/../include/obstack.h
398 hash.o : hash.c
399 input-file.o : input-file.c input-file.h
400 input-scrub.o : input-scrub.c input-file.h sb.h
401 listing.o : listing.c input-file.h subsegs.h $(srcdir)/../include/obstack.h
402 literal.o : literal.c subsegs.h $(srcdir)/../include/obstack.h
403 messages.o : messages.c
404 output-file.o : output-file.c output-file.h
405 read.o : read.c sb.h macro.h $(srcdir)/../include/obstack.h
406 subsegs.o : subsegs.c subsegs.h $(srcdir)/../include/obstack.h
407 symbols.o : symbols.c subsegs.h $(srcdir)/../include/obstack.h
408 write.o : write.c subsegs.h output-file.h $(srcdir)/../include/obstack.h
409 ecoff.o : ecoff.c ecoff.h \
410         $(srcdir)/../include/coff/internal.h $(srcdir)/../include/coff/sym.h \
411         $(srcdir)/../include/coff/ecoff.h \
412         $(srcdir)/../include/coff/symconst.h \
413         $(srcdir)/../include/aout/stab_gnu.h
414 stabs.o : stabs.c subsegs.h $(srcdir)/../include/aout/stab_gnu.h \
415         $(srcdir)/../include/obstack.h
416
417 obj-elf.o : $(srcdir)/config/obj-elf.c
418         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/obj-elf.c
419 obj-ecoff.o : $(srcdir)/config/obj-ecoff.c
420         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/obj-ecoff.c
421 obj-coff.o: $(srcdir)/config/obj-coff.c
422         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/obj-coff.c
423
424 e-mipself.o : $(srcdir)/config/e-mipself.c
425         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/e-mipself.c
426 e-mipsecoff.o : $(srcdir)/config/e-mipsecoff.c
427         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/e-mipsecoff.c
428 e-i386coff.o: $(srcdir)/config/e-i386coff.c
429         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/e-i386coff.c
430 e-i386elf.o: $(srcdir)/config/e-i386elf.c
431         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/config/e-i386elf.c
432
433 # The m68k operand parser.
434
435 # Depend upon itbl-parse.c to serialize a parallel make.
436 m68k-parse.c: $(srcdir)/config/m68k-parse.y itbl-parse.c
437         $(BISON) $(BISONFLAGS) $(srcdir)/config/m68k-parse.y
438         mv -f y.tab.c m68k-parse.c
439 m68k-parse.o: m68k-parse.c $(srcdir)/config/m68k-parse.h
440
441 # The instruction table specification lexical analyzer and parser.
442
443 itbl-parse.h : $(srcdir)/itbl-parse.y
444 itbl-parse.c : $(srcdir)/itbl-parse.y
445 itbl-lex.c : $(srcdir)/itbl-lex.l
446
447 itbl-lex.c: $(srcdir)/itbl-lex.l
448         $(LEX) $(LEXFLAGS) $(srcdir)/itbl-lex.l
449         mv -f lex.yy.c itbl-lex.c
450
451 itbl-lex.o: itbl-lex.c itbl-parse.h
452         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) itbl-lex.c
453
454 itbl-parse.c: $(srcdir)/itbl-parse.y
455         $(BISON) -d $(BISONFLAGS) $(srcdir)/itbl-parse.y
456         mv -f y.tab.c itbl-parse.c
457         mv -f y.tab.h itbl-parse.h
458
459 itbl-parse.h: itbl-parse.c
460
461 itbl-parse.o: itbl-parse.c itbl-parse.h $(srcdir)/itbl-ops.h
462         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) itbl-parse.c
463
464 itbl-ops.o: $(srcdir)/itbl-ops.c $(srcdir)/itbl-ops.h itbl-parse.h
465         $(CC) -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/itbl-ops.c
466
467 # stand-alone itbl assembler & disassembler
468 itbl-test-ops.o: $(srcdir)/itbl-ops.c \
469         $(srcdir)/itbl-ops.h itbl-parse.h
470         $(CC) -o itbl-test-ops.o -DSTAND_ALONE -c $(ALL_CFLAGS) $(CPPFLAGS) $(INCLUDES) $(srcdir)/itbl-ops.c
471
472 itbl-test.o: $(srcdir)/testsuite/gas/all/itbl-test.c $(srcdir)/itbl-ops.h
473         $(CC) -c -DSTAND_ALONE $(ALL_CFLAGS) $(INCLUDES)\
474         $(srcdir)/testsuite/gas/all/itbl-test.c
475
476 IT_TEST_OBJS= itbl-parse.o itbl-lex.o itbl-test-ops.o
477 itbl-test: $(IT_TEST_OBJS) itbl-test.o $(LIBDEPS)
478         $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o itbl-test itbl-test.o $(IT_TEST_OBJS) $(LIBS)
479
480 # Remake the info files.
481
482 doc: $(srcdir)/as.info
483
484 $(srcdir)/as.info: $(srcdir)/doc/as.texinfo
485         @(cd doc; $(MAKE) $(FLAGS_TO_PASS) as.info; mv as.info $srcdir) 
486
487 diststuff: $(DISTSTUFF) info
488
489 clean-here:
490         -rm -f $(STAGESTUFF) core stamp-mk.com
491         -rm -f testsuite/*.o testsuite/*.out \
492                 testsuite/gas.log testsuite/gas.sum testsuite/site.exp
493
494 clean mostlyclean: clean-here
495         @cd doc ; $(MAKE) $(FLAGS_TO_PASS) $@
496
497 # Like clean but also delete the links made to configure gas.
498
499 DISTCLEAN_HERE = config.status Makefile targ-env.h targ-cpu.h obj-format.h \
500         TAGS itbl-cpu.h \
501         config-stamp config.h conf config.log config.cache .gdbinit \
502         testsuite/Makefile testsuite/config.status
503
504 distclean: clean-here
505         @cd doc ; $(MAKE) $(FLAGS_TO_PASS) $@
506         -rm -f $(DISTCLEAN_HERE)
507
508 maintainer-clean realclean: clean-here
509         @echo "This command is intended for maintainers to use;"
510         @echo "it deletes files that may require special tools to rebuild."
511         @cd doc ; $(MAKE) $(FLAGS_TO_PASS) $@
512         -rm -rf $(DISTCLEAN_HERE) $(DISTSTUFF)
513
514 # Entry points `install', `includes' and `uninstall'.
515
516 # Copy the files into directories where they will be run.
517 install:
518         srcroot=`cd $(srcroot); pwd`; export srcroot; \
519         $(INSTALL_XFORM) as.new $(bindir)/as; \
520         $(INSTALL_XFORM1) $(srcdir)/doc/as.1 $(man1dir)/as.1; \
521         test -d $(tooldir) || mkdir $(tooldir); \
522         test -d $(tooldir)/bin || mkdir $(tooldir)/bin; \
523         n=`echo as | sed '$(program_transform_name)'`; \
524         rm -f $(tooldir)/bin/as; \
525         ln $(bindir)/$$n $(tooldir)/bin/as >/dev/null 2>/dev/null \
526          || $(INSTALL_PROGRAM) as.new $(tooldir)/bin/as
527         srcroot=`cd $(srcroot); pwd`; export srcroot; \
528         $(INSTALL_XFORM) gasp.new $(bindir)/gasp
529
530 # Cancel installation by deleting the installed files.
531 uninstall:
532         -n=`t='$(program_transform_name)'; echo as | sed $$t`; \
533         rm -f $(bindir)/$$n; \
534         rm -f $(mandir)/$$n.1
535         -n=`t='$(program_transform_name)'; echo gasp | sed $$t`; \
536         rm -f $(bindir)/$$n; \
537
538 # These exist for maintenance purposes.
539
540 tags TAGS: force
541         etags $(REAL_HEADERS) $(REAL_SOURCES) $(srcdir)/config/*.[hc] $(srcdir)/README $(srcdir)/Makefile.in
542
543 bootstrap: as.new force
544         $(MAKE) stage1
545         rm -f stage && ln -s stage1 stage
546         $(MAKE) CC="$(CC)" CFLAGS="-O -Bstage/ $(CFLAGS)" libdir=$(libdir) ALLOCA= as.new gasp.new
547         $(MAKE) stage2
548         rm -f stage && ln -s stage2 stage
549         $(MAKE) CC="$(CC)" CFLAGS="-O -Bstage/ $(CFLAGS)" libdir=$(libdir) ALLOCA= as.new gasp.new
550         $(MAKE) comparison against=stage2
551
552 bootstrap2: force
553         rm -f stage && ln -s stage1 stage
554         $(MAKE) CC="$(CC)" CFLAGS="-O -Bstage/ $(CFLAGS)" libdir=$(libdir) ALLOCA= as.new gasp.new
555         $(MAKE) stage2
556         rm -f stage && ln -s stage2 stage
557         $(MAKE) CC="$(CC)" CFLAGS="-O -Bstage/ $(CFLAGS)" libdir=$(libdir) ALLOCA= as.new gasp.new
558         $(MAKE) comparison against=stage2
559
560 bootstrap3: force
561         rm -f stage && ln -s stage2 stage
562         $(MAKE) CC="$(CC)" CFLAGS="-O -Bstage/ $(CFLAGS)" libdir=$(libdir) ALLOCA= as.new gasp.new
563         $(MAKE) comparison against=stage2
564
565 # Copy the object files from a particular stage into a subdirectory.
566 stage1: force
567         -mkdir stage1
568         -mv $(STAGESTUFF) stage1
569         if [ -f stage1/as.new -a ! -f stage1/as ] ; then (cd stage1 ; ln -s as.new as) ; fi
570
571 stage2: force
572         -mkdir stage2
573         -mv $(STAGESTUFF) stage2
574         if [ -f stage2/as.new -a ! -f stage2/as ] ; then (cd stage2 ; ln -s as.new as) ; fi
575
576 stage3: force
577         -mkdir stage3
578         -mv $(STAGESTUFF) stage3
579         if [ -f stage3/as.new -a ! -f stage3/as ] ; then (cd stage3 ; ln -s as.new as) ; fi
580
581 against=stage2
582
583 # This rule is derived from corresponding code in the Makefile.in for gcc.
584 # The "tail +16c" is to bypass headers which may include timestamps or
585 # temporary assembly file names.
586 comparison: force
587         x=0 ; \
588         for file in *.o ; do \
589           tail +16c ./$$file > tmp-foo1; \
590           if tail +16c ${against}/$$file > tmp-foo2 2>/dev/null ; then \
591             if cmp tmp-foo1 tmp-foo2 ; then \
592               true ; \
593             else \
594               echo $$file differs ; \
595               x=1 ; \
596             fi ; \
597           else true; fi ; \
598         done ; \
599         exit $$x
600         -rm -f tmp-foo*
601
602 de-stage1: force
603         - (cd stage1 ; rm -f as ; mv -f * ..)
604         - rmdir stage1
605
606 de-stage2: force
607         - (cd stage2 ; rm -f as ; mv -f * ..)
608         - rmdir stage2
609
610 de-stage3: force
611         - (cd stage3 ; rm -f as ; mv -f * ..)
612         - rmdir stage3
613
614 #In GNU Make, ignore whether `stage*' exists.
615 .PHONY: stage1 stage2 stage3 stage4 clean mostlyclean realclean distclean
616 .PHONY: TAGS bootstrap
617
618 force:
619
620 Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag) \
621                 $(srcdir)/configure.in config.status conf.in
622         $(SHELL) ./config.status
623 .gdbinit: $(srcdir)/gdbinit.in config.status
624         $(SHELL) ./config.status