1 # Copyright (C) 1991, 1992, 1993, 1994, 1995 Free Software Foundation, Inc.
2 # This file is part of the GNU C Library.
4 # The GNU C Library is free software; you can redistribute it and/or
5 # modify it under the terms of the GNU Library General Public License as
6 # published by the Free Software Foundation; either version 2 of the
7 # License, or (at your option) any later version.
9 # The GNU C Library is distributed in the hope that it will be useful,
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 # Library General Public License for more details.
14 # You should have received a copy of the GNU Library General Public
15 # License along with the GNU C Library; see the file COPYING.LIB. If
16 # not, write to the Free Software Foundation, Inc., 675 Mass Ave,
17 # Cambridge, MA 02139, USA.
20 # Makefile configuration options for the GNU C library.
23 This makefile requires GNU Make.
26 ifneq "$(origin +included-Makeconfig)" "file"
28 +included-Makeconfig := yes
34 # If config.make exists, the source directory was configured,
35 # so don't try to be clever and find another directory to build in.
36 ifneq (,$(wildcard $(..)config.make))
39 else # Not configured.
47 # Directory for object files and libc.a. If this is not defined, the
48 # object files live in the subdirectories where their sources live, and
49 # libc.a lives in the parent directory (this probably doesn't work any
52 ifeq ($(filter /%,$(ARCH)),)
53 objdir := $(..)$(ARCH)
59 # $(common-objdir) is the place to put objects and
60 # such that are not specific to a single subdir.
63 common-objpfx = $(objpfx)
64 common-objdir = $(objdir)
71 # This is a kludge. make wizards might grok.
72 common-objpfx = sysdeps/../
78 # Get the values defined by options to `configure'.
79 include $(common-objpfx)config.make
81 # Run config.status to update config.make and config.h. We don't show the
82 # dependence of config.h to Make, because it is only touched when it
83 # changes and so config.status would be run every time; the dependence of
84 # config.make should suffice to force regeneration and re-exec, and the new
85 # image will notice if config.h changed.
86 $(common-objpfx)config.make: $(common-objpfx)config.status
87 cd $(<D); $(SHELL) $(<F)
89 # Force the user to configure before making.
90 $(common-objpfx)config.status: $(..)configure
91 @cd $(@D); if test -f $(@F); then exec $(SHELL) $(@F) --recheck; else \
92 echo The GNU C library has not been configured. >&2; \
93 echo Run \`configure\' to configure it before building. >&2; \
94 echo Try \`configure --help\' for more details. >&2; \
97 # Get the user's configuration parameters.
98 ifneq ($(wildcard $(..)configparms),)
99 include $(..)configparms
102 ifneq ($(wildcard $(objpfx)configparms),)
103 include $(objpfx)configparms
107 sysdep_dir := $(..)sysdeps
108 export sysdep_dir := $(sysdep_dir)
111 #### These are the configuration variables. You can define values for
112 #### the variables below in the file `configparms'.
113 #### Do NOT edit this file.
117 # Common prefix for machine-independent installation directories.
118 ifeq ($(origin prefix),undefined) # ifndef would override explicit empty value.
122 # Common prefix for machine-dependent installation directories.
123 ifeq ($(origin exec_prefix),undefined)
124 exec_prefix = $(prefix)
127 # Where to install the library and object files.
129 libdir = $(exec_prefix)/lib
132 # Prefix to put on files installed in $(libdir). For libraries `libNAME.a',
133 # the prefix is spliced between `lib' and the name, so the linker switch
134 # `-l$(libprefix)NAME' finds the library; for other files the prefix is
135 # just prepended to the whole file name.
136 ifeq ($(origin libprefix),undefined)
140 # Where to install the header files.
142 includedir = $(exec_prefix)/include
145 # Where to install machine-independent data files.
146 # These are the timezone database, and the locale database.
148 datadir = $(prefix)/share
151 # Where to install the timezone data files (which are machine-independent).
153 zonedir = $(datadir)/zoneinfo
156 # Where to install the locale data files (which are machine-independent).
158 localedir = $(datadir)/locale
161 # Where to install the locale charmap and message catalog files (which are
162 # machine-independent).
164 nlsdir = $(datadir)/nls
168 # Where to install programs.
170 bindir = $(exec_prefix)/bin
173 # Where to install administrative programs.
175 sbindir = $(exec_prefix)/sbin
178 # Where to install the Info files.
180 infodir = $(prefix)/info
183 # Where to install default configuration files. These include the local
184 # timezone specification and network data base files.
186 sysconfdir = $(prefix)/etc
189 # What timezone should be the installed default (e.g., US/Eastern).
190 # Run `make -C time echo-zonenames' to see a list of available zone names.
191 # The local timezone can be changed with `zic -l TIMEZONE' at any time.
196 # Where to install the "localtime" timezone file; this is the file whose
197 # contents $(localtime) specifies. If this is a relative pathname, it is
198 # relative to $(zonedir). It is a good idea to put this somewhere
199 # other than there, so the zoneinfo directory contains only universal data,
200 # localizing the configuration data elsewhere.
201 ifndef localtime-file
202 localtime-file = $(sysconfdir)/localtime
205 # What timezone's DST rules should be used when a POSIX-style TZ
206 # environment variable doesn't specify any rules. For 1003.1 compliance
207 # this timezone must use rules that are as U.S. federal law defines DST.
208 # Run `make -C time echo-zonenames' to see a list of available zone names.
209 # This setting can be changed with `zic -p TIMEZONE' at any time.
210 # If you want POSIX.1 compatibility, use `America/New_York'.
212 posixrules = America/New_York
215 # Where to install the "posixrules" timezone file; this is file
216 # whose contents $(posixrules) specifies. If this is a relative
217 # pathname, it is relative to $(zonedir).
218 ifndef posixrules-file
219 posixrules-file = posixrules
223 # Directory where your system's native header files live.
224 # This is used on Unix systems to generate some GNU libc header files.
226 sysincludedir = /usr/include
230 # Commands to install files.
232 INSTALL_DATA = $(INSTALL) -m 644
234 ifndef INSTALL_PROGRAM
235 INSTALL_PROGRAM = $(INSTALL)
242 # The name of the C compiler.
243 # If you've got GCC, and it works, use it.
244 ifeq ($(origin CC),default)
248 # The name of the C compiler to use for compilations of programs to run on
249 # the host that is building the library. If you set CC to a
250 # cross-compiler, you must set this to the normal compiler.
255 # Default flags to pass the C compiler.
256 ifndef default_cflags
260 # Flags to pass the C compiler when assembling preprocessed assembly code
261 # (`.S' files). On some systems the assembler doesn't understand the `#' line
262 # directives the preprocessor produces. If you have troubling compiling
263 # assembly code, try using -P here to suppress these directives.
268 # Command for linking programs with the C library.
270 +link = $(CC) -nostdlib $(LDFLAGS) -o $@ \
271 $(addprefix $(csu-objpfx),start.o $(+preinit)) \
272 $(^:lib=$(common-objpfx)libc.a) $(gnulib) $(common-objpfx)libc.a \
273 $(addprefix $(csu-objpfx),$(+postinit))
283 csu-objpfx = $(objpfx)
285 csu-objpfx = $(..)csu/
296 # Extra flags to pass to GCC.
297 +gccwarn := -Wall -Wwrite-strings -Wno-parentheses -Winline -Wbad-function-cast
299 # This is the program that generates makefile
300 # dependencies from C source files.
305 # The program that makes Emacs-style TAGS files.
308 # The `m4' macro processor; this is used by sysdeps/sparc/Makefile (and
309 # perhaps others) to preprocess assembly code in some cases.
313 #### End of configuration variables.
316 # This tells some versions of GNU make before 3.63 not to export all variables.
319 # We want to echo the commands we're running without
320 # umpteem zillion filenames along with it (we use `...' instead)
321 # but we don't want this echoing done when the user has said
322 # he doesn't want to see commands echoed by using -s.
323 ifneq "$(findstring s,$(MAKEFLAGS))" "" # if -s
324 +cmdecho := echo >/dev/null
329 # These are the flags given to the compiler to tell
330 # it what sort of optimization and/or debugging output to do.
332 # If `CFLAGS' was defined, use that.
334 +cflags := $(filter-out -I%,$(CFLAGS))
338 # If none of the above worked, default to "-g".
339 ifeq "$(strip $(+cflags))" ""
340 +cflags := $(default_cflags)
341 endif # $(+cflags) == ""
343 # If using gcc, add flags that only it will grok.
344 ifneq "$(findstring gcc,$(CC))" ""
345 +cflags := $(+cflags) $(+gccwarn)
351 # Don't duplicate options if we inherited variables from the parent.
352 +cflags := $(sort $(+cflags))
355 # These are flags given to the C compiler to tell it to look for include
356 # files (including ones given in angle brackets) in the current directory
357 # and in the parent library source directory.
358 # `+sysdep-includes' will be defined by Makerules.
359 +includes = -I. $(filter-out -I,-I$(patsubst %/,%,$(..))) \
360 $(includes) $(+sysdep-includes) $(last-includes)
363 # These are the variables that the implicit compilation rules use.
364 CPPFLAGS = $(+includes) $(defines) -include $(..)libc-symbols.h \
365 $(sysdep-CPPFLAGS) $(CPPFLAGS-$(suffix $@))
366 override CFLAGS = $(+cflags) $(sysdep-CFLAGS) $(CFLAGS-$(suffix $@))
369 # This is the macro that the implicit linking rules use.
370 ifneq "$(filter -g,$(+cflags))" "" # -g is in $(+cflags)
375 # Enable object files for different versions of the library.
376 # Various things use $(object-suffixes) to know what all to make.
377 # The compilation rules use $(CPPFLAGS-${SUFFIX}) and $(CFLAGS-${SUFFIX})
378 # to pass different flags for each flavor.
379 libtypes = $(foreach o,$(object-suffixes),$(libtype$o))
380 object-suffixes := .o
382 ifeq (yes,$(build-shared))
383 # Under --enable-shared, we will build a shared library of PIC objects.
384 # The PIC object files are named foo.so.
385 object-suffixes += .so
388 libtype.so := lib%_pic.a
390 ifeq (yes,$(build-profile))
391 # Under --enable-profile, we will build a static library of profiled objects.
392 # The profiled object files are named foo.po.
393 object-suffixes += .po
395 libtype.po = lib%_p.a
397 ifeq (yes,$(build-omitfp))
398 # Under --enable-omitfp, we build an the library optimized without
399 # debugging information using -fomit-frame-pointer, and build an extra
400 # library with debugging information. The debuggable objects are named foo.go.
401 object-suffixes += .go
403 CFLAGS-.o = -g0 -O99 -fomit-frame-pointer
404 CFLAGS-.so += $(CFLAGS.o)
405 libtype.go = lib%_g.a
409 +gnu-stabs = $(shell echo>&2 '*** BARF ON ME')
411 ifneq ($(BUILD_CC),$(CC))
412 cross-compiling := yes
414 cross-compiling := no
418 endif # Makeconfig not yet included