]> git.ipfire.org Git - thirdparty/gcc.git/blame - gcc/Makefile.in
gcc_release (announce_snapshot): Use changedir instead of plain cd.
[thirdparty/gcc.git] / gcc / Makefile.in
CommitLineData
73458fb7
NN
1# Makefile for GNU Compiler Collection
2# Run 'configure' to generate Makefile from Makefile.in
3
d7068b3d 4# Copyright (C) 1987, 1988, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
73e61092 5# 1998, 1999, 2000, 2001, 2002, 2003, 2004 Free Software Foundation, Inc.
79d8453e 6
1322177d 7#This file is part of GCC.
79d8453e 8
1322177d 9#GCC is free software; you can redistribute it and/or modify
79d8453e
RS
10#it under the terms of the GNU General Public License as published by
11#the Free Software Foundation; either version 2, or (at your option)
12#any later version.
13
1322177d 14#GCC is distributed in the hope that it will be useful,
79d8453e
RS
15#but WITHOUT ANY WARRANTY; without even the implied warranty of
16#MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17#GNU General Public License for more details.
18
19#You should have received a copy of the GNU General Public License
1322177d 20#along with GCC; see the file COPYING. If not, write to
940d9d63
RK
21#the Free Software Foundation, 59 Temple Place - Suite 330,
22#Boston MA 02111-1307, USA.
79d8453e
RS
23
24# The targets for external use include:
25# all, doc, proto, install, install-cross, install-cross-rest,
f1908d70 26# uninstall, TAGS, mostlyclean, clean, distclean, maintainer-clean,
79d8453e
RS
27# stage1, stage2, stage3, stage4.
28
6c80a645 29# This is the default target.
73458fb7
NN
30# Set by autoconf to "all.internal" for a native build, or
31# "all.cross" to build a cross compiler.
32all: @ALL@
33
34# Depend on this to specify a phony target portably.
35force:
36
37# This tells GNU make version 3 not to export the variables
38# defined in this file into the environment (and thus recursive makes).
39.NOEXPORT:
40# And this tells it not to automatically pass command-line variables
41# to recursive makes.
42MAKEOVERRIDES =
6c80a645 43
03787dfd 44# Suppress smart makes who think they know how to automake yacc and flex file
2e494f70 45.y.c:
03787dfd 46.l.c:
2e494f70 47
73458fb7
NN
48# The only suffixes we want for implicit rules are .c and .o, so clear
49# the list and add them. This speeds up GNU Make, and allows -r to work.
50# For i18n support, we also need .gmo, .po, .pox.
51# This must come before the language makefile fragments to allow them to
52# add suffixes and rules of their own.
53.SUFFIXES:
54.SUFFIXES: .c .o .po .pox .gmo
55
56# -------------------------------
57# Standard autoconf-set variables
58# -------------------------------
59
4665e56c
NN
60build=@build@
61host=@host@
73458fb7 62target=@target@
e165d61b 63target_noncanonical:=@target_noncanonical@
73458fb7
NN
64
65# Sed command to transform gcc to installed name.
e165d61b 66program_transform_name := @program_transform_name@
73458fb7
NN
67
68# -----------------------------
69# Directories used during build
70# -----------------------------
71
72# Directory where sources are, from where we are.
73srcdir = @srcdir@
71cbe2c1
KC
74docdir = @srcdir@/doc
75
76# Directory where sources are, absolute.
77abs_srcdir = @abs_srcdir@
78abs_docdir = @abs_srcdir@/doc
3859c32a 79
73458fb7 80# Top build directory, relative to here.
56694dd9 81top_builddir = ..
73458fb7
NN
82# objdir is set by configure.
83# It's normally the absolute path to the current directory.
84objdir = @objdir@
85
65455962
KC
86# --------
87# Defined vpaths
88# --------
89
90# Directory where sources are, from where we are.
91VPATH = @srcdir@
92
5340bbea 93# We define a vpath for the sources of the .texi files here because they
65455962
KC
94# are split between multiple directories and we would rather use one implicit
95# pattern rule for everything.
96# This vpath could be extended within the Make-lang fragments.
97
98vpath %.texi $(docdir):$(docdir)/include
99
b2c62c45
NN
100# ----
101# Default values for variables overridden in Makefile fragments.
102# These need to be quite early in the Makefile so as to avoid
103# trouble induced by changes in fragment ordering.
104# ----
105
106# For ada/Make-lang.in; overridden in, for example, config/pa/x-ada.
107X_ADA_CFLAGS =
108T_ADA_CFLAGS =
109X_ADAFLAGS =
110T_ADAFLAGS =
111
73458fb7
NN
112# --------
113# UNSORTED
114# --------
115
79d8453e
RS
116# Variables that exist for you to override.
117# See below for how to change them for certain systems.
118
013a2ee0 119# List of language subdirectories.
3c18ea24 120SUBDIRS =@subdirs@
013a2ee0 121
79d8453e 122# Selection of languages to be made.
71205e0b 123CONFIG_LANGUAGES = @all_languages@
4977bab6 124LANGUAGES = c gcov$(exeext) gcov-dump$(exeext) $(CONFIG_LANGUAGES)
79d8453e 125
5e31e473 126# Selection of languages to be made during stage1 build.
3c18ea24 127BOOT_LANGUAGES = c @all_boot_languages@
5e31e473 128
4c457b6b 129# Various ways of specifying flags for compilations:
78faa32d
FS
130# CFLAGS is for the user to override to, e.g., do a cross build with -O2.
131# For recursive bootstrap builds CFLAGS is used to pass in STAGE1_CFLAGS
132# or BOOT_CFLAGS
133# STAGE1_CFLAGS is set by configure on some targets or passed from toplevel
134# and sets the CFLAGS passed to stage1 of a bootstrap compilation.
135# BOOT_CFLAGS is the value of CFLAGS to pass to the stage2, stage3 and stage4
136# bootstrap compilations.
b8dad04b
ZW
137# XCFLAGS is used for most compilations but not when using the GCC just built.
138# TCFLAGS is used for compilations with the GCC just built.
b8dad04b
ZW
139XCFLAGS =
140TCFLAGS =
cbec6573
DB
141CFLAGS = -g
142STAGE1_CFLAGS = -g @stage1_cflags@
9541e2e3 143BOOT_CFLAGS = -g -O2
b8dad04b 144
22aa533e
NS
145# Flags to determine code coverage. When coverage is disabled, this will
146# contain the optimization flags, as you normally want code coverage
e61a2eb7 147# without optimization.
22aa533e 148COVERAGE_FLAGS = @coverage_flags@
160e2e4f 149coverageexts = .{gcda,gcno}
22aa533e 150
5b67ad6f
DA
151# The warning flags are separate from BOOT_CFLAGS because people tend to
152# override optimization flags and we'd like them to still have warnings
153# turned on. These flags are also used to pass other stage dependent
154# flags from configure. The user is free to explicitly turn these flags
155# off if they wish.
b8dad04b
ZW
156# LOOSE_WARN are the warning flags to use when compiling something
157# which is only compiled with gcc, such as libgcc and the frontends
158# other than C.
159# STRICT_WARN and STRICT2_WARN are the additional warning flags to
160# apply to the back end and the C front end, which may be compiled
161# with other compilers. This is partially controlled by configure in
4221057e
RH
162# stage1, as not all versions of gcc understand -Wno-long-long or
163# -Wno-variadic-macros.
204250d2 164LOOSE_WARN = -W -Wall -Wwrite-strings -Wstrict-prototypes -Wmissing-prototypes
78e68f88 165STRICT_WARN = @strict1_warn@
4221057e
RH
166STRICT2_WARN = -pedantic -Wno-long-long -Wold-style-definition \
167 -Wno-variadic-macros @WERROR@
b8dad04b 168
204250d2
RH
169# This is set by --enable-checking. The idea is to catch forgotten
170# "extern" tags in header files.
171NOCOMMON_FLAG = @nocommon_flag@
172
73e232f0 173# This is set by --disable-maintainer-mode (default) to "#"
e9c4897b 174MAINT := @MAINT@
73e232f0 175
414d23ae
HPN
176# These are set by --enable-checking=valgrind.
177RUN_GEN = @valgrind_command@
178VALGRIND_DRIVER_DEFINES = @valgrind_path_defines@
179
b8dad04b
ZW
180# This is how we control whether or not the additional warnings are applied.
181.-warn = $(STRICT_WARN)
31260fb8 182GCC_WARN_CFLAGS = $(LOOSE_WARN) $($(@D)-warn) $(NOCOMMON_FLAG) $($@-warn)
dd859b8a
KG
183
184# These files are to have -Werror bypassed in stage2:
dd859b8a 185# These are very hard to completely clean due to target complexities.
dd859b8a
KG
186gcc.o-warn = -Wno-error
187insn-conditions.o-warn = -Wno-error
dd859b8a
KG
188# Bison-1.75 output often yields (harmless) -Wtraditional warnings
189gengtype-yacc.o-warn = -Wno-error
190c-parse.o-warn = -Wno-error
87f85ea0
ZW
191# flex output may yield harmless "no previous prototype" warnings
192gengtype-lex.o-warn = -Wno-error
ee208a59
AJ
193# SYSCALLS.c misses prototypes
194SYSCALLS.c.X-warn = -Wno-strict-prototypes -Wno-error
b8dad04b
ZW
195
196# All warnings have to be shut off in stage1 if the compiler used then
197# isn't gcc; configure determines that. WARN_CFLAGS will be either
198# $(GCC_WARN_CFLAGS), or nothing.
199WARN_CFLAGS = @warn_cflags@
200
f5d394a6
DB
201CPPFLAGS = @CPPFLAGS@
202
79d8453e
RS
203# These exists to be overridden by the x-* and t-* files, respectively.
204X_CFLAGS =
205T_CFLAGS =
206
207X_CPPFLAGS =
208T_CPPFLAGS =
209
ab87f8c8 210AWK = @AWK@
b614ee64 211CC = @CC@
1e608388 212BISON = @BISON@
0777e4c6 213BISONFLAGS =
1e608388
ZW
214FLEX = @FLEX@
215FLEXFLAGS =
79d8453e 216AR = ar
79d8453e 217AR_FLAGS = rc
6822468a 218RANLIB = @RANLIB@
73458fb7
NN
219
220# -------------------------------------------
221# Programs which operate on the build machine
222# -------------------------------------------
223
b41e09a7 224SHELL = @SHELL@
1e6347d8
RO
225# pwd command to use. Allow user to override default by setting PWDCMD in
226# the environment to account for automounters. The make variable must not
227# be called PWDCMD, otherwise the value set here is passed to make
228# subprocesses and overrides the setting from the user's environment.
8c90b13a
L
229# Don't use PWD since it is a common shell environment variable and we
230# don't want to corrupt it.
231PWD_COMMAND = $${PWDCMD-pwd}
79d8453e 232# on sysV, define this as cp.
3c18ea24 233INSTALL = @INSTALL@
ac64120e
JW
234# Some systems may be missing symbolic links, regular links, or both.
235# Allow configure to check this and use "ln -s", "ln", or "cp" as appropriate.
236LN=@LN@
237LN_S=@LN_S@
79d8453e 238# These permit overriding just for certain files.
fca9d4b0
MH
239INSTALL_PROGRAM = @INSTALL_PROGRAM@
240INSTALL_DATA = @INSTALL_DATA@
7c1e8336 241INSTALL_SCRIPT = @INSTALL@
09fa0705 242MAKEINFO = @MAKEINFO@
a541f69d 243MAKEINFOFLAGS = --no-split
d8984b6e 244TEXI2DVI = texi2dvi
fd939e46 245TEXI2POD = perl $(srcdir)/../contrib/texi2pod.pl
77bd67cb 246POD2MAN = pod2man --center="GNU" --release="gcc-$(version)"
5262d6b6 247# Some versions of `touch' (such as the version on Solaris 2.8)
d9835ae8 248# do not correctly set the timestamp due to buggy versions of `utime'
5262d6b6 249# in the kernel. So, we use `echo' instead.
d9835ae8
MM
250STAMP = echo timestamp >
251
73458fb7
NN
252# Make sure the $(MAKE) variable is defined.
253@SET_MAKE@
7f5cc0f3 254REMAKEFLAGS=LANGUAGES="$(LANGUAGES)" BOOT_CFLAGS="$(BOOT_CFLAGS)"
73458fb7 255
947c6b00
NN
256# Locate mkinstalldirs.
257mkinstalldirs=$(SHELL) $(srcdir)/../mkinstalldirs
258
73458fb7
NN
259# --------
260# UNSORTED
261# --------
262
263# Some compilers can't handle cc -c blah.c -o foo/blah.o.
264# In stage2 and beyond, we force this to "-o $@" since we know we're using gcc.
265OUTPUT_OPTION = @OUTPUT_OPTION@
266
b8dad04b
ZW
267# This is where we get zlib from. zlibdir is -L../zlib and zlibinc is
268# -I../zlib, unless we were configured with --with-system-zlib, in which
269# case both are empty.
270ZLIB = @zlibdir@ -lz
271ZLIBINC = @zlibinc@
79d8453e 272
e256b8b6
DA
273# Substitution type for target's getgroups 2nd arg.
274TARGET_GETGROUPS_T = @TARGET_GETGROUPS_T@
275
ba1811f1 276# Target to use when installing include directory. Either
ff3aaf17 277# install-headers-tar, install-headers-cpio or install-headers-cp.
3c18ea24 278INSTALL_HEADERS_DIR = @build_install_headers_dir@
ba1811f1 279
d7371761
RK
280# Header files that are made available under the same name
281# to programs compiled with GCC.
d57a4b98
RH
282USER_H = $(srcdir)/ginclude/float.h \
283 $(srcdir)/ginclude/iso646.h \
284 $(srcdir)/ginclude/stdarg.h \
285 $(srcdir)/ginclude/stdbool.h \
286 $(srcdir)/ginclude/stddef.h \
287 $(srcdir)/ginclude/varargs.h \
336d0d96 288 $(srcdir)/unwind.h \
d57a4b98 289 $(EXTRA_HEADERS)
d7371761 290
39cef914 291# The GCC to use for compiling libgcc.a and crt*.o.
bf428f48 292# Usually the one we just built.
79d8453e 293# Don't use this as a dependency--use $(GCC_PASSES) or $(GCC_PARTS).
4977bab6 294GCC_FOR_TARGET = $(STAGE_CC_WRAPPER) ./xgcc -B./ -B$(build_tooldir)/bin/ -isystem $(build_tooldir)/include -isystem $(build_tooldir)/sys-include -L$(objdir)/../ld
79d8453e
RS
295
296# This is used instead of ALL_CFLAGS when compiling with GCC_FOR_TARGET.
297# It omits XCFLAGS, and specifies -B./.
3c9a2b55 298# It also specifies -isystem ./include to find, e.g., stddef.h.
3c987b8e 299GCC_CFLAGS=$(INTERNAL_CFLAGS) $(X_CFLAGS) $(T_CFLAGS) $(LOOSE_WARN) -Wold-style-definition $($@-warn) -isystem ./include $(TCFLAGS)
79d8453e 300
73458fb7
NN
301# ---------------------------------------------------
302# Programs which produce files for the target machine
303# ---------------------------------------------------
7e717196
JL
304
305AR_FOR_TARGET = ` \
306 if [ -f $(objdir)/../binutils/ar ] ; then \
307 echo $(objdir)/../binutils/ar ; \
308 else \
4665e56c 309 if [ "$(host)" = "$(target)" ] ; then \
7e717196
JL
310 echo ar; \
311 else \
439020ec 312 t='$(program_transform_name)'; echo ar | sed -e $$t ; \
7e717196
JL
313 fi; \
314 fi`
5262d6b6 315AR_FLAGS_FOR_TARGET =
7bde2862
GK
316AR_CREATE_FOR_TARGET = $(AR_FOR_TARGET) $(AR_FLAGS_FOR_TARGET) rc
317AR_EXTRACT_FOR_TARGET = $(AR_FOR_TARGET) $(AR_FLAGS_FOR_TARGET) x
7e717196
JL
318RANLIB_FOR_TARGET = ` \
319 if [ -f $(objdir)/../binutils/ranlib ] ; then \
320 echo $(objdir)/../binutils/ranlib ; \
321 else \
4665e56c 322 if [ "$(host)" = "$(target)" ] ; then \
6dd05d08 323 echo $(RANLIB); \
7e717196 324 else \
439020ec 325 t='$(program_transform_name)'; echo ranlib | sed -e $$t ; \
7e717196
JL
326 fi; \
327 fi`
83dad10c 328NM_FOR_TARGET = ` \
d08d4a19
AO
329 if [ -f ./nm ] ; then \
330 echo ./nm ; \
331 elif [ -f $(objdir)/../binutils/nm-new ] ; then \
332 echo $(objdir)/../binutils/nm-new ; \
83dad10c 333 else \
4665e56c 334 if [ "$(host)" = "$(target)" ] ; then \
83dad10c
RH
335 echo nm; \
336 else \
439020ec 337 t='$(program_transform_name)'; echo nm | sed -e $$t ; \
83dad10c
RH
338 fi; \
339 fi`
7e717196 340
73458fb7
NN
341# --------
342# UNSORTED
343# --------
344
4e872036
AS
345# Where to find some libiberty headers.
346HASHTAB_H = $(srcdir)/../include/hashtab.h
347OBSTACK_H = $(srcdir)/../include/obstack.h
5193cc6d 348SPLAY_TREE_H= $(srcdir)/../include/splay-tree.h
2a6f0eca 349FIBHEAP_H = $(srcdir)/../include/fibheap.h
56f15830 350PARTITION_H = $(srcdir)/../include/partition.h
73e61092 351MD5_H = $(srcdir)/../include/md5.h
4e872036 352
a078a589
ZW
353# Default native SYSTEM_HEADER_DIR, to be overridden by targets.
354NATIVE_SYSTEM_HEADER_DIR = /usr/include
512b62fb 355# Default cross SYSTEM_HEADER_DIR, to be overridden by targets.
4977bab6 356CROSS_SYSTEM_HEADER_DIR = @CROSS_SYSTEM_HEADER_DIR@
512b62fb 357
a078a589
ZW
358# autoconf sets SYSTEM_HEADER_DIR to one of the above.
359SYSTEM_HEADER_DIR = @SYSTEM_HEADER_DIR@
360
f95e46b9 361# Control whether to run fixproto and fixincludes.
0df47f66
AS
362STMP_FIXPROTO = @STMP_FIXPROTO@
363STMP_FIXINC = @STMP_FIXINC@
ac1284f9 364
40dc28fc
ILT
365# Test to see whether <limits.h> exists in the system header files.
366LIMITS_H_TEST = [ -f $(SYSTEM_HEADER_DIR)/limits.h ]
367
4977bab6
ZW
368# Directory for prefix to system directories, for
369# each of $(system_prefix)/usr/include, $(system_prefix)/usr/lib, etc.
370TARGET_SYSTEM_ROOT = @TARGET_SYSTEM_ROOT@
371
2ed26f6b
ZW
372xmake_file=@xmake_file@
373tmake_file=@tmake_file@
3c18ea24
RK
374out_file=$(srcdir)/config/@out_file@
375out_object_file=@out_object_file@
376md_file=$(srcdir)/config/@md_file@
4977bab6 377tm_file_list=@tm_file_list@
e22340b0 378tm_include_list=@tm_include_list@
d5355cb2 379tm_defines=@tm_defines@
11642c3a 380tm_p_file_list=@tm_p_file_list@
e22340b0 381tm_p_include_list=@tm_p_include_list@
11642c3a 382build_xm_file_list=@build_xm_file_list@
e22340b0 383build_xm_include_list=@build_xm_include_list@
11642c3a
ZW
384build_xm_defines=@build_xm_defines@
385host_xm_file_list=@host_xm_file_list@
e22340b0 386host_xm_include_list=@host_xm_include_list@
11642c3a 387host_xm_defines=@host_xm_defines@
e22340b0
ZW
388xm_file_list=@xm_file_list@
389xm_include_list=@xm_include_list@
3d9d2476 390xm_defines=@xm_defines@
49a41726 391lang_checks=check-gcc
d7b42618 392lang_opt_files=@lang_opt_files@ $(srcdir)/c.opt $(srcdir)/common.opt
3c18ea24 393lang_specs_files=@lang_specs_files@
3103b7db 394lang_tree_files=@lang_tree_files@
11642c3a 395target_cpu_default=@target_cpu_default@
f25270fc 396GCC_THREAD_FILE=@thread_file@
d8bb17c8 397OBJC_BOEHM_GC=@objc_boehm_gc@
f24af81b 398GTHREAD_FLAGS=@gthread_flags@
0974c7d7 399extra_modes_file=@extra_modes_file@
476d9098 400host_hook_obj=@out_host_hook_obj@
f1943b77
MH
401# Be prepared for gcc2 merges.
402gcc_version=@gcc_version@
403gcc_version_trigger=@gcc_version_trigger@
404version=$(gcc_version)
4746ee26 405mainversion=`grep version_string $(srcdir)/version.c | sed -e 's/.*\"\([0-9]*\.[0-9]*\).*/\1/'`
79d8453e 406
73458fb7
NN
407# ------------------------
408# Installation directories
409# ------------------------
410
79d8453e
RS
411# Common prefix for installation directories.
412# NOTE: This directory must exist when you start installation.
3c18ea24 413prefix = @prefix@
c844ddda
RS
414# Directory in which to put localized header files. On the systems with
415# gcc as the native cc, `local_prefix' may not be `prefix' which is
416# `/usr'.
0b2fbcb2 417# NOTE: local_prefix *should not* default from prefix.
3c18ea24 418local_prefix = @local_prefix@
2e494f70 419# Directory in which to put host dependent programs and libraries
3c18ea24 420exec_prefix = @exec_prefix@
79d8453e 421# Directory in which to put the executable for the command `gcc'
3c18ea24 422bindir = @bindir@
79d8453e 423# Directory in which to put the directories used by the compiler.
3c18ea24 424libdir = @libdir@
a8ee6e2d
GK
425# Directory in which GCC puts its executables.
426libexecdir = @libexecdir@
73458fb7
NN
427
428# --------
429# UNSORTED
430# --------
431
a8ee6e2d 432# Directory in which the compiler finds libraries etc.
caa55b1e 433libsubdir = $(libdir)/gcc/$(target_noncanonical)/$(version)
a8ee6e2d 434# Directory in which the compiler finds executables
caa55b1e 435libexecsubdir = $(libexecdir)/gcc/$(target_noncanonical)/$(version)
91c7bd9b 436# Used to produce a relative $(gcc_tooldir) in gcc.o
1f72bfca 437unlibsubdir = ../../..
d062c304 438# Directory in which to find other cross-compilation tools and headers.
4c112cda 439dollar = @dollar@
d062c304
JL
440# Used in install-cross.
441gcc_tooldir = @gcc_tooldir@
2bbea3a6
RH
442# Used to install the shared libgcc.
443slibdir = @slibdir@
f098ead2 444# Since gcc_tooldir does not exist at build-time, use -B$(build_tooldir)/bin/
caa55b1e 445build_tooldir = $(exec_prefix)/$(target_noncanonical)
e2187d3b
BK
446# Directory in which the compiler finds target-independent g++ includes.
447gcc_gxx_include_dir = @gcc_gxx_include_dir@
49ba557e 448# Directory to search for site-specific includes.
793e9558
PB
449local_includedir = $(local_prefix)/include
450includedir = $(prefix)/include
0b2fbcb2 451# where the info files go
3c18ea24 452infodir = @infodir@
587a4ba6
L
453# Where cpp should go besides $prefix/bin if necessary
454cpp_install_dir = @cpp_install_dir@
ab87f8c8 455# where the locale files go
191bf464 456datadir = @datadir@
ab87f8c8 457localedir = $(datadir)/locale
79d8453e 458# Extension (if any) to put in installed man-page filename.
77bd67cb
JM
459man1ext = .1
460man7ext = .7
173712fb 461objext = .o
6e26218f
ILT
462exeext = @host_exeext@
463build_exeext = @build_exeext@
173712fb 464
79d8453e 465# Directory in which to put man pages.
a76b6b40
MH
466mandir = @mandir@
467man1dir = $(mandir)/man1
77bd67cb 468man7dir = $(mandir)/man7
62c13b81
RS
469# Dir for temp files.
470tmpdir = /tmp
79d8453e 471
ab87f8c8
JL
472# Whether we were configured with NLS.
473USE_NLS = @USE_NLS@
474
475# Internationalization library.
56694dd9
ZW
476LIBINTL = @LIBINTL@
477LIBINTL_DEP = @LIBINTL_DEP@
ab87f8c8 478
62c62a4f
RO
479# Character encoding conversion library.
480LIBICONV = @LIBICONV@
56694dd9 481LIBICONV_DEP = @LIBICONV_DEP@
62c62a4f 482
0a25f1f5 483# The GC method to be used on this system.
81bf3d9e 484GGC=@GGC@.o
0a25f1f5
RH
485
486# If a supplementary library is being used for the GC.
487GGC_LIB=
488
7857f134
ZW
489# libgcc.a may be built directly or via stmp-multilib,
490# and installed likewise. Overridden by t-fragment.
b583eed8 491LIBGCC = libgcc.a
b583eed8
DE
492INSTALL_LIBGCC = install-libgcc
493
79d8453e 494# Options to use when compiling libgcc2.a.
7337c67f 495#
2a4ea326 496LIBGCC2_DEBUG_CFLAGS = -g
4c457b6b 497LIBGCC2_CFLAGS = -O2 $(LIBGCC2_INCLUDES) $(GCC_CFLAGS) $(TARGET_LIBGCC2_CFLAGS) $(LIBGCC2_DEBUG_CFLAGS) $(GTHREAD_FLAGS) -DIN_LIBGCC2 -D__GCC_FLOAT_NOT_NEEDED @inhibit_libc@
56f9206d
ILT
498
499# Additional options to use when compiling libgcc2.a.
3c9a2b55 500# Some targets override this to -isystem include
56f9206d
ILT
501LIBGCC2_INCLUDES =
502
7bb7f3df 503# Additional target-dependent options for compiling libgcc2.a.
4c457b6b 504TARGET_LIBGCC2_CFLAGS =
7bb7f3df 505
cea3bd3e
RH
506# Options to use when compiling crtbegin/end.
507CRTSTUFF_CFLAGS = -O2 $(GCC_CFLAGS) $(INCLUDES) $(MULTILIB_CFLAGS) -g0 \
27b41650 508 -finhibit-size-directive -fno-inline-functions -fno-exceptions \
e72fcfe8 509 -fno-zero-initialized-in-bss -fno-unit-at-a-time
cea3bd3e 510
4977bab6 511# Additional sources to handle exceptions; overridden by targets as needed.
52a11cbf 512LIB2ADDEH = $(srcdir)/unwind-dw2.c $(srcdir)/unwind-dw2-fde.c \
0bfa5f65 513 $(srcdir)/unwind-sjlj.c $(srcdir)/gthr-gnat.c $(srcdir)/unwind-c.c
52a11cbf 514LIB2ADDEHDEP = unwind.inc unwind-dw2-fde.h
ce152ef8 515
0ad7574f
DE
516# nm flags to list global symbols in libgcc object files.
517SHLIB_NM_FLAGS = -pg
518
79d8453e
RS
519# List of extra executables that should be compiled for this target machine
520# that are used for compiling from source code to object code.
521# The rules for compiling them should be in the t-* file for the machine.
3c18ea24 522EXTRA_PASSES =@extra_passes@
79d8453e 523
2e494f70 524# Like EXTRA_PASSES, but these are used when linking.
3c18ea24 525EXTRA_PROGRAMS = @extra_programs@
2e494f70
RS
526
527# List of extra object files that should be compiled for this target machine.
79d8453e 528# The rules for compiling them should be in the t-* file for the machine.
3c18ea24 529EXTRA_PARTS = @extra_parts@
79d8453e 530
2e494f70
RS
531# List of extra object files that should be compiled and linked with
532# compiler proper (cc1, cc1obj, cc1plus).
3c18ea24 533EXTRA_OBJS = @extra_objs@
2e494f70 534
43554690
RK
535# List of extra object files that should be compiled and linked with
536# the gcc driver.
30500d84 537EXTRA_GCC_OBJS =@extra_gcc_objs@
43554690 538
f780d21b 539# List of additional header files to install.
3c18ea24 540EXTRA_HEADERS =@extra_headers_list@
f780d21b 541
47547081
RS
542# It is convenient for configure to add the assignment at the beginning,
543# so don't override it here.
10da1131 544USE_COLLECT2 = collect2$(exeext)
47547081 545
fa9518de 546# List of extra C and assembler files to add to static and shared libgcc2.
79d8453e 547# Assembler files should have names ending in `.asm'.
4c457b6b 548LIB2FUNCS_EXTRA =
79d8453e 549
fa9518de
FS
550# List of extra C and assembler files to add to static libgcc2.
551# Assembler files should have names ending in `.asm'.
552LIB2FUNCS_STATIC_EXTRA =
553
79d8453e 554# Program to convert libraries.
4c457b6b 555LIBCONVERT =
79d8453e
RS
556
557# Control whether header files are installed.
e34a3d31 558INSTALL_HEADERS=install-headers install-mkheaders
79d8453e 559
09fa0705
ZW
560# Control whether Info documentation is built and installed.
561BUILD_INFO = @BUILD_INFO@
09fa0705 562
fd939e46
JM
563# Control whether manpages generated by texi2pod.pl can be rebuilt.
564GENERATED_MANPAGES = @GENERATED_MANPAGES@
565
66d7ffbf 566# Additional directories of header files to run fixincludes on.
4ab08223
RS
567# These should be directories searched automatically by default
568# just as /usr/include is.
4c457b6b 569# *Do not* use this for directories that happen to contain
4ab08223 570# header files, but are not searched automatically by default.
66d7ffbf
RS
571# On most systems, this is empty.
572OTHER_FIXINCLUDES_DIRS=
573
7c27f801 574# A list of all the language-specific executables.
3379e8ef 575COMPILERS = cc1$(exeext) @all_compilers@
7c27f801 576
acbbf3d9 577# List of things which should already be built whenever we try to use xgcc
79d8453e 578# to compile anything (without linking).
aaf93206 579GCC_PASSES=xgcc$(exeext) cc1$(exeext) specs $(EXTRA_PASSES)
79d8453e 580
acbbf3d9 581# List of things which should already be built whenever we try to use xgcc
79d8453e 582# to link anything.
b583eed8 583GCC_PARTS=$(GCC_PASSES) $(LIBGCC) $(EXTRA_PROGRAMS) $(USE_COLLECT2) $(EXTRA_PARTS)
79d8453e 584
79d8453e
RS
585# Directory to link to, when using the target `maketest'.
586DIR = ../gcc
587
588# Flags to use when cross-building GCC.
589# Prefix to apply to names of object files when using them
590# to run on the machine we are compiling on.
5c35940c 591BUILD_PREFIX = @BUILD_PREFIX@
79d8453e
RS
592# Prefix to apply to names of object files when compiling them
593# to run on the machine we are compiling on.
4c457b6b 594# The default for this variable is chosen to keep these rules
79d8453e 595# out of the way of the other rules for compiling the same source files.
5c35940c 596BUILD_PREFIX_1 = @BUILD_PREFIX_1@
a078a589 597# Native compiler for the build machine and its switches.
eaf9f3b2 598CC_FOR_BUILD = @CC_FOR_BUILD@
4977bab6 599BUILD_CFLAGS= @BUILD_CFLAGS@ -DGENERATOR_FILE
a078a589
ZW
600
601# Native linker and preprocessor flags. For x-fragment overrides.
4977bab6
ZW
602BUILD_LDFLAGS=$(LDFLAGS)
603BUILD_CPPFLAGS=$(ALL_CPPFLAGS)
79d8453e 604
338023d4 605# Actual name to use when installing a native compiler.
e165d61b
KC
606GCC_INSTALL_NAME := $(shell echo gcc|sed '$(program_transform_name)')
607GCC_TARGET_INSTALL_NAME := $(target_noncanonical)-$(shell echo gcc|sed '$(program_transform_name)')
608CPP_INSTALL_NAME := $(shell echo cpp|sed '$(program_transform_name)')
609PROTOIZE_INSTALL_NAME := $(shell echo protoize|sed '$(program_transform_name)')
610UNPROTOIZE_INSTALL_NAME := $(shell echo unprotoize|sed '$(program_transform_name)')
611GCOV_INSTALL_NAME := $(shell echo gcov|sed '$(program_transform_name)')
612GCCBUG_INSTALL_NAME := $(shell echo gccbug|sed '$(program_transform_name)')
338023d4 613
e933cbe0
JL
614# Setup the testing framework, if you have one
615EXPECT = `if [ -f $${rootme}/../expect/expect ] ; then \
616 echo $${rootme}/../expect/expect ; \
617 else echo expect ; fi`
618
619RUNTEST = `if [ -f $${srcdir}/../dejagnu/runtest ] ; then \
620 echo $${srcdir}/../dejagnu/runtest ; \
621 else echo runtest; fi`
622RUNTESTFLAGS =
623
aefc3801 624# Extra symbols for fixproto to define when parsing headers.
4c457b6b 625FIXPROTO_DEFINES =
aefc3801 626
68d69835 627# Extra flags to use when compiling crt{begin,end}.o.
4c457b6b 628CRTSTUFF_T_CFLAGS =
68d69835 629
522170ca 630# Extra flags to use when compiling [m]crt0.o.
4c457b6b 631CRT0STUFF_T_CFLAGS =
522170ca 632
e9a25f70
JL
633# "t" or nothing, for building multilibbed versions of, say, crtbegin.o.
634T =
635
6c80a645
AO
636# Should T contain a `=', libgcc.mk will make T_TARGET, setting
637# $(T_TARGET) to the name of the actual target filename.
638T_TARGET =
639T_TARGET : $(T_TARGET)
640
3bd6d4c4
AO
641# This should name the specs file that we're going to install. Target
642# Makefiles may override it and name another file to be generated from
643# the built-in specs and installed as the default spec, as long as
644# they also introduce a rule to generate a file name specs, to be used
645# at build time.
646SPECS = specs
647
79d8453e
RS
648# End of variables for you to override.
649
4977bab6
ZW
650# GTM_H lists the config files that the generator files depend on,
651# while TM_H lists the ones ordinary gcc files depend on, which
652# includes several files generated by those generators.
653BCONFIG_H = bconfig.h $(build_xm_file_list)
654CONFIG_H = config.h $(host_xm_file_list)
1b0c37d7 655TCONFIG_H = tconfig.h $(xm_file_list)
4977bab6
ZW
656TM_P_H = tm_p.h $(tm_p_file_list)
657GTM_H = tm.h $(tm_file_list)
658TM_H = $(GTM_H) insn-constants.h insn-flags.h
659
7bb1ad93 660TARGET_H = $(TM_H) target.h
e4ec2cac 661HOOKS_H = hooks.h
aea185b3 662LANGHOOKS_DEF_H = langhooks-def.h $(HOOKS_H)
e4ec2cac 663TARGET_DEF_H = target-def.h $(HOOKS_H)
0974c7d7 664MACHMODE_H = machmode.h mode-classes.def insn-modes.h
c4df8f8c 665RTL_BASE_H = rtl.h rtl.def $(MACHMODE_H)
b9dcdee4 666RTL_H = $(RTL_BASE_H) genrtl.h input.h statistics.h
639bc36c 667PARAMS_H = params.h params.def
e6986399 668TREE_H = tree.h tree.def $(MACHMODE_H) tree-check.h version.h builtins.def \
b9dcdee4 669 input.h statistics.h
56f15830 670BASIC_BLOCK_H = basic-block.h bitmap.h sbitmap.h varray.h $(PARTITION_H) \
9ee634e3 671 hard-reg-set.h cfghooks.h
ca29da43 672COVERAGE_H = coverage.h gcov-io.h gcov-iov.h
c4df8f8c
KC
673DEMANGLE_H = $(srcdir)/../include/demangle.h
674RECOG_H = recog.h
e78d8e51
ZW
675EXPR_H = expr.h
676OPTABS_H = optabs.h insn-codes.h
c4df8f8c
KC
677REGS_H = regs.h varray.h $(MACHMODE_H)
678INTEGRATE_H = integrate.h varray.h
679LOOP_H = loop.h varray.h bitmap.h
680GCC_H = gcc.h version.h
17211ab5 681GGC_H = ggc.h gtype-desc.h
c4df8f8c
KC
682TIMEVAR_H = timevar.h timevar.def
683INSN_ATTR_H = insn-attr.h $(srcdir)/insn-addr.h $(srcdir)/varray.h
81a75f0f 684C_COMMON_H = c-common.h $(SPLAY_TREE_H) $(CPPLIB_H)
c4df8f8c
KC
685C_TREE_H = c-tree.h $(C_COMMON_H)
686SYSTEM_H = system.h hwint.h $(srcdir)/../include/libiberty.h
4db384c9 687PREDICT_H = predict.h predict.def
ef6e958a 688CPPLIB_H = cpplib.h line-map.h
b6fe0bb8
GDR
689PRETTY_PRINT_H = pretty-print.h input.h $(OBSTACK_H)
690DIAGNOSTIC_H = diagnostic.h diagnostic.def $(PRETTY_PRINT_H)
e1a4dd13 691C_PRETTY_PRINT_H = $(PRETTY_PRINT_H) $(C_COMMON_H) $(TREE_H)
c4df8f8c 692
544eb21e 693#\f
79d8453e
RS
694# Now figure out from those variables how to compile and link.
695
a078a589
ZW
696# IN_GCC distinguishes between code compiled into GCC itself and other
697# programs built during a bootstrap.
698# autoconf inserts -DCROSS_COMPILE if we are building a cross compiler.
8733892f 699INTERNAL_CFLAGS = -DIN_GCC @CROSS@
79d8453e 700
83599948 701# This is the variable actually used when we compile. If you change this,
a6a5e4c9 702# you probably want to update BUILD_CFLAGS in configure.ac
22aa533e 703ALL_CFLAGS = $(X_CFLAGS) $(T_CFLAGS) \
8733892f 704 $(CFLAGS) $(INTERNAL_CFLAGS) $(COVERAGE_FLAGS) $(WARN_CFLAGS) $(XCFLAGS) @DEFS@
79d8453e
RS
705
706# Likewise.
707ALL_CPPFLAGS = $(CPPFLAGS) $(X_CPPFLAGS) $(T_CPPFLAGS)
708
06f0b04c
ZW
709# Build and host support libraries. FORBUILD is either
710# .. or ../$(build_alias) depending on whether host != build.
711LIBIBERTY = ../libiberty/libiberty.a
712BUILD_LIBIBERTY = @FORBUILD@/libiberty/libiberty.a
79d8453e 713
935bfb44 714# Dependencies on the intl and portability libraries.
50f59cd7 715LIBDEPS= $(LIBIBERTY) $(LIBINTL_DEP) $(LIBICONV_DEP) libcpp.a
79d8453e
RS
716
717# Likewise, for use in the tools that must run on this machine
718# even if we are cross-building GCC.
4977bab6 719BUILD_LIBDEPS= $(BUILD_LIBIBERTY)
79d8453e
RS
720
721# How to link with both our special library facilities
722# and the system's installed libraries.
50f59cd7 723LIBS = @LIBS@ libcpp.a $(LIBIBERTY) $(LIBINTL) $(LIBICONV)
79d8453e 724
7d600178
RO
725# Any system libraries needed just for GNAT.
726SYSLIBS = @GNAT_LIBEXC@
727
62c9aa5f
ZW
728# Libs needed (at present) just for jcf-dump.
729LDEXP_LIB = @LDEXP_LIB@
730
79d8453e
RS
731# Likewise, for use in the tools that must run on this machine
732# even if we are cross-building GCC.
4977bab6 733BUILD_LIBS = $(BUILD_LIBIBERTY)
79d8453e 734
4977bab6 735BUILD_RTL = $(BUILD_PREFIX)rtl.o read-rtl.o $(BUILD_PREFIX)bitmap.o \
94134f42 736 $(BUILD_PREFIX)ggc-none.o min-insn-modes.o
4977bab6
ZW
737BUILD_SUPPORT = gensupport.o insn-conditions.o
738BUILD_EARLY_SUPPORT = gensupport.o dummy-conditions.o
c88c0d42 739
4977bab6
ZW
740BUILD_PRINT = print-rtl1.o
741BUILD_ERRORS = $(BUILD_PREFIX)errors.o
742BUILD_VARRAY = $(BUILD_PREFIX)varray.o
79d8453e
RS
743
744# Specify the directories to be searched for header files.
745# Both . and srcdir are used, in that order,
eaf4e618 746# so that *config.h will be found in the compilation
79d8453e 747# subdirectory rather than in the source directory.
b8dad04b
ZW
748# -I$(@D) and -I$(srcdir)/$(@D) cause the subdirectory of the file
749# currently being compiled, in both source trees, to be examined as well.
6eb95e99 750# libintl.h will be found in ../intl if we are using the included libintl.
b8dad04b 751INCLUDES = -I. -I$(@D) -I$(srcdir) -I$(srcdir)/$(@D) \
ca11c37c 752 -I$(srcdir)/../include @INCINTL@
79d8453e 753
79d8453e 754.c.o:
b8dad04b 755 $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
79d8453e 756
544eb21e 757#\f
73458fb7
NN
758# Support for additional languages (other than C).
759# C can be supported this way too (leave for later).
013a2ee0 760
2ed26f6b 761LANG_MAKEFRAGS = @all_lang_makefrags@
3c18ea24
RK
762LANG_MAKEFILES = @all_lang_makefiles@
763LANG_STAGESTUFF = @all_stagestuff@
013a2ee0
DE
764
765# Flags to pass to recursive makes.
766# CC is set by configure. Hosts without symlinks need special handling
767# because we need CC="stage1/xgcc -Bstage1/" to work in the language
768# subdirectories.
769# ??? The choices here will need some experimenting with.
e158a5fb
MM
770
771export AR_FOR_TARGET
772export AR_CREATE_FOR_TARGET
773export AR_FLAGS_FOR_TARGET
774export AR_EXTRACT_FOR_TARGET
775export AWK
776export BUILD_PREFIX
777export BUILD_PREFIX_1
778export DESTDIR
779export GCC_FOR_TARGET
780export INCLUDES
781export INSTALL_DATA
782export LIB1ASMSRC
783export LIBGCC2_CFLAGS
784export MACHMODE_H
785export NM_FOR_TARGET
786export RANLIB_FOR_TARGET
787export libsubdir
788export slibdir
789
e6980e1b 790ORDINARY_FLAGS_TO_PASS = \
013a2ee0
DE
791 "BISON=$(BISON)" \
792 "BISONFLAGS=$(BISONFLAGS)" \
5b67ad6f 793 "CFLAGS=$(CFLAGS) $(WARN_CFLAGS)" \
013a2ee0 794 "LDFLAGS=$(LDFLAGS)" \
1e608388
ZW
795 "FLEX=$(FLEX)" \
796 "FLEXFLAGS=$(FLEXFLAGS)" \
ac64120e
JW
797 "LN=$(LN)" \
798 "LN_S=$(LN_S)" \
013a2ee0
DE
799 "MAKEINFO=$(MAKEINFO)" \
800 "MAKEINFOFLAGS=$(MAKEINFOFLAGS)" \
03bbd83f 801 "MAKEOVERRIDES=" \
013a2ee0 802 "SHELL=$(SHELL)" \
aab26e16 803 "exeext=$(exeext)" \
6e26218f 804 "build_exeext=$(build_exeext)" \
aab26e16 805 "objext=$(objext)" \
013a2ee0
DE
806 "exec_prefix=$(exec_prefix)" \
807 "prefix=$(prefix)" \
3bf810d8 808 "local_prefix=$(local_prefix)" \
8f8d3278 809 "gxx_include_dir=$(gcc_gxx_include_dir)" \
f098ead2 810 "build_tooldir=$(build_tooldir)" \
91c7bd9b 811 "gcc_tooldir=$(gcc_tooldir)" \
013a2ee0 812 "bindir=$(bindir)" \
a8ee6e2d 813 "libexecsubdir=$(libsubdir)" \
ab87f8c8 814 "datadir=$(datadir)" \
ab87f8c8 815 "localedir=$(localedir)"
04203c18
AC
816FLAGS_TO_PASS = $(ORDINARY_FLAGS_TO_PASS) "CC=@cc_set_by_configure@" \
817 "STAGE_PREFIX=@stage_prefix_set_by_configure@"
ab87f8c8
JL
818PREPEND_DOTDOT_TO_RELATIVE_PATHS = sed \
819 -e 's|^ *[^ /][^ /]*/|%&|' \
820 -e 's| -B| -B%|g' \
821 -e 's|% *[^- /]|%&|g' \
822 -e 's|%% *|../|g' \
823 -e 's|%||g'
824SUBDIR_FLAGS_TO_PASS = $(ORDINARY_FLAGS_TO_PASS) \
04203c18 825 "CC=`echo @quoted_cc_set_by_configure@ | $(PREPEND_DOTDOT_TO_RELATIVE_PATHS)`" \
596151e1 826 "STAGE_PREFIX=`echo @quoted_stage_prefix_set_by_configure@ | $(PREPEND_DOTDOT_TO_RELATIVE_PATHS)`"
544eb21e 827#\f
79d8453e
RS
828# Lists of files for various purposes.
829
aac69a49
NC
830# Target specific, C specific object file
831C_TARGET_OBJS=@c_target_objs@
832
833# Target specific, C++ specific object file
834CXX_TARGET_OBJS=@cxx_target_objs@
835
3cb88565 836# Language-specific object files for C and Objective C.
aaed0206 837C_AND_OBJC_OBJS = attribs.o c-errors.o c-lex.o c-pragma.o c-decl.o c-typeck.o \
0b6f2917 838 c-convert.o c-aux-info.o c-common.o c-opts.o c-format.o c-semantics.o \
d7b42618 839 c-incpath.o cppdefault.o c-ppoutput.o c-cppbuiltin.o prefix.o \
50f59cd7 840 c-objc-common.o c-dump.o c-pch.o $(C_TARGET_OBJS)
3cb88565 841
79d8453e 842# Language-specific object files for C.
264fa2db 843C_OBJS = c-parse.o c-lang.o c-pretty-print.o stub-objc.o $(C_AND_OBJC_OBJS)
e8066a5d 844
79d8453e 845# Language-independent object files.
a36556a8 846
d1bd0ded
GK
847OBJS-common = \
848 alias.o bb-reorder.o bitmap.o builtins.o caller-save.o calls.o \
e2500fed 849 cfg.o cfganal.o cfgbuild.o cfgcleanup.o cfglayout.o cfgloop.o \
b17d5d7c 850 cfgloopanal.o cfgloopmanip.o loop-init.o loop-unswitch.o loop-unroll.o \
ca29da43
NS
851 cfgrtl.o combine.o conflict.o convert.o coverage.o cse.o cselib.o \
852 dbxout.o debug.o df.o diagnostic.o dojump.o doloop.o dominance.o \
50654f6c 853 dwarf2asm.o dwarf2out.o emit-rtl.o except.o explow.o loop-iv.o \
e2500fed
GK
854 expmed.o expr.o final.o flow.o fold-const.o function.o gcse.o \
855 genrtl.o ggc-common.o global.o graph.o gtype-desc.o \
0974c7d7 856 haifa-sched.o hooks.o ifcvt.o insn-attrtab.o insn-emit.o insn-modes.o \
e2500fed 857 insn-extract.o insn-opinit.o insn-output.o insn-peep.o insn-recog.o \
7f22efe1 858 integrate.o intl.o jump.o langhooks.o lcm.o lists.o local-alloc.o \
ade4289c 859 loop.o optabs.o options.o opts.o params.o postreload.o predict.o \
014a1138 860 print-rtl.o print-tree.o value-prof.o var-tracking.o \
ed8d2920
MM
861 profile.o ra.o ra-build.o ra-colorize.o ra-debug.o ra-rewrite.o \
862 real.o recog.o reg-stack.o regclass.o regmove.o regrename.o \
e2500fed
GK
863 reload.o reload1.o reorg.o resource.o rtl.o rtlanal.o rtl-error.o \
864 sbitmap.o sched-deps.o sched-ebb.o sched-rgn.o sched-vis.o sdbout.o \
c132886e
RH
865 sibcall.o simplify-rtx.o sreal.o stmt.o stor-layout.o stringpool.o \
866 targhooks.o timevar.o toplev.o tracer.o tree.o tree-dump.o unroll.o \
867 varasm.o varray.o version.o vmsdbgout.o xcoffout.o alloc-pool.o \
f6db1481 868 et-forest.o cfghooks.o bt-load.o pretty-print.o $(GGC) web.o passes.o
d1bd0ded
GK
869
870OBJS-md = $(out_object_file)
871OBJS-archive = $(EXTRA_OBJS) $(host_hook_obj) hashtable.o tree-inline.o \
4985cde3 872 tree-optimize.o cgraph.o cgraphunit.o
d1bd0ded
GK
873
874OBJS = $(OBJS-common) $(out_object_file) $(OBJS-archive)
875
876OBJS-onestep = libbackend.o $(OBJS-archive)
79d8453e 877
aa5b94de 878BACKEND = main.o libbackend.a
a36556a8 879
79d8453e 880# Files to be copied away after each stage in building.
aab26e16 881STAGESTUFF = *$(objext) insn-flags.h insn-config.h insn-codes.h \
79d8453e 882 insn-output.c insn-recog.c insn-emit.c insn-extract.c insn-peep.c \
1b0c37d7 883 insn-attr.h insn-attrtab.c insn-opinit.c insn-constants.h tm-preds.h \
94134f42 884 tree-check.h insn-conditions.c min-insn-modes.c insn-modes.c insn-modes.h \
0974c7d7 885 s-flags s-config s-codes s-mlib s-genrtl s-modes s-gtype gtyp-gen.h \
469ef4a3 886 s-gtyp-gen s-output s-recog s-emit s-extract s-peep s-check s-conditions \
1b0c37d7 887 s-attr s-attrtab s-opinit s-preds s-constants s-crt0 \
6e26218f
ILT
888 genemit$(build_exeext) genoutput$(build_exeext) genrecog$(build_exeext) \
889 genextract$(build_exeext) genflags$(build_exeext) gencodes$(build_exeext) \
890 genconfig$(build_exeext) genpeep$(build_exeext) genattrtab$(build_exeext) \
206ae7cf 891 genattr$(build_exeext) genopinit$(build_exeext) gengenrtl$(build_exeext) \
1b0c37d7 892 gencheck$(build_exeext) genpreds$(build_exeext) genconstants$(build_exeext) \
0974c7d7 893 gengtype$(build_exeext) genconditions$(build_exeext) genmodes$(build_exeext) \
ad854f24 894 genrtl.c genrtl.h gt-*.h gtype-*.h gtype-desc.c \
aaf93206 895 xgcc$(exeext) cpp$(exeext) cc1$(exeext) $(EXTRA_PASSES) \
8f7d850c 896 $(EXTRA_PARTS) $(EXTRA_PROGRAMS) gcc-cross$(exeext) \
39cef914 897 protoize$(exeext) unprotoize$(exeext) \
3bd6d4c4 898 $(SPECS) collect2$(exeext) $(USE_COLLECT2) \
4977bab6
ZW
899 gcov-iov$(build_exeext) gcov$(exeext) gcov-dump$(exeext) \
900 *.[0-9][0-9].* *.[si] libcpp.a libbackend.a libgcc.mk \
013a2ee0 901 $(LANG_STAGESTUFF)
79d8453e 902
3fe68d0a 903# Defined in libgcc2.c, included only in the static library.
23af32e6
NS
904LIB2FUNCS_ST = _eprintf __gcc_bcmp
905
906# Defined in libgcov.c, included only in gcov library
af166e5d 907LIBGCOV = _gcov _gcov_merge_add _gcov_merge_single _gcov_merge_delta
3fe68d0a 908
5198352e
JL
909FPBIT_FUNCS = _pack_sf _unpack_sf _addsub_sf _mul_sf _div_sf \
910 _fpcmp_parts_sf _compare_sf _eq_sf _ne_sf _gt_sf _ge_sf \
1eb8759b 911 _lt_sf _le_sf _unord_sf _si_to_sf _sf_to_si _negate_sf _make_sf \
88e83acb 912 _sf_to_df _sf_to_tf _thenan_sf _sf_to_usi _usi_to_sf
5198352e
JL
913
914DPBIT_FUNCS = _pack_df _unpack_df _addsub_df _mul_df _div_df \
915 _fpcmp_parts_df _compare_df _eq_df _ne_df _gt_df _ge_df \
1eb8759b 916 _lt_df _le_df _unord_df _si_to_df _df_to_si _negate_df _make_df \
88e83acb
AO
917 _df_to_sf _df_to_tf _thenan_df _df_to_usi _usi_to_df
918
919TPBIT_FUNCS = _pack_tf _unpack_tf _addsub_tf _mul_tf _div_tf \
920 _fpcmp_parts_tf _compare_tf _eq_tf _ne_tf _gt_tf _ge_tf \
921 _lt_tf _le_tf _unord_tf _si_to_tf _tf_to_si _negate_tf _make_tf \
922 _tf_to_df _tf_to_sf _thenan_tf _tf_to_usi _usi_to_tf
5198352e 923
fc6aa0a9
AH
924# These might cause a divide overflow trap and so are compiled with
925# unwinder info.
926LIB2_DIVMOD_FUNCS = _divdi3 _moddi3 _udivdi3 _umoddi3 _udiv_w_sdiv _udivmoddi4
927
544eb21e 928#\f
013a2ee0
DE
929# Language makefile fragments.
930
931# The following targets define the interface between us and the languages.
932#
a078a589 933# all.cross, start.encap, rest.encap,
013a2ee0 934# install-normal, install-common, install-info, install-man,
436a88a6 935# uninstall,
a03ad584 936# mostlyclean, clean, distclean, maintainer-clean,
013a2ee0
DE
937# stage1, stage2, stage3, stage4
938#
62b81e45
MM
939# Each language is linked in with a series of hooks. The name of each
940# hooked is "lang.${target_name}" (eg: lang.info). Configure computes
941# and adds these here. We use double-colon rules for some of the hooks;
942# double-colon rules should be preferred for any new hooks.
013a2ee0 943
2ed26f6b 944# language hooks, generated by configure
3c18ea24 945@language_hooks@
013a2ee0 946
2ed26f6b
ZW
947# per-language makefile fragments
948ifneq ($(LANG_MAKEFRAGS),)
949include $(LANG_MAKEFRAGS)
950endif
013a2ee0 951
7e63a64e
RO
952# target and host overrides must follow the per-language makefile fragments
953# so they can override or augment language-specific variables
954
955# target overrides
956ifneq ($(tmake_file),)
957include $(tmake_file)
958endif
959
960# host overrides
961ifneq ($(xmake_file),)
962include $(xmake_file)
963endif
964
544eb21e 965#\f
79d8453e 966
73458fb7
NN
967# -----------------------------
968# Rebuilding this configuration
969# -----------------------------
970
fca086c1 971Makefile: config.status $(srcdir)/Makefile.in $(srcdir)/version.c $(LANG_MAKEFRAGS)
2ed26f6b
ZW
972 LANGUAGES="$(CONFIG_LANGUAGES)" \
973 CONFIG_HEADERS= \
e75f9147 974 CONFIG_SHELL="$(SHELL)" \
2ed26f6b 975 CONFIG_FILES=$@ $(SHELL) config.status
79d8453e 976
11642c3a 977config.h: cs-config.h ; @true
4977bab6 978bconfig.h: cs-bconfig.h ; @true
11642c3a 979tconfig.h: cs-tconfig.h ; @true
4977bab6 980tm.h: cs-tm.h ; @true
11642c3a
ZW
981tm_p.h: cs-tm_p.h ; @true
982
983cs-config.h: Makefile
4977bab6 984 TARGET_CPU_DEFAULT="" \
e22340b0 985 HEADERS="$(host_xm_include_list)" DEFINES="$(host_xm_defines)" \
11642c3a
ZW
986 $(SHELL) $(srcdir)/mkconfig.sh config.h
987
4977bab6
ZW
988cs-bconfig.h: Makefile
989 TARGET_CPU_DEFAULT="" \
e22340b0 990 HEADERS="$(build_xm_include_list)" DEFINES="$(build_xm_defines)" \
4977bab6 991 $(SHELL) $(srcdir)/mkconfig.sh bconfig.h
11642c3a 992
0d24f4d1 993cs-tconfig.h: Makefile
3d9d2476 994 TARGET_CPU_DEFAULT="" \
e22340b0 995 HEADERS="$(xm_include_list)" DEFINES="$(xm_defines)" \
11642c3a
ZW
996 $(SHELL) $(srcdir)/mkconfig.sh tconfig.h
997
4977bab6
ZW
998cs-tm.h: Makefile
999 TARGET_CPU_DEFAULT="$(target_cpu_default)" \
e22340b0 1000 HEADERS="$(tm_include_list)" DEFINES="$(tm_defines)" \
4977bab6
ZW
1001 $(SHELL) $(srcdir)/mkconfig.sh tm.h
1002
11642c3a 1003cs-tm_p.h: Makefile
4977bab6 1004 TARGET_CPU_DEFAULT="" \
e22340b0 1005 HEADERS="$(tm_p_include_list)" DEFINES="" \
11642c3a
ZW
1006 $(SHELL) $(srcdir)/mkconfig.sh tm_p.h
1007
a6a5e4c9 1008# Don't automatically run autoconf, since configure.ac might be accidentally
e7f62dcf
NC
1009# newer than configure. Also, this writes into the source directory which
1010# might be on a read-only file system. If configured for maintainer mode
1011# then do allow autoconf to be run.
1012
a6a5e4c9 1013$(srcdir)/configure: @MAINT@ $(srcdir)/configure.ac
b8dad04b 1014 (cd $(srcdir) && autoconf)
3c18ea24 1015
501a4819 1016gccbug: $(srcdir)/gccbug.in
5262d6b6 1017 CONFIG_FILES=gccbug CONFIG_HEADERS= ./config.status
501a4819 1018
3ec83fc2 1019mklibgcc: $(srcdir)/mklibgcc.in
5262d6b6 1020 CONFIG_FILES=mklibgcc CONFIG_HEADERS= ./config.status
3ec83fc2 1021
e34a3d31
GK
1022mkheaders: $(srcdir)/mkheaders.in
1023 CONFIG_FILES=mkheaders CONFIG_HEADERS= ./config.status
1024
da7ece9a 1025# cstamp-h.in controls rebuilding of config.in.
7c0ae5f1
DE
1026# It is named cstamp-h.in and not stamp-h.in so the mostlyclean rule doesn't
1027# delete it. A stamp file is needed as autoheader won't update the file if
1028# nothing has changed.
da7ece9a
DE
1029# It remains in the source directory and is part of the distribution.
1030# This follows what is done in shellutils, fileutils, etc.
5408f8d0
DE
1031# "echo timestamp" is used instead of touch to be consistent with other
1032# packages that use autoconf (??? perhaps also to avoid problems with patch?).
da7ece9a 1033# ??? Newer versions have a maintainer mode that may be useful here.
e7f62dcf
NC
1034
1035# Don't run autoheader automatically either.
1036# Only run it if maintainer mode is enabled.
1037@MAINT@ $(srcdir)/config.in: $(srcdir)/cstamp-h.in
a6a5e4c9 1038@MAINT@ $(srcdir)/cstamp-h.in: $(srcdir)/configure.ac
e7f62dcf
NC
1039@MAINT@ (cd $(srcdir) && autoheader)
1040@MAINT@ @rm -f $(srcdir)/cstamp-h.in
1041@MAINT@ echo timestamp > $(srcdir)/cstamp-h.in
b7cb92ad 1042auto-host.h: cstamp-h ; @true
da7ece9a 1043cstamp-h: config.in config.status
2ed26f6b
ZW
1044 CONFIG_HEADERS=auto-host.h:config.in \
1045 CONFIG_FILES= \
1046 LANGUAGES="$(CONFIG_LANGUAGES)" $(SHELL) config.status
d68b51ef 1047
7c0ae5f1
DE
1048# Really, really stupid make features, such as SUN's KEEP_STATE, may force
1049# a target to build even if it is up-to-date. So we must verify that
1050# config.status does not exist before failing.
61ed06c3 1051config.status: $(srcdir)/configure $(srcdir)/config.gcc version.c
7c0ae5f1 1052 @if [ ! -f config.status ] ; then \
436a88a6 1053 echo You must configure gcc. Look at http://gcc.gnu.org/install/ for details.; \
7c0ae5f1
DE
1054 false; \
1055 else \
71205e0b 1056 LANGUAGES="$(CONFIG_LANGUAGES)" $(SHELL) config.status --recheck; \
7c0ae5f1
DE
1057 fi
1058
73458fb7
NN
1059# --------
1060# UNSORTED
1061# --------
1062
43297964 1063all.internal: start.encap rest.encap doc
79d8453e 1064# This is what to compile if making a cross-compiler.
4871239e 1065all.cross: native gcc-cross cpp$(exeext) specs \
7857f134 1066 $(LIBGCC) $(EXTRA_PARTS) lang.all.cross doc
79d8453e 1067# This is what must be made before installing GCC and converting libraries.
4871239e 1068start.encap: native xgcc$(exeext) cpp$(exeext) specs \
02ba6b22 1069 xlimits.h lang.start.encap @GENINSRC@ srcextra
eea77e5f 1070# These can't be made until after GCC can run.
f95e46b9 1071rest.encap: $(STMP_FIXPROTO) $(LIBGCC) $(EXTRA_PARTS) lang.rest.encap
79d8453e
RS
1072# This is what is made with the host's compiler
1073# whether making a cross compiler or not.
6eb95e99 1074native: config.status auto-host.h build-@POSUB@ $(LANGUAGES) \
88393a07 1075 $(EXTRA_PASSES) $(EXTRA_PROGRAMS) $(USE_COLLECT2)
79d8453e
RS
1076
1077# Define the names for selecting languages in LANGUAGES.
353a10d0 1078C c: cc1$(exeext)
79d8453e
RS
1079PROTO: proto
1080
bff3fc41 1081# Tell GNU make these are phony targets.
3379e8ef 1082.PHONY: C c PROTO proto
bff3fc41 1083
3aa072f2
RS
1084# On the target machine, finish building a cross compiler.
1085# This does the things that can't be done on the host machine.
027ea2a7 1086rest.cross: $(LIBGCC) specs
3aa072f2 1087
3aa072f2
RS
1088# Recompile all the language-independent object files.
1089# This is used only if the user explicitly asks for it.
a36556a8 1090compilations: $(BACKEND)
79d8453e 1091
a36556a8 1092# Like libcpp.a, this archive is strictly for the host.
d1bd0ded 1093libbackend.a: $(OBJS@onestep@)
a36556a8 1094 -rm -rf libbackend.a
d1bd0ded 1095 $(AR) $(AR_FLAGS) libbackend.a $(OBJS@onestep@)
6822468a 1096 -$(RANLIB) libbackend.a
6c1cc7fa 1097
acbbf3d9
RS
1098# We call this executable `xgcc' rather than `gcc'
1099# to avoid confusion if the current directory is in the path
1100# and CC is `gcc'. It is renamed to `gcc' when it is installed.
08dc830e 1101xgcc$(exeext): gcc.o gccspec.o version.o intl.o prefix.o \
917acb0e 1102 version.o $(LIBDEPS) $(EXTRA_GCC_OBJS)
08dc830e
ZW
1103 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ gcc.o gccspec.o intl.o \
1104 prefix.o version.o $(EXTRA_GCC_OBJS) $(LIBS)
3aa072f2 1105
4871239e 1106# cpp is to cpp0 as gcc is to cc1.
922cf99e
ZW
1107# The only difference from xgcc is that it's linked with cppspec.o
1108# instead of gccspec.o.
4871239e 1109cpp$(exeext): gcc.o cppspec.o version.o intl.o prefix.o \
922cf99e
ZW
1110 version.o $(LIBDEPS) $(EXTRA_GCC_OBJS)
1111 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ gcc.o cppspec.o intl.o \
1112 prefix.o version.o $(EXTRA_GCC_OBJS) $(LIBS)
1113
3aa072f2 1114# Dump a specs file to make -B./ read these specs over installed ones.
3bd6d4c4 1115$(SPECS): xgcc$(exeext)
d521a023 1116 $(GCC_FOR_TARGET) -dumpspecs > tmp-specs
3bd6d4c4 1117 mv tmp-specs $(SPECS)
79d8453e 1118
acbbf3d9 1119# We do want to create an executable named `xgcc', so we can use it to
79d8453e
RS
1120# compile libgcc2.a.
1121# Also create gcc-cross, so that install-common will install properly.
e09e14e9 1122gcc-cross: xgcc$(exeext)
aab26e16 1123 cp xgcc$(exeext) gcc-cross$(exeext)
79d8453e 1124
b8dad04b 1125cc1$(exeext): $(C_OBJS) $(BACKEND) $(LIBDEPS)
a36556a8
ZW
1126 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o cc1$(exeext) \
1127 $(C_OBJS) $(BACKEND) $(LIBS)
79d8453e 1128
1402d22c
RS
1129# Build the version of limits.h that we will install.
1130xlimits.h: glimits.h limitx.h limity.h
40dc28fc 1131 if $(LIMITS_H_TEST) ; then \
d521a023 1132 cat $(srcdir)/limitx.h $(srcdir)/glimits.h $(srcdir)/limity.h > tmp-xlimits.h; \
1402d22c 1133 else \
d521a023 1134 cat $(srcdir)/glimits.h > tmp-xlimits.h; \
1402d22c 1135 fi
d521a023 1136 mv tmp-xlimits.h xlimits.h
544eb21e 1137#\f
79d8453e 1138# Build libgcc.a.
a2ab7f2b 1139
52a11cbf 1140LIB2ADD = $(LIB2FUNCS_EXTRA)
fa9518de 1141LIB2ADD_ST = $(LIB2FUNCS_STATIC_EXTRA)
3ec83fc2 1142
556b821e 1143libgcc.mk: config.status Makefile mklibgcc $(LIB2ADD) $(LIB2ADD_ST) xgcc$(exeext) specs
3ec83fc2 1144 objext='$(objext)' \
3ec83fc2 1145 LIB1ASMFUNCS='$(LIB1ASMFUNCS)' \
3fe68d0a 1146 LIB2FUNCS_ST='$(LIB2FUNCS_ST)' \
23af32e6 1147 LIBGCOV='$(LIBGCOV)' \
3ec83fc2 1148 LIB2ADD='$(LIB2ADD)' \
fa9518de 1149 LIB2ADD_ST='$(LIB2ADD_ST)' \
52a11cbf
RH
1150 LIB2ADDEH='$(LIB2ADDEH)' \
1151 LIB2ADDEHDEP='$(LIB2ADDEHDEP)' \
3ec83fc2
RH
1152 FPBIT='$(FPBIT)' \
1153 FPBIT_FUNCS='$(FPBIT_FUNCS)' \
fc6aa0a9 1154 LIB2_DIVMOD_FUNCS='$(LIB2_DIVMOD_FUNCS)' \
3ec83fc2
RH
1155 DPBIT='$(DPBIT)' \
1156 DPBIT_FUNCS='$(DPBIT_FUNCS)' \
88e83acb
AO
1157 TPBIT='$(TPBIT)' \
1158 TPBIT_FUNCS='$(TPBIT_FUNCS)' \
3ec83fc2
RH
1159 MULTILIBS=`$(GCC_FOR_TARGET) --print-multi-lib` \
1160 EXTRA_MULTILIB_PARTS='$(EXTRA_MULTILIB_PARTS)' \
50503ac8 1161 SHLIB_LINK='$(SHLIB_LINK)' \
2bbea3a6 1162 SHLIB_INSTALL='$(SHLIB_INSTALL)' \
aefa45d3 1163 SHLIB_EXT='$(SHLIB_EXT)' \
50503ac8 1164 SHLIB_MULTILIB='$(SHLIB_MULTILIB)' \
83dad10c 1165 SHLIB_MKMAP='$(SHLIB_MKMAP)' \
bac015e7 1166 SHLIB_MKMAP_OPTS='$(SHLIB_MKMAP_OPTS)' \
83dad10c 1167 SHLIB_MAPFILES='$(SHLIB_MAPFILES)' \
0ad7574f 1168 SHLIB_NM_FLAGS='$(SHLIB_NM_FLAGS)' \
5bbcd587 1169 MULTILIB_OSDIRNAMES='$(MULTILIB_OSDIRNAMES)' \
947c6b00 1170 mkinstalldirs='$(mkinstalldirs)' \
3ec83fc2 1171 $(SHELL) mklibgcc > tmp-libgcc.mk
2aceb30d
JM
1172 mv tmp-libgcc.mk libgcc.mk
1173
1174# All the things that might cause us to want to recompile bits of libgcc.
1175LIBGCC_DEPS = $(GCC_PASSES) $(LANGUAGES) stmp-int-hdrs $(STMP_FIXPROTO) \
23af32e6 1176 libgcc.mk $(srcdir)/libgcc2.c $(srcdir)/libgcov.c $(TCONFIG_H) \
52a11cbf 1177 $(MACHMODE_H) longlong.h gbl-ctors.h config.status stmp-int-hdrs \
88e83acb
AO
1178 tsystem.h $(FPBIT) $(DPBIT) $(TPBIT) $(LIB2ADD) \
1179 $(LIB2ADD_ST) $(LIB2ADDEH) $(LIB2ADDEHDEP) $(EXTRA_PARTS) \
990f4800
NS
1180 $(srcdir)/config/$(LIB1ASMSRC) \
1181 $(srcdir)/gcov-io.h $(srcdir)/gcov-io.c gcov-iov.h
3ec83fc2 1182
990f4800 1183libgcov.a: libgcc.a; @true
23af32e6 1184
2aceb30d 1185libgcc.a: $(LIBGCC_DEPS)
e158a5fb 1186 $(MAKE) \
5b67ad6f 1187 CFLAGS="$(CFLAGS) $(WARN_CFLAGS)" \
e158a5fb 1188 CONFIG_H="$(TCONFIG_H)" TM_H="$(TM_H)" \
03bbd83f 1189 MAKEOVERRIDES= \
3ec83fc2 1190 -f libgcc.mk all
79d8453e 1191
f6cdc7ea
DE
1192# Use the genmultilib shell script to generate the information the gcc
1193# driver program needs to select the library directory based on the
1194# switches.
e5e809f4
JL
1195multilib.h: s-mlib; @true
1196s-mlib: $(srcdir)/genmultilib Makefile
c49d2df6
JJ
1197 if test @enable_multilib@ = yes \
1198 || test -n "$(MULTILIB_OSDIRNAMES)"; then \
4d2fb38b
JJ
1199 $(SHELL) $(srcdir)/genmultilib \
1200 "$(MULTILIB_OPTIONS)" \
1201 "$(MULTILIB_DIRNAMES)" \
1202 "$(MULTILIB_MATCHES)" \
1203 "$(MULTILIB_EXCEPTIONS)" \
1204 "$(MULTILIB_EXTRA_OPTS)" \
1205 "$(MULTILIB_EXCLUSIONS)" \
5bbcd587 1206 "$(MULTILIB_OSDIRNAMES)" \
c49d2df6 1207 "@enable_multilib@" \
4d2fb38b
JJ
1208 > tmp-mlib.h; \
1209 else \
c49d2df6
JJ
1210 $(SHELL) $(srcdir)/genmultilib '' '' '' '' '' '' '' no \
1211 > tmp-mlib.h; \
4d2fb38b 1212 fi
88e3a2a3 1213 $(SHELL) $(srcdir)/../move-if-change tmp-mlib.h multilib.h
d9835ae8 1214 $(STAMP) s-mlib
f6cdc7ea
DE
1215
1216# Build multiple copies of libgcc.a, one for each target switch.
2aceb30d 1217stmp-multilib: $(LIBGCC_DEPS)
e158a5fb 1218 $(MAKE) \
5b67ad6f 1219 CFLAGS="$(CFLAGS) $(WARN_CFLAGS)" \
e158a5fb 1220 CONFIG_H="$(CONFIG_H)" \
03bbd83f 1221 MAKEOVERRIDES= \
3ec83fc2 1222 -f libgcc.mk all
d9835ae8 1223 $(STAMP) stmp-multilib
ad3a9224 1224
79d8453e 1225# Compile two additional files that are linked with every program
32988c4a
RM
1226# linked using GCC on systems using COFF or ELF, for the sake of C++
1227# constructors.
11642c3a 1228$(T)crtbegin.o: crtstuff.c $(GCC_PASSES) $(TCONFIG_H) auto-host.h \
4977bab6 1229 gbl-ctors.h stmp-int-hdrs tsystem.h coretypes.h $(TM_H)
cea3bd3e
RH
1230 $(GCC_FOR_TARGET) $(CRTSTUFF_CFLAGS) $(CRTSTUFF_T_CFLAGS) \
1231 @inhibit_libc@ -c $(srcdir)/crtstuff.c -DCRT_BEGIN \
1232 -o $(T)crtbegin$(objext)
47a22692 1233
11642c3a 1234$(T)crtend.o: crtstuff.c $(GCC_PASSES) $(TCONFIG_H) auto-host.h \
4977bab6 1235 gbl-ctors.h stmp-int-hdrs tsystem.h coretypes.h $(TM_H)
cea3bd3e
RH
1236 $(GCC_FOR_TARGET) $(CRTSTUFF_CFLAGS) $(CRTSTUFF_T_CFLAGS) \
1237 @inhibit_libc@ -c $(srcdir)/crtstuff.c -DCRT_END \
1238 -o $(T)crtend$(objext)
32988c4a 1239
a9e6777f 1240# These are versions of crtbegin and crtend for shared libraries.
11642c3a 1241$(T)crtbeginS.o: crtstuff.c $(GCC_PASSES) $(TCONFIG_H) auto-host.h \
4977bab6 1242 gbl-ctors.h stmp-int-hdrs tsystem.h coretypes.h $(TM_H)
cea3bd3e
RH
1243 $(GCC_FOR_TARGET) $(CRTSTUFF_CFLAGS) $(CRTSTUFF_T_CFLAGS_S) \
1244 @inhibit_libc@ -c $(srcdir)/crtstuff.c -DCRT_BEGIN -DCRTSTUFFS_O \
a9e6777f 1245 -o $(T)crtbeginS$(objext)
32988c4a 1246
11642c3a 1247$(T)crtendS.o: crtstuff.c $(GCC_PASSES) $(TCONFIG_H) auto-host.h \
4977bab6 1248 gbl-ctors.h stmp-int-hdrs tsystem.h coretypes.h $(TM_H)
cea3bd3e
RH
1249 $(GCC_FOR_TARGET) $(CRTSTUFF_CFLAGS) $(CRTSTUFF_T_CFLAGS_S) \
1250 @inhibit_libc@ -c $(srcdir)/crtstuff.c -DCRT_END -DCRTSTUFFS_O \
a9e6777f 1251 -o $(T)crtendS$(objext)
522170ca 1252
275b60d6
JJ
1253# This is a version of crtbegin for -static links.
1254$(T)crtbeginT.o: crtstuff.c $(GCC_PASSES) $(TCONFIG_H) auto-host.h \
4977bab6 1255 gbl-ctors.h stmp-int-hdrs tsystem.h coretypes.h $(TM_H)
cea3bd3e
RH
1256 $(GCC_FOR_TARGET) $(CRTSTUFF_CFLAGS) $(CRTSTUFF_T_CFLAGS) \
1257 @inhibit_libc@ -c $(srcdir)/crtstuff.c -DCRT_BEGIN -DCRTSTUFFT_O \
275b60d6
JJ
1258 -o $(T)crtbeginT$(objext)
1259
3ec83fc2
RH
1260# Compile the start modules crt0.o and mcrt0.o that are linked with
1261# every program
e5e809f4
JL
1262crt0.o: s-crt0 ; @true
1263mcrt0.o: s-crt0; @true
522170ca 1264
e5e809f4 1265s-crt0: $(CRT0_S) $(MCRT0_S) $(GCC_PASSES) $(CONFIG_H)
522170ca
RK
1266 $(GCC_FOR_TARGET) $(GCC_CFLAGS) $(CRT0STUFF_T_CFLAGS) \
1267 -o crt0.o -c $(CRT0_S)
1268 $(GCC_FOR_TARGET) $(GCC_CFLAGS) $(CRT0STUFF_T_CFLAGS) \
1269 -o mcrt0.o -c $(MCRT0_S)
d9835ae8 1270 $(STAMP) s-crt0
544eb21e 1271#\f
79d8453e
RS
1272# Compiling object files from source files.
1273
1274# Note that dependencies on obstack.h are not written
1275# because that file is not part of GCC.
79d8453e
RS
1276
1277# C language specific files.
1278
4977bab6 1279c-errors.o: c-errors.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
b6fe0bb8 1280 $(C_TREE_H) flags.h $(DIAGNOSTIC_H) $(TM_P_H)
03787dfd 1281c-parse.o : c-parse.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
4977bab6 1282 $(GGC_H) intl.h $(C_TREE_H) input.h flags.h toplev.h output.h $(CPPLIB_H) \
e57e265b 1283 varray.h gt-c-parse.h langhooks.h
0e5921e8 1284
02ba6b22
KC
1285srcextra: gcc.srcextra lang.srcextra
1286
1287gcc.srcextra: c-parse.y c-parse.c gengtype-lex.c gengtype-yacc.c gengtype-yacc.h
03787dfd
KC
1288 -cp -p $^ $(srcdir)
1289
1290c-parse.c: c-parse.y
5340bbea 1291 -$(BISON) $(BISONFLAGS) -o $@ $<
b88c0704 1292
03787dfd 1293c-parse.y: c-parse.in
49381011 1294 echo '/*WARNING: This file is automatically generated!*/' >tmp-c-parse.y
264fa2db 1295 sed -e "/^@@ifobjc.*/,/^@@end_ifobjc.*/d" \
03787dfd 1296 -e "/^@@ifc.*/d" -e "/^@@end_ifc.*/d" $< >>tmp-c-parse.y
88e3a2a3 1297 $(SHELL) $(srcdir)/../move-if-change tmp-c-parse.y $@
1c48d17e 1298
5793b276 1299c-incpath.o: c-incpath.c c-incpath.h $(CONFIG_H) $(SYSTEM_H) $(CPPLIB_H) \
94d1613b
MS
1300 intl.h prefix.h coretypes.h $(TM_H) cppdefault.h $(TARGET_H) \
1301 $(MACHMODE_H)
5793b276 1302
66ea6f4c
RH
1303c-decl.o : c-decl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1304 $(RTL_H) $(C_TREE_H) $(GGC_H) $(TARGET_H) flags.h function.h output.h \
1305 $(EXPR_H) debug.h toplev.h intl.h $(TM_P_H) tree-inline.h $(TIMEVAR_H) \
40e941af 1306 opts.h c-pragma.h gt-c-decl.h cgraph.h $(HASHTAB_H) libfuncs.h except.h \
48873ed2 1307 $(LANGHOOKS_DEF_H)
4977bab6 1308c-typeck.o : c-typeck.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(C_TREE_H) \
e57e265b
PB
1309 $(TARGET_H) flags.h intl.h output.h $(EXPR_H) $(RTL_H) toplev.h $(TM_P_H) \
1310 langhooks.h
4b780675
GDR
1311c-lang.o : c-lang.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1312 $(C_TREE_H) $(C_PRETTY_PRINT_H) $(DIAGNOSTIC_H) \
dd220c49 1313 $(GGC_H) langhooks.h $(LANGHOOKS_DEF_H) $(C_COMMON_H) gtype-c.h
d70f15d2
ZL
1314stub-objc.o : stub-objc.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TREE_H) \
1315 $(GGC_H) $(C_COMMON_H)
5793b276 1316c-lex.o : c-lex.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
dd220c49 1317 $(RTL_H) debug.h $(C_TREE_H) $(C_COMMON_H) real.h c-incpath.h cppdefault.h \
8f17b5c5 1318 c-pragma.h input.h intl.h flags.h toplev.h output.h \
6338b358 1319 $(CPPLIB_H) $(EXPR_H) $(TM_P_H)
63973df3 1320c-ppoutput.o : c-ppoutput.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
dd220c49 1321 $(C_COMMON_H) $(TREE_H) $(CPPLIB_H) cpphash.h $(TM_P_H) c-pragma.h
4977bab6 1322c-objc-common.o : c-objc-common.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
dd220c49 1323 $(C_TREE_H) $(RTL_H) insn-config.h $(INTEGRATE_H) $(EXPR_H) $(C_TREE_H) \
b6fe0bb8 1324 flags.h toplev.h tree-inline.h $(DIAGNOSTIC_H) $(VARRAY_H) \
4a46cbfb 1325 langhooks.h $(GGC_H) $(TARGET_H) cgraph.h
4977bab6
ZW
1326c-aux-info.o : c-aux-info.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1327 $(C_TREE_H) flags.h toplev.h
1328c-convert.o : c-convert.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
77f9af81 1329 flags.h toplev.h $(C_COMMON_H) real.h
4977bab6
ZW
1330c-pragma.o: c-pragma.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1331 function.h c-pragma.h toplev.h output.h $(GGC_H) $(TM_P_H) $(C_COMMON_H) gt-c-pragma.h
4977bab6 1332graph.o: graph.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) toplev.h flags.h output.h \
ca35b546 1333 $(RTL_H) function.h hard-reg-set.h $(BASIC_BLOCK_H) graph.h
4977bab6
ZW
1334sbitmap.o: sbitmap.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1335 hard-reg-set.h $(BASIC_BLOCK_H)
79d8453e 1336
3fd9d606 1337COLLECT2_OBJS = collect2.o tlink.o intl.o version.o
4e70264f 1338COLLECT2_LIBS = @COLLECT2_LIBS@
a2d25763 1339collect2$(exeext): $(COLLECT2_OBJS) $(LIBDEPS)
057f494b 1340# Don't try modifying collect2 (aka ld) in place--it might be linking this.
ff0a63e8 1341 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o T$@ \
4e70264f 1342 $(COLLECT2_OBJS) $(LIBS) $(COLLECT2_LIBS)
ff0a63e8 1343 mv -f T$@ $@
79d8453e 1344
4977bab6 1345collect2.o : collect2.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) gstab.h intl.h \
4e872036 1346 $(OBSTACK_H) $(DEMANGLE_H) collect2.h version.h
b7b08dcd 1347 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
caa55b1e 1348 -DTARGET_MACHINE=\"$(target_noncanonical)\" \
96a9c44f 1349 -c $(srcdir)/collect2.c $(OUTPUT_OPTION)
79d8453e 1350
4977bab6 1351tlink.o: tlink.c $(DEMANGLE_H) $(HASHTAB_H) $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
e2500fed 1352 $(OBSTACK_H) collect2.h intl.h
eaa41c8d 1353
79d8453e
RS
1354# A file used by all variants of C.
1355
4977bab6 1356c-common.o : c-common.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
d9b2742a 1357 $(OBSTACK_H) $(C_COMMON_H) flags.h toplev.h output.h c-pragma.h intl.h \
cb60f38d 1358 $(GGC_H) $(EXPR_H) $(TM_P_H) builtin-types.def builtin-attrs.def \
b6fe0bb8 1359 $(DIAGNOSTIC_H) gt-c-common.h langhooks.h varray.h $(RTL_H) \
e57e265b 1360 $(TARGET_H) $(C_TREE_H) langhooks.h
e1a4dd13 1361c-pretty-print.o : c-pretty-print.c $(C_PRETTY_PRINT_H) \
4977bab6 1362 $(C_COMMON_H) $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) real.h
1312c143 1363
94d1613b
MS
1364c-opts.o : c-opts.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1365 $(TREE_H) c-pragma.h flags.h toplev.h langhooks.h \
1366 tree-inline.h $(DIAGNOSTIC_H) intl.h debug.h $(C_COMMON_H) \
1367 opts.h options.h $(PARAMS_H)
8951a635
NB
1368 $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1369 $< $(OUTPUT_OPTION) @TARGET_SYSTEM_ROOT_DEFINE@
0b6f2917 1370
cb60f38d
NB
1371c-cppbuiltin.o : c-cppbuiltin.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1372 $(TREE_H) $(C_COMMON_H) c-pragma.h flags.h toplev.h langhooks.h \
e24c3d71 1373 output.h except.h real.h $(TM_P_H)
cb60f38d 1374
aaed0206
RK
1375# A file used by all variants of C and some other languages.
1376
4977bab6 1377attribs.o : attribs.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) flags.h \
aaed0206 1378 toplev.h output.h c-pragma.h $(RTL_H) $(GGC_H) $(EXPR_H) $(TM_P_H) \
7ffb4fd2 1379 builtin-types.def $(TARGET_H) langhooks.h
aaed0206 1380
4977bab6 1381c-format.o : c-format.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) langhooks.h \
b6fe0bb8 1382 $(C_COMMON_H) flags.h toplev.h intl.h $(DIAGNOSTIC_H)
79d8453e 1383
4977bab6
ZW
1384c-semantics.o : c-semantics.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1385 $(C_TREE_H) flags.h toplev.h output.h c-pragma.h $(RTL_H) $(GGC_H) \
96c6931d 1386 $(EXPR_H) $(PREDICT_H) tree-inline.h
f2c5f623 1387
4977bab6
ZW
1388c-dump.o : c-dump.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1389 $(C_TREE_H) tree-dump.h
558ee214 1390
17211ab5 1391c-pch.o : c-pch.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(CPPLIB_H) $(TREE_H) \
18c81520 1392 $(C_COMMON_H) output.h toplev.h c-pragma.h $(GGC_H) debug.h \
7bb1ad93 1393 langhooks.h flags.h hosthooks.h version.h $(TARGET_H)
7451756f
GK
1394 $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1395 -DHOST_MACHINE=\"$(host)\" -DTARGET_MACHINE=\"$(target)\" \
1396 $< $(OUTPUT_OPTION)
17211ab5 1397
79d8453e
RS
1398# Language-independent files.
1399
610c62ac 1400DRIVER_DEFINES = \
0deb20df 1401 -DSTANDARD_STARTFILE_PREFIX=\"$(unlibsubdir)/\" \
a8ee6e2d
GK
1402 -DSTANDARD_EXEC_PREFIX=\"$(libdir)/gcc/\" \
1403 -DSTANDARD_LIBEXEC_PREFIX=\"$(libexecdir)/gcc/\" \
964ceda1 1404 -DDEFAULT_TARGET_VERSION=\"$(version)\" \
caa55b1e 1405 -DDEFAULT_TARGET_MACHINE=\"$(target_noncanonical)\" \
0deb20df 1406 -DSTANDARD_BINDIR_PREFIX=\"$(bindir)/\" \
9db0819e 1407 -DTOOLDIR_BASE_PREFIX=\"$(unlibsubdir)/../\" \
4977bab6 1408 @TARGET_SYSTEM_ROOT_DEFINE@ \
414d23ae 1409 $(VALGRIND_DRIVER_DEFINES) \
db3f0336
HPN
1410 `test "X$${SHLIB_LINK}" = "X" || test "@enable_shared@" != "yes" || echo "-DENABLE_SHARED_LIBGCC"` \
1411 `test "X$${SHLIB_MULTILIB}" = "X" || echo "-DNO_SHARED_LIBGCC_MULTILIB"`
9db0819e 1412
4977bab6 1413gcc.o: gcc.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) intl.h multilib.h \
a693284d 1414 Makefile $(lang_specs_files) specs.h prefix.h $(GCC_H)
8c310e3f
MM
1415 (SHLIB_LINK='$(SHLIB_LINK)' \
1416 SHLIB_MULTILIB='$(SHLIB_MULTILIB)'; \
610c62ac
BK
1417 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1418 $(DRIVER_DEFINES) \
96a9c44f 1419 -c $(srcdir)/gcc.c $(OUTPUT_OPTION))
79d8453e 1420
4977bab6 1421gccspec.o: gccspec.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(GCC_H)
38935c21
FS
1422 (SHLIB_LINK='$(SHLIB_LINK)' \
1423 SHLIB_MULTILIB='$(SHLIB_MULTILIB)'; \
1424 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1425 $(DRIVER_DEFINES) \
96a9c44f 1426 -c $(srcdir)/gccspec.c $(OUTPUT_OPTION))
38935c21 1427
4977bab6 1428cppspec.o: cppspec.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(GCC_H)
08dc830e 1429
12b195d9 1430tree-check.h: s-check ; @true
80bcb4d2 1431s-check : gencheck$(build_exeext)
414d23ae 1432 $(RUN_GEN) ./gencheck$(build_exeext) > tmp-check.h
88e3a2a3 1433 $(SHELL) $(srcdir)/../move-if-change tmp-check.h tree-check.h
d9835ae8 1434 $(STAMP) s-check
12b195d9 1435
4977bab6 1436gencheck$(build_exeext) : gencheck.o $(BUILD_LIBDEPS)
eaf9f3b2 1437 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6 1438 gencheck.o $(BUILD_LIBS)
12b195d9 1439
4977bab6
ZW
1440gencheck.o : gencheck.c gencheck.h tree.def $(BCONFIG_H) $(SYSTEM_H) \
1441 coretypes.h $(GTM_H) $(lang_tree_files)
1a4bf22f 1442
0d24f4d1
ZW
1443gencheck.h : s-gencheck ; @true
1444s-gencheck : Makefile
766c7ad1
ZW
1445 ltf="$(lang_tree_files)"; for f in $$ltf; do \
1446 echo "#include \"$$f\""; \
0d24f4d1 1447 done | sed 's|$(srcdir)/||' > tmp-gencheck.h
88e3a2a3 1448 $(SHELL) $(srcdir)/../move-if-change tmp-gencheck.h gencheck.h
0d24f4d1
ZW
1449 $(STAMP) s-gencheck
1450
0d24f4d1
ZW
1451specs.h : s-specs ; @true
1452s-specs : Makefile
766c7ad1
ZW
1453 lsf="$(lang_specs_files)"; for f in $$lsf; do \
1454 echo "#include \"$$f\""; \
0d24f4d1 1455 done | sed 's|$(srcdir)/||' > tmp-specs.h
88e3a2a3 1456 $(SHELL) $(srcdir)/../move-if-change tmp-specs.h specs.h
0d24f4d1
ZW
1457 $(STAMP) s-specs
1458
469ef4a3
ILT
1459options.c options.h: s-options ; @true
1460s-options: $(lang_opt_files) $(srcdir)/opts.sh Makefile
4ade7b1a 1461 AWK=$(AWK) $(SHELL) $(srcdir)/opts.sh \
88e3a2a3 1462 '$(SHELL) $(srcdir)/../move-if-change' \
4ade7b1a 1463 options.c options.h $(lang_opt_files)
469ef4a3
ILT
1464 $(STAMP) s-options
1465
1466options.o: options.c options.h opts.h intl.h
d7b42618 1467
79d8453e
RS
1468dumpvers: dumpvers.c
1469
4746ee26 1470version.o: version.c version.h
0a25f1f5 1471
4977bab6
ZW
1472gtype-desc.o: gtype-desc.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) varray.h \
1473 $(HASHTAB_H) $(TREE_H) $(RTL_H) function.h insn-config.h $(EXPR_H) $(OPTABS_H) \
e2500fed 1474 libfuncs.h debug.h $(GGC_H) bitmap.h $(BASIC_BLOCK_H) hard-reg-set.h \
c132886e 1475 cselib.h insn-addr.h
e2500fed 1476
17211ab5 1477ggc-common.o: ggc-common.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(GGC_H) \
18c81520 1478 $(HASHTAB_H) toplev.h $(PARAMS_H) hosthooks.h
b49a6a90 1479
4977bab6 1480ggc-page.o: ggc-page.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
c4775f82 1481 flags.h toplev.h $(GGC_H) $(TIMEVAR_H) $(TM_P_H) $(PARAMS_H)
21341cfd 1482
b6f61163
DB
1483ggc-zone.o: ggc-zone.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1484 flags.h toplev.h $(GGC_H) $(TIMEVAR_H) $(TM_P_H) $(PARAMS_H)
1485
17211ab5
GK
1486stringpool.o: stringpool.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1487 $(TREE_H) $(GGC_H) gt-stringpool.h
520a57c8 1488
4977bab6 1489ggc-none.o: ggc-none.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(GGC_H)
9196ece5 1490 $(CC) -c $(ALL_CFLAGS) -DGENERATOR_FILE $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
0a25f1f5 1491
4977bab6 1492prefix.o: prefix.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) Makefile prefix.h
e9a25f70
JL
1493 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1494 -DPREFIX=\"$(prefix)\" \
96a9c44f 1495 -c $(srcdir)/prefix.c $(OUTPUT_OPTION)
79d8453e 1496
4977bab6
ZW
1497convert.o: convert.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) flags.h \
1498 convert.h toplev.h langhooks.h
c5d3565c 1499
4977bab6 1500langhooks.o : langhooks.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) toplev.h \
dd220c49 1501 tree-inline.h $(RTL_H) insn-config.h $(INTEGRATE_H) langhooks.h \
dba65e79 1502 $(LANGHOOKS_DEF_H) flags.h $(GGC_H) gt-langhooks.h diagnostic.h
4977bab6
ZW
1503tree.o : tree.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) flags.h function.h \
1504 toplev.h $(GGC_H) $(HASHTAB_H) $(TARGET_H) output.h $(TM_P_H) langhooks.h \
e2500fed 1505 real.h gt-tree.h
4977bab6
ZW
1506tree-dump.o: tree-dump.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1507 $(C_TREE_H) flags.h langhooks.h toplev.h output.h c-pragma.h $(RTL_H) $(GGC_H) \
89d684bb 1508 $(EXPR_H) $(SPLAY_TREE_H) tree-dump.h
4985cde3
RH
1509tree-inline.o : tree-inline.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1510 $(TREE_H) $(RTL_H) $(EXPR_H) flags.h $(PARAMS_H) input.h insn-config.h \
1511 $(INTEGRATE_H) $(VARRAY_H) $(HASHTAB_H) $(SPLAY_TREE_H) toplev.h \
ddd2d57e 1512 langhooks.h $(C_COMMON_H) tree-inline.h cgraph.h intl.h
4985cde3
RH
1513tree-optimize.o : tree-optimize.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1514 $(TREE_H) toplev.h langhooks.h cgraph.h $(TIMEVAR_H) function.h $(GGC_H)
1515
4977bab6
ZW
1516print-tree.o : print-tree.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1517 $(GGC_H) langhooks.h real.h
1518stor-layout.o : stor-layout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1519 flags.h function.h $(EXPR_H) $(RTL_H) toplev.h $(GGC_H) $(TM_P_H) $(TARGET_H) \
43577e6b 1520 langhooks.h
73e61092
GK
1521fold-const.o : fold-const.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1522 $(TREE_H) flags.h real.h toplev.h $(HASHTAB_H) $(EXPR_H) $(RTL_H) $(GGC_H) \
1523 $(TM_P_H) langhooks.h $(MD5_H)
b6fe0bb8 1524diagnostic.o : diagnostic.c $(DIAGNOSTIC_H) real.h \
4977bab6 1525 $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(TM_P_H) flags.h $(GGC_H) \
e5f3b786 1526 input.h toplev.h intl.h langhooks.h $(LANGHOOKS_DEF_H)
d7b42618 1527opts.o : opts.c opts.h options.h toplev.h $(CONFIG_H) $(SYSTEM_H) \
94c43112 1528 coretypes.h $(TREE_H) $(TM_H) langhooks.h $(GGC_H) $(RTL_H) \
221ee7c9 1529 output.h $(DIAGNOSTIC_H) $(TM_P_H) $(INSN_ATTR_H) intl.h target.h
61f71b34 1530targhooks.o : targhooks.c targhooks.h $(CONFIG_H) $(SYSTEM_H) \
d84a4ef1 1531 coretypes.h $(TREE_H) $(TM_H) $(RTL_H) $(TM_P_H) function.h \
8a89dbd2 1532 output.h toplev.h
61f71b34 1533
4977bab6 1534toplev.o : toplev.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
b6fe0bb8 1535 function.h flags.h xcoffout.h input.h $(INSN_ATTR_H) output.h $(DIAGNOSTIC_H) \
2b85879e 1536 debug.h insn-config.h intl.h $(RECOG_H) Makefile toplev.h \
efc9bd41 1537 dwarf2out.h sdbout.h dbxout.h $(EXPR_H) hard-reg-set.h $(BASIC_BLOCK_H) \
fca9dc00 1538 graph.h $(LOOP_H) except.h $(REGS_H) $(TIMEVAR_H) value-prof.h \
c132886e 1539 $(PARAMS_H) $(TM_P_H) reload.h dwarf2asm.h $(TARGET_H) \
b2e608ca 1540 langhooks.h insn-flags.h cfglayout.h real.h cfgloop.h \
40ca90bf 1541 hosthooks.h $(LANGHOOKS_DEF_H) cgraph.h $(COVERAGE_H) alloc-pool.h
2cc07db4 1542 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
caa55b1e 1543 -DTARGET_NAME=\"$(target_noncanonical)\" \
96a9c44f 1544 -c $(srcdir)/toplev.c $(OUTPUT_OPTION)
f6db1481
RH
1545
1546passes.o : passes.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1547 $(RTL_H) function.h flags.h xcoffout.h input.h $(INSN_ATTR_H) output.h \
1548 $(DIAGNOSTIC_H) debug.h insn-config.h intl.h $(RECOG_H) toplev.h \
1549 dwarf2out.h sdbout.h dbxout.h $(EXPR_H) hard-reg-set.h $(BASIC_BLOCK_H) \
1550 graph.h $(LOOP_H) except.h $(REGS_H) $(TIMEVAR_H) value-prof.h \
1551 $(PARAMS_H) $(TM_P_H) reload.h dwarf2asm.h $(TARGET_H) \
1552 langhooks.h insn-flags.h cfglayout.h real.h cfgloop.h \
1553 hosthooks.h $(LANGHOOKS_DEF_H) cgraph.h $(COVERAGE_H) alloc-pool.h
1554
4977bab6 1555main.o : main.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) toplev.h
79d8453e 1556
476d9098
GK
1557host-default.o : host-default.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
1558 hosthooks.h hosthooks-def.h
1559
4977bab6 1560rtl-error.o: rtl-error.c $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(INSN_ATTR_H) \
b6fe0bb8 1561 insn-config.h input.h toplev.h intl.h $(DIAGNOSTIC_H) $(CONFIG_H)
c895acf2 1562
4977bab6
ZW
1563rtl.o : rtl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(RTL_H) real.h \
1564 $(GGC_H) errors.h
9196ece5 1565 $(CC) -c $(ALL_CFLAGS) -DGENERATOR_FILE $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
79d8453e 1566
757dc040
RH
1567print-rtl.o : print-rtl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1568 $(RTL_H) $(TREE_H) hard-reg-set.h $(BASIC_BLOCK_H) real.h $(TM_P_H)
1569rtlanal.o : rtlanal.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) toplev.h \
1570 $(RTL_H) hard-reg-set.h $(TM_P_H) insn-config.h $(RECOG_H) real.h flags.h \
f894b69b 1571 $(BASIC_BLOCK_H) $(REGS_H) output.h target.h
bc204393 1572
e5610450 1573errors.o : errors.c $(CONFIG_H) $(SYSTEM_H) errors.h
9196ece5 1574 $(CC) -c $(ALL_CFLAGS) -DGENERATOR_FILE $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
79d8453e 1575
4977bab6
ZW
1576varasm.o : varasm.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
1577 flags.h function.h $(EXPR_H) hard-reg-set.h $(REGS_H) \
440aabf8 1578 output.h c-pragma.h toplev.h xcoffout.h debug.h $(GGC_H) $(TM_P_H) \
907aee69 1579 $(HASHTAB_H) $(TARGET_H) langhooks.h gt-varasm.h real.h
4977bab6 1580function.o : function.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
c6b97fac 1581 flags.h function.h $(EXPR_H) $(OPTABS_H) libfuncs.h $(REGS_H) hard-reg-set.h \
e2500fed 1582 insn-config.h $(RECOG_H) output.h toplev.h except.h $(HASHTAB_H) $(GGC_H) \
61f71b34 1583 $(TM_P_H) langhooks.h gt-function.h $(TARGET_H)
4977bab6
ZW
1584stmt.o : stmt.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) flags.h \
1585 function.h insn-config.h hard-reg-set.h $(EXPR_H) libfuncs.h except.h \
43577e6b 1586 $(LOOP_H) $(RECOG_H) toplev.h output.h varray.h $(GGC_H) $(TM_P_H) \
61f71b34 1587 langhooks.h $(PREDICT_H) gt-stmt.h $(OPTABS_H) $(TARGET_H)
dd07abd7
RH
1588except.o : except.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1589 $(TREE_H) flags.h except.h function.h $(EXPR_H) libfuncs.h $(INTEGRATE_H) \
1590 langhooks.h insn-config.h hard-reg-set.h $(BASIC_BLOCK_H) output.h \
e2500fed 1591 dwarf2asm.h dwarf2out.h toplev.h $(HASHTAB_H) intl.h $(GGC_H) \
dd07abd7 1592 gt-except.h cgraph.h
4977bab6 1593expr.o : expr.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) flags.h \
dd220c49 1594 function.h $(REGS_H) $(EXPR_H) $(OPTABS_H) libfuncs.h $(INSN_ATTR_H) insn-config.h \
34e81b5a 1595 $(RECOG_H) output.h typeclass.h hard-reg-set.h toplev.h hard-reg-set.h \
c988af2b 1596 except.h reload.h $(GGC_H) langhooks.h intl.h $(TM_P_H) real.h $(TARGET_H)
1cff8964 1597dojump.o : dojump.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
dd220c49 1598 flags.h function.h $(EXPR_H) $(OPTABS_H) $(INSN_ATTR_H) insn-config.h \
1cff8964 1599 langhooks.h
4977bab6
ZW
1600builtins.o : builtins.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H)\
1601 flags.h $(TARGET_H) function.h $(REGS_H) $(EXPR_H) $(OPTABS_H) insn-config.h \
28f4ec01 1602 $(RECOG_H) output.h typeclass.h hard-reg-set.h toplev.h hard-reg-set.h \
a77a9a18 1603 except.h $(TM_P_H) $(PREDICT_H) libfuncs.h real.h langhooks.h
4977bab6 1604calls.o : calls.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) flags.h \
6e985040 1605 $(EXPR_H) $(OPTABS_H) langhooks.h $(TARGET_H) \
b2dd096b 1606 libfuncs.h $(REGS_H) toplev.h output.h function.h $(TIMEVAR_H) $(TM_P_H) cgraph.h except.h
4977bab6
ZW
1607expmed.o : expmed.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1608 flags.h insn-config.h $(EXPR_H) $(OPTABS_H) $(RECOG_H) real.h \
b0c48229 1609 toplev.h $(TM_P_H) langhooks.h
4977bab6
ZW
1610explow.o : explow.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1611 flags.h hard-reg-set.h insn-config.h $(EXPR_H) $(OPTABS_H) $(RECOG_H) \
94c43112 1612 toplev.h function.h $(GGC_H) $(TM_P_H) langhooks.h gt-explow.h
4977bab6
ZW
1613optabs.o : optabs.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1614 flags.h insn-config.h $(EXPR_H) $(OPTABS_H) libfuncs.h $(RECOG_H) reload.h \
c15c90bb 1615 toplev.h $(GGC_H) real.h $(TM_P_H) except.h gt-optabs.h $(BASIC_BLOCK_H) \
7bb1ad93 1616 $(TARGET_H)
4977bab6
ZW
1617dbxout.o : dbxout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
1618 flags.h $(REGS_H) debug.h $(TM_P_H) $(TARGET_H) function.h langhooks.h \
17211ab5
GK
1619 insn-config.h reload.h gstab.h xcoffout.h output.h dbxout.h toplev.h \
1620 $(GGC_H) gt-dbxout.h
4977bab6 1621debug.o : debug.c debug.h $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H)
21d13d83
ZW
1622sdbout.o : sdbout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) debug.h \
1623 $(TREE_H) $(GGC_H) varray.h $(RTL_H) $(REGS_H) flags.h insn-config.h \
1624 output.h toplev.h $(TM_P_H) gsyms.h langhooks.h $(TARGET_H) sdbout.h \
1625 gt-sdbout.h
73e61092
GK
1626dwarf2out.o : dwarf2out.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1627 $(TREE_H) $(RTL_H) dwarf2.h debug.h flags.h insn-config.h reload.h \
1628 output.h $(DIAGNOSTIC_H) real.h hard-reg-set.h $(REGS_H) $(EXPR_H) \
1629 libfuncs.h toplev.h dwarf2out.h varray.h $(GGC_H) except.h dwarf2asm.h \
1630 $(TM_P_H) langhooks.h $(HASHTAB_H) gt-dwarf2out.h $(TARGET_H) cgraph.h \
6097b0c3 1631 $(MD5_H) input.h
4977bab6 1632dwarf2asm.o : dwarf2asm.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) flags.h $(RTL_H) \
17211ab5 1633 $(TREE_H) output.h dwarf2asm.h $(TM_P_H) $(GGC_H) gt-dwarf2asm.h
4977bab6
ZW
1634vmsdbgout.o : vmsdbgout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
1635 $(RTL_H) flags.h output.h vmsdbg.h debug.h langhooks.h function.h $(TARGET_H)
1636xcoffout.o : xcoffout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) $(RTL_H) \
1637 xcoffout.h flags.h toplev.h output.h dbxout.h $(GGC_H) $(TARGET_H)
1638emit-rtl.o : emit-rtl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1639 flags.h function.h $(REGS_H) insn-config.h $(RECOG_H) real.h $(GGC_H) \
dd220c49 1640 $(EXPR_H) $(OBSTACK_H) hard-reg-set.h bitmap.h toplev.h \
5ba6918e 1641 $(HASHTAB_H) $(TM_P_H) debug.h langhooks.h gt-emit-rtl.h
4977bab6
ZW
1642real.o : real.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) toplev.h $(TM_P_H)
1643integrate.o : integrate.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1644 flags.h debug.h $(INTEGRATE_H) insn-config.h $(EXPR_H) real.h $(REGS_H) \
c6d9a88c 1645 intl.h function.h output.h $(RECOG_H) except.h toplev.h $(LOOP_H) \
e2500fed 1646 $(PARAMS_H) $(TM_P_H) $(TARGET_H) langhooks.h gt-integrate.h
4977bab6
ZW
1647jump.o : jump.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1648 hard-reg-set.h $(REGS_H) insn-config.h $(RECOG_H) $(EXPR_H) real.h except.h function.h \
49468c8b 1649 toplev.h $(INSN_ATTR_H) $(TM_P_H) reload.h $(PREDICT_H) $(TIMEVAR_H) \
b6fe0bb8 1650 $(DIAGNOSTIC_H)
79d8453e 1651
4977bab6
ZW
1652simplify-rtx.o : simplify-rtx.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1653 $(REGS_H) hard-reg-set.h flags.h real.h insn-config.h $(RECOG_H) $(EXPR_H) toplev.h \
7daebb7a 1654 output.h function.h $(GGC_H) $(OBSTACK_H) $(TM_P_H) $(TREE_H) $(TARGET_H)
e72fcfe8 1655cgraph.o : cgraph.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
dc0bfe6a
JH
1656 langhooks.h toplev.h flags.h $(GGC_H) $(TARGET_H) cgraph.h gt-cgraph.h \
1657 output.h intl.h
1c4a429a 1658cgraphunit.o : cgraphunit.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TREE_H) \
dc0bfe6a 1659 langhooks.h tree-inline.h toplev.h flags.h $(GGC_H) $(TARGET_H) cgraph.h intl.h
ca29da43
NS
1660coverage.o : coverage.c gcov-io.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
1661 $(TM_H) $(RTL_H) $(TREE_H) flags.h output.h $(REGS_H) $(EXPR_H) function.h \
1662 toplev.h $(GGC_H) $(TARGET_H) langhooks.h $(COVERAGE_H) libfuncs.h \
1663 gt-coverage.h $(HASHTAB_H)
4977bab6 1664cselib.o : cselib.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
0cedb36c 1665 hard-reg-set.h flags.h real.h insn-config.h $(RECOG_H) $(EXPR_H) toplev.h \
6a59927d
JH
1666 output.h function.h cselib.h $(GGC_H) $(TM_P_H) gt-cselib.h $(PARAMS_H) \
1667 alloc-pool.h
4977bab6 1668cse.o : cse.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
3c50106f
RH
1669 hard-reg-set.h flags.h real.h insn-config.h $(RECOG_H) $(EXPR_H) toplev.h \
1670 output.h function.h $(BASIC_BLOCK_H) $(GGC_H) $(TM_P_H) $(TIMEVAR_H) \
9bf8cfbf 1671 except.h $(TARGET_H) $(PARAMS_H)
62551c66
JH
1672web.o : web.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
1673 hard-reg-set.h flags.h $(BASIC_BLOCK_H) function.h output.h toplev.h df.h
4977bab6 1674gcse.o : gcse.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
dd220c49 1675 hard-reg-set.h flags.h real.h insn-config.h $(GGC_H) $(RECOG_H) $(EXPR_H) \
ca35b546 1676 $(BASIC_BLOCK_H) function.h output.h toplev.h $(TM_P_H) $(PARAMS_H) \
9ddb66ca 1677 except.h gt-gcse.h $(TREE_H) cselib.h
4977bab6
ZW
1678sibcall.o : sibcall.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
1679 function.h hard-reg-set.h flags.h insn-config.h $(RECOG_H) $(BASIC_BLOCK_H)
1680resource.o : resource.c $(CONFIG_H) $(RTL_H) hard-reg-set.h $(SYSTEM_H) coretypes.h \
1681 $(TM_H) $(BASIC_BLOCK_H) $(REGS_H) flags.h output.h resource.h function.h toplev.h \
639bc36c 1682 $(INSN_ATTR_H) except.h $(PARAMS_H) $(TM_P_H)
4977bab6
ZW
1683lcm.o : lcm.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(REGS_H) \
1684 hard-reg-set.h flags.h real.h insn-config.h $(INSN_ATTR_H) $(RECOG_H) $(EXPR_H) \
fa1a0d02 1685 $(BASIC_BLOCK_H) $(TM_P_H) df.h function.h
38afe605 1686df.o : df.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
873ceaab 1687 insn-config.h $(RECOG_H) function.h $(REGS_H) alloc-pool.h hard-reg-set.h \
4977bab6 1688 $(BASIC_BLOCK_H) df.h $(FIBHEAP_H)
014a1138
JZ
1689var-tracking.o : var-tracking.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1690 $(RTL_H) $(TREE_H) hard-reg-set.h insn-config.h reload.h flags.h \
1691 $(BASIC_BLOCK_H) output.h sbitmap.h alloc-pool.h $(FIBHEAP_H) $(HASHTAB_H)
4977bab6
ZW
1692conflict.o : conflict.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(OBSTACK_H) \
1693 $(HASHTAB_H) $(RTL_H) hard-reg-set.h $(BASIC_BLOCK_H)
ca29da43
NS
1694profile.o : profile.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1695 $(TREE_H) flags.h output.h $(REGS_H) $(EXPR_H) function.h \
af166e5d
ZD
1696 toplev.h $(BASIC_BLOCK_H) $(COVERAGE_H) $(TREE_H) value-prof.h
1697value-prof.o : value-prof.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1698 $(BASIC_BLOCK_H) hard-reg-set.h value-prof.h $(EXPR_H) output.h flags.h \
fca9dc00 1699 $(RECOG_H) insn-config.h $(OPTABS_H) $(REGS_H)
4977bab6 1700loop.o : loop.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h $(LOOP_H) \
e78d8e51 1701 insn-config.h $(REGS_H) hard-reg-set.h $(RECOG_H) $(EXPR_H) \
3d436d2a 1702 real.h $(PREDICT_H) $(BASIC_BLOCK_H) function.h cfgloop.h \
c8b6fae3 1703 toplev.h varray.h except.h cselib.h $(OPTABS_H) $(TM_P_H) $(GGC_H)
4977bab6 1704doloop.o : doloop.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
3d436d2a
ZD
1705 $(LOOP_H) $(EXPR_H) hard-reg-set.h $(BASIC_BLOCK_H) $(TM_P_H) toplev.h \
1706 cfgloop.h
4977bab6
ZW
1707unroll.o : unroll.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) insn-config.h \
1708 function.h $(INTEGRATE_H) $(REGS_H) $(RECOG_H) flags.h $(EXPR_H) $(LOOP_H) toplev.h \
3d436d2a
ZD
1709 hard-reg-set.h varray.h $(BASIC_BLOCK_H) $(TM_P_H) $(PREDICT_H) $(PARAMS_H) \
1710 cfgloop.h
1e0f41c9 1711alloc-pool.o : alloc-pool.c $(CONFIG_H) $(SYSTEM_H) alloc-pool.h $(HASHTAB_H)
4977bab6
ZW
1712flow.o : flow.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1713 flags.h insn-config.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h toplev.h \
c132886e 1714 $(RECOG_H) function.h except.h $(EXPR_H) $(GGC_H) $(TM_P_H)
4977bab6 1715cfg.o : cfg.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h insn-config.h \
402209ff 1716 $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h toplev.h $(RECOG_H) \
f6cb56fa 1717 function.h except.h $(GGC_H) $(TM_P_H) alloc-pool.h
9ee634e3 1718cfghooks.o: cfghooks.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
f470c378 1719 $(BASIC_BLOCK_H) cfglayout.h $(TIMEVAR_H) toplev.h
4977bab6
ZW
1720cfgrtl.o : cfgrtl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1721 insn-config.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h toplev.h $(RECOG_H) \
ff25ef99 1722 function.h except.h $(GGC_H) $(TM_P_H) insn-config.h $(EXPR_H)
4977bab6
ZW
1723cfganal.o : cfganal.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1724 $(BASIC_BLOCK_H) hard-reg-set.h insn-config.h $(RECOG_H) $(GGC_H) $(TM_P_H)
1725cfgbuild.o : cfgbuild.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1726 insn-config.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h toplev.h $(RECOG_H) \
0f81faf6 1727 function.h except.h $(GGC_H)
5f24e0dc
RH
1728cfgcleanup.o : cfgcleanup.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1729 $(RTL_H) $(TIMEVAR_H) $(BASIC_BLOCK_H) hard-reg-set.h output.h flags.h \
1730 $(RECOG_H) toplev.h $(GGC_H) insn-config.h cselib.h $(TARGET_H) $(TM_P_H) \
66fd46b6 1731 $(PARAMS_H) $(REGS_H)
cd68f4e4 1732cfgloop.o : cfgloop.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) coretypes.h $(TM_H) \
3d436d2a
ZD
1733 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h flags.h
1734cfgloopanal.o : cfgloopanal.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) \
cd68f4e4 1735 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h $(EXPR_H) coretypes.h $(TM_H)
50654f6c
ZD
1736loop-iv.o : loop-iv.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) $(GGC_H) \
1737 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h $(EXPR_H) coretypes.h $(TM_H)
3d436d2a 1738cfgloopmanip.o : cfgloopmanip.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) \
cd68f4e4 1739 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h cfglayout.h output.h coretypes.h $(TM_H)
94de45d9 1740loop-init.o : loop-init.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) \
ca29da43 1741 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h cfglayout.h \
617b465c
ZD
1742 coretypes.h $(TM_H)
1743loop-unswitch.o : loop-unswitch.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) $(TM_H) \
dd220c49 1744 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h cfglayout.h $(PARAMS_H) \
617b465c 1745 output.h $(EXPR_H) coretypes.h $(TM_H)
b17d5d7c 1746loop-unroll.o: loop-unroll.c $(CONFIG_H) $(SYSTEM_H) $(RTL_H) $(TM_H) \
dd220c49 1747 $(BASIC_BLOCK_H) hard-reg-set.h cfgloop.h cfglayout.h $(PARAMS_H) \
b17d5d7c 1748 output.h $(EXPR_H) coretypes.h $(TM_H)
4977bab6
ZW
1749dominance.o : dominance.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1750 hard-reg-set.h $(BASIC_BLOCK_H) et-forest.h
7f22efe1 1751et-forest.o : et-forest.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) et-forest.h alloc-pool.h
4977bab6
ZW
1752combine.o : combine.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1753 function.h insn-config.h $(INSN_ATTR_H) $(REGS_H) $(EXPR_H) \
61f71b34 1754 $(BASIC_BLOCK_H) $(RECOG_H) real.h hard-reg-set.h toplev.h $(TM_P_H) $(TREE_H) $(TARGET_H)
4977bab6
ZW
1755regclass.o : regclass.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1756 hard-reg-set.h flags.h $(BASIC_BLOCK_H) $(REGS_H) insn-config.h $(RECOG_H) reload.h \
0d446150 1757 real.h toplev.h function.h output.h $(GGC_H) $(TM_P_H) $(EXPR_H) $(TIMEVAR_H)
4977bab6
ZW
1758local-alloc.o : local-alloc.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1759 flags.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h insn-config.h $(RECOG_H) \
a4d3961a 1760 output.h function.h $(INSN_ATTR_H) toplev.h except.h $(TM_P_H)
4977bab6 1761bitmap.o : bitmap.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(RTL_H) flags.h \
e2500fed 1762 $(BASIC_BLOCK_H) $(REGS_H) $(GGC_H)
9196ece5 1763 $(CC) -c $(ALL_CFLAGS) -DGENERATOR_FILE $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
4977bab6
ZW
1764global.o : global.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1765 reload.h function.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h insn-config.h output.h \
1766 toplev.h $(TM_P_H)
9b57b627
JH
1767varray.o : varray.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) varray.h $(GGC_H) errors.h \
1768 $(HASHTAB_H)
4977bab6 1769ra.o : ra.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TM_P_H) insn-config.h \
dd220c49
KG
1770 $(RECOG_H) $(INTEGRATE_H) function.h $(REGS_H) $(OBSTACK_H) hard-reg-set.h \
1771 $(BASIC_BLOCK_H) df.h $(EXPR_H) output.h toplev.h flags.h reload.h ra.h
4977bab6 1772ra-build.o : ra-build.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TM_P_H) \
ed8d2920 1773 insn-config.h $(RECOG_H) function.h $(REGS_H) hard-reg-set.h \
dd220c49 1774 $(BASIC_BLOCK_H) df.h output.h $(GGC_H) ra.h gt-ra-build.h reload.h
4977bab6
ZW
1775ra-colorize.o : ra-colorize.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1776 $(TM_P_H) function.h $(REGS_H) hard-reg-set.h $(BASIC_BLOCK_H) df.h output.h ra.h
1777ra-debug.o : ra-debug.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1778 insn-config.h $(RECOG_H) function.h hard-reg-set.h $(BASIC_BLOCK_H) df.h output.h \
66fd46b6 1779 ra.h $(TM_P_H) $(REGS_H)
4977bab6 1780ra-rewrite.o : ra-rewrite.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
dd220c49 1781 $(TM_P_H) function.h $(REGS_H) hard-reg-set.h $(BASIC_BLOCK_H) df.h $(EXPR_H) \
54b2a7f8 1782 output.h except.h ra.h reload.h insn-config.h
4977bab6 1783reload.o : reload.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h output.h \
e78d8e51 1784 $(EXPR_H) $(OPTABS_H) reload.h $(RECOG_H) hard-reg-set.h insn-config.h \
0bcf8261 1785 $(REGS_H) function.h real.h toplev.h $(TM_P_H) $(PARAMS_H)
4977bab6 1786reload1.o : reload1.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) real.h flags.h \
d9e674f7
KH
1787 $(EXPR_H) $(OPTABS_H) reload.h $(REGS_H) hard-reg-set.h insn-config.h \
1788 $(BASIC_BLOCK_H) $(RECOG_H) output.h function.h toplev.h $(TM_P_H) \
1789 except.h $(TREE_H)
1790postreload.o : postreload.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) real.h flags.h \
e78d8e51 1791 $(EXPR_H) $(OPTABS_H) reload.h $(REGS_H) hard-reg-set.h insn-config.h \
39f95a2c 1792 $(BASIC_BLOCK_H) $(RECOG_H) output.h function.h toplev.h cselib.h $(TM_P_H) \
a20fd5ac 1793 except.h $(TREE_H)
4977bab6
ZW
1794caller-save.o : caller-save.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1795 flags.h $(REGS_H) hard-reg-set.h insn-config.h $(BASIC_BLOCK_H) function.h \
830a47ec 1796 $(RECOG_H) reload.h $(EXPR_H) toplev.h $(TM_P_H)
1194fc79 1797bt-load.o : bt-load.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) except.h \
8f7193b8 1798 $(BASIC_BLOCK_H) $(RTL_H) hard-reg-set.h $(REGS_H) $(OBSTACK_H) $(TM_P_H) \
fe3ad572 1799 $(FIBHEAP_H) output.h $(TARGET_H) $(EXPR_H) flags.h $(INSN_ATTR_H)
4977bab6
ZW
1800reorg.o : reorg.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) conditions.h \
1801 hard-reg-set.h $(BASIC_BLOCK_H) $(REGS_H) insn-config.h $(INSN_ATTR_H) except.h \
639bc36c 1802 $(RECOG_H) function.h flags.h output.h $(EXPR_H) toplev.h $(PARAMS_H) $(TM_P_H)
4977bab6
ZW
1803alias.o : alias.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) flags.h \
1804 hard-reg-set.h $(BASIC_BLOCK_H) $(REGS_H) toplev.h output.h $(EXPR_H) \
e2500fed 1805 $(GGC_H) function.h cselib.h $(TREE_H) $(TM_P_H) langhooks.h $(TARGET_H) \
b255a036 1806 gt-alias.h $(TIMEVAR_H) cgraph.h
4977bab6 1807regmove.o : regmove.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) insn-config.h \
4b983fdc 1808 $(RECOG_H) output.h $(REGS_H) hard-reg-set.h flags.h function.h \
8461e984 1809 $(EXPR_H) $(BASIC_BLOCK_H) toplev.h $(TM_P_H) except.h reload.h
4977bab6
ZW
1810haifa-sched.o : haifa-sched.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1811 sched-int.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h flags.h insn-config.h function.h \
c237e94a 1812 $(INSN_ATTR_H) toplev.h $(RECOG_H) except.h $(TM_P_H) $(TARGET_H)
4977bab6
ZW
1813sched-deps.o : sched-deps.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1814 sched-int.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h flags.h insn-config.h function.h \
4b6c5340 1815 $(INSN_ATTR_H) toplev.h $(RECOG_H) except.h cselib.h $(PARAMS_H) $(TM_P_H)
4977bab6
ZW
1816sched-rgn.o : sched-rgn.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1817 sched-int.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h flags.h insn-config.h function.h \
fae15c93 1818 $(INSN_ATTR_H) toplev.h $(RECOG_H) except.h $(TM_P_H) $(TARGET_H)
4977bab6
ZW
1819sched-ebb.o : sched-ebb.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1820 sched-int.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h flags.h insn-config.h function.h \
ca29da43 1821 $(INSN_ATTR_H) toplev.h $(RECOG_H) except.h $(TM_P_H) $(PARAMS_H)
4977bab6
ZW
1822sched-vis.o : sched-vis.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1823 sched-int.h hard-reg-set.h $(BASIC_BLOCK_H) $(INSN_ATTR_H) $(REGS_H) $(TM_P_H) \
b3ae1ccd 1824 $(TARGET_H) real.h
4977bab6
ZW
1825final.o : final.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1826 flags.h intl.h $(REGS_H) $(RECOG_H) conditions.h insn-config.h $(INSN_ATTR_H) \
1827 function.h real.h output.h hard-reg-set.h except.h debug.h xcoffout.h \
1828 toplev.h reload.h dwarf2out.h $(BASIC_BLOCK_H) $(TM_P_H) $(TARGET_H) \
1829 $(EXPR_H)
1830recog.o : recog.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) function.h \
1831 $(BASIC_BLOCK_H) $(REGS_H) $(RECOG_H) $(EXPR_H) hard-reg-set.h flags.h insn-config.h \
da920570 1832 $(INSN_ATTR_H) real.h toplev.h output.h reload.h $(TM_P_H)
4977bab6
ZW
1833reg-stack.o : reg-stack.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1834 $(RECOG_H) $(REGS_H) hard-reg-set.h flags.h insn-config.h toplev.h reload.h \
e2500fed 1835 varray.h function.h $(TM_P_H) $(GGC_H) gt-reg-stack.h
ac5e69da 1836sreal.o: sreal.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) sreal.h
4977bab6
ZW
1837predict.o: predict.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
1838 flags.h insn-config.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h toplev.h \
ac5e69da 1839 $(RECOG_H) function.h except.h $(EXPR_H) $(TM_P_H) $(PREDICT_H) sreal.h \
ca29da43 1840 $(PARAMS_H) $(TARGET_H) cfgloop.h $(COVERAGE_H)
4977bab6 1841lists.o: lists.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) toplev.h $(RTL_H) $(GGC_H)
aa634f11 1842bb-reorder.o : bb-reorder.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
38700cee 1843 $(RTL_H) $(BASIC_BLOCK_H) flags.h timevar.h output.h cfglayout.h $(FIBHEAP_H) \
aa634f11 1844 $(TARGET_H)
4977bab6 1845tracer.o : tracer.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) $(TREE_H) \
38700cee 1846 $(BASIC_BLOCK_H) hard-reg-set.h output.h cfglayout.h flags.h timevar.h \
ca29da43 1847 $(PARAMS_H) $(COVERAGE_H)
0b077eac
RH
1848cfglayout.o : cfglayout.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1849 $(RTL_H) $(TREE_H) insn-config.h $(BASIC_BLOCK_H) hard-reg-set.h output.h \
0435312e 1850 function.h cfglayout.h cfgloop.h $(TARGET_H) gt-cfglayout.h $(GGC_H)
4977bab6 1851timevar.o : timevar.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(TIMEVAR_H) flags.h \
dd1b7476 1852 intl.h toplev.h
4977bab6
ZW
1853regrename.o : regrename.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
1854 insn-config.h $(BASIC_BLOCK_H) $(REGS_H) hard-reg-set.h output.h $(RECOG_H) function.h \
11642c3a 1855 resource.h $(OBSTACK_H) flags.h $(TM_P_H)
2ef0a555 1856ifcvt.o : ifcvt.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
7bb1ad93 1857 $(REGS_H) toplev.h flags.h insn-config.h function.h $(RECOG_H) $(TARGET_H) \
65f43cdf
ZD
1858 $(BASIC_BLOCK_H) $(EXPR_H) output.h except.h $(TM_P_H) real.h $(OPTABS_H) \
1859 cfgloop.h
4977bab6
ZW
1860params.o : params.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(PARAMS_H) toplev.h
1861hooks.o: hooks.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(HOOKS_H)
13544b81 1862pretty-print.o: $(CONFIG_H) $(SYSTEM_H) pretty-print.c $(PRETTY_PRINT_H)
d061bc1e 1863
4977bab6 1864$(out_object_file): $(out_file) $(CONFIG_H) coretypes.h $(TM_H) $(TREE_H) $(GGC_H) \
6feacd09 1865 $(RTL_H) $(REGS_H) hard-reg-set.h real.h insn-config.h conditions.h \
e78d8e51 1866 output.h $(INSN_ATTR_H) $(SYSTEM_H) toplev.h $(TARGET_H) libfuncs.h \
3ac88239
NB
1867 $(TARGET_DEF_H) function.h sched-int.h $(TM_P_H) $(EXPR_H) $(OPTABS_H) \
1868 langhooks.h
b8dad04b
ZW
1869 $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
1870 $(out_file) $(OUTPUT_OPTION)
79d8453e 1871
4e0db2ce
RK
1872# Build auxiliary files that support ecoff format.
1873mips-tfile: mips-tfile.o version.o $(LIBDEPS)
aab26e16 1874 $(CC) $(CFLAGS) $(LDFLAGS) -o $@ mips-tfile.o version.o $(LIBS)
4e0db2ce 1875
4977bab6 1876mips-tfile.o : mips-tfile.c $(CONFIG_H) $(RTL_H) $(SYSTEM_H) coretypes.h $(TM_H) version.h
4e0db2ce
RK
1877
1878mips-tdump: mips-tdump.o version.o $(LIBDEPS)
aab26e16 1879 $(CC) $(CFLAGS) $(LDFLAGS) -o $@ mips-tdump.o version.o $(LIBS)
4e0db2ce 1880
d90f9882 1881mips-tdump.o : mips-tdump.c $(CONFIG_H) $(RTL_H) $(SYSTEM_H) coretypes.h $(TM_H) version.h
4e0db2ce 1882
d1bd0ded
GK
1883# FIXME: writing proper dependencies for this is a *LOT* of work.
1884libbackend.o : $(OBJS-common:.o=.c) $(out_file) \
1885 insn-config.h insn-flags.h insn-codes.h insn-constants.h \
d2908a50 1886 insn-attr.h
d1bd0ded 1887 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
caa55b1e 1888 -DTARGET_NAME=\"$(target_noncanonical)\" \
d1bd0ded
GK
1889 -DLOCALEDIR=\"$(localedir)\" \
1890 -c $(filter %.c,$^) -o $@
1891
544eb21e 1892#\f
4c457b6b 1893# Generate header and source files from the machine description,
79d8453e
RS
1894# and compile them.
1895
1b0c37d7 1896.PRECIOUS: insn-config.h insn-flags.h insn-codes.h insn-constants.h \
79d8453e
RS
1897 insn-emit.c insn-recog.c insn-extract.c insn-output.c insn-peep.c \
1898 insn-attr.h insn-attrtab.c
1899
1900# The following pair of rules has this effect:
1901# genconfig is run only if the md has changed since genconfig was last run;
1902# but the file insn-config.h is touched only when its contents actually change.
1903
1904# Each of the other insn-* files is handled by a similar pair of rules.
1905
1402d22c 1906# This causes an anomaly in the results of make -n
e5e809f4 1907# because insn-* is older than s-*
1402d22c
RS
1908# and thus make -n thinks that insn-* will be updated
1909# and force recompilation of things that depend on it.
424aa086 1910# We use move-if-change precisely to avoid such recompilation.
1402d22c
RS
1911# But there is no way to teach make -n that it will be avoided.
1912
79d8453e
RS
1913# Each of the insn-*.[ch] rules has a semicolon at the end,
1914# for otherwise the system Make on SunOS 4.1 never tries
7bd95cc1
BK
1915# to recompile insn-*.o. To avoid problems and extra noise from
1916# versions of make which don't like empty commands (nothing after the
1917# trailing `;'), we call true for each.
79d8453e 1918
e5e809f4 1919insn-config.h: s-config ; @true
80bcb4d2 1920s-config : $(md_file) genconfig$(build_exeext)
414d23ae 1921 $(RUN_GEN) ./genconfig$(build_exeext) $(md_file) > tmp-config.h
88e3a2a3 1922 $(SHELL) $(srcdir)/../move-if-change tmp-config.h insn-config.h
d9835ae8 1923 $(STAMP) s-config
79d8453e 1924
2199e5fa 1925insn-conditions.c: s-conditions ; @true
80bcb4d2 1926s-conditions : $(md_file) genconditions$(build_exeext)
414d23ae 1927 $(RUN_GEN) ./genconditions$(build_exeext) $(md_file) > tmp-conditions.c
88e3a2a3 1928 $(SHELL) $(srcdir)/../move-if-change tmp-conditions.c insn-conditions.c
2199e5fa
ZW
1929 $(STAMP) s-conditions
1930
4977bab6
ZW
1931insn-conditions.o : insn-conditions.c $(CONFIG_H) $(SYSTEM_H) coretypes.h \
1932 $(GTM_H) $(RTL_H) $(TM_P_H) $(REGS_H) function.h $(RECOG_H) real.h output.h \
1933 flags.h hard-reg-set.h resource.h toplev.h reload.h gensupport.h \
1934 insn-constants.h
eaf9f3b2 1935 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) insn-conditions.c
2199e5fa 1936
4977bab6
ZW
1937dummy-conditions.o : dummy-conditions.c $(BCONFIG_H) $(SYSTEM_H) \
1938 coretypes.h $(GTM_H) gensupport.h
2199e5fa 1939
e5e809f4 1940insn-flags.h: s-flags ; @true
80bcb4d2 1941s-flags : $(md_file) genflags$(build_exeext)
414d23ae 1942 $(RUN_GEN) ./genflags$(build_exeext) $(md_file) > tmp-flags.h
88e3a2a3 1943 $(SHELL) $(srcdir)/../move-if-change tmp-flags.h insn-flags.h
d9835ae8 1944 $(STAMP) s-flags
79d8453e 1945
e5e809f4 1946insn-codes.h: s-codes ; @true
80bcb4d2 1947s-codes : $(md_file) gencodes$(build_exeext)
414d23ae 1948 $(RUN_GEN) ./gencodes$(build_exeext) $(md_file) > tmp-codes.h
88e3a2a3 1949 $(SHELL) $(srcdir)/../move-if-change tmp-codes.h insn-codes.h
d9835ae8 1950 $(STAMP) s-codes
79d8453e 1951
1b0c37d7 1952insn-constants.h: s-constants ; @true
80bcb4d2 1953s-constants : $(md_file) genconstants$(build_exeext)
414d23ae 1954 $(RUN_GEN) ./genconstants$(build_exeext) $(md_file) > tmp-constants.h
88e3a2a3 1955 $(SHELL) $(srcdir)/../move-if-change tmp-constants.h insn-constants.h
1b0c37d7
ZW
1956 $(STAMP) s-constants
1957
4977bab6
ZW
1958insn-emit.o : insn-emit.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1959 $(RTL_H) $(EXPR_H) real.h output.h insn-config.h $(OPTABS_H) reload.h \
1960 $(RECOG_H) toplev.h function.h flags.h hard-reg-set.h resource.h $(TM_P_H)
96a9c44f
DR
1961 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-emit.c \
1962 $(OUTPUT_OPTION)
79d8453e 1963
e5e809f4 1964insn-emit.c: s-emit ; @true
80bcb4d2 1965s-emit : $(md_file) genemit$(build_exeext)
414d23ae 1966 $(RUN_GEN) ./genemit$(build_exeext) $(md_file) > tmp-emit.c
88e3a2a3 1967 $(SHELL) $(srcdir)/../move-if-change tmp-emit.c insn-emit.c
d9835ae8 1968 $(STAMP) s-emit
79d8453e 1969
4977bab6
ZW
1970insn-recog.o : insn-recog.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1971 $(RTL_H) insn-config.h $(RECOG_H) real.h output.h flags.h function.h \
1972 hard-reg-set.h resource.h $(TM_P_H) toplev.h reload.h
96a9c44f
DR
1973 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-recog.c \
1974 $(OUTPUT_OPTION)
79d8453e 1975
e5e809f4 1976insn-recog.c: s-recog ; @true
80bcb4d2 1977s-recog : $(md_file) genrecog$(build_exeext)
414d23ae 1978 $(RUN_GEN) ./genrecog$(build_exeext) $(md_file) > tmp-recog.c
88e3a2a3 1979 $(SHELL) $(srcdir)/../move-if-change tmp-recog.c insn-recog.c
d9835ae8 1980 $(STAMP) s-recog
79d8453e 1981
4977bab6
ZW
1982insn-opinit.o : insn-opinit.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1983 $(RTL_H) insn-config.h flags.h $(RECOG_H) $(EXPR_H) $(OPTABS_H) reload.h
96a9c44f
DR
1984 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-opinit.c \
1985 $(OUTPUT_OPTION)
118bdbf8 1986
e5e809f4 1987insn-opinit.c: s-opinit ; @true
80bcb4d2 1988s-opinit : $(md_file) genopinit$(build_exeext)
414d23ae 1989 $(RUN_GEN) ./genopinit$(build_exeext) $(md_file) > tmp-opinit.c
88e3a2a3 1990 $(SHELL) $(srcdir)/../move-if-change tmp-opinit.c insn-opinit.c
d9835ae8 1991 $(STAMP) s-opinit
118bdbf8 1992
4977bab6
ZW
1993insn-extract.o : insn-extract.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
1994 $(RTL_H) toplev.h insn-config.h $(RECOG_H)
96a9c44f
DR
1995 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-extract.c \
1996 $(OUTPUT_OPTION)
79d8453e 1997
e5e809f4 1998insn-extract.c: s-extract ; @true
80bcb4d2 1999s-extract : $(md_file) genextract$(build_exeext)
414d23ae 2000 $(RUN_GEN) ./genextract$(build_exeext) $(md_file) > tmp-extract.c
88e3a2a3 2001 $(SHELL) $(srcdir)/../move-if-change tmp-extract.c insn-extract.c
d9835ae8 2002 $(STAMP) s-extract
79d8453e 2003
4977bab6
ZW
2004insn-peep.o : insn-peep.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
2005 $(RTL_H) $(REGS_H) output.h real.h insn-config.h $(RECOG_H) except.h \
2006 function.h $(TM_P_H)
96a9c44f
DR
2007 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-peep.c \
2008 $(OUTPUT_OPTION)
79d8453e 2009
e5e809f4 2010insn-peep.c: s-peep ; @true
80bcb4d2 2011s-peep : $(md_file) genpeep$(build_exeext)
414d23ae 2012 $(RUN_GEN) ./genpeep$(build_exeext) $(md_file) > tmp-peep.c
88e3a2a3 2013 $(SHELL) $(srcdir)/../move-if-change tmp-peep.c insn-peep.c
d9835ae8 2014 $(STAMP) s-peep
79d8453e 2015
4977bab6
ZW
2016insn-attrtab.o : insn-attrtab.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
2017 $(RTL_H) $(REGS_H) real.h output.h $(INSN_ATTR_H) insn-config.h toplev.h \
2018 $(RECOG_H) $(TM_P_H) flags.h
96a9c44f
DR
2019 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-attrtab.c \
2020 $(OUTPUT_OPTION)
79d8453e 2021
e5e809f4 2022insn-attr.h: s-attr ; @true
80bcb4d2 2023s-attr : $(md_file) genattr$(build_exeext)
414d23ae 2024 $(RUN_GEN) ./genattr$(build_exeext) $(md_file) > tmp-attr.h
88e3a2a3 2025 $(SHELL) $(srcdir)/../move-if-change tmp-attr.h insn-attr.h
d9835ae8 2026 $(STAMP) s-attr
79d8453e 2027
e5e809f4 2028insn-attrtab.c: s-attrtab ; @true
80bcb4d2 2029s-attrtab : $(md_file) genattrtab$(build_exeext)
414d23ae 2030 $(RUN_GEN) ./genattrtab$(build_exeext) $(md_file) > tmp-attrtab.c
88e3a2a3 2031 $(SHELL) $(srcdir)/../move-if-change tmp-attrtab.c insn-attrtab.c
d9835ae8 2032 $(STAMP) s-attrtab
79d8453e 2033
4977bab6
ZW
2034insn-output.o : insn-output.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
2035 $(RTL_H) $(GGC_H) $(REGS_H) real.h conditions.h hard-reg-set.h \
2036 insn-config.h $(INSN_ATTR_H) $(EXPR_H) output.h $(RECOG_H) function.h \
2037 toplev.h flags.h insn-codes.h $(TM_P_H) $(TARGET_H)
96a9c44f
DR
2038 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) -c insn-output.c \
2039 $(OUTPUT_OPTION)
79d8453e 2040
e5e809f4 2041insn-output.c: s-output ; @true
80bcb4d2 2042s-output : $(md_file) genoutput$(build_exeext)
414d23ae 2043 $(RUN_GEN) ./genoutput$(build_exeext) $(md_file) > tmp-output.c
88e3a2a3 2044 $(SHELL) $(srcdir)/../move-if-change tmp-output.c insn-output.c
d9835ae8 2045 $(STAMP) s-output
3b80f6ca 2046
4977bab6
ZW
2047genrtl.o : genrtl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) $(RTL_H) \
2048 $(GGC_H)
e5e809f4 2049genrtl.c genrtl.h : s-genrtl
a3f80023
AS
2050 @true # force gnu make to recheck modification times.
2051
80bcb4d2 2052s-genrtl: gengenrtl$(build_exeext)
414d23ae 2053 $(RUN_GEN) ./gengenrtl$(build_exeext) -h > tmp-genrtl.h
88e3a2a3 2054 $(SHELL) $(srcdir)/../move-if-change tmp-genrtl.h genrtl.h
414d23ae 2055 $(RUN_GEN) ./gengenrtl$(build_exeext) > tmp-genrtl.c
88e3a2a3 2056 $(SHELL) $(srcdir)/../move-if-change tmp-genrtl.c genrtl.c
d9835ae8 2057 $(STAMP) s-genrtl
1b0c37d7 2058
94134f42
ZW
2059insn-modes.o : insn-modes.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
2060 $(MACHMODE_H) real.h
2061min-insn-modes.c insn-modes.c insn-modes.h : s-modes ; @true
0974c7d7 2062
80bcb4d2 2063s-modes: genmodes$(build_exeext)
0974c7d7 2064 $(RUN_GEN) ./genmodes$(build_exeext) -h > tmp-modes.h
88e3a2a3 2065 $(SHELL) $(srcdir)/../move-if-change tmp-modes.h insn-modes.h
94134f42 2066 $(RUN_GEN) ./genmodes$(build_exeext) -m > tmp-min-modes.c
88e3a2a3 2067 $(SHELL) $(srcdir)/../move-if-change tmp-min-modes.c min-insn-modes.c
0974c7d7 2068 $(RUN_GEN) ./genmodes$(build_exeext) > tmp-modes.c
88e3a2a3 2069 $(SHELL) $(srcdir)/../move-if-change tmp-modes.c insn-modes.c
0974c7d7
ZW
2070 $(STAMP) s-modes
2071
1b0c37d7
ZW
2072tm-preds.h: s-preds; @true
2073
80bcb4d2 2074s-preds: genpreds$(build_exeext)
414d23ae 2075 $(RUN_GEN) ./genpreds$(build_exeext) > tmp-preds.h
88e3a2a3 2076 $(SHELL) $(srcdir)/../move-if-change tmp-preds.h tm-preds.h
1b0c37d7
ZW
2077 $(STAMP) s-preds
2078
6060edcb 2079GTFILES = $(srcdir)/input.h $(srcdir)/coretypes.h $(srcdir)/cpplib.h \
17211ab5 2080 $(host_xm_file_list) $(tm_file_list) $(HASHTAB_H) $(SPLAY_TREE_H) \
ca29da43
NS
2081 $(srcdir)/bitmap.h $(srcdir)/coverage.c $(srcdir)/function.h $(srcdir)/rtl.h \
2082 $(srcdir)/optabs.h $(srcdir)/tree.h $(srcdir)/libfuncs.h $(srcdir)/hashtable.h \
c132886e 2083 $(srcdir)/real.h $(srcdir)/varray.h $(srcdir)/insn-addr.h \
ed2df68b 2084 $(srcdir)/cselib.h $(srcdir)/basic-block.h $(srcdir)/cgraph.h \
e2500fed 2085 $(srcdir)/c-common.h $(srcdir)/c-tree.h \
988d1653 2086 $(srcdir)/alias.c $(srcdir)/bitmap.c $(srcdir)/cselib.c $(srcdir)/cgraph.c \
17211ab5
GK
2087 $(srcdir)/dbxout.c $(srcdir)/dwarf2out.c $(srcdir)/dwarf2asm.c \
2088 $(srcdir)/emit-rtl.c $(srcdir)/except.c $(srcdir)/explow.c $(srcdir)/expr.c \
e2500fed
GK
2089 $(srcdir)/fold-const.c $(srcdir)/function.c \
2090 $(srcdir)/gcse.c $(srcdir)/integrate.c $(srcdir)/lists.c $(srcdir)/optabs.c \
ed8d2920 2091 $(srcdir)/profile.c $(srcdir)/ra-build.c $(srcdir)/regclass.c \
26e0dcb3 2092 $(srcdir)/reg-stack.c $(srcdir)/cfglayout.c $(srcdir)/langhooks.c \
e2500fed 2093 $(srcdir)/sdbout.c $(srcdir)/stmt.c $(srcdir)/stor-layout.c \
8a89dbd2 2094 $(srcdir)/stringpool.c $(srcdir)/tree.c $(srcdir)/varasm.c \
e2500fed 2095 $(out_file) \
e2500fed
GK
2096 @all_gtfiles@
2097
8ac9d31f
TJ
2098GTFILES_FILES_LANGS = @all_gtfiles_files_langs@
2099GTFILES_FILES_FILES = @all_gtfiles_files_files@
2100GTFILES_LANG_DIR_NAMES = @subdirs@
2101GTFILES_SRCDIR = @srcdir@
2102
ca29da43
NS
2103gt-cgraph.h gt-coverage.h gtype-desc.h gtype-desc.c gt-except.h \
2104gt-function.h gt-integrate.h gt-stmt.h gt-tree.h gt-varasm.h \
2105gt-emit-rtl.h gt-explow.h gt-stor-layout.h gt-regclass.h \
2106gt-lists.h gt-alias.h gt-cselib.h gt-fold-const.h gt-gcse.h \
2107gt-expr.h gt-sdbout.h gt-optabs.h gt-bitmap.h \
2108gt-dwarf2out.h gt-ra-build.h gt-reg-stack.h gt-dwarf2asm.h \
2109gt-dbxout.h gt-c-common.h gt-c-decl.h gt-c-parse.h \
4a46cbfb 2110gt-c-pragma.h gtype-c.h gt-input.h gt-cfglayout.h \
8a89dbd2 2111gt-stringpool.h gt-langhooks.h : s-gtype ; @true
e2500fed 2112
469ef4a3
ILT
2113gtyp-gen.h: s-gtyp-gen ; @true
2114s-gtyp-gen: Makefile
8ac9d31f 2115 echo "/* This file is machine generated. Do not edit. */" > tmp-gtyp.h
83fa8d7a 2116 echo "static const char *const srcdir = " >> tmp-gtyp.h
8ac9d31f
TJ
2117 echo "\"$(GTFILES_SRCDIR)\"" >> tmp-gtyp.h
2118 echo ";" >> tmp-gtyp.h
83fa8d7a 2119 echo "static const char *const lang_files[] = {" >> tmp-gtyp.h
8ac9d31f
TJ
2120 ll="$(GTFILES_FILES_FILES)"; \
2121 for f in $$ll; do \
2122 echo "\"$$f\", "; done >> tmp-gtyp.h
2123 echo "NULL};" >> tmp-gtyp.h
83fa8d7a 2124 echo "static const char *const langs_for_lang_files[] = {" >> tmp-gtyp.h
8ac9d31f
TJ
2125 ff="$(GTFILES_FILES_LANGS)"; \
2126 for f in $$ff; do \
2127 echo "\"$$f\", " ; done >> tmp-gtyp.h
2128 echo "NULL};" >> tmp-gtyp.h
83fa8d7a 2129 echo "static const char *const all_files[] = {" >> tmp-gtyp.h
8ac9d31f
TJ
2130 gf="$(GTFILES)"; \
2131 for f in $$gf; do \
2132 echo "\"$$f\", "; done >> tmp-gtyp.h
2133 echo " NULL};" >> tmp-gtyp.h
83fa8d7a 2134 echo "static const char *const lang_dir_names[] = { \"c\", " >> tmp-gtyp.h
8ac9d31f
TJ
2135 gf="$(GTFILES_LANG_DIR_NAMES)"; \
2136 for l in $$gf; do \
2137 echo "\"$$l\", "; done >> tmp-gtyp.h
2138 echo "NULL};" >> tmp-gtyp.h
88e3a2a3 2139 $(SHELL) $(srcdir)/../move-if-change tmp-gtyp.h gtyp-gen.h
469ef4a3 2140 $(STAMP) s-gtyp-gen
8ac9d31f 2141
b835f6f1 2142s-gtype: gengtype$(build_exeext) $(GTFILES)
414d23ae 2143 $(RUN_GEN) ./gengtype
e2500fed
GK
2144 $(STAMP) s-gtype
2145
544eb21e 2146#\f
79d8453e 2147# Compile the programs that generate insn-* from the machine description.
eaf9f3b2 2148# They are compiled with $(CC_FOR_BUILD), and associated libraries,
79d8453e
RS
2149# since they need to run on this machine
2150# even if GCC is being compiled to run on some other machine.
2151
2152# $(CONFIG_H) is omitted from the deps of the gen*.o
4c457b6b 2153# because these programs don't really depend on anything
79d8453e
RS
2154# about the target machine. They do depend on config.h itself,
2155# since that describes the host machine.
2156
4b09846b
MM
2157# The names of programs that run on the "build" machine.
2158genprognames=genconfig genflags gencodes genemit genopinit genrecog \
2159 genextract genpeep genattr genoutput
2160
2161# The names of the executable files for those programs.
9b0f6145 2162genprogs=$(genprognames:%=%$(build_exeext))
4b09846b
MM
2163
2164# Object files used in those programs.
2165genobjs=$(genprognames:%=%.o) read-rtl.o gensupport.o genattrtab.o \
94134f42 2166 genautomata.o gengenrtl.o genmodes.o genpreds.o gengtype.o \
4b09846b
MM
2167 genconstants.o gen-protos.o scan.o fix-header.o scan-decls.o \
2168 gencheck.o dummy-conditions.o genconditions.o
2169
2170$(genprogs): %$(build_exeext): %.o $(BUILD_RTL) $(BUILD_SUPPORT) \
2171 $(BUILD_PRINT) $(BUILD_ERRORS) \
2172 $(BUILD_LIBDEPS)
2173 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
2174 $< $(BUILD_RTL) $(BUILD_SUPPORT) $(BUILD_PRINT) \
2175 $(BUILD_ERRORS) $(BUILD_LIBS)
2176
2177$(genobjs): %.o : %.c
2178 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
2179
4977bab6 2180read-rtl.o: read-rtl.c $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(RTL_H) \
0f40f9f7 2181 $(OBSTACK_H) $(HASHTAB_H)
4977bab6
ZW
2182
2183gensupport.o: gensupport.c $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(RTL_H) \
2184 $(OBSTACK_H) errors.h $(HASHTAB_H) gensupport.h
4977bab6
ZW
2185
2186genconfig.o : genconfig.c $(RTL_H) $(BCONFIG_H) \
2187 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
4977bab6
ZW
2188
2189genflags.o : genflags.c $(RTL_H) $(OBSTACK_H) $(BCONFIG_H) \
2190 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
4977bab6
ZW
2191
2192gencodes.o : gencodes.c $(RTL_H) $(BCONFIG_H) \
2193 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
4977bab6
ZW
2194
2195genconstants$(build_exeext) : genconstants.o $(BUILD_RTL) $(BUILD_EARLY_SUPPORT) \
2196 $(BUILD_ERRORS) $(BUILD_LIBDEPS)
eaf9f3b2 2197 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6
ZW
2198 genconstants.o $(BUILD_EARLY_SUPPORT) $(BUILD_RTL) \
2199 $(BUILD_ERRORS) $(BUILD_LIBS)
2200
2201genconstants.o : genconstants.c $(RTL_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) \
2202 errors.h
4977bab6
ZW
2203
2204genemit.o : genemit.c $(RTL_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) \
2205 errors.h gensupport.h
4977bab6
ZW
2206
2207genopinit.o : genopinit.c $(RTL_H) $(BCONFIG_H) \
2208 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
4977bab6
ZW
2209
2210genrecog.o : genrecog.c $(RTL_H) $(BCONFIG_H) \
2211 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
4977bab6
ZW
2212
2213genextract.o : genextract.c $(RTL_H) $(BCONFIG_H) \
2214 $(SYSTEM_H) coretypes.h $(GTM_H) insn-config.h errors.h gensupport.h
4977bab6
ZW
2215
2216genpeep.o : genpeep.c $(RTL_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) \
2217 errors.h gensupport.h
4977bab6
ZW
2218
2219genattr.o : genattr.c $(RTL_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) errors.h \
2220 gensupport.h
79d8453e 2221
935bfb44 2222genattrtab$(build_exeext) : genattrtab.o genautomata.o \
4977bab6
ZW
2223 $(BUILD_RTL) $(BUILD_SUPPORT) $(BUILD_PRINT) $(BUILD_ERRORS) $(BUILD_VARRAY) \
2224 $(BUILD_LIBDEPS)
eaf9f3b2 2225 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
935bfb44 2226 genattrtab.o genautomata.o \
4977bab6
ZW
2227 $(BUILD_RTL) $(BUILD_SUPPORT) $(BUILD_PRINT) $(BUILD_ERRORS) \
2228 $(BUILD_VARRAY) $(BUILD_LIBS) -lm
79d8453e 2229
4977bab6
ZW
2230genattrtab.o : genattrtab.c $(RTL_H) $(OBSTACK_H) $(BCONFIG_H) \
2231 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h $(GGC_H) gensupport.h genattrtab.h
79d8453e 2232
4977bab6
ZW
2233genautomata.o : genautomata.c $(RTL_H) $(OBSTACK_H) $(BCONFIG_H) \
2234 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h varray.h genattrtab.h $(HASHTAB_H)
79d8453e 2235
4977bab6
ZW
2236genoutput.o : genoutput.c $(RTL_H) $(BCONFIG_H) \
2237 $(SYSTEM_H) coretypes.h $(GTM_H) errors.h gensupport.h
3b80f6ca 2238
4977bab6 2239gengenrtl$(build_exeext) : gengenrtl.o $(BUILD_LIBDEPS)
eaf9f3b2 2240 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6 2241 gengenrtl.o $(BUILD_LIBS)
3b80f6ca 2242
0974c7d7
ZW
2243gengenrtl.o : gengenrtl.c $(BCONFIG_H) $(SYSTEM_H) rtl.def
2244
2245genmodes$(build_exeext) : genmodes.o $(BUILD_ERRORS) $(BUILD_LIBDEPS)
2246 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
2247 genmodes.o $(BUILD_ERRORS) $(BUILD_LIBS)
2248
b8eaca23
ZW
2249genmodes.o : genmodes.c $(BCONFIG_H) $(SYSTEM_H) errors.h $(HASHTAB_H) \
2250 machmode.def $(extra_modes_file)
1b0c37d7 2251
4977bab6 2252genpreds$(build_exeext) : genpreds.o $(BUILD_LIBDEPS)
eaf9f3b2 2253 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6 2254 genpreds.o $(BUILD_LIBS)
1b0c37d7 2255
4977bab6 2256genpreds.o : genpreds.c $(RTL_BASE_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H)
1b0c37d7 2257
e2500fed 2258gengtype$(build_exeext) : gengtype.o gengtype-lex.o gengtype-yacc.o \
4977bab6 2259 $(BUILD_LIBDEPS)
eaf9f3b2 2260 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6 2261 gengtype.o gengtype-lex.o gengtype-yacc.o $(BUILD_LIBS)
e2500fed 2262
4977bab6 2263gengtype.o : gengtype.c gengtype.h $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) \
5ba6918e 2264 real.h $(RTL_BASE_H) gtyp-gen.h
e2500fed 2265
03787dfd 2266gengtype-lex.o : gengtype-lex.c gengtype.h gengtype-yacc.h \
4977bab6 2267 $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H)
eaf9f3b2 2268 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) \
03787dfd 2269 $< $(OUTPUT_OPTION)
e2500fed 2270
03787dfd 2271gengtype-yacc.o : gengtype-yacc.c gengtype.h $(BCONFIG_H) $(SYSTEM_H) \
4977bab6 2272 coretypes.h $(GTM_H)
eaf9f3b2 2273 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) \
03787dfd 2274 $< $(OUTPUT_OPTION)
e2500fed 2275
03787dfd
KC
2276gengtype-lex.c : gengtype-lex.l
2277 -$(FLEX) $(FLEXFLAGS) -o$@ $<
e2500fed 2278
03787dfd
KC
2279gengtype-yacc.c gengtype-yacc.h: gengtype-yacc.y
2280 -$(BISON) $(BISONFLAGS) -d -o gengtype-yacc.c $<
e2500fed 2281
4977bab6
ZW
2282genconditions$(build_exeext) : genconditions.o $(BUILD_EARLY_SUPPORT) \
2283 $(BUILD_RTL) $(BUILD_ERRORS) $(BUILD_LIBDEPS)
eaf9f3b2 2284 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6
ZW
2285 genconditions.o $(BUILD_EARLY_SUPPORT) $(BUILD_RTL) \
2286 $(BUILD_ERRORS) $(BUILD_LIBS)
2199e5fa 2287
4977bab6
ZW
2288genconditions.o : genconditions.c $(RTL_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h \
2289 $(GTM_H) errors.h
2199e5fa 2290
544eb21e 2291#\f
79d8453e
RS
2292# Compile the libraries to be used by gen*.
2293# If we are not cross-building, gen* use the same .o's that cc1 will use,
5c35940c 2294# and BUILD_PREFIX_1 is `loser-', just to ensure these rules don't conflict
b548dffb 2295# with the rules for rtl.o, etc.
4977bab6 2296$(BUILD_PREFIX_1)rtl.o: $(srcdir)/rtl.c $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H) $(RTL_H) \
66e918e5 2297 real.h $(GGC_H) errors.h
5c35940c 2298 rm -f $(BUILD_PREFIX)rtl.c
4977bab6 2299 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/rtl.c > $(BUILD_PREFIX)rtl.c
eaf9f3b2 2300 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $(BUILD_PREFIX)rtl.c $(OUTPUT_OPTION)
79d8453e 2301
13544b81
KG
2302print-rtl1.o: $(srcdir)/print-rtl.c $(BCONFIG_H) $(SYSTEM_H) coretypes.h \
2303 $(GTM_H) $(RTL_H) $(TREE_H) hard-reg-set.h $(BASIC_BLOCK_H) $(TM_P_H)
4d2d910c 2304 rm -f print-rtl1.c
4977bab6 2305 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/print-rtl.c > print-rtl1.c
eaf9f3b2 2306 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) print-rtl1.c $(OUTPUT_OPTION)
d3614a37 2307
4977bab6 2308$(BUILD_PREFIX_1)bitmap.o: $(srcdir)/bitmap.c $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H) \
e2500fed 2309 $(RTL_H) flags.h $(BASIC_BLOCK_H) $(REGS_H) $(GGC_H)
5c35940c 2310 rm -f $(BUILD_PREFIX)bitmap.c
4977bab6 2311 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/bitmap.c > $(BUILD_PREFIX)bitmap.c
eaf9f3b2 2312 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $(BUILD_PREFIX)bitmap.c $(OUTPUT_OPTION)
0dfa1860 2313
e5610450 2314$(BUILD_PREFIX_1)errors.o: errors.c $(BCONFIG_H) $(SYSTEM_H) errors.h
5c35940c 2315 rm -f $(BUILD_PREFIX)errors.c
4977bab6 2316 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/errors.c > $(BUILD_PREFIX)errors.c
eaf9f3b2 2317 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $(BUILD_PREFIX)errors.c $(OUTPUT_OPTION)
f8b6598e 2318
4977bab6 2319$(BUILD_PREFIX_1)varray.o: varray.c $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H) varray.h \
fde59d4b 2320 $(RTL_H) $(GGC_H) $(TREE_H) bitmap.h errors.h
5c35940c 2321 rm -f $(BUILD_PREFIX)varray.c
4977bab6 2322 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/varray.c > \
5c35940c 2323 $(BUILD_PREFIX)varray.c
eaf9f3b2 2324 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) \
5c35940c 2325 $(BUILD_PREFIX)varray.c $(OUTPUT_OPTION)
fae15c93 2326
4977bab6 2327$(BUILD_PREFIX_1)ggc-none.o: ggc-none.c $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H) $(GGC_H)
5c35940c 2328 rm -f $(BUILD_PREFIX)ggc-none.c
4977bab6 2329 sed -e 's/config[.]h/bconfig.h/' $(srcdir)/ggc-none.c > $(BUILD_PREFIX)ggc-none.c
eaf9f3b2 2330 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $(BUILD_PREFIX)ggc-none.c $(OUTPUT_OPTION)
d7160de9 2331
94134f42
ZW
2332min-insn-modes.o: insn-modes.c $(BCONFIG_H) $(SYSTEM_H) $(MACHMODE_H)
2333 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) \
2334 min-insn-modes.c $(OUTPUT_OPTION)
0974c7d7 2335
ab87f8c8
JL
2336#\f
2337# Remake internationalization support.
4977bab6 2338intl.o: intl.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) intl.h Makefile
ab87f8c8
JL
2339 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
2340 -DLOCALEDIR=\"$(localedir)\" \
96a9c44f 2341 -c $(srcdir)/intl.c $(OUTPUT_OPTION)
ab87f8c8 2342
544eb21e 2343#\f
79d8453e
RS
2344# Remake cpp and protoize.
2345
d059a239
FF
2346PREPROCESSOR_DEFINES = \
2347 -DGCC_INCLUDE_DIR=\"$(libsubdir)/include\" \
2348 -DGPLUSPLUS_INCLUDE_DIR=\"$(gcc_gxx_include_dir)\" \
caa55b1e 2349 -DGPLUSPLUS_TOOL_INCLUDE_DIR=\"$(gcc_gxx_include_dir)/$(target_noncanonical)\" \
98c2359b 2350 -DGPLUSPLUS_BACKWARD_INCLUDE_DIR=\"$(gcc_gxx_include_dir)/backward\" \
793e9558 2351 -DLOCAL_INCLUDE_DIR=\"$(local_includedir)\" \
4977bab6 2352 -DCROSS_INCLUDE_DIR=\"$(CROSS_SYSTEM_HEADER_DIR)\" \
047d636f
DJ
2353 -DTOOL_INCLUDE_DIR=\"$(gcc_tooldir)/include\" \
2354 @TARGET_SYSTEM_ROOT_DEFINE@
79d8453e 2355
004cb263 2356LIBCPP_OBJS = cpplib.o cpplex.o cppmacro.o cppexp.o cppfiles.o cpptrad.o \
1613e52b 2357 cpphash.o cpperror.o cppinit.o cppcharset.o \
6338b358 2358 hashtable.o line-map.o mkdeps.o cpppch.o
19283265 2359
ef6e958a 2360LIBCPP_DEPS = $(CPPLIB_H) cpphash.h line-map.h hashtable.h intl.h \
bf42e45b 2361 $(OBSTACK_H) $(CONFIG_H) $(SYSTEM_H)
8ebb00d5 2362
a36556a8
ZW
2363# Most of the other archives built/used by this makefile are for
2364# targets. This one is strictly for the host.
19283265 2365libcpp.a: $(LIBCPP_OBJS)
b8d12d79 2366 -rm -rf libcpp.a
8f25d5cd 2367 $(AR) $(AR_FLAGS) libcpp.a $(LIBCPP_OBJS)
6822468a 2368 -$(RANLIB) libcpp.a
19283265 2369
e6cc3a24 2370cppcharset.o: cppcharset.c $(LIBCPP_DEPS) cppucnid.h
4977bab6
ZW
2371cpperror.o: cpperror.c $(LIBCPP_DEPS)
2372cppexp.o: cppexp.c $(LIBCPP_DEPS)
6338b358 2373cpplex.o: cpplex.c $(LIBCPP_DEPS)
4977bab6
ZW
2374cppmacro.o: cppmacro.c $(LIBCPP_DEPS)
2375cpplib.o: cpplib.c $(LIBCPP_DEPS)
2376cpphash.o: cpphash.c $(LIBCPP_DEPS)
2377cpptrad.o: cpptrad.c $(LIBCPP_DEPS)
73e61092 2378cppfiles.o: cppfiles.c $(LIBCPP_DEPS) $(HASHTAB_H) $(MD5_H) mkdeps.h
c1bad961 2379cppinit.o: cppinit.c $(LIBCPP_DEPS) mkdeps.h
17211ab5 2380cpppch.o: cpppch.c $(LIBCPP_DEPS) mkdeps.h
e915b770 2381
5793b276
NB
2382cppdefault.o: cppdefault.c $(CONFIG_H) $(SYSTEM_H) coretypes.h $(TM_H) \
2383 cppdefault.h Makefile
59949f60 2384 $(CC) $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
d059a239 2385 $(PREPROCESSOR_DEFINES) \
96a9c44f 2386 -c $(srcdir)/cppdefault.c $(OUTPUT_OPTION)
5538ada6 2387
43839642
ZW
2388mkdeps.o: mkdeps.c $(CONFIG_H) $(SYSTEM_H) mkdeps.h
2389hashtable.o: hashtable.c hashtable.h $(CONFIG_H) $(SYSTEM_H) $(OBSTACK_H)
2390line-map.o: line-map.c line-map.h intl.h $(CONFIG_H) $(SYSTEM_H)
49e6c08e 2391
7bd95cc1
BK
2392# Note for the stamp targets, we run the program `true' instead of
2393# having an empty command (nothing following the semicolon).
2394
e09e14e9 2395proto: config.status protoize$(exeext) unprotoize$(exeext) SYSCALLS.c.X
79d8453e 2396
75a65e46 2397PROTO_OBJS = intl.o version.o cppdefault.o
ab87f8c8
JL
2398
2399protoize$(exeext): protoize.o $(PROTO_OBJS) $(LIBDEPS)
2400 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ protoize.o $(PROTO_OBJS) $(LIBS)
2e0b13db 2401
ab87f8c8
JL
2402unprotoize$(exeext): unprotoize.o $(PROTO_OBJS) $(LIBDEPS)
2403 $(CC) $(ALL_CFLAGS) $(LDFLAGS) -o $@ unprotoize.o $(PROTO_OBJS) $(LIBS)
2e0b13db 2404
911e6107 2405protoize.o: protoize.c $(srcdir)/../include/getopt.h $(CONFIG_H) $(SYSTEM_H) \
4977bab6 2406 coretypes.h $(TM_H) Makefile version.h
8c310e3f
MM
2407 (SHLIB_LINK='$(SHLIB_LINK)' \
2408 SHLIB_MULTILIB='$(SHLIB_MULTILIB)'; \
79d8453e 2409 $(CC) -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
75a65e46 2410 $(DRIVER_DEFINES) \
8c310e3f 2411 $(srcdir)/protoize.c $(OUTPUT_OPTION))
6c32c807 2412
75a65e46 2413unprotoize.o: protoize.c $(srcdir)/../include/getopt.h \
911e6107 2414 $(CONFIG_H) $(SYSTEM_H) Makefile version.h
8c310e3f
MM
2415 (SHLIB_LINK='$(SHLIB_LINK)' \
2416 SHLIB_MULTILIB='$(SHLIB_MULTILIB)'; \
75a65e46
ZW
2417 $(CC) -c -DUNPROTOIZE $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
2418 $(DRIVER_DEFINES) \
2419 $(srcdir)/protoize.c $(OUTPUT_OPTION))
79d8453e 2420
79d8453e 2421# This info describes the target machine, so compile with GCC just built.
aab26e16
RK
2422SYSCALLS.c.X: $(srcdir)/sys-types.h $(srcdir)/sys-protos.h $(GCC_PASSES) \
2423 stmp-int-hdrs
c21cf0a7 2424 -rm -f SYSCALLS.c tmp-SYSCALLS.s
e256b8b6
DA
2425 sed -e s/TARGET_GETGROUPS_T/$(TARGET_GETGROUPS_T)/ \
2426 $(srcdir)/sys-types.h $(srcdir)/sys-protos.h > SYSCALLS.c
79d8453e 2427 $(GCC_FOR_TARGET) $(GCC_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) \
c21cf0a7
RS
2428 -aux-info $@ -S -o tmp-SYSCALLS.s SYSCALLS.c
2429 -rm -f SYSCALLS.c tmp-SYSCALLS.s
9c0022f6 2430
ac1284f9 2431
9c0022f6 2432test-protoize-simple: ./protoize ./unprotoize $(GCC_PASSES)
4803a34a 2433 -rm -f tmp-proto.[cso]
d3614a37
RS
2434 cp $(srcdir)/protoize.c tmp-proto.c
2435 chmod u+w tmp-proto.c
4803a34a 2436 ./protoize -N -B ./ -x getopt.h -c "-B./ -Wall -Wwrite-strings \
d059a239 2437 $(GCC_CFLAGS) $(INCLUDES) \
9c0022f6
RS
2438 -DGCC_INCLUDE_DIR=0 \
2439 -DGPLUSPLUS_INCLUDE_DIR=0 \
2440 -DCROSS_INCLUDE_DIR=0 \
14b18068 2441 -DTOOL_INCLUDE_DIR=0 \
d059a239
FF
2442 -DSTANDARD_EXEC_PREFIX=0 \
2443 -DDEFAULT_TARGET_MACHINE=0 \
2444 -DDEFAULT_TARGET_VERSION=0" tmp-proto.c
e3e873d2 2445 @echo '**********' Expect 400 lines of differences.
4803a34a
RK
2446 -diff $(srcdir)/protoize.c tmp-proto.c > tmp-proto.diff
2447 -wc -l tmp-proto.diff
2448 ./unprotoize -N -x getopt.h -c "-B./ -Wall -Wwrite-strings \
d059a239 2449 $(GCC_CFLAGS) $(INCLUDES) \
9c0022f6
RS
2450 -DGCC_INCLUDE_DIR=0 \
2451 -DGPLUSPLUS_INCLUDE_DIR=0 \
2452 -DCROSS_INCLUDE_DIR=0 \
14b18068 2453 -DTOOL_INCLUDE_DIR=0 \
d059a239
FF
2454 -DSTANDARD_EXEC_PREFIX=0 \
2455 -DDEFAULT_TARGET_MACHINE=0 \
2456 -DDEFAULT_TARGET_VERSION=0" tmp-proto.c
9c0022f6 2457 @echo Expect zero differences.
d3614a37 2458 diff $(srcdir)/protoize.c tmp-proto.c | cat
aab26e16 2459 -rm -f tmp-proto.[cs] tmp-proto$(objext)
59a64126 2460
4977bab6
ZW
2461# gcov-iov.c is run on the build machine to generate gcov-iov.h from version.c
2462gcov-iov.o: gcov-iov.c version.c $(BCONFIG_H) coretypes.h $(GTM_H) $(SYSTEM_H) coretypes.h $(TM_H)
eaf9f3b2 2463 $(CC_FOR_BUILD) -c $(BUILD_CFLAGS) $(BUILD_CPPFLAGS) $(INCLUDES) $(srcdir)/gcov-iov.c $(OUTPUT_OPTION)
4977bab6 2464gcov-iov$(build_exeext): gcov-iov.o
eaf9f3b2 2465 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) gcov-iov.o -o $@
28068c2c 2466gcov-iov.h: s-iov
80bcb4d2 2467s-iov: gcov-iov$(build_exeext)
28068c2c 2468 ./gcov-iov$(build_exeext) > tmp-gcov-iov.h
88e3a2a3 2469 $(SHELL) $(srcdir)/../move-if-change tmp-gcov-iov.h gcov-iov.h
28068c2c 2470 $(STAMP) s-iov
4977bab6 2471
990f4800
NS
2472gcov.o: gcov.c gcov-io.h gcov-io.c gcov-iov.h intl.h $(SYSTEM_H) coretypes.h $(TM_H) $(CONFIG_H)
2473gcov-dump.o: gcov-dump.c gcov-io.h gcov-io.c gcov-iov.h $(SYSTEM_H) coretypes.h $(TM_H) $(CONFIG_H)
59a64126 2474
2ea9a965
NC
2475# Only one of 'gcov' or 'gcov.exe' is actually built, depending
2476# upon whether $(exeext) is empty or not.
5735c3ea 2477GCOV_OBJS = gcov.o intl.o version.o
ab87f8c8
JL
2478gcov$(exeext): $(GCOV_OBJS) $(LIBDEPS)
2479 $(CC) $(ALL_CFLAGS) $(LDFLAGS) $(GCOV_OBJS) $(LIBS) -o $@
4977bab6
ZW
2480GCOV_DUMP_OBJS = gcov-dump.o version.o
2481gcov-dump$(exeext): $(GCOV_DUMP_OBJS) $(LIBDEPS)
2482 $(CC) $(ALL_CFLAGS) $(LDFLAGS) $(GCOV_DUMP_OBJS) $(LIBS) -o $@
544eb21e 2483#\f
ba1811f1 2484# Build the include directory. The stamp files are stmp-* rather than
e5e809f4 2485# s-* so that mostlyclean does not force the include directory to
ba1811f1
ILT
2486# be rebuilt.
2487
d57a4b98 2488# Build the include directory
f95e46b9 2489stmp-int-hdrs: $(STMP_FIXINC) $(USER_H) xlimits.h
ba1811f1
ILT
2490# Copy in the headers provided with gcc.
2491# The sed command gets just the last file name component;
2492# this is necessary because VPATH could add a dirname.
2493# Using basename would be simpler, but some systems don't have it.
c85f7c16 2494# The touch command is here to workaround an AIX/Linux NFS bug.
7bfe3c97 2495 -if [ -d include ] ; then true; else mkdir include; chmod a+rx include; fi
d7371761
RK
2496 for file in .. $(USER_H); do \
2497 if [ X$$file != X.. ]; then \
2498 realfile=`echo $$file | sed -e 's|.*/\([^/]*\)$$|\1|'`; \
d9835ae8 2499 $(STAMP) include/$$realfile; \
ae678a13
JW
2500 rm -f include/$$realfile; \
2501 cp $$file include; \
2502 chmod a+r include/$$realfile; \
d7371761 2503 fi; \
ba1811f1 2504 done
1f050b9b 2505 rm -f include/limits.h
ba1811f1
ILT
2506 cp xlimits.h include/limits.h
2507 chmod a+r include/limits.h
e7f62ad3
MH
2508# Install the README
2509 rm -f include/README
2510 cp $(srcdir)/README-fixinc include/README
2511 chmod a+r include/README
d9835ae8 2512 $(STAMP) $@
e7f62ad3 2513
f2321837
KG
2514# fixinc.sh depends on this, not on specs directly.
2515# The idea is to make sure specs gets built, but not rerun fixinc.sh
2516# after each stage just because specs' mtime has changed.
2517specs.ready: specs
2518 -if [ -f specs.ready ] ; then \
2519 true; \
2520 else \
d9835ae8 2521 $(STAMP) specs.ready; \
f2321837
KG
2522 fi
2523
31260fb8
LR
2524# Until someone fixes this recursive make nightmare (please note where
2525# BUILD_CFLAGS and WARN_CFLAGS are first expanded below versus which
2526# later make invocation has the fine-grain -warn markings for fixinc):
2527fixinc.sh-warn = -Wno-error
2528
5d55e5cd
RL
2529FIXINCSRCDIR=$(srcdir)/fixinc
2530fixinc.sh: $(FIXINCSRCDIR)/mkfixinc.sh $(FIXINCSRCDIR)/fixincl.c \
ab747408 2531 $(FIXINCSRCDIR)/procopen.c $(FIXINCSRCDIR)/server.c \
f2321837 2532 $(FIXINCSRCDIR)/server.h $(FIXINCSRCDIR)/inclhack.def specs.ready
8c90b13a 2533 (MAKE="$(MAKE)"; srcdir=`cd $(srcdir)/fixinc && ${PWD_COMMAND}` ; \
eaf9f3b2 2534 CC="$(CC_FOR_BUILD)"; CFLAGS="$(BUILD_CFLAGS)"; LDFLAGS="$(BUILD_LDFLAGS)"; \
5f08e44f 2535 WARN_CFLAGS="$(WARN_CFLAGS)"; LIBERTY=`${PWD_COMMAND}`/"$(BUILD_LIBIBERTY)"; \
7a615b25
AO
2536 export MAKE srcdir CC CFLAGS LDFLAGS WARN_CFLAGS LIBERTY; \
2537 cd ./fixinc && \
4665e56c 2538 $(SHELL) $${srcdir}/mkfixinc.sh $(build) $(target))
9f3d1bc2 2539
4977bab6
ZW
2540.PHONY: install-gcc-tooldir
2541install-gcc-tooldir:
947c6b00 2542 $(mkinstalldirs) $(DESTDIR)$(gcc_tooldir)
4977bab6 2543
ba1811f1 2544# Build fixed copies of system files.
9f3d1bc2 2545stmp-fixinc: fixinc.sh gsyslimits.h
4977bab6
ZW
2546 @if test ! -d ${SYSTEM_HEADER_DIR}; then \
2547 echo The directory that should contain system headers does not exist: >&2 ; \
2548 echo " ${SYSTEM_HEADER_DIR}" >&2 ; \
2549 if test "x${SYSTEM_HEADER_DIR}" = "x${gcc_tooldir}/sys-include"; \
2550 then sleep 1; else exit 1; fi; \
2551 fi
9f3d1bc2 2552 rm -rf include; mkdir include
c5c76735 2553 -chmod a+rx include
8c90b13a 2554 (TARGET_MACHINE='$(target)'; srcdir=`cd $(srcdir); ${PWD_COMMAND}`; \
fecd6201
ZW
2555 SHELL='$(SHELL)' ;\
2556 export TARGET_MACHINE srcdir SHELL ; \
8c90b13a 2557 $(SHELL) ./fixinc.sh `${PWD_COMMAND}`/include $(SYSTEM_HEADER_DIR) $(OTHER_FIXINCLUDES_DIRS); \
b8dad04b 2558 rm -f include/syslimits.h; \
3dc4a939
RK
2559 if [ -f include/limits.h ]; then \
2560 mv include/limits.h include/syslimits.h; \
2561 else \
2562 cp $(srcdir)/gsyslimits.h include/syslimits.h; \
b8dad04b
ZW
2563 fi; \
2564 chmod a+r include/syslimits.h)
d9835ae8 2565 $(STAMP) stmp-fixinc
469778e2 2566
ac1284f9 2567# Files related to the fixproto script.
eaf9f3b2 2568# gen-protos and fix-header are compiled with CC_FOR_BUILD, but they are only
f95e46b9
ZW
2569# used in native and host-x-target builds, so it's safe to link them with
2570# libiberty.a.
ac1284f9 2571
74bb4fdf 2572deduced.h: $(GCC_PASSES) $(srcdir)/scan-types.sh stmp-int-hdrs
4977bab6 2573 if [ -d "$(SYSTEM_HEADER_DIR)" ]; \
40859b41 2574 then \
3c9a2b55 2575 CC="$(GCC_FOR_TARGET) $(GCC_CFLAGS) $(ALL_CPPFLAGS) -I. -I$(srcdir) -isystem include -isystem ${SYSTEM_HEADER_DIR}"; \
ac1284f9 2576 export CC; \
40859b41
JL
2577 $(SHELL) $(srcdir)/scan-types.sh "$(srcdir)" >tmp-deduced.h; \
2578 mv tmp-deduced.h deduced.h; \
2579 else \
d9835ae8 2580 $(STAMP) deduced.h; \
40859b41 2581 fi
ac1284f9 2582
5fa7f88c 2583GEN_PROTOS_OBJS = gen-protos.o scan.o
193ad8c6 2584gen-protos$(build_exeext): $(GEN_PROTOS_OBJS)
eaf9f3b2 2585 ${CC_FOR_BUILD} $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ \
4977bab6 2586 $(GEN_PROTOS_OBJS) $(BUILD_LIBS)
ac1284f9 2587
4977bab6 2588gen-protos.o: gen-protos.c scan.h $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H)
c192da27 2589
4977bab6 2590scan.o: scan.c scan.h $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H)
7b41f815 2591
193ad8c6 2592xsys-protos.h: $(GCC_PASSES) $(srcdir)/sys-protos.h deduced.h gen-protos$(build_exeext) Makefile
e256b8b6
DA
2593 sed -e s/TARGET_GETGROUPS_T/$(TARGET_GETGROUPS_T)/ \
2594 deduced.h $(srcdir)/sys-protos.h > tmp-fixtmp.c
d521a023 2595 mv tmp-fixtmp.c fixtmp.c
c061c5d7 2596 $(GCC_FOR_TARGET) fixtmp.c -w -U__SIZE_TYPE__ -U__PTRDIFF_TYPE__ -U__WCHAR_TYPE__ -E \
c1b9947f 2597 | sed -e 's/ / /g' -e 's/ *(/ (/g' -e 's/ [ ]*/ /g' -e 's/( )/()/' \
414d23ae 2598 | $(RUN_GEN) ./gen-protos >xsys-protos.hT
d521a023 2599 mv xsys-protos.hT xsys-protos.h
d7a58f93 2600 rm -rf fixtmp.c
ac1284f9 2601
6650a443
ZW
2602# This is nominally a 'build' program, but it's run only when host==build,
2603# so we can (indeed, must) use $(LIBDEPS) and $(LIBS).
d577781c 2604fix-header$(build_exeext): fix-header.o scan-decls.o scan.o xsys-protos.h \
c1bad961 2605 c-incpath.o cppdefault.o prefix.o $(LIBDEPS) libcpp.a
eaf9f3b2 2606 $(CC_FOR_BUILD) $(BUILD_CFLAGS) $(BUILD_LDFLAGS) -o $@ fix-header.o \
50f59cd7 2607 c-incpath.o cppdefault.o scan-decls.o prefix.o scan.o $(LIBS)
ac1284f9 2608
4e872036 2609fix-header.o: fix-header.c $(OBSTACK_H) scan.h \
4977bab6 2610 xsys-protos.h $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H) $(CPPLIB_H)
c192da27 2611
4977bab6 2612scan-decls.o: scan-decls.c scan.h $(CPPLIB_H) $(BCONFIG_H) $(SYSTEM_H) coretypes.h $(GTM_H)
ac1284f9 2613
74bb4fdf
RS
2614# stmp-fixproto depends on this, not on fix-header directly.
2615# The idea is to make sure fix-header gets built,
2616# but not rerun fixproto after each stage
2617# just because fix-header's mtime has changed.
d577781c 2618fixhdr.ready: fix-header$(build_exeext)
74bb4fdf
RS
2619 -if [ -f fixhdr.ready ] ; then \
2620 true; \
2621 else \
d9835ae8 2622 $(STAMP) fixhdr.ready; \
74bb4fdf
RS
2623 fi
2624
f95e46b9 2625# stmp-int-headers is to make sure fixincludes has already finished.
700ba19c
RS
2626# The if statement is so that we don't run fixproto a second time
2627# if it has already been run on the files in `include'.
f95e46b9 2628stmp-fixproto: fixhdr.ready fixproto stmp-int-hdrs
01b2995f 2629 if [ -f include/fixed ] ; then true; \
700ba19c 2630 else \
b1f99e2f 2631 : This line works around a 'make' bug in BSDI 1.1.; \
b3ca463c 2632 FIXPROTO_DEFINES="$(FIXPROTO_DEFINES)"; export FIXPROTO_DEFINES; \
947c6b00 2633 mkinstalldirs="$(mkinstalldirs)"; \
bcf1ba1d 2634 export mkinstalldirs; \
4977bab6 2635 if [ -d "$(SYSTEM_HEADER_DIR)" ]; then \
aef1617c 2636 $(SHELL) ${srcdir}/fixproto include include $(SYSTEM_HEADER_DIR); \
01b2995f 2637 if [ $$? -eq 0 ] ; then true ; else exit 1 ; fi ; \
aef1617c 2638 else true; fi; \
d9835ae8 2639 $(STAMP) include/fixed; \
700ba19c 2640 fi
d9835ae8 2641 $(STAMP) stmp-fixproto
544eb21e 2642#\f
79d8453e
RS
2643# Remake the info files.
2644
51817b10 2645doc: $(BUILD_INFO) $(GENERATED_MANPAGES) gccbug
a541f69d
KC
2646
2647INFOFILES = doc/cpp.info doc/gcc.info doc/gccint.info \
2648 doc/gccinstall.info doc/cppinternals.info
2649
2650info: $(INFOFILES) lang.info @GENINSRC@ srcinfo lang.srcinfo
2651
2652srcinfo: $(INFOFILES)
2653 -cp -p $^ $(srcdir)/doc
65455962
KC
2654
2655TEXI_CPP_FILES = cpp.texi fdl.texi cppenv.texi cppopts.texi
2656
2657TEXI_GCC_FILES = gcc.texi gcc-common.texi frontends.texi standards.texi \
2658 invoke.texi extend.texi md.texi objc.texi gcov.texi trouble.texi \
2659 bugreport.texi service.texi contribute.texi compat.texi funding.texi \
2660 gnu.texi gpl.texi fdl.texi contrib.texi cppenv.texi cppopts.texi
2661
2662TEXI_GCCINT_FILES = gccint.texi gcc-common.texi contribute.texi makefile.texi \
2663 configterms.texi portability.texi interface.texi passes.texi \
2664 c-tree.texi rtl.texi md.texi tm.texi hostconfig.texi fragments.texi \
2665 configfiles.texi collect2.texi headerdirs.texi funding.texi gnu.texi \
2666 gpl.texi fdl.texi contrib.texi languages.texi sourcebuild.texi \
2667 gty.texi libgcc.texi
2668
2669TEXI_GCCINSTALL_FILES = install.texi install-old.texi fdl.texi
2670
2671TEXI_CPPINT_FILES = cppinternals.texi
2672
5340bbea 2673# The *.1, *.7, *.info, and *.dvi files are being generated from implicit
cb7c0b5a 2674# patterns. To use them, put each of the specific targets with its
65455962 2675# specific dependencies but no build commands.
e2500fed 2676
a541f69d
KC
2677doc/cpp.info: $(TEXI_CPP_FILES)
2678doc/gcc.info: $(TEXI_GCC_FILES)
2679doc/gccint.info: $(TEXI_GCCINT_FILES)
2680doc/cppinternals.info: $(TEXI_CPPINT_FILES)
d7f8491b 2681
a541f69d 2682doc/%.info: %.texi
1f9b3087
MM
2683 if [ x$(BUILD_INFO) = xinfo ]; then \
2684 $(MAKEINFO) $(MAKEINFOFLAGS) -I $(docdir) \
2685 -I $(docdir)/include -o $@ $<; \
2686 fi
23de1fbf 2687
63069342 2688# Duplicate entry to handle renaming of gccinstall.info
a541f69d 2689doc/gccinstall.info: $(TEXI_GCCINSTALL_FILES)
63069342
KC
2690 if [ x$(BUILD_INFO) = xinfo ]; then \
2691 $(MAKEINFO) $(MAKEINFOFLAGS) -I $(docdir) \
2692 -I $(docdir)/include -o $@ $<; \
2693 fi
2694
a541f69d
KC
2695doc/cpp.dvi: $(TEXI_CPP_FILES)
2696doc/gcc.dvi: $(TEXI_GCC_FILES)
2697doc/gccint.dvi: $(TEXI_GCCINT_FILES)
2698doc/cppinternals.dvi: $(TEXI_CPPINT_FILES)
63069342 2699
a541f69d
KC
2700dvi:: doc/gcc.dvi doc/gccint.dvi doc/gccinstall.dvi doc/cpp.dvi \
2701 doc/cppinternals.dvi
8dbda01e 2702
a541f69d 2703doc/%.dvi: %.texi
71cbe2c1 2704 $(TEXI2DVI) -I $(abs_docdir) -I $(abs_docdir)/include -o $@ $<
95e30ecc 2705
63069342 2706# Duplicate entry to handle renaming of gccinstall.dvi
a541f69d 2707doc/gccinstall.dvi: $(TEXI_GCCINSTALL_FILES)
71cbe2c1 2708 $(TEXI2DVI) -I $(abs_docdir) -I $(abs_docdir)/include -o $@ $<
d7f8491b 2709
a541f69d
KC
2710MANFILES = doc/gcov.1 doc/cpp.1 doc/gcc.1 doc/gfdl.7 doc/gpl.7 doc/fsf-funding.7
2711
5340bbea 2712generated-manpages: man
ce5c1cf3
KC
2713
2714man: $(MANFILES) lang.man @GENINSRC@ srcman lang.srcman
a541f69d
KC
2715
2716srcman: $(MANFILES)
2717 -cp -p $^ $(srcdir)/doc
c01a508e 2718
a541f69d 2719doc/%.1: %.pod
6280c439 2720 $(STAMP) $@
65455962 2721 -($(POD2MAN) --section=1 $< > $(@).T$$$$ && \
6280c439
MM
2722 mv -f $(@).T$$$$ $@) || \
2723 (rm -f $(@).T$$$$ && exit 1)
6280c439 2724
a541f69d 2725doc/%.7: %.pod
6280c439 2726 $(STAMP) $@
65455962 2727 -($(POD2MAN) --section=7 $< > $(@).T$$$$ && \
6280c439
MM
2728 mv -f $(@).T$$$$ $@) || \
2729 (rm -f $(@).T$$$$ && exit 1)
65455962
KC
2730
2731%.pod: %.texi
2732 $(STAMP) $@
2733 -$(TEXI2POD) $< > $@
2734
2735.INTERMEDIATE: cpp.pod gcc.pod gfdl.pod fsf-funding.pod
2736cpp.pod: cpp.texi cppenv.texi cppopts.texi
2737
2738# These next rules exist because the output name is not the same as
cb7c0b5a 2739# the input name, so our implicit %.pod rule will not work.
65455962
KC
2740
2741gcc.pod: invoke.texi cppenv.texi cppopts.texi
2742 $(STAMP) $@
2743 -$(TEXI2POD) $< > $@
2744gfdl.pod: fdl.texi
2745 $(STAMP) $@
2746 -$(TEXI2POD) $< > $@
2747fsf-funding.pod: funding.texi
2748 $(STAMP) $@
2749 -$(TEXI2POD) $< > $@
77bd67cb 2750
544eb21e 2751#\f
79d8453e
RS
2752# Deletion of files made during compilation.
2753# There are four levels of this:
f1908d70 2754# `mostlyclean', `clean', `distclean' and `maintainer-clean'.
79d8453e 2755# `mostlyclean' is useful while working on a particular type of machine.
2e494f70 2756# It deletes most, but not all, of the files made by compilation.
79d8453e 2757# It does not delete libgcc.a or its parts, so it won't have to be recompiled.
2e494f70 2758# `clean' deletes everything made by running `make all'.
47547081 2759# `distclean' also deletes the files made by config.
f1908d70 2760# `maintainer-clean' also deletes everything that could be regenerated
63d9b81c
RK
2761# automatically, except for `configure'.
2762# We remove as much from the language subdirectories as we can
013a2ee0 2763# (less duplicated code).
79d8453e 2764
6eb95e99 2765mostlyclean: lang.mostlyclean
79d8453e 2766 -rm -f $(STAGESTUFF)
22aa533e 2767 -rm -f *$(coverageexts)
4993ddc1 2768 -rm -rf libgcc
79d8453e 2769# Delete the temporary source copies for cross compilation.
5c35940c
NN
2770 -rm -f $(BUILD_PREFIX_1)rtl.c $(BUILD_PREFIX_1)print-rtl.c
2771 -rm -f $(BUILD_PREFIX_1)bitmap.c $(BUILD_PREFIX_1)errors.c
4977bab6 2772 -rm -f $(BUILD_PREFIX_1)ggc-none.c print-rtl1.c
79d8453e 2773# Delete the temp files made in the course of building libgcc.a.
7857f134 2774 -rm -f xlimits.h
e5e809f4 2775# Delete other built files.
d57a4b98 2776 -rm -f xsys-protos.hT
d2908a50 2777 -rm -f specs.h gencheck.h options.c options.h
e5e809f4
JL
2778# Delete the stamp and temporary files.
2779 -rm -f s-* tmp-* stamp-* stmp-*
013a2ee0 2780 -rm -f */stamp-* */tmp-*
2e494f70 2781# Delete debugging dump files.
61098249 2782 -rm -f *.[0-9][0-9].* */*.[0-9][0-9].*
2e494f70 2783# Delete some files made during installation.
3bd6d4c4 2784 -rm -f specs $(SPECS) SYSCALLS.c.X SYSCALLS.c
b548dffb 2785 -rm -f collect collect2 mips-tfile mips-tdump
ac1284f9 2786# Delete files generated for fixproto
d577781c 2787 -rm -rf fix-header$(build_exeext) xsys-protos.h deduced.h tmp-deduced.h \
193ad8c6 2788 gen-protos$(build_exeext) fixproto.list fixtmp.* fixhdr.ready
fa9c7493
ZW
2789# Delete files generated for fixincl
2790 -rm -rf fixincl fixinc.sh specs.ready
f0267a67 2791 (cd fixinc && $(MAKE) clean)
2e494f70
RS
2792# Delete unwanted output files from TeX.
2793 -rm -f *.toc *.log *.vr *.fn *.cp *.tp *.ky *.pg
013a2ee0 2794 -rm -f */*.toc */*.log */*.vr */*.fn */*.cp */*.tp */*.ky */*.pg
47547081
RS
2795# Delete sorted indices we don't actually use.
2796 -rm -f gcc.vrs gcc.kys gcc.tps gcc.pgs gcc.fns
2e494f70 2797# Delete core dumps.
013a2ee0 2798 -rm -f core */core
8ac9d31f
TJ
2799# Delete file generated for gengtype.c
2800 -rm -f gtyp-gen.h
2801# Delete files generated by gengtype.c
2802 -rm -f gtype-*
2803 -rm -f gt-*
79d8453e 2804
47547081
RS
2805# Delete all files made by compilation
2806# that don't exist in the distribution.
6eb95e99 2807clean: mostlyclean lang.clean
23af32e6
NS
2808 -rm -f libgcc.a libgcc_eh.a libgcov.a
2809 -rm -f libgcc_s$(SHLIB_EXT) libgcc_s$(SHLIB_EXT).1
4977bab6 2810 -rm -f config.h tconfig.h bconfig.h tm_p.h tm.h
11642c3a 2811 -rm -f cs-*
97d81d66 2812 -rm -rf libgcc
a541f69d 2813 -rm -f doc/*.dvi
ba1811f1 2814# Delete the include directory.
e5e809f4 2815 -rm -rf include
75ed5d8b 2816# Delete files used by the "multilib" facility (including libgcc subdirs).
f6cdc7ea 2817 -rm -f multilib.h tmpmultilib*
75ed5d8b
DE
2818 -if [ "x$(MULTILIB_DIRNAMES)" != x ] ; then \
2819 rm -rf $(MULTILIB_DIRNAMES); \
2820 else if [ "x$(MULTILIB_OPTIONS)" != x ] ; then \
2821 rm -rf `echo $(MULTILIB_OPTIONS) | sed -e 's/\// /g'`; \
2822 fi ; fi
8f231b5d 2823 -rm -fr stage1 stage2 stage3 stage4 stageprofile stagefeedback
204093e6 2824# Delete stamps of bootstrap stages
770861f3
DD
2825 -rm -f stage?_*
2826 -rm -f clean?_*
2827 -rm -f stage_last
79d8453e 2828
47547081
RS
2829# Delete all files that users would normally create
2830# while building and installing GCC.
6eb95e99 2831distclean: clean lang.distclean
11642c3a 2832 -rm -f auto-host.h auto-build.h
d1209685 2833 -rm -f cstamp-h
63d9b81c 2834 -rm -f config.status config.run config.cache config.bak
d232dfa4 2835 -rm -f Make-lang Make-hooks Make-host Make-target
ad854f24 2836 -rm -f Makefile *.oaux
f24af81b 2837 -rm -f gthr-default.h
8f231b5d 2838 -rm -f */stage1 */stage2 */stage3 */stage4 */include */stageprofile */stagefeedback
03787dfd 2839 -rm -f c-parse.y c-parse.c c-parse.output TAGS */TAGS
338023d4 2840 -rm -f *.asm
a051ad3a 2841 -rm -f site.exp site.bak testsuite/site.exp testsuite/site.bak
ad854f24 2842 -rm -f testsuite/*.log testsuite/*.sum
1bb1f121 2843 -cd testsuite && rm -f x *.x *.x? *.exe *.rpo *.o *.s *.S *.c
4977bab6 2844 -cd testsuite && rm -f *.out *.gcov *$(coverageexts)
f362c762 2845 -rm -rf ${QMTEST_DIR} stamp-qmtest
06f0b04c 2846 -rm -f cxxmain.c
ad854f24 2847 -rm -f mklibgcc mkheaders gccbug .gdbinit configargs.h
c01a508e 2848 -rm -f gcov.pod
5fcee6f3 2849 -rm -f fixinc/Makefile
ad854f24
ZW
2850# Delete po/*.gmo only if we are not building in the source directory.
2851 -if [ ! -f po/exgettext ]; then rm -f po/*.gmo; fi
2852 -rmdir ada cp f java objc fixinc intl po testsuite 2>/dev/null
2e494f70 2853
63d9b81c 2854# Get rid of every file that's generated from some other file, except for `configure'.
79d8453e 2855# Most of these files ARE PRESENT in the GCC distribution.
63d9b81c
RK
2856maintainer-clean:
2857 @echo 'This command is intended for maintainers to use; it'
2858 @echo 'deletes files that may need special tools to rebuild.'
6eb95e99 2859 $(MAKE) lang.maintainer-clean distclean
03787dfd 2860 -rm -f $(srcdir)/c-parse.y $(srcdir)/c-parse.c
17db6582
JM
2861 -rm -f cpp.??s cpp.*aux
2862 -rm -f gcc.??s gcc.*aux
a541f69d 2863 -rm -f $(docdir)/*.info $(docdir)/*.1 $(docdir)/*.7 $(docdir)/*.dvi
544eb21e 2864#\f
79d8453e 2865# Entry points `install' and `uninstall'.
2e494f70 2866# Also use `install-collect2' to install collect2 when the config files don't.
79d8453e 2867
ba1811f1 2868# Copy the compiler files into directories where they will be run.
aab26e16
RK
2869# Install the driver last so that the window when things are
2870# broken is small.
a078a589 2871install: install-common $(INSTALL_HEADERS) $(INSTALL_LIBGCC) \
6eb95e99 2872 install-cpp install-man install-info install-@POSUB@ \
09fa0705 2873 lang.install-normal install-driver
79d8453e 2874
587a4ba6 2875# Handle cpp installation.
4871239e 2876install-cpp: cpp$(exeext)
439020ec
KC
2877 -rm -f $(DESTDIR)$(bindir)/$(CPP_INSTALL_NAME)$(exeext)
2878 -$(INSTALL_PROGRAM) -m 755 cpp$(exeext) $(DESTDIR)$(bindir)/$(CPP_INSTALL_NAME)$(exeext)
2879 -if [ x$(cpp_install_dir) != x ]; then \
2880 rm -f $(DESTDIR)$(prefix)/$(cpp_install_dir)/$(CPP_INSTALL_NAME)$(exeext); \
2881 $(INSTALL_PROGRAM) -m 755 cpp$(exeext) $(DESTDIR)$(prefix)/$(cpp_install_dir)/$(CPP_INSTALL_NAME)$(exeext); \
2882 else true; fi
587a4ba6 2883
69cbb85a 2884# Create the installation directories.
a8ee6e2d 2885# $(libdir)/gcc/include isn't currently searched by cpp.
69cbb85a 2886installdirs:
947c6b00
NN
2887 $(mkinstalldirs) $(DESTDIR)$(libsubdir)
2888 $(mkinstalldirs) $(DESTDIR)$(libexecsubdir)
2889 $(mkinstalldirs) $(DESTDIR)$(bindir)
2890 $(mkinstalldirs) $(DESTDIR)$(includedir)
2891 $(mkinstalldirs) $(DESTDIR)$(infodir)
2892 $(mkinstalldirs) $(DESTDIR)$(slibdir)
2893 $(mkinstalldirs) $(DESTDIR)$(man1dir)
2894 $(mkinstalldirs) $(DESTDIR)$(man7dir)
79d8453e
RS
2895
2896# Install the compiler executables built during cross compilation.
55de4f08 2897install-common: native $(EXTRA_PARTS) lang.install-common installdirs
79d8453e
RS
2898 for file in $(COMPILERS); do \
2899 if [ -f $$file ] ; then \
a8ee6e2d
GK
2900 rm -f $(DESTDIR)$(libexecsubdir)/$$file; \
2901 $(INSTALL_PROGRAM) $$file $(DESTDIR)$(libexecsubdir)/$$file; \
79d8453e
RS
2902 else true; \
2903 fi; \
2904 done
2fe8d2d6 2905 for file in $(EXTRA_PASSES) $(EXTRA_PROGRAMS) $(USE_COLLECT2) ..; do \
79d8453e 2906 if [ x"$$file" != x.. ]; then \
a8ee6e2d
GK
2907 rm -f $(DESTDIR)$(libexecsubdir)/$$file; \
2908 $(INSTALL_PROGRAM) $$file $(DESTDIR)$(libexecsubdir)/$$file; \
79d8453e
RS
2909 else true; fi; \
2910 done
2fe8d2d6
RK
2911 for file in $(EXTRA_PARTS) ..; do \
2912 if [ x"$$file" != x.. ]; then \
90961eff
AJ
2913 rm -f $(DESTDIR)$(libsubdir)/$$file; \
2914 $(INSTALL_DATA) $$file $(DESTDIR)$(libsubdir)/$$file; \
2915 chmod a-x $(DESTDIR)$(libsubdir)/$$file; \
2fe8d2d6
RK
2916 else true; fi; \
2917 done
f0ec1f64 2918# Don't mess with specs if it doesn't exist yet.
2a7bccbb 2919 -if [ -f specs ] ; then \
90961eff 2920 rm -f $(DESTDIR)$(libsubdir)/specs; \
3bd6d4c4 2921 $(INSTALL_DATA) $(SPECS) $(DESTDIR)$(libsubdir)/specs; \
90961eff 2922 chmod a-x $(DESTDIR)$(libsubdir)/specs; \
f0ec1f64 2923 fi
aab26e16 2924# Install protoize if it was compiled.
439020ec
KC
2925 -if [ -f protoize$(exeext) ]; then \
2926 rm -f $(DESTDIR)$(bindir)/$(PROTOIZE_INSTALL_NAME)$(exeext); \
2927 $(INSTALL_PROGRAM) protoize$(exeext) $(DESTDIR)$(bindir)/$(PROTOIZE_INSTALL_NAME)$(exeext); \
2928 rm -f $(DESTDIR)$(bindir)/$(UNPROTOIZE_INSTALL_NAME)$(exeext); \
2929 $(INSTALL_PROGRAM) unprotoize$(exeext) $(DESTDIR)$(bindir)/$(UNPROTOIZE_INSTALL_NAME)$(exeext); \
2930 rm -f $(DESTDIR)$(libsubdir)/SYSCALLS.c.X; \
2931 $(INSTALL_DATA) SYSCALLS.c.X $(DESTDIR)$(libsubdir)/SYSCALLS.c.X; \
2932 chmod a-x $(DESTDIR)$(libsubdir)/SYSCALLS.c.X; \
aab26e16 2933 fi
ca363bb6 2934# Install gcov if it was compiled.
59a64126
DE
2935 -if [ -f gcov$(exeext) ]; \
2936 then \
3743ea05 2937 rm -f $(DESTDIR)$(bindir)/$(GCOV_INSTALL_NAME)$(exeext); \
90961eff 2938 $(INSTALL_PROGRAM) gcov$(exeext) $(DESTDIR)$(bindir)/$(GCOV_INSTALL_NAME)$(exeext); \
59a64126 2939 fi
90961eff 2940 $(INSTALL_SCRIPT) gccbug $(DESTDIR)$(bindir)/$(GCCBUG_INSTALL_NAME)
aab26e16 2941
5340bbea 2942# Install the driver program as $(target_noncanonical)-gcc,
caa55b1e 2943# $(target_noncanonical)-gcc-$(version)
91c7bd9b 2944# and also as either gcc (if native) or $(gcc_tooldir)/bin/gcc.
e658449e 2945install-driver: installdirs xgcc$(exeext)
439020ec
KC
2946 -rm -f $(DESTDIR)$(bindir)/$(GCC_INSTALL_NAME)$(exeext)
2947 -$(INSTALL_PROGRAM) xgcc$(exeext) $(DESTDIR)$(bindir)/$(GCC_INSTALL_NAME)$(exeext)
2948 -rm -f $(DESTDIR)$(bindir)/$(target_noncanonical)-gcc-$(version)
2949 -( cd $(DESTDIR)$(bindir) && \
2950 $(LN) $(GCC_INSTALL_NAME)$(exeext) $(target_noncanonical)-gcc-$(version) )
173712fb 2951 -if [ -f gcc-cross$(exeext) ] ; then \
90961eff
AJ
2952 if [ -d $(DESTDIR)$(gcc_tooldir)/bin/. ] ; then \
2953 rm -f $(DESTDIR)$(gcc_tooldir)/bin/gcc$(exeext); \
2954 $(INSTALL_PROGRAM) gcc-cross$(exeext) $(DESTDIR)$(gcc_tooldir)/bin/gcc$(exeext); \
79d8453e
RS
2955 else true; fi; \
2956 else \
caa55b1e 2957 rm -f $(DESTDIR)$(bindir)/$(target_noncanonical)-gcc-tmp$(exeext); \
90961eff 2958 ( cd $(DESTDIR)$(bindir) && \
caa55b1e
NN
2959 $(LN) $(GCC_INSTALL_NAME)$(exeext) $(target_noncanonical)-gcc-tmp$(exeext) && \
2960 mv -f $(target_noncanonical)-gcc-tmp$(exeext) $(GCC_TARGET_INSTALL_NAME)$(exeext) ); \
79d8453e 2961 fi
79d8453e 2962
0b2fbcb2 2963# Install the info files.
feb9ea1a 2964# $(INSTALL_DATA) might be a relative pathname, so we can't cd into srcdir
ee5b121e 2965# to do the install.
97ae108d
MM
2966install-info:: doc installdirs \
2967 $(DESTDIR)$(infodir)/cpp.info \
2968 $(DESTDIR)$(infodir)/gcc.info \
2969 $(DESTDIR)$(infodir)/cppinternals.info \
ee312cd0 2970 $(DESTDIR)$(infodir)/gccinstall.info \
97ae108d
MM
2971 $(DESTDIR)$(infodir)/gccint.info
2972
a541f69d 2973$(DESTDIR)$(infodir)/%.info: doc/%.info installdirs
97ae108d
MM
2974 rm -f $@
2975 if [ -f $< ]; then \
2976 for f in $(<)*; do \
17db6582 2977 realfile=`echo $$f | sed -e 's|.*/\([^/]*\)$$|\1|'`; \
90961eff 2978 $(INSTALL_DATA) $$f $(DESTDIR)$(infodir)/$$realfile; \
3d56d025 2979 chmod a-x $(DESTDIR)$(infodir)/$$realfile; \
17db6582
JM
2980 done; \
2981 else true; fi
ee5b121e 2982 -if $(SHELL) -c 'install-info --version' >/dev/null 2>&1; then \
90961eff 2983 if [ -f $(DESTDIR)$(infodir)/dir ] ; then \
97ae108d 2984 if [ -f $@ ]; then \
6a09dded 2985 install-info --dir-file=$(DESTDIR)$(infodir)/dir $@; \
97ae108d 2986 else true; fi; \
f8c86b58 2987 else true; fi; \
265ce5bb 2988 else true; fi;
0b2fbcb2 2989
79d8453e 2990# Install the man pages.
a541f69d
KC
2991install-man: installdirs lang.install-man \
2992 $(DESTDIR)$(man1dir)/$(GCC_INSTALL_NAME)$(man1ext) \
52ccb3d2
GK
2993 $(DESTDIR)$(man1dir)/$(CPP_INSTALL_NAME)$(man1ext) \
2994 $(DESTDIR)$(man1dir)/$(GCOV_INSTALL_NAME)$(man1ext) \
a541f69d
KC
2995 $(DESTDIR)$(man7dir)/fsf-funding$(man7ext) \
2996 $(DESTDIR)$(man7dir)/gfdl$(man7ext) \
2997 $(DESTDIR)$(man7dir)/gpl$(man7ext)
2998
52ccb3d2 2999$(DESTDIR)$(man7dir)/%$(man7ext): doc/%.7
a541f69d
KC
3000 -rm -f $@
3001 -$(INSTALL_DATA) $< $@
3002 -chmod a-x $@
3003
52ccb3d2 3004$(DESTDIR)$(man1dir)/$(GCC_INSTALL_NAME)$(man1ext): doc/gcc.1
a541f69d 3005 -rm -f $@
5340bbea 3006 -$(INSTALL_DATA) $< $@
a541f69d
KC
3007 -chmod a-x $@
3008
52ccb3d2
GK
3009$(DESTDIR)$(man1dir)/$(CPP_INSTALL_NAME)$(man1ext): doc/cpp.1
3010 -rm -f $@
5340bbea 3011 -$(INSTALL_DATA) $< $@
52ccb3d2
GK
3012 -chmod a-x $@
3013
3014$(DESTDIR)$(man1dir)/$(GCOV_INSTALL_NAME)$(man1ext): doc/gcov.1
a541f69d 3015 -rm -f $@
5340bbea 3016 -$(INSTALL_DATA) $< $@
a541f69d 3017 -chmod a-x $@
79d8453e
RS
3018
3019# Install the library.
23af32e6 3020install-libgcc: libgcc.mk libgcc.a libgcov.a installdirs
e158a5fb 3021 $(MAKE) \
67680154 3022 CFLAGS="$(CFLAGS) $(WARN_CFLAGS)" \
e158a5fb 3023 CONFIG_H="$(TCONFIG_H)" \
67680154 3024 MAKEOVERRIDES= \
3a41db81 3025 mkinstalldirs='$(mkinstalldirs)' \
2bbea3a6 3026 -f libgcc.mk install
79d8453e 3027
23af32e6 3028# Install multiple versions of libgcc.a, libgcov.a.
69cbb85a 3029install-multilib: stmp-multilib installdirs
e158a5fb 3030 $(MAKE) \
67680154 3031 CFLAGS="$(CFLAGS) $(WARN_CFLAGS)" \
e158a5fb 3032 CONFIG_H="$(CONFIG_H)" \
67680154 3033 MAKEOVERRIDES= \
3a41db81 3034 mkinstalldirs='$(mkinstalldirs)' \
2bbea3a6 3035 -f libgcc.mk install
f6cdc7ea 3036
ba1811f1 3037# Install all the header files built in the include subdirectory.
fecd6201 3038install-headers: $(INSTALL_HEADERS_DIR)
ba1811f1
ILT
3039# Fix symlinks to absolute paths in the installed include directory to
3040# point to the installed directory, not the build directory.
ac64120e 3041# Don't need to use LN_S here since we really do need ln -s and no substitutes.
90961eff 3042 -files=`cd $(DESTDIR)$(libsubdir)/include; find . -type l -print 2>/dev/null`; \
ba1811f1 3043 if [ $$? -eq 0 ]; then \
8c90b13a 3044 dir=`cd include; ${PWD_COMMAND}`; \
ba1811f1 3045 for i in $$files; do \
90961eff 3046 dest=`ls -ld $(DESTDIR)$(libsubdir)/include/$$i | sed -n 's/.*-> //p'`; \
ba1811f1 3047 if expr "$$dest" : "$$dir.*" > /dev/null; then \
90961eff
AJ
3048 rm -f $(DESTDIR)$(libsubdir)/include/$$i; \
3049 ln -s `echo $$i | sed "s|/[^/]*|/..|g" | sed 's|/..$$||'``echo "$$dest" | sed "s|$$dir||"` $(DESTDIR)$(libsubdir)/include/$$i; \
ba1811f1
ILT
3050 fi; \
3051 done; \
3052 fi
79d8453e 3053
ba1811f1 3054# Create or recreate the gcc private include file directory.
69cbb85a 3055install-include-dir: installdirs
90961eff
AJ
3056 -rm -rf $(DESTDIR)$(libsubdir)/include
3057 mkdir $(DESTDIR)$(libsubdir)/include
3058 -chmod a+rx $(DESTDIR)$(libsubdir)/include
ba1811f1
ILT
3059
3060# Install the include directory using tar.
f95e46b9 3061install-headers-tar: stmp-int-hdrs $(STMP_FIXPROTO) install-include-dir
965c3f43
AO
3062# We use `pwd`/include instead of just include to problems with CDPATH
3063# Unless a full pathname is provided, some shells would print the new CWD,
3064# found in CDPATH, corrupting the output. We could just redirect the
3065# output of `cd', but some shells lose on redirection within `()'s
8c90b13a 3066 (cd `${PWD_COMMAND}`/include ; \
90961eff 3067 tar -cf - .; exit 0) | (cd $(DESTDIR)$(libsubdir)/include; tar xpf - )
e6431ec5
RS
3068# /bin/sh on some systems returns the status of the first tar,
3069# and that can lose with GNU tar which always writes a full block.
3070# So use `exit 0' to ignore its exit status.
ba1811f1
ILT
3071
3072# Install the include directory using cpio.
f95e46b9 3073install-headers-cpio: stmp-int-hdrs $(STMP_FIXPROTO) install-include-dir
965c3f43 3074# See discussion about the use of `pwd` above
8c90b13a 3075 cd `${PWD_COMMAND}`/include ; \
90961eff 3076 find . -print | cpio -pdum $(DESTDIR)$(libsubdir)/include
79d8453e 3077
ff3aaf17
DR
3078# Install the include directory using cp.
3079install-headers-cp: stmp-int-hdrs $(STMP_FIXPROTO) install-include-dir
90961eff 3080 cp -p -r include $(DESTDIR)$(libsubdir)
ff3aaf17 3081
a8ee6e2d
GK
3082itoolsdir = $(libexecsubdir)/install-tools
3083itoolsdatadir = $(libsubdir)/install-tools
e34a3d31
GK
3084# Don't install the headers. Instead, install appropriate scripts
3085# and supporting files for fixincludes to be run later.
3086install-mkheaders: stmp-int-hdrs $(STMP_FIXPROTO) install-include-dir \
3087 mkheaders xlimits.h
a8ee6e2d 3088 -rm -rf $(DESTDIR)$(itoolsdir) $(DESTDIR)$(itoolsdatadir)
947c6b00
NN
3089 $(mkinstalldirs) $(DESTDIR)$(itoolsdatadir)/include
3090 $(mkinstalldirs) $(DESTDIR)$(itoolsdir)
e34a3d31
GK
3091 for file in $(USER_H); do \
3092 realfile=`echo $$file | sed -e 's|.*/\([^/]*\)$$|\1|'`; \
3093 $(INSTALL_DATA) $$file \
a8ee6e2d 3094 $(DESTDIR)$(itoolsdatadir)/include/$$realfile ; \
e34a3d31 3095 done
a8ee6e2d 3096 $(INSTALL_DATA) xlimits.h $(DESTDIR)$(itoolsdatadir)/include/limits.h
e34a3d31
GK
3097 if [ x$(STMP_FIXINC) != x ] ; then \
3098 $(INSTALL_DATA) $(srcdir)/README-fixinc \
a8ee6e2d 3099 $(DESTDIR)$(itoolsdatadir)/include/README ; \
f0c4fac7 3100 $(INSTALL_SCRIPT) fixinc.sh $(DESTDIR)$(itoolsdir)/fixinc.sh ; \
90961eff 3101 $(INSTALL_PROGRAM) fixinc/fixincl $(DESTDIR)$(itoolsdir)/fixincl ; \
a8ee6e2d
GK
3102 $(INSTALL_DATA) $(srcdir)/gsyslimits.h \
3103 $(DESTDIR)$(itoolsdatadir)/gsyslimits.h ; \
e34a3d31
GK
3104 else :; fi
3105 if [ x$(STMP_FIXPROTO) != x ] ; then \
947c6b00 3106 $(INSTALL_SCRIPT) $(mkinstalldirs) \
90961eff 3107 $(DESTDIR)$(itoolsdir)/mkinstalldirs ; \
f0c4fac7 3108 $(INSTALL_SCRIPT) $(srcdir)/fixproto $(DESTDIR)$(itoolsdir)/fixproto ; \
e34a3d31 3109 $(INSTALL_PROGRAM) fix-header$(build_exeext) \
90961eff 3110 $(DESTDIR)$(itoolsdir)/fix-header$(build_exeext) ; \
e34a3d31 3111 else :; fi
f0c4fac7 3112 $(INSTALL_SCRIPT) mkheaders $(DESTDIR)$(itoolsdir)/mkheaders
4977bab6 3113 echo 'SYSTEM_HEADER_DIR="'"$(SYSTEM_HEADER_DIR)"'"' \
a8ee6e2d 3114 > $(DESTDIR)$(itoolsdatadir)/mkheaders.conf
e34a3d31 3115 echo 'OTHER_FIXINCLUDES_DIRS="$(OTHER_FIXINCLUDES_DIRS)"' \
a8ee6e2d 3116 >> $(DESTDIR)$(itoolsdatadir)/mkheaders.conf
e34a3d31 3117 echo 'FIXPROTO_DEFINES="$(FIXPROTO_DEFINES)"' \
a8ee6e2d
GK
3118 >> $(DESTDIR)$(itoolsdatadir)/mkheaders.conf
3119 echo 'STMP_FIXPROTO="$(STMP_FIXPROTO)"' \
3120 >> $(DESTDIR)$(itoolsdatadir)/mkheaders.conf
3121 echo 'STMP_FIXINC="$(STMP_FIXINC)"' \
3122 >> $(DESTDIR)$(itoolsdatadir)/mkheaders.conf
e34a3d31 3123
10da1131 3124# Use this target to install the program `collect2' under the name `collect2'.
69cbb85a 3125install-collect2: collect2 installdirs
a8ee6e2d 3126 $(INSTALL_PROGRAM) collect2$(exeext) $(DESTDIR)$(libexecsubdir)/collect2$(exeext)
2e494f70 3127# Install the driver program as $(libsubdir)/gcc for collect2.
a8ee6e2d 3128 $(INSTALL_PROGRAM) xgcc$(exeext) $(DESTDIR)$(libexecsubdir)/gcc$(exeext)
2e494f70 3129
79d8453e 3130# Cancel installation by deleting the installed files.
6eb95e99 3131uninstall: lang.uninstall
90961eff 3132 -rm -rf $(DESTDIR)$(libsubdir)
a8ee6e2d 3133 -rm -rf $(DESTDIR)$(libexecsubdir)
90961eff 3134 -rm -rf $(DESTDIR)$(bindir)/$(GCC_INSTALL_NAME)$(exeext)
90961eff 3135 -rm -f $(DESTDIR)$(bindir)/$(CPP_INSTALL_NAME)$(exeext)
1e730c5c 3136 -if [ x$(cpp_install_dir) != x ]; then \
90961eff 3137 rm -f $(DESTDIR)$(prefix)/$(cpp_install_dir)/$(CPP_INSTALL_NAME)$(exeext); \
1e730c5c 3138 else true; fi
90961eff 3139 -rm -rf $(DESTDIR)$(bindir)/$(PROTOIZE_INSTALL_NAME)$(exeext)
90961eff 3140 -rm -rf $(DESTDIR)$(bindir)/$(UNPROTOIZE_INSTALL_NAME)$(exeext)
90961eff
AJ
3141 -rm -rf $(DESTDIR)$(bindir)/$(GCOV_INSTALL_NAME)$(exeext)
3142 -rm -rf $(DESTDIR)$(man1dir)/$(GCC_INSTALL_NAME)$(man1ext)
90961eff
AJ
3143 -rm -rf $(DESTDIR)$(man1dir)/cpp$(man1ext)
3144 -rm -rf $(DESTDIR)$(man1dir)/protoize$(man1ext)
3145 -rm -rf $(DESTDIR)$(man1dir)/unprotoize$(man1ext)
3146 -rm -f $(DESTDIR)$(infodir)/cpp.info* $(DESTDIR)$(infodir)/gcc.info*
3147 -rm -f $(DESTDIR)$(infodir)/cppinternals.info* $(DESTDIR)$(infodir)/gccint.info*
544eb21e 3148#\f
4c457b6b 3149# These targets are for the dejagnu testsuites. The file site.exp
e933cbe0
JL
3150# contains global variables that all the testsuites will use.
3151
e933cbe0
JL
3152target_subdir = @target_subdir@
3153
3154site.exp: ./config.status Makefile
3155 @echo "Making a new config file..."
3156 -@rm -f ./tmp?
d9835ae8 3157 @$(STAMP) site.exp
e933cbe0
JL
3158 -@mv site.exp site.bak
3159 @echo "## these variables are automatically generated by make ##" > ./tmp0
3160 @echo "# Do not edit here. If you wish to override these values" >> ./tmp0
3161 @echo "# add them to the last section" >> ./tmp0
8c90b13a
L
3162 @echo "set rootme \"`${PWD_COMMAND}`\"" >> ./tmp0
3163 @echo "set srcdir \"`cd ${srcdir}; ${PWD_COMMAND}`\"" >> ./tmp0
4665e56c
NN
3164 @echo "set host_triplet $(host)" >> ./tmp0
3165 @echo "set build_triplet $(build)" >> ./tmp0
e933cbe0 3166 @echo "set target_triplet $(target)" >> ./tmp0
caa55b1e 3167 @echo "set target_alias $(target_noncanonical)" >> ./tmp0
5340bbea 3168 @echo "set libiconv \"$(LIBICONV)\"" >> ./tmp0
e933cbe0
JL
3169# CFLAGS is set even though it's empty to show we reserve the right to set it.
3170 @echo "set CFLAGS \"\"" >> ./tmp0
76438597 3171 @echo "set CXXFLAGS \"\"" >> ./tmp0
4091fa5f 3172 @echo "set TESTING_IN_BUILD_TREE 1" >> ./tmp0
22fdd65e 3173 @echo "set HAVE_LIBSTDCXX_V3 1" >> ./tmp0
e933cbe0
JL
3174# If newlib has been configured, we need to pass -B to gcc so it can find
3175# newlib's crt0.o if it exists. This will cause a "path prefix not used"
3176# message if it doesn't, but the testsuite is supposed to ignore the message -
3177# it's too difficult to tell when to and when not to pass -B (not all targets
3178# have crt0's). We could only add the -B if ../newlib/crt0.o exists, but that
3179# seems like too selective a test.
3180# ??? Another way to solve this might be to rely on linker scripts. Then
3181# theoretically the -B won't be needed.
3182# We also need to pass -L ../ld so that the linker can find ldscripts.
6a1b7268 3183 @if [ -d $(objdir)/../$(target_subdir)/newlib ] \
4665e56c 3184 && [ "${host}" != "${target}" ]; then \
6a1b7268
NN
3185 echo "set newlib_cflags \"-I$(objdir)/../$(target_subdir)/newlib/targ-include -I\$$srcdir/../newlib/libc/include\"" >> ./tmp0; \
3186 echo "set newlib_ldflags \"-B$(objdir)/../$(target_subdir)/newlib/\"" >> ./tmp0; \
e933cbe0
JL
3187 echo "append CFLAGS \" \$$newlib_cflags\"" >> ./tmp0; \
3188 echo "append CXXFLAGS \" \$$newlib_cflags\"" >> ./tmp0; \
3189 echo "append LDFLAGS \" \$$newlib_ldflags\"" >> ./tmp0; \
3190 else true; \
3191 fi
3192 @if [ -d $(objdir)/../ld ] ; then \
3193 echo "append LDFLAGS \" -L$(objdir)/../ld\"" >> ./tmp0; \
3194 else true; \
3195 fi
ccdb9251 3196 echo "set tmpdir $(objdir)/testsuite" >> ./tmp0
e933cbe0 3197 @echo "set srcdir \"\$${srcdir}/testsuite\"" >> ./tmp0
6ccfe27c
JJ
3198 @if [ "X$(ALT_CC_UNDER_TEST)" != "X" ] ; then \
3199 echo "set ALT_CC_UNDER_TEST \"$(ALT_CC_UNDER_TEST)\"" >> ./tmp0; \
3200 else true; \
3201 fi
fa870451 3202 @if [ "X$(ALT_CXX_UNDER_TEST)" != "X" ] ; then \
6ccfe27c 3203 echo "set ALT_CXX_UNDER_TEST \"$(ALT_CXX_UNDER_TEST)\"" >> ./tmp0; \
fa870451
JJ
3204 else true; \
3205 fi
3206 @if [ "X$(COMPAT_OPTIONS)" != "X" ] ; then \
6ccfe27c 3207 echo "set COMPAT_OPTIONS \"$(COMPAT_OPTIONS)\"" >> ./tmp0; \
fa870451
JJ
3208 else true; \
3209 fi
e933cbe0
JL
3210 @echo "## All variables above are generated by configure. Do Not Edit ##" >> ./tmp0
3211 @cat ./tmp0 > site.exp
3212 @cat site.bak | sed \
3213 -e '1,/^## All variables above are.*##/ d' >> site.exp
3214 -@rm -f ./tmp?
3215
71a94577 3216CHECK_TARGETS = check-gcc @check_languages@
cbc59f01 3217
e933cbe0
JL
3218check: $(CHECK_TARGETS)
3219
a738a85c 3220# The idea is to parallelize testing of multilibs, for example:
7dd232a8 3221# make -j3 check-gcc//sh-hms-sim/{-m1,-m2,-m3,-m3e,-m4}/{,-nofpu}
a738a85c
AO
3222# will run 3 concurrent sessions of check-gcc, eventually testing
3223# all 10 combinations. GNU make is required, as is a shell that expands
3224# alternations within braces.
49a41726
JM
3225lang_checks_parallel = $(lang_checks:=//%)
3226$(lang_checks_parallel): site.exp
7dd232a8
AO
3227 target=`echo "$@" | sed 's,//.*,,'`; \
3228 variant=`echo "$@" | sed 's,^[^/]*//,,'`; \
a738a85c
AO
3229 vardots=`echo "$$variant" | sed 's,/,.,g'`; \
3230 $(MAKE) TESTSUITEDIR="testsuite.$$vardots" \
3231 RUNTESTFLAGS="--target_board=$$variant $(RUNTESTFLAGS)" \
3232 "$$target"
3233
3234TESTSUITEDIR = testsuite
3235
3236$(TESTSUITEDIR)/site.exp: site.exp
3237 test -d $(TESTSUITEDIR) || mkdir $(TESTSUITEDIR)
3238 -rm -f $@
3239 sed '/set tmpdir/ s|testsuite|$(TESTSUITEDIR)|' < site.exp > $@
3240
49a41726 3241$(lang_checks): check-% : $(TESTSUITEDIR)/site.exp
8c90b13a
L
3242 -(rootme=`${PWD_COMMAND}`; export rootme; \
3243 srcdir=`cd ${srcdir}; ${PWD_COMMAND}` ; export srcdir ; \
a738a85c 3244 cd $(TESTSUITEDIR); \
d8bb17c8
OP
3245 EXPECT=${EXPECT} ; export EXPECT ; \
3246 if [ -f $${rootme}/../expect/expect ] ; then \
8c90b13a 3247 TCL_LIBRARY=`cd .. ; cd ${srcdir}/../tcl/library ; ${PWD_COMMAND}` ; \
d8bb17c8 3248 export TCL_LIBRARY ; fi ; \
4b09846b 3249 $(RUNTEST) --tool $* $(RUNTESTFLAGS))
d8bb17c8 3250
c36ae96c 3251check-consistency: testsuite/site.exp
8c90b13a
L
3252 -rootme=`${PWD_COMMAND}`; export rootme; \
3253 srcdir=`cd ${srcdir}; ${PWD_COMMAND}` ; export srcdir ; \
c36ae96c
GK
3254 cd testsuite; \
3255 EXPECT=${EXPECT} ; export EXPECT ; \
3256 if [ -f $${rootme}/../expect/expect ] ; then \
8c90b13a 3257 TCL_LIBRARY=`cd .. ; cd ${srcdir}/../tcl/library ; ${PWD_COMMAND}` ; \
c36ae96c
GK
3258 export TCL_LIBRARY ; fi ; \
3259 $(RUNTEST) --tool consistency $(RUNTESTFLAGS)
3260
f362c762
MM
3261# QMTest targets
3262
3263# The path to qmtest.
3264QMTEST_PATH=qmtest
3265
3266# The flags to pass to qmtest.
3267QMTESTFLAGS=
3268
3269# The flags to pass to "qmtest run".
d7068b3d 3270QMTESTRUNFLAGS=-f none --result-stream dejagnu_stream.DejaGNUStream
f362c762
MM
3271
3272# The command to use to invoke qmtest.
3273QMTEST=${QMTEST_PATH} ${QMTESTFLAGS}
3274
3275# The tests (or suites) to run.
d7068b3d 3276QMTEST_GPP_TESTS=g++
f362c762
MM
3277
3278# The subdirectory of the OBJDIR that will be used to store the QMTest
3279# test database configuration and that will be used for temporary
3280# scratch space during QMTest's execution.
62363d99 3281QMTEST_DIR=qmtestsuite
f362c762
MM
3282
3283# Create the QMTest database configuration.
3284${QMTEST_DIR} stamp-qmtest:
d7068b3d
MM
3285 ${QMTEST} -D ${QMTEST_DIR} create-tdb \
3286 -c gcc_database.GCCDatabase \
5f08e44f 3287 -a srcdir=`cd ${srcdir}/testsuite && ${PWD_COMMAND}` && \
d7068b3d 3288 $(STAMP) stamp-qmtest
f362c762
MM
3289
3290# Create the QMTest context file.
3291${QMTEST_DIR}/context: stamp-qmtest
d7068b3d
MM
3292 rm -f $@
3293 echo "CompilerTable.languages=c cplusplus" >> $@
3294 echo "CompilerTable.c_kind=GCC" >> $@
3295 echo "CompilerTable.c_path=${objdir}/xgcc" >> $@
3296 echo "CompilerTable.c_options=-B${objdir}/" >> $@
3297 echo "CompilerTable.cplusplus_kind=GCC" >> $@
3298 echo "CompilerTable.cplusplus_path=${objdir}/g++" >> $@
3299 echo "CompilerTable.cplusplus_options=-B${objdir}/" >> $@
caa55b1e 3300 echo "DejaGNUTest.target=${target_noncanonical}" >> $@
f362c762
MM
3301
3302# Run the G++ testsuite using QMTest.
d7068b3d 3303qmtest-g++: ${QMTEST_DIR}/context
f362c762 3304 cd ${QMTEST_DIR} && ${QMTEST} run ${QMTESTRUNFLAGS} -C context \
d7068b3d 3305 -o g++.qmr ${QMTEST_GPP_TESTS}
f362c762
MM
3306
3307# Use the QMTest GUI.
3308qmtest-gui: ${QMTEST_DIR}/context
3309 cd ${QMTEST_DIR} && ${QMTEST} gui -C context
3310
f362c762
MM
3311.PHONY: qmtest-g++
3312
efdc7e19
RH
3313# Run Paranoia on real.c.
3314
3315paranoia.o: $(srcdir)/../contrib/paranoia.cc $(CONFIG_H) $(SYSTEM_H) \
3316 real.h $(TREE_H)
3317 g++ -c $(ALL_CFLAGS) $(ALL_CPPFLAGS) $(INCLUDES) $< $(OUTPUT_OPTION)
3318
3319paranoia: paranoia.o real.o $(LIBIBERTY)
3320 g++ -o $@ paranoia.o real.o $(LIBIBERTY)
3321
79d8453e
RS
3322# These exist for maintenance purposes.
3323
3324# Update the tags table.
65ebbf81 3325TAGS: lang.tags
7d60db05
JM
3326 (cd $(srcdir); \
3327 incs= ; \
3328 list='$(SUBDIRS)'; for dir in $$list; do \
3329 if test -f $$dir/TAGS; then \
3330 incs="$$incs --include $$dir/TAGS.sub"; \
3331 fi; \
3332 done; \
3333 mkdir tmp-tags; \
3334 mv -f c-parse.[ch] tmp-tags; \
3335 etags -o TAGS.sub *.y *.h *.c; \
3336 mv tmp-tags/* .; \
3337 rmdir tmp-tags; \
3338 etags --include TAGS.sub $$incs)
79d8453e 3339
39e73137
NN
3340# ------------------------------------------------------
3341# Bootstrap-related targets (not used during 'make all')
3342# ------------------------------------------------------
3343
87a8affe 3344# A list of files to be destroyed during "lean" builds.
a36556a8 3345VOL_FILES=`echo $(BACKEND) $(OBJS) $(C_OBJS) $(LIBCPP_OBJS) *.c *.h gen*`
87a8affe 3346
b8dad04b
ZW
3347# Flags to pass to stage2 and later recursive makes. Note that the
3348# WARN_CFLAGS setting can't be to the expansion of GCC_WARN_CFLAGS in
3349# the context of the stage_x rule.
8f231b5d
JH
3350
3351POSTSTAGE1_FLAGS_TO_PASS = \
15cc172b 3352 ADAFLAGS="$(BOOT_ADAFLAGS)" \
b8dad04b
ZW
3353 CFLAGS="$(BOOT_CFLAGS)" \
3354 LDFLAGS="$(BOOT_LDFLAGS)" \
3355 WARN_CFLAGS="\$$(GCC_WARN_CFLAGS)" \
3356 STRICT_WARN="$(STRICT2_WARN)" \
3357 libdir=$(libdir) \
3358 LANGUAGES="$(LANGUAGES)" \
fca086c1
KC
3359 MAKEINFO="$(MAKEINFO)" \
3360 MAKEINFOFLAGS="$(MAKEINFOFLAGS)" \
03bbd83f 3361 MAKEOVERRIDES= \
b8dad04b
ZW
3362 OUTPUT_OPTION="-o \$$@"
3363
8f231b5d
JH
3364STAGE2_FLAGS_TO_PASS = \
3365 CFLAGS="$(BOOT_CFLAGS)" \
3366 WERROR="@WERROR@" \
3367
3368STAGEPROFILE_FLAGS_TO_PASS = \
5340bbea 3369 CFLAGS="$(BOOT_CFLAGS) -fprofile-generate"
8f231b5d
JH
3370
3371# Files never linked into the final executable produces warnings about missing
3372# profile.
3373STAGEFEEDBACK_FLAGS_TO_PASS = \
5340bbea 3374 CFLAGS="$(BOOT_CFLAGS) -fprofile-use"
8f231b5d 3375
9c4614c3
TW
3376# Only build the C compiler for stage1, because that is the only one that
3377# we can guarantee will build with the native compiler, and also it is the
78faa32d
FS
3378# only thing useful for building stage2. STAGE1_CFLAGS (via CFLAGS),
3379# MAKEINFO and MAKEINFOFLAGS are explicitly passed here to make them
3380# overrideable (for a bootstrap build stage1 also builds gcc.info).
770861f3 3381stage1_build:
78faa32d
FS
3382 $(MAKE) CC="$(CC)" libdir=$(libdir) LANGUAGES="$(BOOT_LANGUAGES)" \
3383 CFLAGS="$(STAGE1_CFLAGS)" MAKEINFO="$(MAKEINFO)" \
ed2d8944
RH
3384 MAKEINFOFLAGS="$(MAKEINFOFLAGS)" COVERAGE_FLAGS= \
3385 OBJS-onestep="$(OBJS)"
d9835ae8 3386 $(STAMP) stage1_build
770861f3 3387 echo stage1_build > stage_last
204093e6 3388
770861f3 3389stage1_copy: stage1_build
79d8453e 3390 $(MAKE) stage1
d9835ae8 3391 $(STAMP) stage1_copy
770861f3 3392 echo stage2_build > stage_last
204093e6 3393
770861f3 3394stage2_build: stage1_copy
eaf9f3b2 3395 $(MAKE) CC="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" CC_FOR_BUILD="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" \
b8dad04b 3396 STAGE_PREFIX=stage1/ \
8f231b5d 3397 $(POSTSTAGE1_FLAGS_TO_PASS) \
b8dad04b 3398 $(STAGE2_FLAGS_TO_PASS)
d9835ae8 3399 $(STAMP) stage2_build
770861f3 3400 echo stage2_build > stage_last
204093e6 3401
770861f3 3402stage2_copy: stage2_build
3d84f80f 3403 $(MAKE) stage2
d9835ae8 3404 $(STAMP) stage2_copy
770861f3 3405 echo stage3_build > stage_last
b8dad04b 3406
8f231b5d 3407stageprofile_build: stage1_copy
eaf9f3b2 3408 $(MAKE) CC="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" CC_FOR_BUILD="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" \
8f231b5d
JH
3409 STAGE_PREFIX=stage1/ \
3410 $(POSTSTAGE1_FLAGS_TO_PASS) \
3411 $(STAGEPROFILE_FLAGS_TO_PASS)
3412 $(STAMP) stageprofile_build
3413 echo stageprofile_build > stage_last
3414
3415stageprofile_copy: stageprofile_build
3416 $(MAKE) stageprofile
3417 $(STAMP) stageprofile_copy
3418 echo stagefeedback_build > stage_last
3419
770861f3 3420stage3_build: stage2_copy
eaf9f3b2 3421 $(MAKE) CC="$(STAGE_CC_WRAPPER) stage2/xgcc$(exeext) -Bstage2/ -B$(build_tooldir)/bin/" CC_FOR_BUILD="$(STAGE_CC_WRAPPER) stage2/xgcc$(exeext) -Bstage2/ -B$(build_tooldir)/bin/" \
b8dad04b 3422 STAGE_PREFIX=stage2/ \
8f231b5d 3423 $(POSTSTAGE1_FLAGS_TO_PASS) \
b8dad04b 3424 $(STAGE2_FLAGS_TO_PASS)
d9835ae8 3425 $(STAMP) stage3_build
770861f3 3426 echo stage3_build > stage_last
204093e6 3427
8f231b5d 3428stagefeedback_build: stageprofile_copy stage1_copy
eaf9f3b2 3429 $(MAKE) CC="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" CC_FOR_BUILD="$(STAGE_CC_WRAPPER) stage1/xgcc$(exeext) -Bstage1/ -B$(build_tooldir)/bin/" \
8f231b5d
JH
3430 STAGE_PREFIX=stage1/ \
3431 $(POSTSTAGE1_FLAGS_TO_PASS) \
3432 $(STAGEFEEDBACK_FLAGS_TO_PASS)
3433 $(STAMP) stagefeedback_build
3434 echo stagefeedback_build > stage_last
3435
3436stagefeedback_copy: stagefeedback_build
3437 $(MAKE) stagefeedback
3438 $(STAMP) stagefeedback_copy
3439 echo stagefeedback2_build > stage_last
3440
204093e6 3441# For bootstrap4:
770861f3 3442stage3_copy: stage3_build
3d84f80f 3443 $(MAKE) stage3
d9835ae8 3444 $(STAMP) stage3_copy
770861f3
DD
3445 echo stage4_build > stage_last
3446
3447stage4_build: stage3_copy
eaf9f3b2 3448 $(MAKE) CC="$(STAGE_CC_WRAPPER) stage3/xgcc$(exeext) -Bstage3/ -B$(build_tooldir)/bin/" CC_FOR_BUILD="$(STAGE_CC_WRAPPER) stage3/xgcc$(exeext) -Bstage3/ -B$(build_tooldir)/bin/" \
b8dad04b 3449 STAGE_PREFIX=stage3/ \
8f231b5d 3450 $(POSTSTAGE1_FLAGS_TO_PASS) \
b8dad04b 3451 $(STAGE2_FLAGS_TO_PASS)
d9835ae8 3452 $(STAMP) stage4_build
770861f3 3453 echo stage4_build > stage_last
204093e6
DT
3454
3455# Additional steps for *-lean targets:
770861f3 3456clean_s1: stage1_copy
b8dad04b 3457 -(cd stage1 && rm -f $(VOL_FILES))
d9835ae8 3458 $(STAMP) clean_s1
204093e6 3459
770861f3 3460clean_s2: stage2_copy
204093e6 3461 -rm -rf stage1
d9835ae8 3462 $(STAMP) clean_s2
204093e6 3463
770861f3
DD
3464# The various entry points for bootstrapping.
3465
3466bootstrap: stage3_build
3467 @echo
3468 @echo Bootstrap complete - make \"quickstrap\" to redo last build,
3469 @echo \"restage1\" through \"restage3\" to rebuild specific stages,
9c8d079c
JM
3470 @echo \"restrap\" to redo the bootstrap from stage1, or
3471 @echo \"cleanstrap\" to redo the bootstrap from scratch.
770861f3
DD
3472
3473bootstrap-lean : clean_s1 clean_s2 stage3_build
3474 @echo
3475 @echo Bootstrap complete - make \"quickstrap\" to redo last build,
3476 @echo or \"cleanstrap\" to redo the bootstrap from scratch.
3477
3478bootstrap2: bootstrap
3479
4f92461a 3480bootstrap2-lean : bootstrap-lean
770861f3
DD
3481
3482bootstrap3 bootstrap3-lean: bootstrap
4f92461a 3483
770861f3
DD
3484bootstrap4 bootstrap4-lean: stage4_build
3485
8f231b5d 3486unstage1 unstage2 unstage3 unstage4 unstageprofile unstagefeedback:
770861f3 3487 -set -vx; stage=`echo $@ | sed -e 's/un//'`; \
4992fc7f
RH
3488 rm -f $$stage/as$(exeext); \
3489 rm -f $$stage/ld$(exeext); \
3490 rm -f $$stage/collect-ld$(exeext); \
770861f3 3491 if test -d $$stage; then \
ff3d4e83 3492 mv $$stage/specs $(SPECS) 2>/dev/null || :; \
770861f3
DD
3493 mv $$stage/* . 2>/dev/null; \
3494 for i in `cd $$stage; echo *` ; do \
3495 if test -d $$stage/$$i; then \
3496 mv $$stage/$$i/* $$i/. 2>/dev/null; \
3497 else \
3498 mv $$stage/$$i .; \
20266bb1 3499 fi; \
770861f3
DD
3500 done \
3501 fi ; \
3502 rm -f $${stage}_build $${stage}_copy ;\
3503 echo $${stage}_build > stage_last
3504
3505restage1: unstage1
7f5cc0f3 3506 $(MAKE) $(REMAKEFLAGS) stage1_build
770861f3
DD
3507
3508restage2: unstage2
7f5cc0f3 3509 $(MAKE) $(REMAKEFLAGS) stage2_build
770861f3
DD
3510
3511restage3: unstage3
7f5cc0f3 3512 $(MAKE) $(REMAKEFLAGS) stage3_build
770861f3
DD
3513
3514restage4: unstage4
7f5cc0f3 3515 $(MAKE) $(REMAKEFLAGS) stage4_build
770861f3 3516
8f231b5d 3517restageprofile: unstageprofile
7f5cc0f3 3518 $(MAKE) $(REMAKEFLAGS) stageprofile_build
8f231b5d
JH
3519
3520restagefeedback: unstagefeedback
7f5cc0f3 3521 $(MAKE) $(REMAKEFLAGS) stagefeedback_build
8f231b5d 3522
40209195
JM
3523# Bubble up a bugfix through all the stages. Primarily useful for fixing
3524# bugs that cause the compiler to crash while building stage 2.
770861f3 3525bubblestrap:
40209195 3526 if test -f stage_last; then \
57ac311f 3527 LAST=`sed -e 's/_build//' < stage_last`; \
40209195 3528 if test "$$LAST" != "stage1"; then \
7f5cc0f3 3529 $(MAKE) $(REMAKEFLAGS) $$LAST; \
40209195
JM
3530 $(STAMP) $${LAST}_copy; \
3531 fi; \
3532 fi
3533 if test -f stage1_copy; then $(MAKE) unstage1; fi
7f5cc0f3 3534 $(MAKE) $(REMAKEFLAGS) stage1_copy
40209195 3535 if test -f stage2_copy; then $(MAKE) unstage2; fi
7f5cc0f3 3536 $(MAKE) $(REMAKEFLAGS) stage2_copy
40209195 3537 if test -f stage3_copy; then $(MAKE) unstage3; fi
7f5cc0f3 3538 $(MAKE) $(REMAKEFLAGS) stage3_build
40209195 3539 if test -f stage4_copy; then \
7f5cc0f3
KC
3540 $(MAKE) $(REMAKEFLAGS) stage3_copy; $(MAKE) unstage4; \
3541 $(MAKE) $(REMAKEFLAGS) stage4_build || exit 1; \
770861f3 3542 fi
770861f3
DD
3543
3544quickstrap:
3545 if test -f stage_last ; then \
7f5cc0f3 3546 LAST=`cat stage_last`; rm $$LAST; $(MAKE) $(REMAKEFLAGS) $$LAST; \
770861f3 3547 else \
7f5cc0f3 3548 $(MAKE) $(REMAKEFLAGS) stage1_build; \
770861f3
DD
3549 fi
3550
3551cleanstrap:
3552 -$(MAKE) clean
7f5cc0f3 3553 $(MAKE) $(REMAKEFLAGS) bootstrap
361e618f 3554
9c8d079c 3555unstrap:
a7db751a 3556 -rm -rf stage[234]*
9c8d079c 3557 $(MAKE) unstage1
a7db751a 3558 -rm -f stage_last
9c8d079c
JM
3559
3560# Differs from cleanstrap in that it starts from the earlier stage1 build,
3561# not from scratch.
3562restrap:
3563 $(MAKE) unstrap
7f5cc0f3 3564 $(MAKE) $(REMAKEFLAGS) bootstrap
9c8d079c 3565
269a7343
KG
3566# These targets compare the object files in the current directory with
3567# those in a stage directory. We need to skip the first N bytes of
3568# each object file. The "slow" mechanism assumes nothing special
3569# about cmp and uses the tail command to skip. ./ avoids a bug in
3570# some versions of tail. The "gnu" targets use gnu cmp (diffutils
3571# v2.4 or later), to avoid running tail and the overhead of twice
3572# copying each object file. Likewise, the "fast" targets use the skip
3573# parameter of cmp available on some systems to accomplish the same
3574# thing. An exit status of 1 is precisely the result we're looking
3575# for (other values mean other problems).
3576slowcompare slowcompare3 slowcompare4 slowcompare-lean slowcompare3-lean slowcompare4-lean \
3577fastcompare fastcompare3 fastcompare4 fastcompare-lean fastcompare3-lean fastcompare4-lean \
3578 gnucompare gnucompare3 gnucompare4 gnucompare-lean gnucompare3-lean gnucompare4-lean: force
3fb2f401 3579 -rm -f .bad_compare
269a7343 3580 case "$@" in *compare | *compare-lean ) stage=2 ;; * ) stage=`echo $@ | sed -e 's,^[a-z]*compare\([0-9][0-9]*\).*,\1,'` ;; esac; \
611764ec 3581 for dir in . $(SUBDIRS); do \
b1e3ddfd
AJ
3582 if [ "`echo $$dir/*$(objext)`" != "$$dir/*$(objext)" ] ; then \
3583 for file in $$dir/*$(objext); do \
269a7343
KG
3584 case "$@" in \
3585 slowcompare* ) \
3586 tail +16c ./$$file > tmp-foo1; \
3587 tail +16c stage$$stage/$$file > tmp-foo2 \
3588 && (cmp tmp-foo1 tmp-foo2 > /dev/null 2>&1 || echo $$file differs >> .bad_compare) || true; \
3589 ;; \
3590 fastcompare* ) \
3591 cmp $$file stage$$stage/$$file 16 16 > /dev/null 2>&1; \
3592 test $$? -eq 1 && echo $$file differs >> .bad_compare || true; \
3593 ;; \
3594 gnucompare* ) \
3595 cmp --ignore-initial=16 $$file stage$$stage/$$file > /dev/null 2>&1; \
3596 test $$? -eq 1 && echo $$file differs >> .bad_compare || true; \
3597 ;; \
3598 esac ; \
b1e3ddfd 3599 done; \
7ce1e6c8 3600 else true; fi; \
b1e3ddfd 3601 done
269a7343
KG
3602 -rm -f tmp-foo*
3603 case "$@" in *compare | *compare-lean ) stage=2 ;; * ) stage=`echo $@ | sed -e 's,^[a-z]*compare\([0-9][0-9]*\).*,\1,'` ;; esac; \
b1e3ddfd
AJ
3604 if [ -f .bad_compare ]; then \
3605 echo "Bootstrap comparison failure!"; \
3606 cat .bad_compare; \
3607 exit 1; \
e85988b5
MH
3608 else \
3609 case "$@" in \
3610 *-lean ) rm -rf stage$$stage ;; \
269a7343 3611 *) ;; \
e85988b5 3612 esac; true; \
b1e3ddfd
AJ
3613 fi
3614
c7a5cf61
PE
3615# Forwarding wrappers to the most appropriate version.
3616compare: @make_compare_target@
3617compare3: @make_compare_target@3
3618compare4: @make_compare_target@4
3619compare-lean: @make_compare_target@-lean
3620compare3-lean: @make_compare_target@3-lean
3621compare4-lean: @make_compare_target@4-lean
3622
79d8453e 3623# Copy the object files from a particular stage into a subdirectory.
013a2ee0 3624stage1-start:
2e494f70 3625 -if [ -d stage1 ] ; then true ; else mkdir stage1 ; fi
f472a17c 3626 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stage1
6f3fcc0b 3627 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
013a2ee0 3628 do \
9a517e7b 3629 if [ -d stage1/$$dir ] ; then true ; else mkdir stage1/$$dir ; fi ; \
013a2ee0 3630 done
ff3d4e83
AO
3631# If SPECS is overridden, make sure it is `installed' as specs.
3632 -mv $(SPECS) stage1/specs
79d8453e 3633 -mv $(STAGESTUFF) stage1
338023d4
DE
3634# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3635# dir will work properly.
c926f674
DR
3636 -if [ -f as$(exeext) ] ; then (cd stage1 && $(LN_S) ../as$(exeext) .) ; else true ; fi
3637 -if [ -f ld$(exeext) ] ; then (cd stage1 && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3638 -if [ -f collect-ld$(exeext) ] ; then (cd stage1 && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
23af32e6 3639 -rm -f stage1/libgcc.a stage1/libgcc_eh.a stage1/libgcov.a
79d8453e 3640 -cp libgcc.a stage1
6dd05d08 3641 -$(RANLIB_FOR_TARGET) stage1/libgcc.a
23af32e6
NS
3642 -cp libgcov.a stage1
3643 -$(RANLIB_FOR_TARGET) stage1/libgcov.a
275b60d6 3644 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stage1; \
275b60d6 3645 $(RANLIB_FOR_TARGET) stage1/libgcc_eh.a; \
6dd05d08 3646 fi
04e95620
JM
3647 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3648 cp stage1/$${f} . ; \
db814993 3649 else true; \
04e95620 3650 fi; done
013a2ee0 3651stage1: force stage1-start lang.stage1
4977bab6
ZW
3652 -for dir in . $(SUBDIRS) ; \
3653 do \
3654 rm -f $$dir/*$(coverageexts) ; \
3655 done
79d8453e 3656
013a2ee0 3657stage2-start:
2e494f70 3658 -if [ -d stage2 ] ; then true ; else mkdir stage2 ; fi
f472a17c 3659 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stage2
56694dd9 3660 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
013a2ee0 3661 do \
9a517e7b 3662 if [ -d stage2/$$dir ] ; then true ; else mkdir stage2/$$dir ; fi ; \
013a2ee0 3663 done
ff3d4e83
AO
3664# If SPECS is overridden, make sure it is `installed' as specs.
3665 -mv $(SPECS) stage2/specs
79d8453e 3666 -mv $(STAGESTUFF) stage2
338023d4
DE
3667# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3668# dir will work properly.
c926f674
DR
3669 -if [ -f as$(exeext) ] ; then (cd stage2 && $(LN_S) ../as$(exeext) .) ; else true ; fi
3670 -if [ -f ld$(exeext) ] ; then (cd stage2 && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3671 -if [ -f collect-ld$(exeext) ] ; then (cd stage2 && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
23af32e6 3672 -rm -f stage2/libgcc.a stage2/libgcov.a stage2/libgcc_eh.a
79d8453e 3673 -cp libgcc.a stage2
6dd05d08 3674 -$(RANLIB_FOR_TARGET) stage2/libgcc.a
23af32e6
NS
3675 -cp libgcov.a stage2
3676 -$(RANLIB_FOR_TARGET) stage2/libgcov.a
275b60d6 3677 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stage2; \
275b60d6 3678 $(RANLIB_FOR_TARGET) stage2/libgcc_eh.a; \
6dd05d08 3679 fi
04e95620
JM
3680 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3681 cp stage2/$${f} . ; \
db814993 3682 else true; \
04e95620 3683 fi; done
013a2ee0 3684stage2: force stage2-start lang.stage2
79d8453e 3685
013a2ee0 3686stage3-start:
935e11b0 3687 -if [ -d stage3 ] ; then true ; else mkdir stage3 ; fi
f472a17c 3688 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stage3
56694dd9 3689 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
013a2ee0 3690 do \
9a517e7b 3691 if [ -d stage3/$$dir ] ; then true ; else mkdir stage3/$$dir ; fi ; \
013a2ee0 3692 done
ff3d4e83
AO
3693# If SPECS is overridden, make sure it is `installed' as specs.
3694 -mv $(SPECS) stage3/specs
79d8453e 3695 -mv $(STAGESTUFF) stage3
338023d4
DE
3696# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3697# dir will work properly.
c926f674
DR
3698 -if [ -f as$(exeext) ] ; then (cd stage3 && $(LN_S) ../as$(exeext) .) ; else true ; fi
3699 -if [ -f ld$(exeext) ] ; then (cd stage3 && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3700 -if [ -f collect-ld$(exeext) ] ; then (cd stage3 && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
23af32e6 3701 -rm -f stage3/libgcc.a stage3/libgcov.a stage3/libgcc_eh.a
79d8453e 3702 -cp libgcc.a stage3
6dd05d08 3703 -$(RANLIB_FOR_TARGET) stage3/libgcc.a
23af32e6
NS
3704 -cp libgcov.a stage3
3705 -$(RANLIB_FOR_TARGET) stage3/libgcov.a
275b60d6 3706 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stage3; \
275b60d6 3707 $(RANLIB_FOR_TARGET) stage3/libgcc_eh.a; \
6dd05d08 3708 fi
04e95620
JM
3709 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3710 cp stage3/$${f} . ; \
db814993 3711 else true; \
04e95620 3712 fi; done
013a2ee0 3713stage3: force stage3-start lang.stage3
79d8453e 3714
013a2ee0 3715stage4-start:
935e11b0 3716 -if [ -d stage4 ] ; then true ; else mkdir stage4 ; fi
f472a17c 3717 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stage4
56694dd9 3718 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
013a2ee0 3719 do \
9a517e7b 3720 if [ -d stage4/$$dir ] ; then true ; else mkdir stage4/$$dir ; fi ; \
013a2ee0 3721 done
ff3d4e83
AO
3722# If SPECS is overridden, make sure it is `installed' as specs.
3723 -mv $(SPECS) stage4/specs
79d8453e 3724 -mv $(STAGESTUFF) stage4
338023d4
DE
3725# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3726# dir will work properly.
c926f674
DR
3727 -if [ -f as$(exeext) ] ; then (cd stage4 && $(LN_S) ../as$(exeext) .) ; else true ; fi
3728 -if [ -f ld$(exeext) ] ; then (cd stage4 && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3729 -if [ -f collect-ld$(exeext) ] ; then (cd stage4 && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
23af32e6 3730 -rm -f stage4/libgcc.a stage4/libgcov.a stage4/libgcc_eh.a
79d8453e 3731 -cp libgcc.a stage4
6dd05d08 3732 -$(RANLIB_FOR_TARGET) stage4/libgcc.a
23af32e6
NS
3733 -cp libgcov.a stage4
3734 -$(RANLIB_FOR_TARGET) stage4/libgcov.a
275b60d6 3735 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stage4; \
275b60d6 3736 $(RANLIB_FOR_TARGET) stage4/libgcc_eh.a; \
6dd05d08 3737 fi
04e95620
JM
3738 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3739 cp stage4/$${f} . ; \
db814993 3740 else true; \
04e95620 3741 fi; done
013a2ee0 3742stage4: force stage4-start lang.stage4
79d8453e 3743
8f231b5d
JH
3744stageprofile-start:
3745 -if [ -d stageprofile ] ; then true ; else mkdir stageprofile ; fi
3746 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stageprofile
56694dd9 3747 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
8f231b5d
JH
3748 do \
3749 if [ -d stageprofile/$$dir ] ; then true ; else mkdir stageprofile/$$dir ; fi ; \
3750 done
3751 -mv $(STAGESTUFF) stageprofile
8f231b5d
JH
3752# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3753# dir will work properly.
3754 -if [ -f as$(exeext) ] ; then (cd stageprofile && $(LN_S) ../as$(exeext) .) ; else true ; fi
3755 -if [ -f ld$(exeext) ] ; then (cd stageprofile && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3756 -if [ -f collect-ld$(exeext) ] ; then (cd stageprofile && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
3757 -rm -f stageprofile/libgcc.a stageprofile/libgcov.a stageprofile/libgcc_eh.a
3758 -cp libgcc.a stageprofile
3759 -$(RANLIB_FOR_TARGET) stageprofile/libgcc.a
3760 -cp libgcov.a stageprofile
3761 -$(RANLIB_FOR_TARGET) stageprofile/libgcov.a
3762 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stageprofile; \
3763 $(RANLIB_FOR_TARGET) stageprofile/libgcc_eh.a; \
3764 fi
3765 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3766 cp stageprofile/$${f} . ; \
3767 else true; \
3768 fi; done
3769stageprofile: force stageprofile-start lang.stageprofile
3770
3771stagefeedback-start:
3772 -if [ -d stagefeedback ] ; then true ; else mkdir stagefeedback ; fi
3773 $(MAKE) -f libgcc.mk libgcc-stage-start stage=stagefeedback
56694dd9 3774 -subdirs="$(SUBDIRS)"; for dir in $$subdirs; \
8f231b5d
JH
3775 do \
3776 if [ -d stagefeedback/$$dir ] ; then true ; else mkdir stagefeedback/$$dir ; fi ; \
3777 done
3778 -mv $(STAGESTUFF) stagefeedback
8f231b5d
JH
3779# Copy as/ld if they exist to stage dir, so that running xgcc from the stage
3780# dir will work properly.
3781 -if [ -f as$(exeext) ] ; then (cd stagefeedback && $(LN_S) ../as$(exeext) .) ; else true ; fi
3782 -if [ -f ld$(exeext) ] ; then (cd stagefeedback && $(LN_S) ../ld$(exeext) .) ; else true ; fi
3783 -if [ -f collect-ld$(exeext) ] ; then (cd stagefeedback && $(LN_S) ../collect-ld$(exeext) .) ; else true ; fi
3784 -rm -f stagefeedback/libgcc.a stagefeedback/libgcov.a stagefeedback/libgcc_eh.a
84fb2019 3785 -rm -f *.da
6eb95e99 3786 -for dir in fixinc po testsuite $(SUBDIRS); \
84fb2019
RK
3787 do \
3788 rm -f $$dir/*.da ; \
3789 done
8f231b5d
JH
3790 -cp libgcc.a stagefeedback
3791 -$(RANLIB_FOR_TARGET) stagefeedback/libgcc.a
3792 -cp libgcov.a stagefeedback
3793 -$(RANLIB_FOR_TARGET) stagefeedback/libgcov.a
3794 -if [ -f libgcc_eh.a ] ; then cp libgcc_eh.a stagefeedback; \
3795 $(RANLIB_FOR_TARGET) stagefeedback/libgcc_eh.a; \
3796 fi
3797 -for f in .. $(EXTRA_MULTILIB_PARTS); do if [ x$${f} != x.. ]; then \
3798 cp stagefeedback/$${f} . ; \
3799 else true; \
3800 fi; done
3801stagefeedback: force stagefeedback-start lang.stagefeedback
3802
79d8453e
RS
3803# Copy just the executable files from a particular stage into a subdirectory,
3804# and delete the object files. Use this if you're just verifying a version
3805# that is pretty sure to work, and you are short of disk space.
aab26e16 3806risky-stage1: stage1
e108653c 3807 -$(MAKE) clean
79d8453e 3808
aab26e16 3809risky-stage2: stage2
e108653c 3810 -$(MAKE) clean
79d8453e 3811
aab26e16 3812risky-stage3: stage3
e108653c 3813 -$(MAKE) clean
79d8453e 3814
aab26e16 3815risky-stage4: stage4
e108653c 3816 -$(MAKE) clean
79d8453e
RS
3817
3818#In GNU Make, ignore whether `stage*' exists.
f1908d70 3819.PHONY: stage1 stage2 stage3 stage4 clean maintainer-clean TAGS bootstrap
79d8453e 3820.PHONY: risky-stage1 risky-stage2 risky-stage3 risky-stage4
8f231b5d 3821.PHONY: stagefeedback stageprofile
79d8453e 3822
39e73137 3823# -----------------------------------------------------
5b7874aa
ZW
3824# Rules for generating translated message descriptions.
3825# Disabled by autoconf if the tools are not available.
39e73137 3826# -----------------------------------------------------
5b7874aa
ZW
3827
3828XGETTEXT = @XGETTEXT@
3829GMSGFMT = @GMSGFMT@
3830MSGMERGE = msgmerge
3831
3832PACKAGE = @PACKAGE@
3833CATALOGS = @CATALOGS@
3834
0f81faf6 3835.PHONY: build- install- build-po install-po update-po
5b7874aa
ZW
3836
3837# Dummy rules to deal with dependencies produced by use of
3838# "build-@POSUB@" and "install-@POSUB@" above, when NLS is disabled.
3839build-: ; @true
3840install-: ; @true
3841
3842build-po: $(CATALOGS)
3843
3844# This notation should be acceptable to all Make implementations used
3845# by people who are interested in updating .po files.
3846update-po: $(CATALOGS:.gmo=.pox)
3847
9f6682b7
ZW
3848# N.B. We do not attempt to copy these into $(srcdir). The snapshot
3849# script does that.
5b7874aa 3850.po.gmo:
7227d624 3851 -test -d po || mkdir po
bc524dd0 3852 $(GMSGFMT) --statistics -o $@ $<
5b7874aa 3853
9f6682b7
ZW
3854# The new .po has to be gone over by hand, so we deposit it into
3855# build/po with a different extension.
359cd11e
ZW
3856# If build/po/$(PACKAGE).pot exists, use it (it was just created),
3857# else use the one in srcdir.
5b7874aa 3858.po.pox:
7227d624 3859 -test -d po || mkdir po
359cd11e
ZW
3860 $(MSGMERGE) $< `if test -f po/$(PACKAGE).pot; \
3861 then echo po/$(PACKAGE).pot; \
3862 else echo $(srcdir)/po/$(PACKAGE).pot; fi` -o $@
5b7874aa 3863
9f6682b7
ZW
3864# This rule has to look for .gmo modules in both srcdir and
3865# the cwd, and has to check that we actually have a catalog
3866# for each language, in case they weren't built or included
3867# with the distribution.
5b7874aa 3868install-po:
947c6b00 3869 $(mkinstalldirs) $(DESTDIR)$(datadir)
318b7749 3870 cats="$(CATALOGS)"; for cat in $$cats; do \
9f6682b7
ZW
3871 lang=`basename $$cat | sed 's/\.gmo$$//'`; \
3872 if [ -f $$cat ]; then :; \
3873 elif [ -f $(srcdir)/$$cat ]; then cat=$(srcdir)/$$cat; \
3874 else continue; \
3875 fi; \
5b7874aa 3876 dir=$(localedir)/$$lang/LC_MESSAGES; \
947c6b00
NN
3877 echo $(mkinstalldirs) $(DESTDIR)$$dir; \
3878 $(mkinstalldirs) $(DESTDIR)$$dir || exit 1; \
9f6682b7
ZW
3879 echo $(INSTALL_DATA) $$cat $(DESTDIR)$$dir/$(PACKAGE).mo; \
3880 $(INSTALL_DATA) $$cat $(DESTDIR)$$dir/$(PACKAGE).mo; \
5b7874aa
ZW
3881 done
3882
3883# Rule for regenerating the message template (gcc.pot).
3884# Instead of forcing everyone to edit POTFILES.in, which proved impractical,
3885# this rule has no dependencies and always regenerates gcc.pot. This is
3886# relatively harmless since the .po files do not directly depend on it.
3887# Note that exgettext has an awk script embedded in it which requires a
3888# fairly modern (POSIX-compliant) awk.
359cd11e 3889# The .pot file is left in the build directory.
5b7874aa 3890$(PACKAGE).pot: po/$(PACKAGE).pot
02ba6b22 3891po/$(PACKAGE).pot: force options.c
7227d624 3892 -test -d po || mkdir po
02ba6b22 3893 $(MAKE) srcextra
5b7874aa
ZW
3894 AWK=$(AWK) $(SHELL) $(srcdir)/po/exgettext \
3895 $(XGETTEXT) $(PACKAGE) $(srcdir)