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