X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=Makefile.in;h=a106172206892f21817755ba6a84f1e38ed51efa;hb=0ee3427297272a636e7ef8378182a38d64ed7b7d;hp=c9eb80ebb0f6e328478e5a159c026e91df0b372e;hpb=79337c85b8e706bd247a99d26a237f6dddf4ffe5;p=deliverable%2Fbinutils-gdb.git diff --git a/Makefile.in b/Makefile.in index c9eb80ebb0..a106172206 100644 --- a/Makefile.in +++ b/Makefile.in @@ -24,7 +24,7 @@ prefix = /usr/local exec_prefix = $(prefix) bindir = $(exec_prefix)/bin libdir = $(exec_prefix)/lib -tooldir = $(libdir) +tooldir = $(exec_prefix)/$(target) program_transform_name = @@ -45,39 +45,65 @@ docdir = $(datadir)/doc SHELL = /bin/sh -INSTALL = cp +INSTALL = $${srcroot}/install.sh -c INSTALL_PROGRAM = $(INSTALL) -INSTALL_DATA = $(INSTALL) +INSTALL_DATA = $(INSTALL) -m 644 +INSTALL_XFORM = $(INSTALL) -t='$(program_transform_name)' AS = as AR = ar AR_FLAGS = rc CC = cc + +# We don't specify -g -O because many compilers don't support -g -O, +# and/or -O is broken in and of itself. CFLAGS = -g + # start-sanitize-chill CHILLFLAGS = $(CFLAGS) CHILL_LIB = -lchill # end-sanitize-chill CXX = gcc + +# Use -O to stress test the compiler. CXXFLAGS = -g -O + RANLIB = ranlib NM = nm -GZIP = gzip +# Not plain GZIP, since gzip looks there for extra command-line options. +GZIPPROG = gzip # BISON: This line sed'ed to BISON = bison -y for FSF releases, don't remove. -BISON = `if [ -f $${rootme}/byacc/byacc ] ; \ - then echo $${rootme}/byacc/byacc ; \ +BISON = `if [ -f $$r/byacc/byacc ] ; \ + then echo $$r/byacc/byacc ; \ else echo byacc ; \ fi` -LEX = `if [ -f $${rootme}/flex/flex ] ; \ - then echo $${rootme}/flex/flex ; \ +LEX = `if [ -f $$r/flex/flex ] ; \ + then echo $$r/flex/flex ; \ else echo flex ; fi` -MAKEINFO = `if [ -f $${rootme}/texinfo/makeinfo/makeinfo ] ; \ - then echo $${rootme}/texinfo/makeinfo/makeinfo ; \ +M4 = `if [ -f $$r/m4/m4 ] ; \ + then echo $$r/m4/m4 ; \ + else echo m4 ; fi` + +MAKEINFO = `if [ -f $$r/texinfo/makeinfo/makeinfo ] ; \ + then echo $$r/texinfo/makeinfo/makeinfo ; \ else echo makeinfo ; fi` +# This just becomes part of the MAKEINFO definition passed down to +# sub-makes. It lets flags be given on the command line while still +# using the makeinfo from the object tree. +MAKEINFOFLAGS = + +EXPECT = `if [ -f $$r/expect/expect ] ; \ + then echo $$r/expect/expect ; \ + else echo expect ; fi` + +RUNTEST = `if [ -f $${srcroot}/dejagnu/runtest ] ; \ + then echo $${srcroot}/dejagnu/runtest ; \ + else echo runtest ; fi` + # libraries that may need to be augmented on a system-by-system basis X11_LIB = -lX11 @@ -91,11 +117,15 @@ SUBDIRS = "this is set via configure, don't edit this" OTHERS = ALL = all.normal -INSTALL_TARGET = install.all +INSTALL_TARGET = install-dirs \ + $(INSTALL_MODULES) \ + $(INSTALL_TARGET_MODULES) \ + $(INSTALL_X11_MODULES) \ + install-gcc CC_FOR_TARGET = ` \ - if [ -f $${rootme}/gcc/Makefile ] ; then \ - echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/; \ + if [ -f $$r/gcc/Makefile ] ; then \ + echo $$r/gcc/xgcc -B$$r/gcc/; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(CC); \ @@ -106,8 +136,8 @@ CC_FOR_TARGET = ` \ # start-sanitize-chill CHILL_FOR_TARGET = ` \ - if [ -f $${rootme}/gcc/Makefile ] ; then \ - echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/ -L$${rootme}/chillrt/; \ + if [ -f $$r/gcc/Makefile ] ; then \ + echo $$r/gcc/xgcc -B$$r/gcc/ -L$$r/chillrt/; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(CC); \ @@ -119,8 +149,8 @@ CHILL_FOR_TARGET = ` \ # end-sanitize-chill CXX_FOR_TARGET = ` \ - if [ -f $${rootme}/gcc/Makefile ] ; then \ - echo $${rootme}/gcc/xgcc -B$${rootme}/gcc/; \ + if [ -f $$r/gcc/Makefile ] ; then \ + echo $$r/gcc/xgcc -B$$r/gcc/; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(CXX); \ @@ -130,8 +160,8 @@ CXX_FOR_TARGET = ` \ fi` AS_FOR_TARGET = ` \ - if [ -f $${rootme}/gas/Makefile ] ; then \ - echo $${rootme}/gas/as.new ; \ + if [ -f $$r/gas/Makefile ] ; then \ + echo $$r/gas/as.new ; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(AS); \ @@ -141,8 +171,8 @@ AS_FOR_TARGET = ` \ fi` AR_FOR_TARGET = ` \ - if [ -f $${rootme}/binutils/Makefile ] ; then \ - echo $${rootme}/binutils/ar ; \ + if [ -f $$r/binutils/ar ] ; then \ + echo $$r/binutils/ar ; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(AR); \ @@ -152,8 +182,8 @@ AR_FOR_TARGET = ` \ fi` RANLIB_FOR_TARGET = ` \ - if [ -f $${rootme}/binutils/Makefile ] ; then \ - echo $${rootme}/binutils/ranlib ; \ + if [ -f $$r/binutils/ranlib ] ; then \ + echo $$r/binutils/ranlib ; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(RANLIB); \ @@ -163,8 +193,8 @@ RANLIB_FOR_TARGET = ` \ fi` NM_FOR_TARGET = ` \ - if [ -f $${rootme}/binutils/Makefile ] ; then \ - echo $${rootme}/binutils/nm ; \ + if [ -f $$r/binutils/Makefile ] ; then \ + echo $$r/binutils/nm ; \ else \ if [ "$(host_canonical)" = "$(target_canonical)" ] ; then \ echo $(NM); \ @@ -175,18 +205,16 @@ NM_FOR_TARGET = ` \ # FIXME: This is badly named. XTRAFLAGS = ` \ - if [ -f $${rootme}/gcc/Makefile ] ; then \ - if [ -f $${rootme}/newlib/Makefile ] ; then \ - echo -I$${rootme}/newlib/targ-include -I$${srcroot}/newlib/libc/include -I$${rootme}/gcc/include -nostdinc ; \ + if [ -f $$r/gcc/Makefile ] ; then \ + if [ -f $$r/newlib/Makefile ] ; then \ + echo -I$$r/newlib/targ-include -I$${srcroot}/newlib/libc/include -I$$r/gcc/include -nostdinc ; \ else \ - echo -I$${rootme}/gcc/include ; \ + echo -I$$r/gcc/include ; \ fi ; \ else \ echo ; \ fi` -PRMS = install-prms - #### host and target specific makefile fragments come in here. ### @@ -208,18 +236,23 @@ BASE_FLAGS_TO_PASS = \ "CXX_FOR_BUILD=$(CXX_FOR_BUILD)" \ "CXXFLAGS=$(CXXFLAGS)" \ "CXX_FOR_TARGET=$(CXX_FOR_TARGET)" \ - 'GCC_FOR_TARGET=$$(CC_FOR_TARGET)' \ + "GCC_FOR_TARGET=$(CC_FOR_TARGET)" \ "INSTALL=$(INSTALL)" \ "INSTALL_DATA=$(INSTALL_DATA)" \ "INSTALL_PROGRAM=$(INSTALL_PROGRAM)" \ + "INSTALL_XFORM=$(INSTALL_XFORM)" \ "LDFLAGS=$(LDFLAGS)" \ "LEX=$(LEX)" \ - "LOADLIBES=$(LOADLIBES)" \ - "MAKEINFO=$(MAKEINFO)" \ + "M4=$(M4)" \ + "MAKEINFO=$(MAKEINFO) $(MAKEINFOFLAGS)" \ "NM_FOR_TARGET=$(NM_FOR_TARGET)" \ - "PRMS=$(PRMS)" \ "RANLIB_FOR_TARGET=$(RANLIB_FOR_TARGET)" \ + "SHELL=$(SHELL)" \ + "EXPECT=$(EXPECT)" \ + "RUNTEST=$(RUNTEST)" \ + "RUNTESTFLAGS=$(RUNTESTFLAGS)" \ "XTRAFLAGS_FOR_TARGET=$(XTRAFLAGS)" \ + "YACC=$(BISON)" \ "exec_prefix=$(exec_prefix)" \ "prefix=$(prefix)" \ "tooldir=$(tooldir)" @@ -264,18 +297,26 @@ TARGET_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_TARGET_FLAGS) # unfortunately needs the native compiler and the target ar and # ranlib. # If any variables are added here, they must be added to do-*, below. +# The HOST_* variables are a special case, which are used for the gcc +# cross-building scheme. +HOST_CC = $(CC_FOR_BUILD) +HOST_PREFIX = +HOST_PREFIX_1 = loser- EXTRA_GCC_FLAGS = \ 'AR=$$(AR_FOR_TARGET)' \ 'AS=$(AS)' \ 'CC=$(CC)' \ 'CXX=$(CXX)' \ + 'HOST_CC=$(CC_FOR_BUILD)' \ + 'HOST_PREFIX=$(HOST_PREFIX)' \ + 'HOST_PREFIX_1=$(HOST_PREFIX_1)' \ 'NM=$(NM)' \ 'RANLIB=$$(RANLIB_FOR_TARGET)' \ 'XTRAFLAGS=' GCC_FLAGS_TO_PASS = $(BASE_FLAGS_TO_PASS) $(EXTRA_GCC_FLAGS) -# This is a list of the targets for all the modules which are compiled +# This is a list of the targets for all of the modules which are compiled # using $(FLAGS_TO_PASS). ALL_MODULES = \ all-autoconf \ @@ -285,6 +326,7 @@ ALL_MODULES = \ all-cvs \ all-dejagnu \ all-diff \ + all-dosutils \ all-etc \ all-fileutils \ all-find \ @@ -304,10 +346,12 @@ ALL_MODULES = \ all-make \ all-mmalloc \ all-opcodes \ + all-pagas \ all-patch \ all-prms \ all-rcs \ all-readline \ + all-release \ all-recode \ all-sed \ all-send-pr \ @@ -322,7 +366,55 @@ ALL_MODULES = \ all-uudecode \ all-wdiff -# This is a list of the install targets for all the modules which are +# This is a list of the check targets for all of the modules which are +# compiled using $(FLAGS_TO_PASS). +CHECK_MODULES = \ + check-autoconf \ + check-bfd \ + check-binutils \ + check-byacc \ + check-cvs \ + check-dejagnu \ + check-diff \ + check-etc \ + check-fileutils \ + check-find \ + check-flex \ + check-gas \ + check-gawk \ + check-gdb \ + check-gprof \ + check-grep \ + check-gzip \ + check-hello \ + check-indent \ + check-ispell \ + check-ld \ + check-libiberty \ + check-m4 \ + check-make \ + check-mmcheckoc \ + check-opcodes \ + check-pagas \ + check-patch \ + check-prms \ + check-rcs \ + check-readline \ + check-recode \ + check-sed \ + check-send-pr \ + check-shellutils \ + check-sim \ + check-tar \ + check-tcl \ + check-texinfo \ + check-textutils \ + check-tgas \ + check-time \ + check-uudecode \ + check-wdiff + +# This is a list of the install targets for all of the modules which are # compiled using $(FLAGS_TO_PASS). INSTALL_MODULES = \ install-autoconf \ @@ -352,6 +444,7 @@ INSTALL_MODULES = \ install-make \ install-mmalloc \ install-opcodes \ + install-pagas \ install-patch \ install-prms \ install-rcs \ @@ -370,51 +463,75 @@ INSTALL_MODULES = \ install-uudecode \ install-wdiff -# This is a list of the targets for all the modules which are compiled +# This is a list of the targets for all of the modules which are compiled # using $(X11_FLAGS_TO_PASS). ALL_X11_MODULES = \ all-emacs \ all-expect \ + all-gash \ all-tclX \ all-tk +# This is a list of the check targets for all of the modules which are +# compiled using $(X11_FLAGS_TO_PASS). +CHECK_X11_MODULES = \ + check-emacs \ + check-expect \ + check-gash \ + check-tclX \ + check-tk + # This is a list of the install targets for all the modules which are # compiled using $(X11_FLAGS_TO_PASS). INSTALL_X11_MODULES = \ install-emacs \ install-expect \ + install-gash \ install-tclX \ install-tk -# This is a list of the targets for all the modules which are compiled +# This is a list of the targets for all of the modules which are compiled # using $(TARGET_FLAGS_TO_PASS). ALL_TARGET_MODULES = \ $(start-sanitize-chill) \ all-chillrt \ $(end-sanitize-chill) \ + all-libio \ all-libg++ \ all-newlib \ all-xiberty -# This is a list of the install targets for all the modules which are +# This is a list of the check targets for all of the modules which are +# compiled using $(TARGET_FLAGS_TO_PASS). +CHECK_TARGET_MODULES = \ + $(start-sanitize-chill) \ + check-chillrt \ + $(end-sanitize-chill) \ + check-libio \ + check-libg++ \ + check-newlib \ + check-xiberty + +# This is a list of the install targets for all of the modules which are # compiled using $(TARGET_FLAGS_TO_PASS). INSTALL_TARGET_MODULES = \ $(start-sanitize-chill) \ install-chillrt \ $(end-sanitize-chill) \ + install-libio \ install-libg++ \ install-newlib \ install-xiberty # This is a shell case of all modules which are compiled using # $(TARGET_FLAGS_TO_PASS), used in the do-X rule. -TARGET_LIBS = libg++ | newlib | xiberty +TARGET_LIBS = libio | libg++ | newlib | xiberty # start-sanitize-chill -TARGET_LIBS = chillrt | libg++ | newlib | xiberty +TARGET_LIBS = chillrt | libio | libg++ | newlib | xiberty # end-sanitize-chill # The first rule in the file had better be this one. Don't put any above it. -all: $(ALL) +all: all.normal .PHONY: all # The target built for a native build. @@ -422,28 +539,9 @@ all: $(ALL) all.normal: \ $(ALL_MODULES) \ $(ALL_TARGET_MODULES) \ - $(ALL_X11_MODULES) + $(ALL_X11_MODULES) \ all-gcc -# The target built for a cross build. -.PHONY: all.cross -all.cross: \ - all-bfd \ - all-binutils \ - all-byacc \ - all-dejagnu \ - all-flex \ - all-gas \ - all-gcc \ - all-gdb \ - all-ld \ - all-libiberty \ - all-mmalloc \ - all-opcodes \ - all-readline \ - all-sim \ - $(ALL_TARGET_MODULES) - # Do a target for all the subdirectories. A ``make do-X'' will do a # ``make X'' in all subdirectories (because, in general, there is a # dependency (below) of X upon do-X, a ``make X'' will also do this, @@ -452,7 +550,6 @@ all.cross: \ # because it is so large that it can easily overflow the command line # length limit on some systems. DO_X = \ - do-check \ do-clean \ do-distclean \ do-dvi \ @@ -464,7 +561,7 @@ DO_X = \ .PHONY: $(DO_X) $(DO_X): @target=`echo $@ | sed -e 's/^do-//'`; \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ for i in $(SUBDIRS); do \ if [ -f ./$$i/Makefile ]; then \ @@ -497,20 +594,18 @@ $(DO_X): # Here are the targets which correspond to the do-X targets. -.PHONY: info check installcheck dvi install-info +.PHONY: info installcheck dvi install-info .PHONY: clean distclean mostlyclean realclean local-clean local-distclean info: do-info -check: do-check installcheck: do-installcheck dvi: do-dvi -install-info: install-info-dirs do-install-info dir.info +install-info: do-install-info dir.info + srcroot=`cd $(srcdir); pwd`; export srcroot; \ if [ -f dir.info ] ; then \ $(INSTALL_DATA) dir.info $(infodir)/dir.info ; \ else true ; fi -do-install-info: install-info-dirs - local-clean: -rm -f *.a TEMP errs core *.o *~ \#* TAGS *.E @@ -522,33 +617,48 @@ mostlyclean: do-mostlyclean local-clean distclean: do-distclean local-clean local-distclean realclean: do-realclean local-clean local-distclean +# Check target. + +.PHONY: check +check: $(CHECK_MODULES) \ + $(CHECK_TARGET_MODULES) \ + $(CHECK_X11_MODULES) \ + check-gcc + # Installation targets. -.PHONY: install uninstall +.PHONY: install uninstall vault-install install: $(INSTALL_TARGET) uninstall: @echo "the uninstall target is not supported in this tree" +vault-install: + @if [ -f ./release/vault-install ] ; then \ + ./release/vault-install $(host_alias) $(target_alias) ; \ + else \ + true ; \ + fi + .PHONY: install.all install.all: install-no-fixedincludes @if [ -f ./gcc/Makefile ] ; then \ - rootme=`pwd` ; export rootme ; \ + r=`pwd` ; export r ; \ (cd ./gcc; \ $(MAKE) $(FLAGS_TO_PASS) install-headers) ; \ else \ true ; \ fi -# install-no-fixedincludes is used because Cygnus can not distributed +# install-no-fixedincludes is used because Cygnus can not distribute # the fixed header files. .PHONY: install-no-fixedincludes install-no-fixedincludes: \ install-dirs \ - gcc-no-fixedincludes \ $(INSTALL_MODULES) \ $(INSTALL_TARGET_MODULES) \ - $(INSTALL_X11_MODULES) + $(INSTALL_X11_MODULES) \ + gcc-no-fixedincludes # Install the gcc headers files, but not the fixed include files, # which Cygnus is not allowed to distribute. This rule is very @@ -559,9 +669,10 @@ gcc-no-fixedincludes: rm -rf gcc/tmp-include; \ mv gcc/include gcc/tmp-include 2>/dev/null; \ mkdir gcc/include; \ - touch gcc/stmp-fixincludes; \ - rm -f gcc/stmp-headers; \ - rootme=`pwd`; export rootme; \ + cp $(srcdir)/gcc/gsyslimits.h gcc/include/syslimits.h; \ + touch gcc/stmp-fixinc gcc/stmp-fixproto; \ + rm -f gcc/stmp-headers gcc/stmp-int-hdrs; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd` ; export srcroot; \ (cd ./gcc; \ $(MAKE) $(GCC_FLAGS_TO_PASS) install); \ @@ -569,25 +680,6 @@ gcc-no-fixedincludes: mv gcc/tmp-include gcc/include 2>/dev/null; \ else true; fi -.PHONY: install.cross -install.cross: \ - install-dirs \ - install-binutils \ - install-byacc \ - install-dejagnu \ - install-etc \ - install-flex \ - install-gas \ - install-gcc \ - install-gdb \ - install-glob \ - install-ld \ - install-libiberty \ - install-mmalloc \ - install-opcodes \ - install-readline \ - $(INSTALL_TARGET_MODULES) - # This rule is used to build the modules which use FLAGS_TO_PASS. To # build a target all-X means to cd to X and make all. # all-glob is handled specially because it doesn't actually build. @@ -595,40 +687,65 @@ install.cross: \ $(ALL_MODULES) all-glob: @dir=`echo $@ | sed -e 's/all-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; $(MAKE) $(FLAGS_TO_PASS) all); \ else \ true; \ fi +# This rule is used to check the modules which use FLAGS_TO_PASS. To +# build a target check-X means to cd to X and make all. +.PHONY: $(CHECK_MODULES) +$(CHECK_MODULES): + @dir=`echo $@ | sed -e 's/check-//'`; \ + if [ -f ./$${dir}/Makefile ] ; then \ + r=`pwd`; export r; \ + srcroot=`cd $(srcdir); pwd`; export srcroot; \ + (cd $${dir}; $(MAKE) $(FLAGS_TO_PASS) check); \ + else \ + true; \ + fi + # This rule is used to install the modules which use FLAGS_TO_PASS. # To build a target install-X means to cd to X and make install. .PHONY: $(INSTALL_MODULES) $(INSTALL_MODULES): install-dirs @dir=`echo $@ | sed -e 's/install-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; $(MAKE) $(FLAGS_TO_PASS) install); \ else \ true; \ fi -# This rule is used the build the modules which use -# TARGET_FLAGS_TO_PASS. To build a target all-X means to cd to X and -# make all. +# This rule is used to build the modules which use TARGET_FLAGS_TO_PASS. +# To build a target all-X means to cd to X and make all. .PHONY: $(ALL_TARGET_MODULES) $(ALL_TARGET_MODULES): @dir=`echo $@ | sed -e 's/all-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; $(MAKE) $(TARGET_FLAGS_TO_PASS) all); \ else \ true; \ fi +# This rule is used to check the modules which use TARGET_FLAGS_TO_PASS. +# To build a target install-X means to cd to X and make install. +.PHONY: $(CHECK_TARGET_MODULES) +$(CHECK_TARGET_MODULES): + @dir=`echo $@ | sed -e 's/check-//'`; \ + if [ -f ./$${dir}/Makefile ] ; then \ + r=`pwd`; export r; \ + srcroot=`cd $(srcdir); pwd`; export srcroot; \ + (cd $${dir}; $(MAKE) $(TARGET_FLAGS_TO_PASS) check); \ + else \ + true; \ + fi + # This rule is used to install the modules which use # TARGET_FLAGS_TO_PASS. To build a target install-X means to cd to X # and make install. @@ -636,20 +753,20 @@ $(ALL_TARGET_MODULES): $(INSTALL_TARGET_MODULES): install-dirs @dir=`echo $@ | sed -e 's/install-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; $(MAKE) $(TARGET_FLAGS_TO_PASS) install); \ else \ true; \ fi -# This rule is used the build the modules which use X11_FLAGS_TO_PASS. +# This rule is used to build the modules which use X11_FLAGS_TO_PASS. # To build a target all-X means to cd to X and make all. .PHONY: $(ALL_X11_MODULES) $(ALL_X11_MODULES): @dir=`echo $@ | sed -e 's/all-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; \ $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) all); \ @@ -657,13 +774,27 @@ $(ALL_X11_MODULES): true; \ fi -# This rule is used the install the modules which use X11_FLAGS_TO_PASS. +# This rule is used to check the modules which use X11_FLAGS_TO_PASS. +# To build a target check-X means to cd to X and make all. +.PHONY: $(CHECK_X11_MODULES) +$(CHECK_X11_MODULES): + @dir=`echo $@ | sed -e 's/check-//'`; \ + if [ -f ./$${dir}/Makefile ] ; then \ + r=`pwd`; export r; \ + srcroot=`cd $(srcdir); pwd`; export srcroot; \ + (cd $${dir}; \ + $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) check); \ + else \ + true; \ + fi + +# This rule is used to install the modules which use X11_FLAGS_TO_PASS. # To build a target install-X means to cd to X and make install. .PHONY: $(INSTALL_X11_MODULES) $(INSTALL_X11_MODULES): - @dir=`echo $@ | sed -e 's/all-//'`; \ + @dir=`echo $@ | sed -e 's/install-//'`; \ if [ -f ./$${dir}/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd $${dir}; \ $(MAKE) $(FLAGS_TO_PASS) $(X11_FLAGS_TO_PASS) install); \ @@ -675,17 +806,27 @@ $(INSTALL_X11_MODULES): .PHONY: all-gcc all-gcc: @if [ -f ./gcc/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd gcc; $(MAKE) $(GCC_FLAGS_TO_PASS) all); \ else \ true; \ fi +.PHONY: check-gcc +check-gcc: + @if [ -f ./gcc/Makefile ] ; then \ + r=`pwd`; export r; \ + srcroot=`cd $(srcdir); pwd`; export srcroot; \ + (cd gcc; $(MAKE) $(GCC_FLAGS_TO_PASS) check); \ + else \ + true; \ + fi + .PHONY: install-gcc install-gcc: @if [ -f ./gcc/Makefile ] ; then \ - rootme=`pwd`; export rootme; \ + r=`pwd`; export r; \ srcroot=`cd $(srcdir); pwd`; export srcroot; \ (cd gcc; $(MAKE) $(GCC_FLAGS_TO_PASS) install); \ else \ @@ -693,7 +834,7 @@ install-gcc: fi # This is a list of inter-dependencies among modules. -all-autoconf: +all-autoconf: all-m4 all-bfd: all-binutils: all-libiberty all-opcodes all-bfd all-flex all-byacc: @@ -705,36 +846,38 @@ all-dejagnu: all-diff: all-libiberty all-emacs: all-etc: -all-expect: all-tcl -all-fileutils: +all-expect: all-tcl all-tk +all-fileutils: all-libiberty all-find: -all-flex: all-libiberty +all-flex: all-libiberty all-byacc all-gas: all-libiberty all-opcodes all-bfd +all-gash: all-tcl all-gawk: -all-gcc: all-libiberty all-byacc all-binutils all-gas -all-gdb: all-libiberty all-opcodes all-bfd all-mmalloc all-readline all-glob all-byacc +all-gcc: all-libiberty all-byacc all-binutils all-gas all-pagas +all-gdb: all-libiberty all-opcodes all-bfd all-mmalloc all-readline all-glob all-byacc all-sim all-glob: all-gprof: all-libiberty all-bfd -all-grep: +all-grep: all-libiberty all-gzip: all-libiberty all-hello: all-libiberty all-indent: all-ispell: all-emacs all-ld: all-libiberty all-bfd all-byacc all-flex -all-libg++: all-gas all-ld all-gcc all-xiberty all-newlib +all-libg++: all-gas all-pagas all-ld all-gcc all-xiberty all-newlib all-libio +all-libio: all-gas all-pagas all-ld all-gcc all-xiberty all-newlib all-libiberty: all-m4: all-libiberty all-make: all-libiberty all-mmalloc: -all-newlib: all-binutils all-gas all-gcc -all-opcodes: +all-newlib: all-binutils all-gas all-pagas all-gcc +all-opcodes: all-bfd all-patch: -all-prms: +all-prms: all-libiberty all-rcs: all-readline: all-recode: all-libiberty -all-sed: -all-send-pr: +all-sed: all-libiberty +all-send-pr: all-prms all-shellutils: all-sim: all-libiberty all-bfd all-tar: all-libiberty @@ -760,7 +903,7 @@ MAKEDIRS= \ install-dirs: @for i in $(MAKEDIRS) ; do \ echo Making $$i... ; \ - parent=`echo $$i|sed -e 's@/[^/]*$$@@'`; \ + parent=`echo $$i | sed -e 's@/[^/]*$$@@' | sed -e 's@^$$@/@'`; \ if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi ; \ if [ ! -d $$i ] ; then \ if mkdir $$i ; then \ @@ -773,12 +916,6 @@ install-dirs: fi ; \ done -.PHONY: install-info-dirs -install-info-dirs: - if [ -d $(prefix) ] ; then true ; else mkdir $(prefix) ; fi - -parent=`echo $(infodir)|sed -e 's@/[^/]*$$@@'`; \ - if [ -d $$parent ] ; then true ; else mkdir $$parent ; fi - -if [ -d $(infodir) ] ; then true ; else mkdir $(infodir) ; fi dir.info: do-install-info if [ -f $(srcdir)/texinfo/gen-info-dir ] ; then \ @@ -811,31 +948,44 @@ ls: # with the gnu make, this is done automatically. -Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag) +Makefile: Makefile.in configure.in $(host_makefile_frag) $(target_makefile_frag) $(SHELL) ./config.status # -# Build GDB distributions that contain BFD, Include, Libiberty, Readline, etc +# Support for building net releases +# Files in devo used in any net release. +# ChangeLog omitted because it may refer to files which are not in this +# distribution (perhaps it would be better to include it anyway). DEVO_SUPPORT= README Makefile.in configure configure.in \ - config.guess config.sub config move-if-change + config.guess config.sub config move-if-change \ + COPYING COPYING.LIB install.sh + +# Files in devo/etc used in any net release. +# ChangeLog omitted because it may refer to files which are not in this +# distribution (perhaps it would be better to include it anyway). ETC_SUPPORT= Makefile.in cfg-paper.texi configure.in configure.man \ - configure.texi + configure.texi standards.texi make-stds.texi + GDB_SUPPORT_DIRS= bfd include libiberty mmalloc opcodes readline glob sim GDB_SUPPORT_FILES= $(GDB_SUPPORT_DIRS) -.PHONY: setup-dirs-gdb gdb.tar.Z make-gdb.tar.Z +.PHONY: setup-dirs-gdb gdb.tar.gz make-gdb.tar.gz setup-dirs-gdb: + $(start-sanitize-Sanitize) + @if [ -f .Sanitize ] ; then echo "RUN Sanitize FIRST!" ; false ; fi ; + $(end-sanitize-Sanitize) ./configure sun4 $(MAKE) clean ./configure -rm sun4 chmod og=u `find etc $(DEVO_SUPPORT) $(GDB_SUPPORT_FILES) -print` -gdb.tar.Z: setup-dirs-gdb +gdb.tar.gz: setup-dirs-gdb (cd gdb; $(MAKE) -f Makefile.in make-proto-gdb.dir BISON="byacc") - $(MAKE) $(MFLAGS) -f Makefile.in make-gdb.tar.Z + (cd gdb; $(MAKE) -f Makefile.in make-proto-testsuite.dir) + $(MAKE) $(MFLAGS) -f Makefile.in make-gdb.tar.gz -make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/texinfo.tex +make-gdb.tar.gz: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/texinfo.tex rm -rf proto-toplev; mkdir proto-toplev ln -s ../gdb/proto-gdb.dir proto-toplev/gdb (cd proto-toplev; for i in $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS); do \ @@ -853,6 +1003,12 @@ make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/texinfo.tex rm proto-toplev/readline/COPYING ln proto-toplev/gdb/COPYING proto-toplev/readline/COPYING + # Change the bug reporting address in configure to bug-gdb + rm proto-toplev/configure + sed -e 's/configure@cygnus.com/bug-gdb@prep.ai.mit.edu/' \ + proto-toplev/configure + chmod a+x proto-toplev/configure + # Take out texinfo and glob from configurable dirs rm proto-toplev/configure.in sed -e '/^host_tools=/s/texinfo //' \ @@ -869,83 +1025,145 @@ make-gdb.tar.Z: $(DEVO_SUPPORT) $(GDB_SUPPORT_DIRS) gdb texinfo/texinfo.tex mkdir proto-toplev/texinfo ln -s ../../texinfo/texinfo.tex proto-toplev/texinfo/ + ln -s ../../texinfo/gpl.texinfo proto-toplev/texinfo/ ln -s ../../texinfo/tex3patch proto-toplev/texinfo/ chmod og=u `find proto-toplev -print` (VER=`sed Making gdb-$$VER.tar.Z"; \ - ln -s proto-toplev gdb-$$VER; \ + echo "==> Making gdb-$$VER.tar.gz"; \ + rm -f gdb-$$VER; ln -s proto-toplev gdb-$$VER; \ tar cfh - gdb-$$VER \ - | compress -v >gdb-$$VER.tar.Z) - $(GZIP) -d gdb-$$VER.tar.z + | $(GZIPPROG) -v -9 >gdb-$$VER.tar.gz) + + # Make the testsuite archive separately. + ln -s ../../gdb/proto-testsuite.dir/testsuite proto-toplev/gdb/testsuite + # Blow away the Chill test that requires a Chill compiled executable, + # since GNU Chill is not yet publically available. + rm -rf proto-toplev/gdb/testsuite/gdb.t31 + + # Put a copy of COPYING in the tar file. + ln proto-toplev/gdb/COPYING proto-toplev/gdb/testsuite/COPYING + chmod og=u `find proto-toplev/gdb/testsuite -print` + (VER=`sed Making gdb-$$VER-testsuite.tar.gz"; \ + tar cfh - gdb-$$VER/configure gdb-$$VER/config.guess \ + gdb-$$VER/config.sub gdb-$$VER/move-if-change \ + gdb-$$VER/gdb/testsuite \ + | $(GZIPPROG) -v -9 >gdb-$$VER-testsuite.tar.gz) # When you use `make setup-dirs' or `make taz' you should always redefine # this macro. SUPPORT_FILES = list-of-support-files-for-tool-in-question -# Directories that might want `make proto-dir' run. -PROTODIRS= gdb - -.PHONY: setup-dirs taz -setup-dirs: +# Directories that might want `make diststuff' run. +DISTSTUFFDIRS= ld gprof gdb libg++ binutils gnats +# Files where "byacc" (Cygnus version) should be changed to "bison -y" (FSF). +DISTBISONFILES= binutils/Makefile.in gas/Makefile.in gdb/Makefile.in +# Directories where "info" should be built. +DISTDOCDIRS= ld gprof binutils gas bfd libg++ libio gdb gnats send-pr + +.PHONY: taz + +taz: $(DEVO_SUPPORT) $(SUPPORT_FILES) \ + texinfo/texinfo.tex texinfo/gpl.texinfo texinfo/lgpl.texinfo + # Make sure "diststuff" files get built properly. + for f in $(DISTBISONFILES) ; do \ + if [ -r $$f ]; then \ + sed '/^BISON *=.*$$/s/.*/BISON = bison -y/' <$$f >tmp ; \ + mv -f tmp $$f ; \ + else true; fi ; \ + done + # Take out texinfo from a few places; make simple BISON=bison line. + sed -e '/^all\.normal: /s/\all-texinfo //' \ + -e '/^ install-texinfo /d' \ + -e '/^BISON = /,/^$$/d' \ + -e '/^# BISON:/s/.*/BISON = bison -y/' \ + tmp + mv -f tmp Makefile.in + # ./configure sun4 - $(MAKE) clean - ./configure -rm sun4 - chmod og=u `find etc $(DEVO_SUPPORT) $(SUPPORT_FILES) -print` - for d in .. $(PROTODIRS) ; do \ - if [ $$d != ".." ] && [ -d $$d ]; then \ - (cd $$d ; $(MAKE) -f Makefile.in proto-dir) ; \ + # Doc files don't change; include them in distribution. + for f in $(DISTDOCDIRS) ; do \ + if [ -r $$f/Makefile ]; then \ + (cd $$f ; $(MAKE) info) || exit 1 ; \ else true ; fi ; \ done - -taz: $(DEVO_SUPPORT) $(SUPPORT_FILES) texinfo/texinfo.tex - rm -rf proto-toplev; mkdir proto-toplev - for d in .. $(PROTODIRS) ; do \ - if [ $$d != .. ]; then \ - if [ -d $$d ]; then \ + # Make links, and run "make diststuff" when needed. + # The `echo' for setting `p' is to convert all whitespace to spaces. + # Then the `case' further below should tell whether $$d is in + # DISTSTUFFDIRS. + rm -rf proto-toplev ; mkdir proto-toplev + set -e ; dirs="$(TOOL) $(DEVO_SUPPORT) $(SUPPORT_FILES)" ; \ + p=" `echo $(DISTSTUFFDIRS)` " ; \ + for d in $$dirs ; do \ + if [ -d $$d ]; then \ + case " $$p " in \ + *" $$d "*) \ + echo making diststuff in $$d ; \ + (cd $$d ; pwd ; $(MAKE) diststuff ) || exit 1 ;; \ + esac ; \ + if [ -d $$d/proto-$$d.dir ]; then \ ln -s ../$$d/proto-$$d.dir proto-toplev/$$d ; \ - else true ; fi ; \ - else true ; fi ; \ + else \ + ln -s ../$$d proto-toplev/$$d ; \ + fi ; \ + else ln -s ../$$d proto-toplev/$$d ; fi ; \ done - (cd proto-toplev; for i in $(TOOL) $(DEVO_SUPPORT) $(SUPPORT_FILES); do \ - if [ ! -d $$i ]; then ln -s ../$$i . ; else true ; fi ; \ - done) + $(MAKE) distclean + # mkdir proto-toplev/etc (cd proto-toplev/etc; for i in $(ETC_SUPPORT); do \ ln -s ../../etc/$$i . ; \ done) - # Put only one copy (four hard links) of COPYING in the tar file. - ## FIX ME LATER - + # # Take out texinfo and glob from configurable dirs rm proto-toplev/configure.in sed -e '/^host_tools=/s/texinfo //' \ -e '/^host_libs=/s/glob //' \ proto-toplev/configure.in - - # Take out texinfo from a few places; make simple BISON=bison line. - rm proto-toplev/Makefile.in - sed -e '/^all\.normal: /s/\all-texinfo //' \ - -e '/^ install-texinfo /d' \ - -e '/^BISON = /,/^$$/d' \ - -e '/^# BISON:/s/.*/BISON = bison -y/' \ - proto-toplev/Makefile.in - + # mkdir proto-toplev/texinfo ln -s ../../texinfo/texinfo.tex proto-toplev/texinfo/ + ln -s ../../texinfo/gpl.texinfo proto-toplev/texinfo/ + ln -s ../../texinfo/lgpl.texinfo proto-toplev/texinfo/ ln -s ../../texinfo/tex3patch proto-toplev/texinfo/ - chmod og=u `find proto-toplev -print` - (VER=`sed <$(TOOL)/Makefile.in -n 's/VERSION *= *//p'`; \ - echo "==> Making $(TOOL)-$$VER.tar.z"; \ - ln -s proto-toplev $(TOOL)-$$VER; \ + chmod og=u `find . -print` + (VER=`sed <$(TOOL)/Makefile.in -n 's/^VERSION *= *//p'`; \ + echo "==> Making $(TOOL)-$$VER.tar.gz"; \ + rm -f $(TOOL)-$$VER; ln -s proto-toplev $(TOOL)-$$VER; \ tar cfh - $(TOOL)-$$VER \ - | $(GZIP) -v >$(TOOL)-$$VER.tar.z) + | $(GZIPPROG) -v -9 >$(TOOL)-$$VER.tar.gz ) -GAS_SUPPORT_DIRS= bfd include libiberty opcodes - -.PHONY: gas.tar.z -gas.tar.z: $(DEVO_SUPPORT) $(GAS_SUPPORT_DIRS) gas texinfo/texinfo.tex - $(MAKE) -f Makefile.in setup-dirs SUPPORT_FILES="$(GAS_SUPPORT_DIRS)" - $(MAKE) -f Makefile.in taz SUPPORT_FILES="$(GAS_SUPPORT_DIRS)" TOOL=gas +TEXINFO_SUPPORT= texinfo/texinfo.tex texinfo/gpl.texinfo texinfo/lgpl.texinfo +DIST_SUPPORT= $(DEVO_SUPPORT) $(TEXINFO_SUPPORT) +.PHONY: gas.tar.gz +GAS_SUPPORT_DIRS= bfd include libiberty opcodes +gas.tar.gz: $(DIST_SUPPORT) $(GAS_SUPPORT_DIRS) gas + $(MAKE) -f Makefile.in taz TOOL=gas \ + SUPPORT_FILES="$(GAS_SUPPORT_DIRS)" + +# The FSF "binutils" release includes gprof and ld. +.PHONY: binutils.tar.gz +BINUTILS_SUPPORT_DIRS= bfd include libiberty opcodes ld gprof +binutils.tar.gz: $(DIST_SUPPORT) $(BINUTILS_SUPPORT_DIRS) binutils + $(MAKE) -f Makefile.in taz TOOL=binutils \ + SUPPORT_FILES="$(BINUTILS_SUPPORT_DIRS)" + +.PHONY: gas+binutils.tar.gz +GASB_SUPPORT_DIRS= $(GAS_SUPPORT_DIRS) binutils ld gprof +gas+binutils.tar.gz: $(DIST_SUPPORT) $(GASB_SUPPORT_DIRS) gas + $(MAKE) -f Makefile.in taz TOOL=gas \ + SUPPORT_FILES="$(GASB_SUPPORT_DIRS)" + +.PHONY: libg++.tar.gz +LIBGXX_SUPPORT_DIRS=include libio libiberty xiberty +libg++.tar.gz: $(DIST_SUPPORT) libg++ + $(MAKE) -f Makefile.in taz TOOL=libg++ \ + SUPPORT_FILES="$(LIBGXX_SUPPORT_DIRS)" + +GNATS_SUPPORT_DIRS=include libiberty send-pr +gnats.tar.gz: $(DIST_SUPPORT) $(GNATS_SUPPORT_DIRS) gnats + $(MAKE) -f Makefile.in taz TOOL=gnats \ + SUPPORT_FILES="$(GNATS_SUPPORT_DIRS)" .NOEXPORT: MAKEOVERRIDES=