X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=Makefile;h=17e796fe1bb1c6590235c20b99476d5e8098c161;hb=0ddd15f52f742f48174597f82bee98ad9767d84a;hp=70c94225e763e19755ba5b657302fe7383d4f8cd;hpb=53da80ab8870138b81b212c540c32b5c1eeccaf4;p=platform%2Fupstream%2Fglibc.git diff --git a/Makefile b/Makefile index 70c9422..17e796f 100644 --- a/Makefile +++ b/Makefile @@ -1,4 +1,4 @@ -# Copyright (C) 1991-1999, 2000, 2001, 2002 Free Software Foundation, Inc. +# Copyright (C) 1991-2015 Free Software Foundation, Inc. # This file is part of the GNU C Library. # The GNU C Library is free software; you can redistribute it and/or @@ -12,9 +12,8 @@ # Lesser General Public License for more details. # You should have received a copy of the GNU Lesser General Public -# License along with the GNU C Library; if not, write to the Free -# Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA -# 02111-1307 USA. +# License along with the GNU C Library; if not, see +# . # # Master Makefile for the GNU C library @@ -32,24 +31,16 @@ all: lib others ifneq ($(AUTOCONF),no) -ifeq ($(with-cvs),yes) -define autoconf-it-cvs -test ! -d CVS || cvs $(CVSOPTS) commit -m'Regenerated: autoconf $(ACFLAGS) $<' $@ -endef -else -autoconf-it-cvs = -endif - define autoconf-it @-rm -f $@.new $(AUTOCONF) $(ACFLAGS) $< > $@.new -chmod a-w,a+x $@.new +chmod a-w$(patsubst %,$(comma)a+x,$(filter .,$(@D))) $@.new mv -f $@.new $@ -$(autoconf-it-cvs) endef -configure: configure.in aclocal.m4; $(autoconf-it) -%/configure: %/configure.in aclocal.m4; $(autoconf-it) +configure: configure.ac aclocal.m4; $(autoconf-it) +%/configure: %/configure.ac aclocal.m4; $(autoconf-it) +%/preconfigure: %/preconfigure.ac aclocal.m4; $(autoconf-it) endif # $(AUTOCONF) = no @@ -60,15 +51,15 @@ endif # $(AUTOCONF) = no # These are the targets that are made by making them in each subdirectory. +subdir_targets := subdir_lib objects objs others subdir_mostlyclean \ subdir_clean subdir_distclean subdir_realclean \ - tests xtests subdir_lint.out \ - subdir_distinfo \ - subdir_echo-headers subdir_echo-distinfo \ + tests xtests \ + subdir_update-abi subdir_check-abi \ + subdir_echo-headers \ subdir_install \ - subdir_testclean \ + subdir_objs subdir_stubs subdir_testclean \ $(addprefix install-, no-libc.a bin lib data headers others) headers := limits.h values.h features.h gnu-versions.h bits/libc-lock.h \ - bits/xopen_lim.h gnu/libc-version.h + bits/xopen_lim.h gnu/libc-version.h stdc-predef.h echo-headers: subdir_echo-headers @@ -78,7 +69,7 @@ vpath %.h $(subdir-dirs) # What to install. install-others = $(inst_includedir)/gnu/stubs.h -install-bin-script = glibcbug +install-bin-script = ifeq (yes,$(build-shared)) headers += gnu/lib-names.h @@ -114,13 +105,13 @@ install-symbolic-link: subdir_install rm -f $(symbolic-link-list) install: - -test ! -x $(common-objpfx)elf/ldconfig || LC_ALL=C LANGUAGE=C \ - $(common-objpfx)elf/ldconfig $(addprefix -r ,$(install_root)) \ - $(slibdir) $(libdir) + -test ! -x $(elf-objpfx)ldconfig || LC_ALL=C \ + $(elf-objpfx)ldconfig $(addprefix -r ,$(install_root)) \ + $(slibdir) $(libdir) ifneq (no,$(PERL)) ifeq (/usr,$(prefix)) ifeq (,$(install_root)) - CC="$(CC)" $(PERL) scripts/test-installation.pl $(common-objpfx) + LD_SO=$(ld.so-version) CC="$(CC)" $(PERL) scripts/test-installation.pl $(common-objpfx) endif endif endif @@ -132,8 +123,8 @@ lib-noranlib: subdir_lib ifeq (yes,$(build-shared)) # Build the shared object from the PIC object library. -lib: $(common-objpfx)libc.so -endif +lib: $(common-objpfx)libc.so $(common-objpfx)linkobj/libc.so +endif # $(build-shared) # This is a handy script for running any dynamically linked program against @@ -141,8 +132,10 @@ endif $(common-objpfx)testrun.sh: $(common-objpfx)config.make \ $(..)Makeconfig $(..)Makefile (echo '#!/bin/sh'; \ - echo "GCONV_PATH='$(common-objpfx)iconvdata' \\"; \ - echo 'exec $(run-program-prefix) $${1+"$$@"}'; \ + echo 'builddir=`dirname "$$0"`'; \ + echo 'GCONV_PATH="$${builddir}/iconvdata" \'; \ + echo 'exec $(subst $(common-objdir),"$${builddir}",\ + $(test-program-prefix)) $${1+"$$@"}'; \ ) > $@T chmod a+x $@T mv -f $@T $@ @@ -157,13 +150,41 @@ others: $(common-objpfx)testrun.sh subdir-stubs := $(foreach dir,$(subdirs),$(common-objpfx)$(dir)/stubs) +ifndef abi-variants +installed-stubs = $(inst_includedir)/gnu/stubs.h +else +installed-stubs = $(inst_includedir)/gnu/stubs-$(default-abi).h + +$(inst_includedir)/gnu/stubs.h: $(+force) + $(make-target-directory) + { \ + echo '/* This file is automatically generated.';\ + echo " This file selects the right generated file of \`__stub_FUNCTION' macros";\ + echo ' based on the architecture being compiled for. */'; \ + echo ''; \ + $(foreach h,$(abi-includes), echo '#include <$(h)>';) \ + echo ''; \ + $(foreach v,$(abi-variants),\ + $(if $(abi-$(v)-condition),\ + echo '#if $(abi-$(v)-condition)'; \ + echo '# include '); \ + $(if $(abi-$(v)-condition),echo '#endif';) \ + rm -f $(@:.d=.h).new$(v); \ + ) \ + } > $(@:.d=.h).new + mv -f $(@:.d=.h).new $(@:.d=.h) + +install-others-nosubdir: $(installed-stubs) +endif + + # Since stubs.h is never needed when building the library, we simplify the # hairy installation process by producing it in place only as the last part # of the top-level `make install'. It depends on subdir_install, which # iterates over all the subdirs; subdir_install in each subdir depends on # the subdir's stubs file. Having more direct dependencies would result in # extra iterations over the list for subdirs and many recursive makes. -$(inst_includedir)/gnu/stubs.h: include/stubs-prologue.h subdir_install +$(installed-stubs): include/stubs-prologue.h subdir_install $(make-target-directory) @rm -f $(objpfx)stubs.h (sed '/^@/d' $<; LC_ALL=C sort $(subdir-stubs)) > $(objpfx)stubs.h @@ -172,11 +193,6 @@ $(inst_includedir)/gnu/stubs.h: include/stubs-prologue.h subdir_install else $(INSTALL_DATA) $(objpfx)stubs.h $@; fi rm -f $(objpfx)stubs.h -# The `glibcbug' script contains the version number and it shall be rebuild -# whenever this changes or the `glibcbug.in' file. -$(objpfx)glibcbug: $(common-objpfx)config.status glibcbug.in - cd $( $@; \ + $(evaluate-test) +endif + +$(objpfx)check-local-headers.out: scripts/check-local-headers.sh + AWK='$(AWK)' scripts/check-local-headers.sh \ + "$(includedir)" "$(objpfx)" > $@; \ + $(evaluate-test) + +ifneq ($(PERL),no) +installed-headers = argp/argp.h assert/assert.h catgets/nl_types.h \ + crypt/crypt.h ctype/ctype.h debug/execinfo.h \ + dirent/dirent.h dlfcn/dlfcn.h elf/elf.h elf/link.h \ + gmon/sys/gmon.h gmon/sys/gmon_out.h gmon/sys/profil.h \ + grp/grp.h gshadow/gshadow.h iconv/iconv.h iconv/gconv.h \ + $(wildcard inet/netinet/*.h) \ + $(wildcard inet/arpa/*.h inet/protocols/*.h) \ + inet/aliases.h inet/ifaddrs.h inet/netinet/ip6.h \ + inet/netinet/icmp6.h intl/libintl.h io/sys/stat.h \ + io/sys/statfs.h io/sys/vfs.h io/sys/statvfs.h \ + io/fcntl.h io/sys/fcntl.h io/poll.h io/sys/poll.h \ + io/utime.h io/ftw.h io/fts.h io/sys/sendfile.h \ + libio/stdio.h libio/libio.h locale/locale.h \ + locale/langinfo.h locale/xlocale.h login/utmp.h \ + login/lastlog.h login/pty.h malloc/malloc.h \ + malloc/obstack.h malloc/mcheck.h math/math.h \ + math/complex.h math/fenv.h math/tgmath.h misc/sys/uio.h \ + $(wildcard nis/rpcsvc/*.h) nptl_db/thread_db.h \ + sysdeps/nptl/pthread.h sysdeps/pthread/semaphore.h \ + nss/nss.h posix/sys/utsname.h posix/sys/times.h \ + posix/sys/wait.h posix/sys/types.h posix/unistd.h \ + posix/glob.h posix/regex.h posix/wordexp.h posix/fnmatch.h\ + posix/getopt.h posix/tar.h posix/sys/unistd.h \ + posix/sched.h posix/re_comp.h posix/wait.h \ + posix/cpio.h posix/spawn.h pwd/pwd.h resolv/resolv.h \ + resolv/netdb.h $(wildcard resolv/arpa/*.h) \ + resource/sys/resource.h resource/sys/vlimit.h \ + resource/sys/vtimes.h resource/ulimit.h rt/aio.h \ + rt/mqueue.h setjmp/setjmp.h shadow/shadow.h \ + signal/signal.h signal/sys/signal.h socket/sys/socket.h \ + socket/sys/un.h stdio-common/printf.h \ + stdio-common/stdio_ext.h stdlib/stdlib.h stdlib/alloca.h \ + stdlib/monetary.h stdlib/fmtmsg.h stdlib/ucontext.h \ + sysdeps/generic/inttypes.h sysdeps/generic/stdint.h \ + stdlib/errno.h stdlib/sys/errno.h string/string.h \ + string/strings.h string/memory.h string/endian.h \ + string/argz.h string/envz.h string/byteswap.h \ + $(wildcard sunrpc/rpc/*.h sunrpc/rpcsvc/*.h) \ + sysvipc/sys/ipc.h sysvipc/sys/msg.h sysvipc/sys/sem.h \ + sysvipc/sys/shm.h termios/termios.h \ + termios/sys/termios.h termios/sys/ttychars.h time/time.h \ + time/sys/time.h time/sys/timeb.h wcsmbs/wchar.h \ + wctype/wctype.h + +tests-special += $(objpfx)begin-end-check.out +$(objpfx)begin-end-check.out: scripts/begin-end-check.pl + $(PERL) scripts/begin-end-check.pl $(installed-headers) > $@; \ + $(evaluate-test) +endif + +tests-special-notdir = $(patsubst $(objpfx)%, %, $(tests-special)) +tests: $(tests-special) + $(..)scripts/merge-test-results.sh -s $(objpfx) "" \ + $(sort $(tests-special-notdir:.out=)) \ + > $(objpfx)subdir-tests.sum + $(..)scripts/merge-test-results.sh -t $(objpfx) subdir-tests.sum \ + $(sort $(subdirs) .) \ + > $(objpfx)tests.sum + @grep '^ERROR:' $(objpfx)tests.sum || true + @grep '^FAIL:' $(objpfx)tests.sum || true + @echo "Summary of test results:" + @sed 's/:.*//' < $(objpfx)tests.sum | sort | uniq -c + @if grep -q '^ERROR:' $(objpfx)tests.sum; then exit 1; fi + @if grep -q '^FAIL:' $(objpfx)tests.sum; then exit 1; fi +xtests: + $(..)scripts/merge-test-results.sh -t $(objpfx) subdir-xtests.sum \ + $(sort $(subdirs)) \ + > $(objpfx)xtests.sum + @grep '^ERROR:' $(objpfx)xtests.sum || true + @grep '^FAIL:' $(objpfx)xtests.sum || true + @echo "Summary of test results for extra tests:" + @sed 's/:.*//' < $(objpfx)xtests.sum | sort | uniq -c + @if grep -q '^ERROR:' $(objpfx)xtests.sum; then exit 1; fi + @if grep -q '^FAIL:' $(objpfx)xtests.sum; then exit 1; fi + # The realclean target is just like distclean for the parent, but we want # the subdirs to know the difference in case they care. realclean distclean: parent-clean @@ -244,81 +357,69 @@ distclean-1: subdir_$(distclean-1) -rm -f $(config-generated) -rm -f $(addprefix $(objpfx),config.status config.cache config.log) -rm -f $(addprefix $(objpfx),config.make config-name.h config.h) - -rm -f $(addprefix $(objpfx),glibcbug) ifdef objdir -rm -f $(objpfx)Makefile endif -rm -f $(sysdep-$(distclean-1)) -.PHONY: echo_subdirs -echo_subdirs:;@echo '$(subdirs)' - -.PHONY: echo-distinfo parent_echo-distinfo -echo-distinfo: parent_echo-distinfo subdir_echo-distinfo -parent_echo-distinfo: - @echo $(addprefix +header+,$(headers)) \ - $(addprefix +nodist+,$(generated)) - +# Make the TAGS file for Emacs users. + +.PHONY: TAGS +TAGS: + scripts/list-sources.sh | sed -n -e '/Makefile/p' \ + $(foreach S,[chsSyl] cxx sh bash pl,\ + $(subst .,\.,-e '/.$S\(.in\)*$$/p')) \ + | $(ETAGS) -o $@ - # Make the distribution tarfile. +.PHONY: dist dist-prepare -distribute := README README.libm INSTALL FAQ FAQ.in NOTES NEWS BUGS \ - PROJECTS COPYING.LIB COPYING ChangeLog ChangeLog.[0-9] \ - ChangeLog.1[0-9] Makefile Makeconfig Makerules Rules \ - Make-dist MakeTAGS extra-lib.mk o-iterator.mk configure \ - configure.in aclocal.m4 config.h.in config.make.in \ - config-name.in Makefile.in sysdep.h set-hooks.h \ - libc-symbols.h version.h shlib-versions rpm/Makefile \ - rpm/template rpm/rpmrc glibcbug.in abi-tags stub-tag.h \ - test-skeleton.c include/des.h include/libc-internal.h \ - include/shlib-compat.h include/pthread.h Versions.def \ - cppflags-iterator.mk tls.make.c \ - INTERFACE CONFORMANCE NAMESPACE LICENSES \ - $(addprefix scripts/, \ - rellns-sh config.sub config.guess \ - mkinstalldirs move-if-change install-sh \ - test-installation.pl gen-FAQ.pl versions.awk\ - gen-sorted.awk abi-versions.awk abilist.awk \ - firstversions.awk documented.sh cpp) - -distribute := $(strip $(distribute)) generated := $(generated) stubs.h -README: README.template version.h - -rm -f $@ - sed -e 's/RELEASE/$(release)/' -e 's/VERSION/$(version)/' < $< > $@ -# Make it unwritable so I won't change it by mistake. - chmod 444 $@ -ifeq ($(with-cvs),yes) - test ! -d CVS || cvs $(CVSOPTS) commit -m'Remade for $(release)-$(version)' $@ -endif +files-for-dist := README INSTALL configure ChangeLog NEWS -define format-me -@rm -f $@ -makeinfo --no-validate --no-warn --no-headers $< -o $@ --chmod a-w $@ -endef -INSTALL: manual/install.texi; $(format-me) -NOTES: manual/creature.texi; $(format-me) -manual/dir-add.texi manual/dir-add.info: FORCE - $(MAKE) $(PARALLELMFLAGS) -C $(@D) $(@F) -FAQ: scripts/gen-FAQ.pl FAQ.in - $(PERL) $^ > $@.new && rm -f $@ && mv $@.new $@ && chmod a-w $@ -ifeq ($(with-cvs),yes) - test ! -d CVS || cvs $(CVSOPTS) commit -m'Regenerated: $(PERL) $^' $@ -endif -FORCE: +# Regenerate stuff, then error if these things are not committed yet. +dist-prepare: $(files-for-dist) + conf=`find sysdeps $(addsuffix /sysdeps,$(sysdeps-add-ons)) \ + -name configure`; \ + $(MAKE) $$conf && \ + git diff --stat HEAD -- $^ $$conf \ + | $(AWK) '{ print; rc=1 } END { exit rc }' -rpm/%: subdir_distinfo - $(MAKE) $(PARALLELMFLAGS) -C $(@D) $(@F) +%.tar: FORCE + git archive --prefix=$*/ $* > $@.new + mv -f $@.new $@ -iconvdata/% localedata/% po/% manual/%: - $(MAKE) $(PARALLELMFLAGS) -C $(@D) $(@F) +# Do `make dist dist-version=X.Y.Z' to make tar files of an older version. + +ifneq (,$(strip $(dist-version))) +dist: $(foreach Z,.bz2 .gz .xz,$(dist-version).tar$Z) + md5sum $^ +else +dist: dist-prepare + @if v=`git describe`; then \ + echo Distribution version $$v; \ + $(MAKE) dist dist-version=$$v; \ + else \ + false; \ + fi +endif + +INSTALL: manual/install-plain.texi manual/macros.texi \ + $(common-objpfx)manual/pkgvers.texi manual/install.texi + makeinfo --no-validate --plaintext --no-number-sections \ + -I$(common-objpfx)manual $< -o $@-tmp + $(AWK) 'NF == 0 { ++n; next } \ + NF != 0 { while (n-- > 0) print ""; n = 0; print }' \ + < $@-tmp > $@-tmp2 + rm -f $@-tmp + -chmod a-w $@-tmp2 + mv -f $@-tmp2 $@ +$(common-objpfx)manual/%: FORCE + $(MAKE) $(PARALLELMFLAGS) -C manual $@ +FORCE: -# This is a special goal for people making binary distributions. Normally -# everybody uses the DES based crypt library but for the distribution we -# need the only-MD5 based one as well. -md5-crypt/libmd5crypt: +iconvdata/% localedata/% po/%: FORCE $(MAKE) $(PARALLELMFLAGS) -C $(@D) $(@F) # glibc 2.0 contains some header files which aren't used with glibc 2.1 @@ -330,18 +431,18 @@ install: remove-old-headers endif endif -headers2_0 := __math.h bytesex.h confname.h direntry.h elfclass.h \ - errnos.h fcntlbits.h huge_val.h ioctl-types.h \ - ioctls.h iovec.h jmp_buf.h libc-lock.h local_lim.h \ - mathcalls.h mpool.h nan.h ndbm.h posix1_lim.h \ - posix2_lim.h posix_opt.h resourcebits.h schedbits.h \ - selectbits.h semaphorebits.h sigaction.h sigcontext.h \ - signum.h sigset.h sockaddrcom.h socketbits.h stab.def \ - statbuf.h statfsbuf.h stdio-lock.h stdio_lim.h \ - syscall-list.h termbits.h timebits.h ustatbits.h \ - utmpbits.h utsnamelen.h waitflags.h waitstatus.h \ - xopen_lim.h gnu/types.h sys/ipc_buf.h \ - sys/kernel_termios.h sys/msq_buf.h sys/sem_buf.h \ +headers2_0 := __math.h bytesex.h confname.h direntry.h elfclass.h \ + errnos.h fcntlbits.h huge_val.h ioctl-types.h \ + ioctls.h iovec.h jmp_buf.h libc-lock.h local_lim.h \ + mathcalls.h mpool.h nan.h ndbm.h posix1_lim.h \ + posix2_lim.h posix_opt.h resourcebits.h schedbits.h \ + selectbits.h semaphorebits.h sigaction.h sigcontext.h \ + signum.h sigset.h sockaddrcom.h socketbits.h stab.def \ + statbuf.h statfsbuf.h stdio-lock.h stdio_lim.h \ + syscall-list.h termbits.h timebits.h ustatbits.h \ + utmpbits.h utsnamelen.h waitflags.h waitstatus.h \ + xopen_lim.h gnu/types.h sys/ipc_buf.h \ + sys/kernel_termios.h sys/msq_buf.h sys/sem_buf.h \ sys/shm_buf.h sys/socketcall.h sigstack.h .PHONY: remove-old-headers