1 # Makefile for GNU Assembler
2 # Copyright (C) 1987-1992 Free Software Foundation, Inc.
4 #This file is part of GNU GAS.
6 #GNU GAS is free software; you can redistribute it and/or modify
7 #it under the terms of the GNU General Public License as published by
8 #the Free Software Foundation; either version 2, or (at your option)
11 #GNU GAS is distributed in the hope that it will be useful,
12 #but WITHOUT ANY WARRANTY; without even the implied warranty of
13 #MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 #GNU General Public License for more details.
16 #You should have received a copy of the GNU General Public License
17 #along with GNU GAS; see the file COPYING. If not, write to
18 #the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
20 # The targets for external use include:
21 # all, doc, proto, install, uninstall, includes, TAGS,
22 # clean, cleanconfig, realclean, stage1, stage2, stage3, stage4.
24 # Variables that exist for you to override.
25 # See below for how to change them for certain systems.
31 program_transform_name
=
32 exec_prefix = $(prefix)
33 bindir = $(exec_prefix)/bin
34 libdir = $(exec_prefix)/lib
35 tooldir
= $(libdir)/$(target_alias
)
37 datadir = $(prefix)/lib
38 mandir = $(prefix)/man
39 man1dir = $(mandir)/man1
40 man2dir = $(mandir)/man2
41 man3dir = $(mandir)/man3
42 man4dir = $(mandir)/man4
43 man5dir = $(mandir)/man5
44 man6dir = $(mandir)/man6
45 man7dir = $(mandir)/man7
46 man8dir = $(mandir)/man8
47 man9dir = $(mandir)/man9
48 infodir = $(prefix)/info
49 includedir = $(prefix)/include
50 docdir
= $(datadir)/doc
55 INSTALL_PROGRAM
= $(INSTALL
)
56 INSTALL_DATA
= $(INSTALL
)
67 "exec_prefix=$(exec_prefix)" \
68 "tooldir=$(tooldir)" \
70 "AR_FLAGS=$(AR_FLAGS)" \
74 "LOADLIBES=$(LOADLIBES)" \
75 "LDFLAGS=$(LDFLAGS)" \
78 "MAKEINFO=$(MAKEINFO)" \
79 "INSTALL=$(INSTALL)" \
80 "INSTALL_DATA=$(INSTALL_DATA)" \
81 "INSTALL_PROGRAM=$(INSTALL_PROGRAM)"
83 # Lists of files for various purposes.
88 $(srcdir)/atof-generic.c \
89 $(srcdir)/bignum-copy.c \
92 $(srcdir)/flonum-konst.c \
93 $(srcdir)/flonum-copy.c \
94 $(srcdir)/flonum-mult.c \
97 $(srcdir)/hex-value.c \
98 $(srcdir)/input-file.c \
99 $(srcdir)/input-scrub.c \
100 $(srcdir)/messages.c \
101 $(srcdir)/output-file.c \
103 $(srcdir)/subsegs.c \
104 $(srcdir)/symbols.c \
105 $(srcdir)/version.c \
107 $(srcdir)/listing.c \
110 # in an expedient order
116 SOURCES
= $(LINKED_SOURCES
) $(REAL_SOURCES
)
125 $(srcdir)/input-file.h \
126 $(srcdir)/listing.h \
130 $(srcdir)/struc-symbol.h \
131 $(srcdir)/subsegs.h \
132 $(srcdir)/symbols.h \
144 HEADERS
= $(LINKED_HEADERS
) $(REAL_HEADERS
)
174 #### host, target, and site specific Makefile frags come in here.
177 @
(cd doc
; $(MAKE
) $(FLAGS_TO_PASS
) all)
180 @
(cd doc
; $(MAKE
) $(FLAGS_TO_PASS
) info)
183 @
(cd doc
; $(MAKE
) $(FLAGS_TO_PASS
) install-info
)
186 @
(cd doc
; $(MAKE
) $(FLAGS_TO_PASS
) clean-info
)
188 # Now figure out from those variables how to compile and link.
190 # This is the variable actually used when we compile.
191 ALL_CFLAGS
= $(INTERNAL_CFLAGS
) $(CROSS
) $(CFLAGS
) $(HDEFINES
) $(TDEFINES
) -DTARGET_CPU
=\"$(target_cpu
)\"
193 # How to link with both our special library facilities
194 # and the system's installed libraries.
196 LIBS
= ..
/opcodes
/libopcodes.a
$(LOCAL_LOADLIBES
) $(CLIB
) ..
/libiberty
/libiberty.a
198 # Specify the directories to be searched for header files.
199 # Both . and srcdir are used, in that order,
200 # so that tm.h and config.h will be found in the compilation
201 # subdirectory rather than in the source directory.
202 INCLUDES
= -I.
-I
$(srcdir) -I
$(srcdir)/config
-I
$(srcdir)/..
/include
203 SUBDIR_INCLUDES
= -I..
-I
$(srcdir) -I
$(srcdir)/config
205 # Always use -I$(srcdir)/config when compiling.
207 $(CC
) -c
$(ALL_CFLAGS
) $(CPPFLAGS
) $(INCLUDES
) $<
209 # This tells GNU make version 3 not to export all the variables
210 # defined in this file into the environment.
213 # Files to be copied away after each stage in building.
214 STAGESTUFF
= *.o
as.new
216 as.new
: $(OBJS
) $(LIBS
)
217 [ ! -f
as.new
] || mv
as.new
as.old
218 $(CC
) $(ALL_CFLAGS
) $(LDFLAGS
) -o
as.new
$(OBJS
) $(LIBS
) $(LOADLIBES
)
223 @echo You must configure gas. Look at the INSTALL file for details.
226 # Compiling object files from source files.
228 app.o
: app.c
as.h host.h targ-env.h obj-format.h \
229 targ-cpu.h struc-symbol.h \
230 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
231 as.o
: as.c
as.h host.h targ-env.h obj-format.h \
232 targ-cpu.h struc-symbol.h \
233 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h subsegs.h \
235 atof-generic.o
: atof-generic.c
as.h host.h targ-env.h obj-format.h \
236 targ-cpu.h struc-symbol.h \
237 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
238 bignum-copy.o
: bignum-copy.c
as.h host.h \
239 targ-env.h obj-format.h \
240 targ-cpu.h struc-symbol.h \
241 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
242 cond.o
: cond.c
as.h host.h targ-env.h obj-format.h \
243 targ-cpu.h struc-symbol.h \
244 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
246 debug.o
: debug.c
as.h host.h targ-env.h obj-format.h \
247 targ-cpu.h struc-symbol.h \
248 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
250 expr.o
: expr.c
as.h host.h targ-env.h obj-format.h \
251 targ-cpu.h struc-symbol.h \
252 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
254 flonum-konst.o
: flonum-konst.c flonum.h bignum.h
255 flonum-copy.o
: flonum-copy.c
as.h host.h targ-env.h obj-format.h \
256 targ-cpu.h struc-symbol.h \
257 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
258 flonum-mult.o
: flonum-mult.c flonum.h bignum.h
259 frags.o
: frags.c
as.h host.h targ-env.h obj-format.h \
260 targ-cpu.h struc-symbol.h \
261 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
263 hash.o
: hash.c
as.h host.h targ-env.h obj-format.h \
264 targ-cpu.h struc-symbol.h \
265 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
266 hex-value.o
: hex-value.c
267 input-file.o
: input-file.c
as.h host.h \
268 targ-env.h obj-format.h targ-cpu.h \
269 struc-symbol.h write.h flonum.h bignum.h expr.h \
270 frags.h hash.h read.h symbols.h tc.h obj.h input-file.h
271 input-scrub.o
: input-scrub.c
/usr
/include/errno.h
/usr
/include/sys
/errno.h \
272 as.h host.h targ-env.h obj-format.h \
273 targ-cpu.h struc-symbol.h \
274 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
276 listing.o
: listing.c
as.h host.h targ-env.h flonum.h bignum.h \
277 listing.h obj-format.h targ-cpu.h struc-symbol.h write.h expr.h \
278 frags.h hash.h read.h symbols.h tc.h obj.h input-file.h
279 messages.o
: messages.c
as.h host.h targ-env.h obj-format.h \
280 targ-cpu.h struc-symbol.h \
281 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
282 output-file.o
: output-file.c
as.h host.h targ-env.h obj-format.h \
283 targ-cpu.h struc-symbol.h \
284 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
286 read.o
: read.c
as.h host.h targ-env.h obj-format.h \
287 targ-cpu.h struc-symbol.h \
288 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h
289 subsegs.o
: subsegs.c
as.h host.h targ-env.h obj-format.h \
290 targ-cpu.h struc-symbol.h \
291 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
293 symbols.o
: symbols.c
as.h host.h targ-env.h obj-format.h \
294 targ-cpu.h struc-symbol.h \
295 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
297 version.o
: version.c
298 write.o
: write.c
as.h host.h targ-env.h obj-format.h \
299 targ-cpu.h struc-symbol.h \
300 write.h flonum.h bignum.h expr.h frags.h hash.h read.h symbols.h tc.h obj.h \
301 subsegs.h output-file.h
302 xmalloc.o
: xmalloc.c
303 atof-targ.o
: atof-targ.c
as.h host.h targ-env.h obj-format.h \
304 targ-cpu.h struc-symbol.h \
305 write.h flonum.h bignum.h expr.h frags.h hash.h read.h \
307 obj-format.o
: obj-format.c
as.h host.h targ-env.h obj-format.h \
308 targ-cpu.h struc-symbol.h \
309 write.h flonum.h bignum.h expr.h frags.h hash.h read.h \
310 subsegs.h symbols.h tc.h obj.h
311 targ-cpu.o
: targ-cpu.c targ-env.h obj-format.h \
312 targ-cpu.h struc-symbol.h \
313 write.h flonum.h bignum.h expr.h frags.h hash.h read.h \
314 symbols.h tc.h obj.h
$(TARG_CPU_DEPENDENTS
)
316 # Remake the info files.
318 doc
: $(srcdir)/as.
info
320 $(srcdir)/as.
info: $(srcdir)/doc
/as.texinfo
321 @
(cd doc
; make
$(FLAGS_TO_PASS
) as.
info; mv
as.
info $srcdir)
324 @
(cd doc
; $(MAKE
) $(FLAGS_TO_PASS
) clean)
325 -rm -f
$(STAGESTUFF
) core
327 # Like clean but also delete the links made to configure gas.
329 -rm -f config.status Makefile host.h targ-env.h targ-cpu.h \
330 targ-cpu.c obj-format.h obj-format.c atof-targ.c \
331 gas.aux gas.cps gas.fns gas.
info gas.kys gas.pgs
332 gas.tps gas.vrs TAGS gas.
info* gas.?? gas.??s gas.log \
333 gas.toc gas.
*aux
*.
dvi
335 # Entry points `install', `includes' and `uninstall'.
337 # Copy the files into directories where they will be run.
339 -parent
=`echo $(bindir)|sed -e 's@/[^/]*$$@@'`; \
340 if
[ -d
$$parent ] ; then true
; else mkdir
$$parent ; fi
341 -if
[ -d
$(bindir) ] ; then true
; else mkdir
$(bindir) ; fi
342 -parent
=`echo $(man1dir)|sed -e 's@/[^/]*$$@@'`; \
343 if
[ -d
$$parent ] ; then true
; else mkdir
$$parent ; fi
344 -if
[ -d
$(man1dir) ] ; then true
; else mkdir
$(man1dir) ; fi
345 -n
=`t='$(program_transform_name)'; echo as | sed -e "" $$t`; \
346 rm -f
$(bindir)/$$n; \
347 $(INSTALL_PROGRAM
) as.new
$(bindir)/$$n; \
348 $(INSTALL_DATA
) $(srcdir)/doc
/as.1 $(man1dir)/$$n.1; \
349 if
[ -d
$(tooldir
) ]; then \
350 if
[ -d
$(tooldir
)/bin
] ; then true
; else mkdir
$(tooldir
)/bin
; fi
; \
351 rm -f
$(tooldir
)/bin
/as; \
352 ln
$(bindir)/$$n $(tooldir
)/bin
/as \
353 ||
$(INSTALL_PROGRAM
) as.new
$(tooldir
)/bin
/as; \
356 # Cancel installation by deleting the installed files.
358 -n
=`t='$(program_transform_name)'; echo as | sed -e "" $$t`; \
359 rm -f
$(bindir)/$$n; \
360 rm -f
$(mandir)/$$n.1
362 # These exist for maintenance purposes.
365 etags
$(REAL_HEADERS
) $(REAL_SOURCES
) $(srcdir)/config
/*.
[hc
] $(srcdir)/README
$(srcdir)/Makefile.in
367 bootstrap
: as.new
force
369 $(MAKE
) CC
="$(CC)" CFLAGS
="-O -Bstage1/ $(CFLAGS)" libdir=$(libdir) ALLOCA
= as.new
371 $(MAKE
) CC
="$(CC)" CFLAGS
="-O -Bstage2/ $(CFLAGS)" libdir=$(libdir) ALLOCA
= as.new
372 $(MAKE
) comparison against
=stage2
375 $(MAKE
) CC
="$(CC)" CFLAGS
="-O -Bstage1/ $(CFLAGS)" libdir=$(libdir) ALLOCA
= as.new
377 $(MAKE
) CC
="$(CC)" CFLAGS
="-O -Bstage2/ $(CFLAGS)" libdir=$(libdir) ALLOCA
= as.new
378 $(MAKE
) comparison against
=stage2
381 $(MAKE
) CC
="$(CC)" CFLAGS
="-O -Bstage2/ $(CFLAGS)" libdir=$(libdir) ALLOCA
= as.new
382 $(MAKE
) comparison against
=stage2
384 # Copy the object files from a particular stage into a subdirectory.
387 -mv
$(STAGESTUFF
) stage1
388 if
[ -f stage1
/as.new
-a
! -f stage1
/as ] ; then
(cd stage1
; ln
-s
as.new
as) ; fi
392 -mv
$(STAGESTUFF
) stage2
393 if
[ -f stage2
/as.new
-a
! -f stage2
/as ] ; then
(cd stage2
; ln
-s
as.new
as) ; fi
397 -mv
$(STAGESTUFF
) stage3
398 if
[ -f stage3
/as.new
-a
! -f stage3
/as ] ; then
(cd stage3
; ln
-s
as.new
as) ; fi
403 for i in
$(STAGESTUFF
) ; do cmp
$$i $(against
)/$$i ; done
406 - (cd stage1
; rm as ; mv
-f
* ..
)
410 - (cd stage2
; rm as ; mv
-f
* ..
)
414 - (cd stage3
; rm as ; mv
-f
* ..
)
417 #In GNU Make, ignore whether `stage*' exists.
418 .PHONY
: stage1 stage2 stage3 stage4
clean realclean TAGS bootstrap
422 Makefile
: $(srcdir)/Makefile.in
$(host_makefile_frag
) $(target_makefile_frag
)
423 $(SHELL
) .
/config.status