update from main archive 961217
[glibc.git] / Makeconfig
blobb61af28b0b95043b8b1d7aaa35d37c732ed0b52e
1 # Copyright (C) 1991, 92, 93, 94, 95, 96 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.
22 ifneq (,)
23 This makefile requires GNU Make.
24 endif
26 ifneq "$(origin +included-Makeconfig)" "file"
28 +included-Makeconfig := yes
30 ifdef subdir
31 .. := ../
32 endif
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))
37 ARCH =
38 machine =
39 else    # Not configured.
40 ifndef ARCH
41 ifdef machine
42 ARCH = $(machine)
43 endif # machine
44 endif # ARCH
45 endif # config.make
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
50 # more).
51 ifdef ARCH
52 ifeq ($(filter /%,$(ARCH)),)
53 objdir := $(..)$(ARCH)
54 else
55 objdir = $(ARCH)
56 endif
57 endif
59 # $(common-objdir) is the place to put objects and
60 # such that are not specific to a single subdir.
61 ifdef objdir
62 objpfx := $(patsubst %//,%/,$(objdir)/$(subdir)/)
63 common-objpfx = $(objdir)/
64 common-objdir = $(objdir)
65 else
66 objpfx :=
67 ifdef ..
68 common-objpfx = $(..)
69 common-objdir = ..
70 else
71 # This is a kludge.  make wizards might grok.
72 common-objpfx = sysdeps/../
73 common-objdir = .
74 endif
75 endif
77 # Root of the sysdeps tree.
78 sysdep_dir := $(..)sysdeps
79 export sysdep_dir := $(sysdep_dir)
81 # Get the values defined by options to `configure'.
82 include $(common-objpfx)config.make
84 # Complete path to sysdep dirs.
85 full-config-sysdirs := $(filter /%, $(config-sysdirs)) \
86                        $(addprefix $(..), $(filter-out /%, $(config-sysdirs)))
87 export full-config-sysdirs := $(full-config-sysdirs)
89 # Run config.status to update config.make and config.h.  We don't show the
90 # dependence of config.h to Make, because it is only touched when it
91 # changes and so config.status would be run every time; the dependence of
92 # config.make should suffice to force regeneration and re-exec, and the new
93 # image will notice if config.h changed.
94 $(common-objpfx)config.make: $(common-objpfx)config.status $(..)config.h.in
95         cd $(<D); $(SHELL) $(<F)
97 # Find all the sysdeps configure fragments, to make sure we re-run
98 # configure when any of them changes.
99 $(common-objpfx)config.status: $(..)configure \
100                                $(foreach dir,$(full-config-sysdirs),\
101                                          $(wildcard \
102                                            $(dir)/Implies) \
103                                          $(patsubst %.in,%,\
104                                                     $(firstword $(wildcard \
105  $(addprefix $(dir)/,configure configure.in)))))
106         @cd $(@D); if test -f $(@F); then exec $(SHELL) $(@F) --recheck; else \
107          echo The GNU C library has not been configured. >&2; \
108          echo Run \`configure\' to configure it before building. >&2; \
109          echo Try \`configure --help\' for more details. >&2; \
110          exit 1; fi
112 # Get the user's configuration parameters.
113 ifneq ($(wildcard $(..)configparms),)
114 include $(..)configparms
115 endif
116 ifneq ($(objpfx),)
117 ifneq ($(wildcard $(common-objpfx)configparms),)
118 include $(common-objpfx)configparms
119 endif
120 endif
122 ####
123 ####    These are the configuration variables.  You can define values for
124 ####    the variables below in the file `configparms'.
125 ####    Do NOT edit this file.
126 ####
129 # Set this to either `stdio' or `libio', to compile in either GNU stdio
130 # or GNU libio.
131 ifndef stdio
132 stdio = stdio
133 endif
135 # Common prefix for machine-independent installation directories.
136 ifeq ($(origin prefix),undefined) # ifndef would override explicit empty value.
137 prefix = /usr/local
138 endif
140 # Common prefix for machine-dependent installation directories.
141 ifeq ($(origin exec_prefix),undefined)
142 exec_prefix = $(prefix)
143 endif
145 # Where to install the library and object files.
146 ifndef libdir
147 libdir = $(exec_prefix)/lib
148 endif
150 # Where to install the shared library and dynamic linker.
151 ifndef slibdir
152 slibdir = $(exec_prefix)/lib
153 endif
155 # Prefix to put on files installed in $(libdir).  For libraries `libNAME.a',
156 # the prefix is spliced between `lib' and the name, so the linker switch
157 # `-l$(libprefix)NAME' finds the library; for other files the prefix is
158 # just prepended to the whole file name.
159 ifeq ($(origin libprefix),undefined)
160 libprefix =
161 endif
163 # Where to install the header files.
164 ifndef includedir
165 includedir = $(exec_prefix)/include
166 endif
168 # Where to install machine-independent data files.
169 # These are the timezone database, and the locale database.
170 ifndef datadir
171 datadir = $(prefix)/share
172 endif
174 # Where to install the timezone data files (which are machine-independent).
175 ifndef zonedir
176 zonedir = $(datadir)/zoneinfo
177 endif
179 # Where to install the locale and message catalog data files (which are
180 # machine-independent).
181 ifndef localedir
182 localedir = $(datadir)/locale
183 endif
185 # Where to install the locale charmap source files.
186 ifndef i18ndir
187 i18ndir = $(datadir)/i18n
188 endif
191 # Where to install programs.
192 ifndef bindir
193 bindir = $(exec_prefix)/bin
194 endif
196 # Where to install administrative programs.
197 ifndef sbindir
198 sbindir = $(exec_prefix)/sbin
199 endif
201 # Where to install the Info files.
202 ifndef infodir
203 infodir = $(prefix)/info
204 endif
206 # Where to install default configuration files.  These include the local
207 # timezone specification and network data base files.
208 ifndef sysconfdir
209 sysconfdir = $(prefix)/etc
210 endif
212 # What timezone should be the installed default (e.g., US/Eastern).
213 # Run `make -C time echo-zonenames' to see a list of available zone names.
214 # The local timezone can be changed with `zic -l TIMEZONE' at any time.
215 ifndef localtime
216 localtime = Factory
217 endif
219 # Where to install the "localtime" timezone file; this is the file whose
220 # contents $(localtime) specifies.  If this is a relative pathname, it is
221 # relative to $(zonedir).  It is a good idea to put this somewhere
222 # other than there, so the zoneinfo directory contains only universal data,
223 # localizing the configuration data elsewhere.
224 ifndef localtime-file
225 localtime-file = $(sysconfdir)/localtime
226 endif
228 # What to use for leap second specifications in compiling the default
229 # timezone files.  Set this to `/dev/null' for no leap second handling as
230 # 1003.1 requires, or to `leapseconds' for proper leap second handling.
231 # Both zone flavors are always available as `posix/ZONE' and `right/ZONE'.
232 # This variable determines the default: if it's `/dev/null',
233 # ZONE==posix/ZONE; if it's `leapseconds', ZONE==right/ZONE.
234 ifndef leapseconds
235 leapseconds = /dev/null
236 endif
238 # What timezone's DST rules should be used when a POSIX-style TZ
239 # environment variable doesn't specify any rules.  For 1003.1 compliance
240 # this timezone must use rules that are as U.S. federal law defines DST.
241 # Run `make -C time echo-zonenames' to see a list of available zone names.
242 # This setting can be changed with `zic -p TIMEZONE' at any time.
243 # If you want POSIX.1 compatibility, use `America/New_York'.
244 ifndef posixrules
245 posixrules = America/New_York
246 endif
248 # Where to install the "posixrules" timezone file; this is file
249 # whose contents $(posixrules) specifies.  If this is a relative
250 # pathname, it is relative to $(zonedir).
251 ifndef posixrules-file
252 posixrules-file = posixrules
253 endif
256 # Directory where your system's native header files live.
257 # This is used on Unix systems to generate some GNU libc header files.
258 ifndef sysincludedir
259 sysincludedir = /usr/include
260 endif
263 # Commands to install files.
264 ifndef INSTALL_DATA
265 INSTALL_DATA = $(INSTALL) -m 644
266 endif
267 ifndef INSTALL_PROGRAM
268 INSTALL_PROGRAM = $(INSTALL)
269 endif
270 ifndef INSTALL
271 INSTALL = install
272 endif
275 # The name of the C compiler.
276 # If you've got GCC, and it works, use it.
277 ifeq ($(origin CC),default)
278 CC := gcc
279 endif
281 # The name of the C compiler to use for compilations of programs to run on
282 # the host that is building the library.  If you set CC to a
283 # cross-compiler, you must set this to the normal compiler.
284 ifndef BUILD_CC
285 BUILD_CC = $(CC)
286 endif
288 # Default flags to pass the C compiler.
289 ifndef default_cflags
290 default_cflags := -g -O
291 endif
293 # Flags to pass the C compiler when assembling preprocessed assembly code
294 # (`.S' files).  On some systems the assembler doesn't understand the `#' line
295 # directives the preprocessor produces.  If you have troubling compiling
296 # assembly code, try using -P here to suppress these directives.
297 ifndef asm-CPPFLAGS
298 asm-CPPFLAGS =
299 endif
301 # Command for linking programs with the C library.
302 ifndef +link
303 +link = $(CC) -nostdlib -nostartfiles -o $@ \
304               $(sysdep-LDFLAGS) $(config-LDFLAGS) $(LDFLAGS)  \
305               $(addprefix $(csu-objpfx),start.o) $(+preinit) \
306               $(filter-out $(addprefix $(csu-objpfx),start.o) $(+preinit) \
307                 $(link-extra-libs) $(common-objpfx)libc% $(+postinit),$^) \
308               $(link-extra-libs) $(link-libc) $(+postinit)
309 endif
310 ifndef config-LDFLAGS
311 ifeq (yes,$(build-shared))
312 config-LDFLAGS = -Wl,-dynamic-linker=$(slibdir)/$(rtld-installed-name)
313 endif
314 endif
315 ifndef link-libc
316 ifeq (yes,$(build-shared))
317 # We need the versioned name of libc.so in the deps of $(others) et al
318 # so that the symlink to libc.so is created before anything tries to
319 # run the linked programs.
320 link-libc = -Wl,-rpath-link=$(rpath-link) \
321             $(common-objpfx)libc.so$(libc.so-version) \
322             $(elfobjdir)/$(rtld-installed-name) \
323             $(common-objpfx)libc.a $(gnulib)
324 # Choose the default search path for the dynamic linker based on
325 # where we will install libraries.
326 ifneq ($(libdir),$(slibdir))
327 default-rpath = $(slibdir):$(libdir)
328 else
329 default-rpath = $(libdir)
330 endif
331 # This is how to find at build-time things that will be installed there.
332 rpath-link = $(common-objdir):$(elfobjdir):$(nssobjdir)
333 elfobjdir := $(patsubst ../$(subdir),.,$(common-objpfx)elf)
334 nssobjdir := $(patsubst ../$(subdir),.,$(common-objpfx)nss)
335 else
336 link-libc = $(common-objpfx)libc.a $(gnulib) $(common-objpfx)libc.a
337 endif
338 endif
339 ifndef link-extra-libs
340 ifeq (yes,$(build-shared))
341 link-extra-libs = $(foreach lib,$(LDLIBS-$(@F)),$(common-objpfx)$(lib).so$($(notdir $(lib)).so-version))
342 else
343 link-extra-libs = $(foreach lib,$(LDLIBS-$(@F)),$(common-objpfx)$(lib).a)
344 endif
345 endif
346 ifndef gnulib
347 gnulib := -lgcc
348 endif
349 ifeq ($(elf),yes)
350 +preinit = $(addprefix $(csu-objpfx),crti.o)
351 +postinit = $(addprefix $(csu-objpfx),crtn.o)
352 endif
353 csu-objpfx = $(common-objpfx)csu/
354 elf-objpfx = $(common-objpfx)elf/
355 db-objpfx = $(common-objpfx)db/
357 # How to run a program we just linked with our library.
358 # The program binary is assumed to be $(word 2,$^).
359 built-program-file = $(dir $(word 2,$^))$(notdir $(word 2,$^))
360 ifneq (yes,$(build-shared))
361 built-program-cmd = $(built-program-file)
362 else
363 comma = ,
364 sysdep-library-path = \
365 $(subst $(empty) ,:,$(strip $(patsubst -Wl$(comma)-rpath-link=%, %,\
366                                        $(filter -Wl$(comma)-rpath-link=%,\
367                                                 $(sysdep-LDFLAGS)))))
368 define built-program-cmd
369 LD_LIBRARY_PATH=$(rpath-link)$(patsubst %,:%,$(sysdep-library-path)) \
370 $(elf-objpfx)$(rtld-installed-name) $(built-program-file)
371 endef
372 endif
374 ifndef LD
375 LD := ld -X
376 endif
378 ifndef  RANLIB
379 RANLIB = ranlib
380 endif
382 # Extra flags to pass to GCC.
383 +gccwarn := -Wall -Wwrite-strings -Wno-parentheses -Winline -Wstrict-prototypes
385 # This is the program that generates makefile
386 # dependencies from C source files.
387 ifndef +mkdep
388 +mkdep = $(CC) -M
389 endif
391 # The program that makes Emacs-style TAGS files.
392 ETAGS   := etags -T
394 # The `m4' macro processor; this is used by sysdeps/sparc/Makefile (and
395 # perhaps others) to preprocess assembly code in some cases.
396 M4 = m4
398 ####
399 #### End of configuration variables.
400 ####
402 # This tells some versions of GNU make before 3.63 not to export all variables.
403 .NOEXPORT:
405 # We want to echo the commands we're running without
406 # umpteem zillion filenames along with it (we use `...' instead)
407 # but we don't want this echoing done when the user has said
408 # he doesn't want to see commands echoed by using -s.
409 ifneq   "$(findstring s,$(MAKEFLAGS))" ""       # if -s
410 +cmdecho        := echo >/dev/null
411 else                                            # not -s
412 +cmdecho        := echo
413 endif                                           # -s
415 # These are the flags given to the compiler to tell
416 # it what sort of optimization and/or debugging output to do.
417 ifndef  +cflags
418 # If `CFLAGS' was defined, use that.
419 ifdef           CFLAGS
420 +cflags := $(filter-out -I%,$(CFLAGS))
421 endif           # CFLAGS
422 endif   # +cflags
424 # If none of the above worked, default to "-g".
425 ifeq    "$(strip $(+cflags))" ""
426 +cflags := $(default_cflags)
427 endif   # $(+cflags) == ""
429 +cflags := $(+cflags) $(+gccwarn)
430 +gcc-nowarn := -w
432 # Don't duplicate options if we inherited variables from the parent.
433 +cflags := $(sort $(+cflags))
436 # These are flags given to the C compiler to tell it to look for include
437 # files (including ones given in angle brackets) in the current directory
438 # and in the parent library source directory.
439 # `+sysdep-includes' will be defined by Makerules.
440 +includes = -I. $(filter-out -I,-I$(patsubst %/,%,$(..))) $($(stdio)-include) \
441             $(includes) $(+sysdep-includes) $(last-includes)
443 # Since libio has several internal header files, we use a -I instead
444 # of many little headers in the top level source directory.
445 libio-include = -I$(..)libio
447 # These are the variables that the implicit compilation rules use.
448 CPPFLAGS = $(+includes) $(defines) -include $(..)libc-symbols.h \
449            $(sysdep-CPPFLAGS) $(CPPFLAGS-$(suffix $@)) $(CPPFLAGS-$(<F)) \
450            $(CPPFLAGS-$(@F))
451 override CFLAGS = $(+cflags) $(sysdep-CFLAGS) $(CFLAGS-$(suffix $@)) \
452                   $(CFLAGS-$(<F)) $(CFLAGS-$(@F))
455 # This is the macro that the implicit linking rules use.
456 ifneq "$(filter -g,$(+cflags))" "" # -g is in $(+cflags)
457 LDFLAGS := -g
458 endif
461 # Enable object files for different versions of the library.
462 # Various things use $(object-suffixes) to know what all to make.
463 # The compilation rules use $(CPPFLAGS-${SUFFIX}) and $(CFLAGS-${SUFFIX})
464 # to pass different flags for each flavor.
465 libtypes = $(foreach o,$(object-suffixes),$(libtype$o))
466 object-suffixes := .o
467 libtype.o := lib%.a
468 ifeq (yes,$(build-shared))
469 # Under --enable-shared, we will build a shared library of PIC objects.
470 # The PIC object files are named foo.so.
471 object-suffixes += .so
472 CPPFLAGS-.so = -DPIC
473 CFLAGS-.so = -fPIC
474 libtype.so := lib%_pic.a
475 endif
476 ifeq (yes,$(build-profile))
477 # Under --enable-profile, we will build a static library of profiled objects.
478 # The profiled object files are named foo.po.
479 object-suffixes += .po
480 CPPFLAGS-.po = -DPROF
481 CFLAGS-.po = -pg
482 libtype.po = lib%_p.a
483 endif
484 ifeq (yes,$(build-omitfp))
485 # Under --enable-omitfp, we build an the library optimized without
486 # debugging information using -fomit-frame-pointer, and build an extra
487 # library with debugging information.  The debuggable objects are named foo.go.
488 object-suffixes += .go
489 CFLAGS-.go = -g
490 CFLAGS-.o = -g0 -O99 -fomit-frame-pointer
491 CFLAGS-.so += $(CFLAGS-.o)
492 libtype.go = lib%_g.a
493 endif
496 +gnu-stabs = $(shell echo>&2 '*** BARF ON ME')
498 ifndef BUILD_CC
499 BUILD_CC = $(CC)
500 endif
502 ifneq ($(BUILD_CC),$(CC))
503 cross-compiling := yes
504 else
505 cross-compiling := no
506 endif
508 # Figure out the version numbers from version.h.
510 $(common-objpfx)version.mk: $(..)version.h $(..)Makeconfig
511         sed -n -e 's/^.*RELEASE.*"\([^"]*\)".*$$/release=\1/p' \
512                -e 's/^.*VERSION.*"\([^"]*\)".*$$/version=\1/p' \
513             < $< > $@-new
514         mv -f $@-new $@
516 ifeq (yes, $(build-shared))
518 # Process the shlib-versions file, which tells us what shared library
519 # version numbers to use when we install shared objects on this system.
520 -include $(common-objpfx)soversions.mk
521 $(common-objpfx)soversions.mk: $(..)shlib-versions $(..)Makeconfig \
522                                $(wildcard $(patsubst %, $(..)%/shlib-versions,\
523                                                         $(add-ons))) \
524                                $(common-objpfx)config.make
525         (file="$(wildcard $(patsubst %,$(..)%/shlib-versions,$(add-ons))) \
526                $(..)shlib-versions"; \
527          for f in $$file; do \
528            sed 's/#.*$$//' $$f | while read conf versions; do \
529              test -n "$$versions" && \
530              test `expr '$(config-machine)-$(config-vendor)-$(config-os)' \
531                         : "$$conf"` != 0 || continue; \
532              for v in $$versions; do \
533                lib=`echo $$v | sed 's/=.*$$//'`; \
534                if eval "test -z \"\$$vers_lib$$lib\""; then \
535                  eval vers_lib$${lib}=yes; \
536                  number=`echo $$v | sed "s/^.*=//"`; \
537                  case $$number in \
538                    [0-9]*) echo "$$lib.so-version=.$$number"; \
539                            echo "all-sonames+=$$lib.so\$$($$lib.so-version)";;\
540                    *) echo "$$lib.so-version=$$number"; \
541                       echo "all-sonames+=\$$($$lib.so-version)";;  \
542                  esac; \
543                fi; \
544              done; \
545            done; \
546          done;) > $@T; exit 0
547         mv -f $@T $@
549 # Get $(version) defined with the release version number.
550 -include $(common-objpfx)version.mk
553 # The name under which the run-time dynamic linker is installed.
554 # We are currently going for the convention that `/lib/ld.so.1'
555 # names the SVR4/ELF ABI-compliant dynamic linker.
556 ifndef rtld-installed-name
557 ifdef ld.so-version
558 rtld-installed-name = $(ld.so-version)
559 else
560 rtld-installed-name = ld.so.1
561 endif
562 endif
564 endif # build-shared
566 endif # Makeconfig not yet included