diff options
Diffstat (limited to 'contrib')
| -rw-r--r-- | contrib/gcc/INSTALL | 1877 | ||||
| -rw-r--r-- | contrib/gcc/config/i386/freebsd.h.fixed | 302 | ||||
| -rw-r--r-- | contrib/gdb/bfd/ChangeLog | 3385 | ||||
| -rw-r--r-- | contrib/global/gctags/ctags.c | 2 | ||||
| -rw-r--r-- | contrib/libg++/libg++/genclass/genclass.1 | 2 | ||||
| -rwxr-xr-x | contrib/libgmp/configure | 2 | ||||
| -rw-r--r-- | contrib/libgmp/texinfo.tex | 2 | ||||
| -rw-r--r-- | contrib/libpcap/nlpid.h | 2 | ||||
| -rw-r--r-- | contrib/pnpinfo/pnpinfo.8 | 2 | ||||
| -rw-r--r-- | contrib/pnpinfo/pnpinfo.c | 2 | ||||
| -rw-r--r-- | contrib/pnpinfo/pnpinfo.h | 2 | ||||
| -rw-r--r-- | contrib/tcpdump/print-fr.c | 2 | ||||
| -rw-r--r-- | contrib/traceroute/CHANGES | 2 | ||||
| -rw-r--r-- | contrib/traceroute/INSTALL | 2 | ||||
| -rw-r--r-- | contrib/traceroute/Makefile.in | 2 | ||||
| -rw-r--r-- | contrib/traceroute/README | 2 | ||||
| -rw-r--r-- | contrib/traceroute/acsite.m4 | 2 | ||||
| -rw-r--r-- | contrib/traceroute/configure.in | 2 | ||||
| -rw-r--r-- | contrib/traceroute/lbl/gnuc.h | 2 | ||||
| -rw-r--r-- | contrib/traceroute/lbl/os-solaris2.h | 2 | ||||
| -rw-r--r-- | contrib/traceroute/lbl/os-sunos4.h | 2 | ||||
| -rw-r--r-- | contrib/traceroute/traceroute.8 | 2 | ||||
| -rw-r--r-- | contrib/traceroute/traceroute.c | 2 | 
23 files changed, 5282 insertions, 322 deletions
| diff --git a/contrib/gcc/INSTALL b/contrib/gcc/INSTALL new file mode 100644 index 000000000000..d792b336e4c7 --- /dev/null +++ b/contrib/gcc/INSTALL @@ -0,0 +1,1877 @@ +This file documents the installation of the GNU compiler.  Copyright +(C) 1988, 1989, 1992, 1994, 1995 Free Software Foundation, Inc.  You +may copy, distribute, and modify it freely as long as you preserve this +copyright notice and permission notice. + +Installing GNU CC +***************** + +   Here is the procedure for installing GNU CC on a Unix system.  See +*Note VMS Install::, for VMS systems.  In this section we assume you +compile in the same directory that contains the source files; see *Note +Other Dir::, to find out how to compile in a separate directory on Unix +systems. + +   You cannot install GNU C by itself on MSDOS; it will not compile +under any MSDOS compiler except itself.  You need to get the complete +compilation package DJGPP, which includes binaries as well as sources, +and includes all the necessary compilation tools and libraries. + +  1. If you have built GNU CC previously in the same directory for a +     different target machine, do `make distclean' to delete all files +     that might be invalid.  One of the files this deletes is +     `Makefile'; if `make distclean' complains that `Makefile' does not +     exist, it probably means that the directory is already suitably +     clean. + +  2. On a System V release 4 system, make sure `/usr/bin' precedes +     `/usr/ucb' in `PATH'.  The `cc' command in `/usr/ucb' uses +     libraries which have bugs. + +  3. Specify the host, build and target machine configurations.  You do +     this by running the file `configure'. + +     The "build" machine is the system which you are using, the "host" +     machine is the system where you want to run the resulting compiler +     (normally the build machine), and the "target" machine is the +     system for which you want the compiler to generate code. + +     If you are building a compiler to produce code for the machine it +     runs on (a native compiler), you normally do not need to specify +     any operands to `configure'; it will try to guess the type of +     machine you are on and use that as the build, host and target +     machines.  So you don't need to specify a configuration when +     building a native compiler unless `configure' cannot figure out +     what your configuration is or guesses wrong. + +     In those cases, specify the build machine's "configuration name" +     with the `--build' option; the host and target will default to be +     the same as the build machine.  (If you are building a +     cross-compiler, see *Note Cross-Compiler::.) + +     Here is an example: + +          ./configure --build=sparc-sun-sunos4.1 + +     A configuration name may be canonical or it may be more or less +     abbreviated. + +     A canonical configuration name has three parts, separated by +     dashes.  It looks like this: `CPU-COMPANY-SYSTEM'.  (The three +     parts may themselves contain dashes; `configure' can figure out +     which dashes serve which purpose.)  For example, +     `m68k-sun-sunos4.1' specifies a Sun 3. + +     You can also replace parts of the configuration by nicknames or +     aliases.  For example, `sun3' stands for `m68k-sun', so +     `sun3-sunos4.1' is another way to specify a Sun 3.  You can also +     use simply `sun3-sunos', since the version of SunOS is assumed by +     default to be version 4.  `sun3-bsd' also works, since `configure' +     knows that the only BSD variant on a Sun 3 is SunOS. + +     You can specify a version number after any of the system types, +     and some of the CPU types.  In most cases, the version is +     irrelevant, and will be ignored.  So you might as well specify the +     version if you know it. + +     See *Note Configurations::, for a list of supported configuration +     names and notes on many of the configurations.  You should check +     the notes in that section before proceeding any further with the +     installation of GNU CC. + +     There are four additional options you can specify independently to +     describe variant hardware and software configurations.  These are +     `--with-gnu-as', `--with-gnu-ld', `--with-stabs' and `--nfp'. + +    `--with-gnu-as' +          If you will use GNU CC with the GNU assembler (GAS), you +          should declare this by using the `--with-gnu-as' option when +          you run `configure'. + +          Using this option does not install GAS.  It only modifies the +          output of GNU CC to work with GAS.  Building and installing +          GAS is up to you. + +          Conversely, if you *do not* wish to use GAS and do not specify +          `--with-gnu-as' when building GNU CC, it is up to you to make +          sure that GAS is not installed.  GNU CC searches for a +          program named `as' in various directories; if the program it +          finds is GAS, then it runs GAS.  If you are not sure where +          GNU CC finds the assembler it is using, try specifying `-v' +          when you run it. + +          The systems where it makes a difference whether you use GAS +          are +          `hppa1.0-ANY-ANY', `hppa1.1-ANY-ANY', `i386-ANY-sysv', +          `i386-ANY-isc', +          `i860-ANY-bsd', `m68k-bull-sysv', `m68k-hp-hpux', +          `m68k-sony-bsd', +          `m68k-altos-sysv', `m68000-hp-hpux', `m68000-att-sysv', +          `ANY-lynx-lynxos', and `mips-ANY').  On any other system, +          `--with-gnu-as' has no effect. + +          On the systems listed above (except for the HP-PA, for ISC on +          the 386, and for `mips-sgi-irix5.*'), if you use GAS, you +          should also use the GNU linker (and specify `--with-gnu-ld'). + +    `--with-gnu-ld' +          Specify the option `--with-gnu-ld' if you plan to use the GNU +          linker with GNU CC. + +          This option does not cause the GNU linker to be installed; it +          just modifies the behavior of GNU CC to work with the GNU +          linker.  Specifically, it inhibits the installation of +          `collect2', a program which otherwise serves as a front-end +          for the system's linker on most configurations. + +    `--with-stabs' +          On MIPS based systems and on Alphas, you must specify whether +          you want GNU CC to create the normal ECOFF debugging format, +          or to use BSD-style stabs passed through the ECOFF symbol +          table.  The normal ECOFF debug format cannot fully handle +          languages other than C.  BSD stabs format can handle other +          languages, but it only works with the GNU debugger GDB. + +          Normally, GNU CC uses the ECOFF debugging format by default; +          if you prefer BSD stabs, specify `--with-stabs' when you +          configure GNU CC. + +          No matter which default you choose when you configure GNU CC, +          the user can use the `-gcoff' and `-gstabs+' options to +          specify explicitly the debug format for a particular +          compilation. + +          `--with-stabs' is meaningful on the ISC system on the 386, +          also, if `--with-gas' is used.  It selects use of stabs +          debugging information embedded in COFF output.  This kind of +          debugging information supports C++ well; ordinary COFF +          debugging information does not. + +          `--with-stabs' is also meaningful on 386 systems running +          SVR4.  It selects use of stabs debugging information embedded +          in ELF output.  The C++ compiler currently (2.6.0) does not +          support the DWARF debugging information normally used on 386 +          SVR4 platforms; stabs provide a workable alternative.  This +          requires gas and gdb, as the normal SVR4 tools can not +          generate or interpret stabs. + +    `--nfp' +          On certain systems, you must specify whether the machine has +          a floating point unit.  These systems include +          `m68k-sun-sunosN' and `m68k-isi-bsd'.  On any other system, +          `--nfp' currently has no effect, though perhaps there are +          other systems where it could usefully make a difference. + +     The `configure' script searches subdirectories of the source +     directory for other compilers that are to be integrated into GNU +     CC.  The GNU compiler for C++, called G++ is in a subdirectory +     named `cp'.  `configure' inserts rules into `Makefile' to build +     all of those compilers. + +     Here we spell out what files will be set up by `configure'. +     Normally you need not be concerned with these files. + +        * A file named `config.h' is created that contains a `#include' +          of the top-level config file for the machine you will run the +          compiler on (*note The Configuration File: +          (gcc.info)Config.).  This file is responsible for defining +          information about the host machine.  It includes `tm.h'. + +          The top-level config file is located in the subdirectory +          `config'.  Its name is always `xm-SOMETHING.h'; usually +          `xm-MACHINE.h', but there are some exceptions. + +          If your system does not support symbolic links, you might +          want to set up `config.h' to contain a `#include' command +          which refers to the appropriate file. + +        * A file named `tconfig.h' is created which includes the +          top-level config file for your target machine.  This is used +          for compiling certain programs to run on that machine. + +        * A file named `tm.h' is created which includes the +          machine-description macro file for your target machine.  It +          should be in the subdirectory `config' and its name is often +          `MACHINE.h'. + +        * The command file `configure' also constructs the file +          `Makefile' by adding some text to the template file +          `Makefile.in'.  The additional text comes from files in the +          `config' directory, named `t-TARGET' and `x-HOST'.  If these +          files do not exist, it means nothing needs to be added for a +          given target or host. + +  4. The standard directory for installing GNU CC is `/usr/local/lib'. +     If you want to install its files somewhere else, specify +     `--prefix=DIR' when you run `configure'.  Here DIR is a directory +     name to use instead of `/usr/local' for all purposes with one +     exception: the directory `/usr/local/include' is searched for +     header files no matter where you install the compiler.  To override +     this name, use the `--local-prefix' option below. + +  5. Specify `--local-prefix=DIR' if you want the compiler to search +     directory `DIR/include' for locally installed header files +     *instead* of `/usr/local/include'. + +     You should specify `--local-prefix' *only* if your site has a +     different convention (not `/usr/local') for where to put +     site-specific files. + +     *Do not* specify `/usr' as the `--local-prefix'!  The directory +     you use for `--local-prefix' *must not* contain any of the +     system's standard header files.  If it did contain them, certain +     programs would be miscompiled (including GNU Emacs, on certain +     targets), because this would override and nullify the header file +     corrections made by the `fixincludes' script. + +  6. Make sure the Bison parser generator is installed.  (This is +     unnecessary if the Bison output files `c-parse.c' and `cexp.c' are +     more recent than `c-parse.y' and `cexp.y' and you do not plan to +     change the `.y' files.) + +     Bison versions older than Sept 8, 1988 will produce incorrect +     output for `c-parse.c'. + +  7. If you have chosen a configuration for GNU CC which requires other +     GNU tools (such as GAS or the GNU linker) instead of the standard +     system tools, install the required tools in the build directory +     under the names `as', `ld' or whatever is appropriate.  This will +     enable the compiler to find the proper tools for compilation of +     the program `enquire'. + +     Alternatively, you can do subsequent compilation using a value of +     the `PATH' environment variable such that the necessary GNU tools +     come before the standard system tools. + +  8. Build the compiler.  Just type `make LANGUAGES=c' in the compiler +     directory. + +     `LANGUAGES=c' specifies that only the C compiler should be +     compiled.  The makefile normally builds compilers for all the +     supported languages; currently, C, C++ and Objective C.  However, +     C is the only language that is sure to work when you build with +     other non-GNU C compilers.  In addition, building anything but C +     at this stage is a waste of time. + +     In general, you can specify the languages to build by typing the +     argument `LANGUAGES="LIST"', where LIST is one or more words from +     the list `c', `c++', and `objective-c'.  If you have any +     additional GNU compilers as subdirectories of the GNU CC source +     directory, you may also specify their names in this list. + +     Ignore any warnings you may see about "statement not reached" in +     `insn-emit.c'; they are normal.  Also, warnings about "unknown +     escape sequence" are normal in `genopinit.c' and perhaps some +     other files.  Likewise, you should ignore warnings about "constant +     is so large that it is unsigned" in `insn-emit.c' and +     `insn-recog.c' and a warning about a comparison always being zero +     in `enquire.o'.  Any other compilation errors may represent bugs in +     the port to your machine or operating system, and should be +     investigated and reported. + +     Some commercial compilers fail to compile GNU CC because they have +     bugs or limitations.  For example, the Microsoft compiler is said +     to run out of macro space.  Some Ultrix compilers run out of +     expression space; then you need to break up the statement where +     the problem happens. + +  9. If you are building a cross-compiler, stop here.  *Note +     Cross-Compiler::. + + 10. Move the first-stage object files and executables into a +     subdirectory with this command: + +          make stage1 + +     The files are moved into a subdirectory named `stage1'.  Once +     installation is complete, you may wish to delete these files with +     `rm -r stage1'. + + 11. If you have chosen a configuration for GNU CC which requires other +     GNU tools (such as GAS or the GNU linker) instead of the standard +     system tools, install the required tools in the `stage1' +     subdirectory under the names `as', `ld' or whatever is +     appropriate.  This will enable the stage 1 compiler to find the +     proper tools in the following stage. + +     Alternatively, you can do subsequent compilation using a value of +     the `PATH' environment variable such that the necessary GNU tools +     come before the standard system tools. + + 12. Recompile the compiler with itself, with this command: + +          make CC="stage1/xgcc -Bstage1/" CFLAGS="-g -O2" + +     This is called making the stage 2 compiler. + +     The command shown above builds compilers for all the supported +     languages.  If you don't want them all, you can specify the +     languages to build by typing the argument `LANGUAGES="LIST"'.  LIST +     should contain one or more words from the list `c', `c++', +     `objective-c', and `proto'.  Separate the words with spaces. +     `proto' stands for the programs `protoize' and `unprotoize'; they +     are not a separate language, but you use `LANGUAGES' to enable or +     disable their installation. + +     If you are going to build the stage 3 compiler, then you might +     want to build only the C language in stage 2. + +     Once you have built the stage 2 compiler, if you are short of disk +     space, you can delete the subdirectory `stage1'. + +     On a 68000 or 68020 system lacking floating point hardware, unless +     you have selected a `tm.h' file that expects by default that there +     is no such hardware, do this instead: + +          make CC="stage1/xgcc -Bstage1/" CFLAGS="-g -O2 -msoft-float" + + 13. If you wish to test the compiler by compiling it with itself one +     more time, install any other necessary GNU tools (such as GAS or +     the GNU linker) in the `stage2' subdirectory as you did in the +     `stage1' subdirectory, then do this: + +          make stage2 +          make CC="stage2/xgcc -Bstage2/" CFLAGS="-g -O2" + +     This is called making the stage 3 compiler.  Aside from the `-B' +     option, the compiler options should be the same as when you made +     the stage 2 compiler.  But the `LANGUAGES' option need not be the +     same.  The command shown above builds compilers for all the +     supported languages; if you don't want them all, you can specify +     the languages to build by typing the argument `LANGUAGES="LIST"', +     as described above. + +     If you do not have to install any additional GNU tools, you may +     use the command + +          make bootstrap LANGUAGES=LANGUAGE-LIST BOOT_CFLAGS=OPTION-LIST + +     instead of making `stage1', `stage2', and performing the two +     compiler builds. + + 14. Then compare the latest object files with the stage 2 object +     files--they ought to be identical, aside from time stamps (if any). + +     On some systems, meaningful comparison of object files is +     impossible; they always appear "different."  This is currently +     true on Solaris and some systems that use ELF object file format. +     On some versions of Irix on SGI machines and DEC Unix (OSF/1) on +     Alpha systems, you will not be able to compare the files without +     specifying `-save-temps'; see the description of individual +     systems above to see if you get comparison failures.  You may have +     similar problems on other systems. + +     Use this command to compare the files: + +          make compare + +     This will mention any object files that differ between stage 2 and +     stage 3.  Any difference, no matter how innocuous, indicates that +     the stage 2 compiler has compiled GNU CC incorrectly, and is +     therefore a potentially serious bug which you should investigate +     and report. + +     If your system does not put time stamps in the object files, then +     this is a faster way to compare them (using the Bourne shell): + +          for file in *.o; do +          cmp $file stage2/$file +          done + +     If you have built the compiler with the `-mno-mips-tfile' option on +     MIPS machines, you will not be able to compare the files. + + 15. Install the compiler driver, the compiler's passes and run-time +     support with `make install'.  Use the same value for `CC', +     `CFLAGS' and `LANGUAGES' that you used when compiling the files +     that are being installed.  One reason this is necessary is that +     some versions of Make have bugs and recompile files gratuitously +     when you do this step.  If you use the same variable values, those +     files will be recompiled properly. + +     For example, if you have built the stage 2 compiler, you can use +     the following command: + +          make install CC="stage2/xgcc -Bstage2/" CFLAGS="-g -O" LANGUAGES="LIST" + +     This copies the files `cc1', `cpp' and `libgcc.a' to files `cc1', +     `cpp' and `libgcc.a' in the directory +     `/usr/local/lib/gcc-lib/TARGET/VERSION', which is where the +     compiler driver program looks for them.  Here TARGET is the target +     machine type specified when you ran `configure', and VERSION is +     the version number of GNU CC.  This naming scheme permits various +     versions and/or cross-compilers to coexist. + +     This also copies the driver program `xgcc' into +     `/usr/local/bin/gcc', so that it appears in typical execution +     search paths. + +     On some systems, this command causes recompilation of some files. +     This is usually due to bugs in `make'.  You should either ignore +     this problem, or use GNU Make. + +     *Warning: there is a bug in `alloca' in the Sun library.  To avoid +     this bug, be sure to install the executables of GNU CC that were +     compiled by GNU CC.  (That is, the executables from stage 2 or 3, +     not stage 1.)  They use `alloca' as a built-in function and never +     the one in the library.* + +     (It is usually better to install GNU CC executables from stage 2 +     or 3, since they usually run faster than the ones compiled with +     some other compiler.) + + 16. If you're going to use C++, it's likely that you need to also +     install the libg++ distribution.  It should be available from the +     same place where you got the GNU C distribution.  Just as GNU C +     does not distribute a C runtime library, it also does not include +     a C++ run-time library.  All I/O functionality, special class +     libraries, etc., are available in the libg++ distribution. + +Configurations Supported by GNU CC +================================== + +   Here are the possible CPU types: + +     1750a, a29k, alpha, arm, cN, clipper, dsp16xx, elxsi, h8300, +     hppa1.0, hppa1.1, i370, i386, i486, i586, i860, i960, m68000, m68k, +     m88k, mips, mipsel, mips64, mips64el, ns32k, powerpc, powerpcle, +     pyramid, romp, rs6000, sh, sparc, sparclite, sparc64, vax, we32k. + +   Here are the recognized company names.  As you can see, customary +abbreviations are used rather than the longer official names. + +     acorn, alliant, altos, apollo, att, bull, cbm, convergent, convex, +     crds, dec, dg, dolphin, elxsi, encore, harris, hitachi, hp, ibm, +     intergraph, isi, mips, motorola, ncr, next, ns, omron, plexus, +     sequent, sgi, sony, sun, tti, unicom, wrs. + +   The company name is meaningful only to disambiguate when the rest of +the information supplied is insufficient.  You can omit it, writing +just `CPU-SYSTEM', if it is not needed.  For example, `vax-ultrix4.2' +is equivalent to `vax-dec-ultrix4.2'. + +   Here is a list of system types: + +     386bsd, aix, acis, amigados, aos, aout, bosx, bsd, clix, coff, +     ctix, cxux, dgux, dynix, ebmon, ecoff, elf, esix, freebsd, hms, +     genix, gnu, gnu/linux, hiux, hpux, iris, irix, isc, luna, lynxos, +     mach, minix, msdos, mvs, netbsd, newsos, nindy, ns, osf, osfrose, +     ptx, riscix, riscos, rtu, sco, sim, solaris, sunos, sym, sysv, +     udi, ultrix, unicos, uniplus, unos, vms, vsta, vxworks, winnt, +     xenix. + +You can omit the system type; then `configure' guesses the operating +system from the CPU and company. + +   You can add a version number to the system type; this may or may not +make a difference.  For example, you can write `bsd4.3' or `bsd4.4' to +distinguish versions of BSD.  In practice, the version number is most +needed for `sysv3' and `sysv4', which are often treated differently. + +   If you specify an impossible combination such as `i860-dg-vms', then +you may get an error message from `configure', or it may ignore part of +the information and do the best it can with the rest.  `configure' +always prints the canonical name for the alternative that it used.  GNU +CC does not support all possible alternatives. + +   Often a particular model of machine has a name.  Many machine names +are recognized as aliases for CPU/company combinations.  Thus, the +machine name `sun3', mentioned above, is an alias for `m68k-sun'. +Sometimes we accept a company name as a machine name, when the name is +popularly used for a particular machine.  Here is a table of the known +machine names: + +     3300, 3b1, 3bN, 7300, altos3068, altos, apollo68, att-7300, +     balance, convex-cN, crds, decstation-3100, decstation, delta, +     encore, fx2800, gmicro, hp7NN, hp8NN, hp9k2NN, hp9k3NN, hp9k7NN, +     hp9k8NN, iris4d, iris, isi68, m3230, magnum, merlin, miniframe, +     mmax, news-3600, news800, news, next, pbd, pc532, pmax, powerpc, +     powerpcle, ps2, risc-news, rtpc, sun2, sun386i, sun386, sun3, +     sun4, symmetry, tower-32, tower. + +Remember that a machine name specifies both the cpu type and the company +name.  If you want to install your own homemade configuration files, +you can use `local' as the company name to access them.  If you use +configuration `CPU-local', the configuration name without the cpu prefix +is used to form the configuration file names. + +   Thus, if you specify `m68k-local', configuration uses files +`m68k.md', `local.h', `m68k.c', `xm-local.h', `t-local', and `x-local', +all in the directory `config/m68k'. + +   Here is a list of configurations that have special treatment or +special things you must know: + +`1750a-*-*' +     MIL-STD-1750A processors. + +     Starting with GCC 2.6.1, the MIL-STD-1750A cross configuration no +     longer supports the Tektronix Assembler, but instead produces +     output for `as1750', an assembler/linker available under the GNU +     Public License for the 1750A. Contact *kellogg@space.otn.dasa.de* +     for more details on obtaining `as1750'.  A similarly licensed +     simulator for the 1750A is available from same address. + +     You should ignore a fatal error during the building of libgcc +     (libgcc is not yet implemented for the 1750A.) + +     The `as1750' assembler requires the file `ms1750.inc', which is +     found in the directory `config/1750a'. + +     GNU CC produced the same sections as the Fairchild F9450 C +     Compiler, namely: + +    `Normal' +          The program code section. + +    `Static' +          The read/write (RAM) data section. + +    `Konst' +          The read-only (ROM) constants section. + +    `Init' +          Initialization section (code to copy KREL to SREL). + +     The smallest addressable unit is 16 bits (BITS_PER_UNIT is 16). +     This means that type `char' is represented with a 16-bit word per +     character.  The 1750A's "Load/Store Upper/Lower Byte" instructions +     are not used by GNU CC. + +`alpha-*-osf1' +     Systems using processors that implement the DEC Alpha architecture +     and are running the DEC Unix (OSF/1) operating system, for example +     the DEC Alpha AXP systems.  (VMS on the Alpha is not currently +     supported by GNU CC.) + +     GNU CC writes a `.verstamp' directive to the assembler output file +     unless it is built as a cross-compiler.  It gets the version to +     use from the system header file `/usr/include/stamp.h'.  If you +     install a new version of DEC Unix, you should rebuild GCC to pick +     up the new version stamp. + +     Note that since the Alpha is a 64-bit architecture, +     cross-compilers from 32-bit machines will not generate code as +     efficient as that generated when the compiler is running on a +     64-bit machine because many optimizations that depend on being +     able to represent a word on the target in an integral value on the +     host cannot be performed.  Building cross-compilers on the Alpha +     for 32-bit machines has only been tested in a few cases and may +     not work properly. + +     `make compare' may fail on old versions of DEC Unix unless you add +     `-save-temps' to `CFLAGS'.  On these systems, the name of the +     assembler input file is stored in the object file, and that makes +     comparison fail if it differs between the `stage1' and `stage2' +     compilations.  The option `-save-temps' forces a fixed name to be +     used for the assembler input file, instead of a randomly chosen +     name in `/tmp'.  Do not add `-save-temps' unless the comparisons +     fail without that option.  If you add `-save-temps', you will have +     to manually delete the `.i' and `.s' files after each series of +     compilations. + +     GNU CC now supports both the native (ECOFF) debugging format used +     by DBX and GDB and an encapsulated STABS format for use only with +     GDB.  See the discussion of the `--with-stabs' option of +     `configure' above for more information on these formats and how to +     select them. + +     There is a bug in DEC's assembler that produces incorrect line +     numbers for ECOFF format when the `.align' directive is used.  To +     work around this problem, GNU CC will not emit such alignment +     directives while writing ECOFF format debugging information even +     if optimization is being performed.  Unfortunately, this has the +     very undesirable side-effect that code addresses when `-O' is +     specified are different depending on whether or not `-g' is also +     specified. + +     To avoid this behavior, specify `-gstabs+' and use GDB instead of +     DBX.  DEC is now aware of this problem with the assembler and +     hopes to provide a fix shortly. + +`arm' +     Advanced RISC Machines ARM-family processors.  These are often +     used in embedded applications.  There are no standard Unix +     configurations.  This configuration corresponds to the basic +     instruction sequences and will produce a.out format object modules. + +     You may need to make a variant of the file `arm.h' for your +     particular configuration. + +`arm-*-riscix' +     The ARM2 or ARM3 processor running RISC iX, Acorn's port of BSD +     Unix.  If you are running a version of RISC iX prior to 1.2 then +     you must specify the version number during configuration.  Note +     that the assembler shipped with RISC iX does not support stabs +     debugging information; a new version of the assembler, with stabs +     support included, is now available from Acorn. + +`a29k' +     AMD Am29k-family processors.  These are normally used in embedded +     applications.  There are no standard Unix configurations.  This +     configuration corresponds to AMD's standard calling sequence and +     binary interface and is compatible with other 29k tools. + +     You may need to make a variant of the file `a29k.h' for your +     particular configuration. + +`a29k-*-bsd' +     AMD Am29050 used in a system running a variant of BSD Unix. + +`decstation-*' +     DECstations can support three different personalities: Ultrix, DEC +     OSF/1, and OSF/rose.  To configure GCC for these platforms use the +     following configurations: + +    `decstation-ultrix' +          Ultrix configuration. + +    `decstation-osf1' +          Dec's version of OSF/1. + +    `decstation-osfrose' +          Open Software Foundation reference port of OSF/1 which uses +          the OSF/rose object file format instead of ECOFF.  Normally, +          you would not select this configuration. + +     The MIPS C compiler needs to be told to increase its table size +     for switch statements with the `-Wf,-XNg1500' option in order to +     compile `cp/parse.c'.  If you use the `-O2' optimization option, +     you also need to use `-Olimit 3000'.  Both of these options are +     automatically generated in the `Makefile' that the shell script +     `configure' builds.  If you override the `CC' make variable and +     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit +     3000'. + +`elxsi-elxsi-bsd' +     The Elxsi's C compiler has known limitations that prevent it from +     compiling GNU C.  Please contact `mrs@cygnus.com' for more details. + +`dsp16xx' +     A port to the AT&T DSP1610 family of processors. + +`h8300-*-*' +     The calling convention and structure layout has changed in release +     2.6.  All code must be recompiled.  The calling convention now +     passes the first three arguments in function calls in registers. +     Structures are no longer a multiple of 2 bytes. + +`hppa*-*-*' +     There are several variants of the HP-PA processor which run a +     variety of operating systems.  GNU CC must be configured to use +     the correct processor type and operating system, or GNU CC will +     not function correctly.  The easiest way to handle this problem is +     to *not* specify a target when configuring GNU CC, the `configure' +     script will try to automatically determine the right processor +     type and operating system. + +     `-g' does not work on HP-UX, since that system uses a peculiar +     debugging format which GNU CC does not know about.  However, `-g' +     will work if you also use GAS and GDB in conjunction with GCC.  We +     highly recommend using GAS for all HP-PA configurations. + +     You should be using GAS-2.6 (or later) along with GDB-4.16 (or +     later).  These can be retrieved from all the traditional GNU ftp +     archive sites. + +     GAS will need to be installed into a directory before `/bin', +     `/usr/bin', and `/usr/ccs/bin' in your search path.  You should +     install GAS before you build GNU CC. + +     To enable debugging, you must configure GNU CC with the +     `--with-gnu-as' option before building. + +`i370-*-*' +     This port is very preliminary and has many known bugs.  We hope to +     have a higher-quality port for this machine soon. + +`i386-*-linuxoldld' +     Use this configuration to generate a.out binaries on Linux-based +     GNU systems, if you do not have gas/binutils version 2.5.2 or later +     installed.  This is an obsolete configuration. + +`i386-*-linuxaout' +     Use this configuration to generate a.out binaries on Linux-based +     GNU systems.  This configuration is being superseded.  You must use +     gas/binutils version 2.5.2 or later. + +`i386-*-linux' +     Use this configuration to generate ELF binaries on Linux-based GNU +     systems.  You must use gas/binutils version 2.5.2 or later. + +`i386-*-sco' +     Compilation with RCC is recommended.  Also, it may be a good idea +     to link with GNU malloc instead of the malloc that comes with the +     system. + +`i386-*-sco3.2v4' +     Use this configuration for SCO release 3.2 version 4. + +`i386-*-isc' +     It may be a good idea to link with GNU malloc instead of the +     malloc that comes with the system. + +     In ISC version 4.1, `sed' core dumps when building `deduced.h'. +     Use the version of `sed' from version 4.0. + +`i386-*-esix' +     It may be good idea to link with GNU malloc instead of the malloc +     that comes with the system. + +`i386-ibm-aix' +     You need to use GAS version 2.1 or later, and and LD from GNU +     binutils version 2.2 or later. + +`i386-sequent-bsd' +     Go to the Berkeley universe before compiling.  In addition, you +     probably need to create a file named `string.h' containing just +     one line: `#include <strings.h>'. + +`i386-sequent-ptx1*' +     Sequent DYNIX/ptx 1.x. + +`i386-sequent-ptx2*' +     Sequent DYNIX/ptx 2.x. + +`i386-sun-sunos4' +     You may find that you need another version of GNU CC to begin +     bootstrapping with, since the current version when built with the +     system's own compiler seems to get an infinite loop compiling part +     of `libgcc2.c'.  GNU CC version 2 compiled with GNU CC (any +     version) seems not to have this problem. + +     See *Note Sun Install::, for information on installing GNU CC on +     Sun systems. + +`i[345]86-*-winnt3.5' +     This version requires a GAS that has not let been released.  Until +     it is, you can get a prebuilt binary version via anonymous ftp from +     `cs.washington.edu:pub/gnat' or `cs.nyu.edu:pub/gnat'. You must +     also use the Microsoft header files from the Windows NT 3.5 SDK. +     Find these on the CDROM in the `/mstools/h' directory dated +     9/4/94.  You must use a fixed version of Microsoft linker made +     especially for NT 3.5, which is also is available on the NT 3.5 +     SDK CDROM.  If you do not have this linker, can you also use the +     linker from Visual C/C++ 1.0 or 2.0. + +     Installing GNU CC for NT builds a wrapper linker, called `ld.exe', +     which mimics the behaviour of Unix `ld' in the specification of +     libraries (`-L' and `-l').  `ld.exe' looks for both Unix and +     Microsoft named libraries.  For example, if you specify `-lfoo', +     `ld.exe' will look first for `libfoo.a' and then for `foo.lib'. + +     You may install GNU CC for Windows NT in one of two ways, +     depending on whether or not you have a Unix-like shell and various +     Unix-like utilities. + +       1. If you do not have a Unix-like shell and few Unix-like +          utilities, you will use a DOS style batch script called +          `configure.bat'.  Invoke it as `configure winnt' from an +          MSDOS console window or from the program manager dialog box. +          `configure.bat' assumes you have already installed and have +          in your path a Unix-like `sed' program which is used to +          create a working `Makefile' from `Makefile.in'. + +          `Makefile' uses the Microsoft Nmake program maintenance +          utility and the Visual C/C++ V8.00 compiler to build GNU CC. +          You need only have the utilities `sed' and `touch' to use +          this installation method, which only automatically builds the +          compiler itself.  You must then examine what `fixinc.winnt' +          does, edit the header files by hand and build `libgcc.a' +          manually. + +       2. The second type of installation assumes you are running a +          Unix-like shell, have a complete suite of Unix-like utilities +          in your path, and have a previous version of GNU CC already +          installed, either through building it via the above +          installation method or acquiring a pre-built binary.  In this +          case, use the `configure' script in the normal fashion. + +`i860-intel-osf1' +     This is the Paragon.  If you have version 1.0 of the operating +     system, you need to take special steps to build GNU CC due to +     peculiarities of the system.  Newer system versions have no +     problem.  See the section `Installation Problems' in the GNU CC +     Manual. + +`*-lynx-lynxos' +     LynxOS 2.2 and earlier comes with GNU CC 1.x already installed as +     `/bin/gcc'.  You should compile with this instead of `/bin/cc'. +     You can tell GNU CC to use the GNU assembler and linker, by +     specifying `--with-gnu-as --with-gnu-ld' when configuring.  These +     will produce COFF format object files and executables;  otherwise +     GNU CC will use the installed tools, which produce a.out format +     executables. + +`m68000-hp-bsd' +     HP 9000 series 200 running BSD.  Note that the C compiler that +     comes with this system cannot compile GNU CC; contact +     `law@cs.utah.edu' to get binaries of GNU CC for bootstrapping. + +`m68k-altos' +     Altos 3068.  You must use the GNU assembler, linker and debugger. +     Also, you must fix a kernel bug.  Details in the file +     `README.ALTOS'. + +`m68k-att-sysv' +     AT&T 3b1, a.k.a. 7300 PC.  Special procedures are needed to +     compile GNU CC with this machine's standard C compiler, due to +     bugs in that compiler.  You can bootstrap it more easily with +     previous versions of GNU CC if you have them. + +     Installing GNU CC on the 3b1 is difficult if you do not already +     have GNU CC running, due to bugs in the installed C compiler. +     However, the following procedure might work.  We are unable to +     test it. + +       1. Comment out the `#include "config.h"' line on line 37 of +          `cccp.c' and do `make cpp'.  This makes a preliminary version +          of GNU cpp. + +       2. Save the old `/lib/cpp' and copy the preliminary GNU cpp to +          that file name. + +       3. Undo your change in `cccp.c', or reinstall the original +          version, and do `make cpp' again. + +       4. Copy this final version of GNU cpp into `/lib/cpp'. + +       5. Replace every occurrence of `obstack_free' in the file +          `tree.c' with `_obstack_free'. + +       6. Run `make' to get the first-stage GNU CC. + +       7. Reinstall the original version of `/lib/cpp'. + +       8. Now you can compile GNU CC with itself and install it in the +          normal fashion. + +`m68k-bull-sysv' +     Bull DPX/2 series 200 and 300 with BOS-2.00.45 up to BOS-2.01. GNU +     CC works either with native assembler or GNU assembler. You can use +     GNU assembler with native coff generation by providing +     `--with-gnu-as' to the configure script or use GNU assembler with +     dbx-in-coff encapsulation by providing `--with-gnu-as --stabs'. +     For any problem with native assembler or for availability of the +     DPX/2 port of GAS, contact `F.Pierresteguy@frcl.bull.fr'. + +`m68k-crds-unox' +     Use `configure unos' for building on Unos. + +     The Unos assembler is named `casm' instead of `as'.  For some +     strange reason linking `/bin/as' to `/bin/casm' changes the +     behavior, and does not work.  So, when installing GNU CC, you +     should install the following script as `as' in the subdirectory +     where the passes of GCC are installed: + +          #!/bin/sh +          casm $* + +     The default Unos library is named `libunos.a' instead of `libc.a'. +     To allow GNU CC to function, either change all references to +     `-lc' in `gcc.c' to `-lunos' or link `/lib/libc.a' to +     `/lib/libunos.a'. + +     When compiling GNU CC with the standard compiler, to overcome bugs +     in the support of `alloca', do not use `-O' when making stage 2. +     Then use the stage 2 compiler with `-O' to make the stage 3 +     compiler.  This compiler will have the same characteristics as the +     usual stage 2 compiler on other systems.  Use it to make a stage 4 +     compiler and compare that with stage 3 to verify proper +     compilation. + +     (Perhaps simply defining `ALLOCA' in `x-crds' as described in the +     comments there will make the above paragraph superfluous.  Please +     inform us of whether this works.) + +     Unos uses memory segmentation instead of demand paging, so you +     will need a lot of memory.  5 Mb is barely enough if no other +     tasks are running.  If linking `cc1' fails, try putting the object +     files into a library and linking from that library. + +`m68k-hp-hpux' +     HP 9000 series 300 or 400 running HP-UX.  HP-UX version 8.0 has a +     bug in the assembler that prevents compilation of GNU CC.  To fix +     it, get patch PHCO_4484 from HP. + +     In addition, if you wish to use gas `--with-gnu-as' you must use +     gas version 2.1 or later, and you must use the GNU linker version +     2.1 or later.  Earlier versions of gas relied upon a program which +     converted the gas output into the native HP/UX format, but that +     program has not been kept up to date.  gdb does not understand +     that native HP/UX format, so you must use gas if you wish to use +     gdb. + +`m68k-sun' +     Sun 3.  We do not provide a configuration file to use the Sun FPA +     by default, because programs that establish signal handlers for +     floating point traps inherently cannot work with the FPA. + +     See *Note Sun Install::, for information on installing GNU CC on +     Sun systems. + +`m88k-*-svr3' +     Motorola m88k running the AT&T/Unisoft/Motorola V.3 reference port. +     These systems tend to use the Green Hills C, revision 1.8.5, as the +     standard C compiler.  There are apparently bugs in this compiler +     that result in object files differences between stage 2 and stage +     3.  If this happens, make the stage 4 compiler and compare it to +     the stage 3 compiler.  If the stage 3 and stage 4 object files are +     identical, this suggests you encountered a problem with the +     standard C compiler; the stage 3 and 4 compilers may be usable. + +     It is best, however, to use an older version of GNU CC for +     bootstrapping if you have one. + +`m88k-*-dgux' +     Motorola m88k running DG/UX.  To build 88open BCS native or cross +     compilers on DG/UX, specify the configuration name as +     `m88k-*-dguxbcs' and build in the 88open BCS software development +     environment.  To build ELF native or cross compilers on DG/UX, +     specify `m88k-*-dgux' and build in the DG/UX ELF development +     environment.  You set the software development environment by +     issuing `sde-target' command and specifying either `m88kbcs' or +     `m88kdguxelf' as the operand. + +     If you do not specify a configuration name, `configure' guesses the +     configuration based on the current software development +     environment. + +`m88k-tektronix-sysv3' +     Tektronix XD88 running UTekV 3.2e.  Do not turn on optimization +     while building stage1 if you bootstrap with the buggy Green Hills +     compiler.  Also, The bundled LAI System V NFS is buggy so if you +     build in an NFS mounted directory, start from a fresh reboot, or +     avoid NFS all together.  Otherwise you may have trouble getting +     clean comparisons between stages. + +`mips-mips-bsd' +     MIPS machines running the MIPS operating system in BSD mode.  It's +     possible that some old versions of the system lack the functions +     `memcpy', `memcmp', and `memset'.  If your system lacks these, you +     must remove or undo the definition of `TARGET_MEM_FUNCTIONS' in +     `mips-bsd.h'. + +     The MIPS C compiler needs to be told to increase its table size +     for switch statements with the `-Wf,-XNg1500' option in order to +     compile `cp/parse.c'.  If you use the `-O2' optimization option, +     you also need to use `-Olimit 3000'.  Both of these options are +     automatically generated in the `Makefile' that the shell script +     `configure' builds.  If you override the `CC' make variable and +     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit +     3000'. + +`mips-mips-riscos*' +     The MIPS C compiler needs to be told to increase its table size +     for switch statements with the `-Wf,-XNg1500' option in order to +     compile `cp/parse.c'.  If you use the `-O2' optimization option, +     you also need to use `-Olimit 3000'.  Both of these options are +     automatically generated in the `Makefile' that the shell script +     `configure' builds.  If you override the `CC' make variable and +     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit +     3000'. + +     MIPS computers running RISC-OS can support four different +     personalities: default, BSD 4.3, System V.3, and System V.4 (older +     versions of RISC-OS don't support V.4).  To configure GCC for +     these platforms use the following configurations: + +    `mips-mips-riscos`rev'' +          Default configuration for RISC-OS, revision `rev'. + +    `mips-mips-riscos`rev'bsd' +          BSD 4.3 configuration for RISC-OS, revision `rev'. + +    `mips-mips-riscos`rev'sysv4' +          System V.4 configuration for RISC-OS, revision `rev'. + +    `mips-mips-riscos`rev'sysv' +          System V.3 configuration for RISC-OS, revision `rev'. + +     The revision `rev' mentioned above is the revision of RISC-OS to +     use.  You must reconfigure GCC when going from a RISC-OS revision +     4 to RISC-OS revision 5.  This has the effect of avoiding a linker +     bug. + +`mips-sgi-*' +     In order to compile GCC on an SGI running IRIX 4, the "c.hdr.lib" +     option must be installed from the CD-ROM supplied from Silicon +     Graphics.  This is found on the 2nd CD in release 4.0.1. + +     In order to compile GCC on an SGI running IRIX 5, the +     "compiler_dev.hdr" subsystem must be installed from the IDO CD-ROM +     supplied by Silicon Graphics. + +     `make compare' may fail on version 5 of IRIX unless you add +     `-save-temps' to `CFLAGS'.  On these systems, the name of the +     assembler input file is stored in the object file, and that makes +     comparison fail if it differs between the `stage1' and `stage2' +     compilations.  The option `-save-temps' forces a fixed name to be +     used for the assembler input file, instead of a randomly chosen +     name in `/tmp'.  Do not add `-save-temps' unless the comparisons +     fail without that option.  If you do you `-save-temps', you will +     have to manually delete the `.i' and `.s' files after each series +     of compilations. + +     The MIPS C compiler needs to be told to increase its table size +     for switch statements with the `-Wf,-XNg1500' option in order to +     compile `cp/parse.c'.  If you use the `-O2' optimization option, +     you also need to use `-Olimit 3000'.  Both of these options are +     automatically generated in the `Makefile' that the shell script +     `configure' builds.  If you override the `CC' make variable and +     use the MIPS compilers, you may need to add `-Wf,-XNg1500 -Olimit +     3000'. + +     On Irix version 4.0.5F, and perhaps on some other versions as well, +     there is an assembler bug that reorders instructions incorrectly. +     To work around it, specify the target configuration +     `mips-sgi-irix4loser'.  This configuration inhibits assembler +     optimization. + +     In a compiler configured with target `mips-sgi-irix4', you can turn +     off assembler optimization by using the `-noasmopt' option.  This +     compiler option passes the option `-O0' to the assembler, to +     inhibit reordering. + +     The `-noasmopt' option can be useful for testing whether a problem +     is due to erroneous assembler reordering.  Even if a problem does +     not go away with `-noasmopt', it may still be due to assembler +     reordering--perhaps GNU CC itself was miscompiled as a result. + +     To enable debugging under Irix 5, you must use GNU as 2.5 or later, +     and use the `--with-gnu-as' configure option when configuring gcc. +     GNU as is distributed as part of the binutils package. + +`mips-sony-sysv' +     Sony MIPS NEWS.  This works in NEWSOS 5.0.1, but not in 5.0.2 +     (which uses ELF instead of COFF).  Support for 5.0.2 will probably +     be provided soon by volunteers.  In particular, the linker does +     not like the code generated by GCC when shared libraries are +     linked in. + +`ns32k-encore' +     Encore ns32000 system.  Encore systems are supported only under +     BSD. + +`ns32k-*-genix' +     National Semiconductor ns32000 system.  Genix has bugs in `alloca' +     and `malloc'; you must get the compiled versions of these from GNU +     Emacs. + +`ns32k-sequent' +     Go to the Berkeley universe before compiling.  In addition, you +     probably need to create a file named `string.h' containing just +     one line: `#include <strings.h>'. + +`ns32k-utek' +     UTEK ns32000 system ("merlin").  The C compiler that comes with +     this system cannot compile GNU CC; contact `tektronix!reed!mason' +     to get binaries of GNU CC for bootstrapping. + +`romp-*-aos' +`romp-*-mach' +     The only operating systems supported for the IBM RT PC are AOS and +     MACH.  GNU CC does not support AIX running on the RT.  We +     recommend you compile GNU CC with an earlier version of itself; if +     you compile GNU CC with `hc', the Metaware compiler, it will work, +     but you will get mismatches between the stage 2 and stage 3 +     compilers in various files.  These errors are minor differences in +     some floating-point constants and can be safely ignored; the stage +     3 compiler is correct. + +`rs6000-*-aix' +`powerpc-*-aix' +     Various early versions of each release of the IBM XLC compiler +     will not bootstrap GNU CC.  Symptoms include differences between +     the stage2 and stage3 object files, and errors when compiling +     `libgcc.a' or `enquire'.  Known problematic releases include: +     xlc-1.2.1.8, xlc-1.3.0.0 (distributed with AIX 3.2.5), and +     xlc-1.3.0.19.  Both xlc-1.2.1.28 and xlc-1.3.0.24 (PTF 432238) are +     known to produce working versions of GNU CC, but most other recent +     releases correctly bootstrap GNU CC.  Also, releases of AIX prior +     to AIX 3.2.4 include a version of the IBM assembler which does not +     accept debugging directives: assembler updates are available as +     PTFs.  Also, if you are using AIX 3.2.5 or greater and the GNU +     assembler, you must have a version modified after October 16th, +     1995 in order for the GNU C compiler to build.  See the file +     `README.RS6000' for more details on of these problems. + +     GNU CC does not yet support the 64-bit PowerPC instructions. + +     Objective C does not work on this architecture because it makes +     assumptions that are incompatible with the calling conventions. + +     AIX on the RS/6000 provides support (NLS) for environments outside +     of the United States.  Compilers and assemblers use NLS to support +     locale-specific representations of various objects including +     floating-point numbers ("." vs "," for separating decimal +     fractions).  There have been problems reported where the library +     linked with GNU CC does not produce the same floating-point +     formats that the assembler accepts.  If you have this problem, set +     the LANG environment variable to "C" or "En_US". + +     Due to changes in the way that GNU CC invokes the binder (linker) +     for AIX 4.1, you may now receive warnings of duplicate symbols +     from the link step that were not reported before.  The assembly +     files generated by GNU CC for AIX have always included multiple +     symbol definitions for certain global variable and function +     declarations in the original program.  The warnings should not +     prevent the linker from producing a correct library or runnable +     executable. + +`powerpc-*-elf' +`powerpc-*-sysv4' +     PowerPC system in big endian mode, running System V.4. + +     This configuration is currently under development. + +`powerpc-*-eabiaix' +     Embedded PowerPC system in big endian mode with -mcall-aix +     selected as the default.  This system is currently under +     development. + +`powerpc-*-eabisim' +     Embedded PowerPC system in big endian mode for use in running +     under the PSIM simulator.  This system is currently under +     development. + +`powerpc-*-eabi' +     Embedded PowerPC system in big endian mode. + +     This configuration is currently under development. + +`powerpcle-*-elf' +`powerpcle-*-sysv4' +     PowerPC system in little endian mode, running System V.4. + +     This configuration is currently under development. + +`powerpcle-*-sysv4' +     Embedded PowerPC system in little endian mode. + +     This system is currently under development. + +`powerpcle-*-eabisim' +     Embedded PowerPC system in little endian mode for use in running +     under the PSIM simulator. + +     This system is currently under development. + +`powerpcle-*-eabi' +     Embedded PowerPC system in little endian mode. + +     This configuration is currently under development. + +`vax-dec-ultrix' +     Don't try compiling with Vax C (`vcc').  It produces incorrect code +     in some cases (for example, when `alloca' is used). + +     Meanwhile, compiling `cp/parse.c' with pcc does not work because of +     an internal table size limitation in that compiler.  To avoid this +     problem, compile just the GNU C compiler first, and use it to +     recompile building all the languages that you want to run. + +`sparc-sun-*' +     See *Note Sun Install::, for information on installing GNU CC on +     Sun systems. + +`vax-dec-vms' +     See *Note VMS Install::, for details on how to install GNU CC on +     VMS. + +`we32k-*-*' +     These computers are also known as the 3b2, 3b5, 3b20 and other +     similar names.  (However, the 3b1 is actually a 68000; see *Note +     Configurations::.) + +     Don't use `-g' when compiling with the system's compiler.  The +     system's linker seems to be unable to handle such a large program +     with debugging information. + +     The system's compiler runs out of capacity when compiling `stmt.c' +     in GNU CC.  You can work around this by building `cpp' in GNU CC +     first, then use that instead of the system's preprocessor with the +     system's C compiler to compile `stmt.c'.  Here is how: + +          mv /lib/cpp /lib/cpp.att +          cp cpp /lib/cpp.gnu +          echo '/lib/cpp.gnu -traditional ${1+"$@"}' > /lib/cpp +          chmod +x /lib/cpp + +     The system's compiler produces bad code for some of the GNU CC +     optimization files.  So you must build the stage 2 compiler without +     optimization.  Then build a stage 3 compiler with optimization. +     That executable should work.  Here are the necessary commands: + +          make LANGUAGES=c CC=stage1/xgcc CFLAGS="-Bstage1/ -g" +          make stage2 +          make CC=stage2/xgcc CFLAGS="-Bstage2/ -g -O" + +     You may need to raise the ULIMIT setting to build a C++ compiler, +     as the file `cc1plus' is larger than one megabyte. + +Compilation in a Separate Directory +=================================== + +   If you wish to build the object files and executables in a directory +other than the one containing the source files, here is what you must +do differently: + +  1. Make sure you have a version of Make that supports the `VPATH' +     feature.  (GNU Make supports it, as do Make versions on most BSD +     systems.) + +  2. If you have ever run `configure' in the source directory, you must +     undo the configuration.  Do this by running: + +          make distclean + +  3. Go to the directory in which you want to build the compiler before +     running `configure': + +          mkdir gcc-sun3 +          cd gcc-sun3 + +     On systems that do not support symbolic links, this directory must +     be on the same file system as the source code directory. + +  4. Specify where to find `configure' when you run it: + +          ../gcc/configure ... + +     This also tells `configure' where to find the compiler sources; +     `configure' takes the directory from the file name that was used to +     invoke it.  But if you want to be sure, you can specify the source +     directory with the `--srcdir' option, like this: + +          ../gcc/configure --srcdir=../gcc OTHER OPTIONS + +     The directory you specify with `--srcdir' need not be the same as +     the one that `configure' is found in. + +   Now, you can run `make' in that directory.  You need not repeat the +configuration steps shown above, when ordinary source files change.  You +must, however, run `configure' again when the configuration files +change, if your system does not support symbolic links. + +Building and Installing a Cross-Compiler +======================================== + +   GNU CC can function as a cross-compiler for many machines, but not +all. + +   * Cross-compilers for the Mips as target using the Mips assembler +     currently do not work, because the auxiliary programs +     `mips-tdump.c' and `mips-tfile.c' can't be compiled on anything +     but a Mips.  It does work to cross compile for a Mips if you use +     the GNU assembler and linker. + +   * Cross-compilers between machines with different floating point +     formats have not all been made to work.  GNU CC now has a floating +     point emulator with which these can work, but each target machine +     description needs to be updated to take advantage of it. + +   * Cross-compilation between machines of different word sizes is +     somewhat problematic and sometimes does not work. + +   Since GNU CC generates assembler code, you probably need a +cross-assembler that GNU CC can run, in order to produce object files. +If you want to link on other than the target machine, you need a +cross-linker as well.  You also need header files and libraries suitable +for the target machine that you can install on the host machine. + +Steps of Cross-Compilation +-------------------------- + +   To compile and run a program using a cross-compiler involves several +steps: + +   * Run the cross-compiler on the host machine to produce assembler +     files for the target machine.  This requires header files for the +     target machine. + +   * Assemble the files produced by the cross-compiler.  You can do this +     either with an assembler on the target machine, or with a +     cross-assembler on the host machine. + +   * Link those files to make an executable.  You can do this either +     with a linker on the target machine, or with a cross-linker on the +     host machine.  Whichever machine you use, you need libraries and +     certain startup files (typically `crt....o') for the target +     machine. + +   It is most convenient to do all of these steps on the same host +machine, since then you can do it all with a single invocation of GNU +CC.  This requires a suitable cross-assembler and cross-linker.  For +some targets, the GNU assembler and linker are available. + +Configuring a Cross-Compiler +---------------------------- + +   To build GNU CC as a cross-compiler, you start out by running +`configure'.  Use the `--target=TARGET' to specify the target type.  If +`configure' was unable to correctly identify the system you are running +on, also specify the `--build=BUILD' option.  For example, here is how +to configure for a cross-compiler that produces code for an HP 68030 +system running BSD on a system that `configure' can correctly identify: + +     ./configure --target=m68k-hp-bsd4.3 + +Tools and Libraries for a Cross-Compiler +---------------------------------------- + +   If you have a cross-assembler and cross-linker available, you should +install them now.  Put them in the directory `/usr/local/TARGET/bin'. +Here is a table of the tools you should put in this directory: + +`as' +     This should be the cross-assembler. + +`ld' +     This should be the cross-linker. + +`ar' +     This should be the cross-archiver: a program which can manipulate +     archive files (linker libraries) in the target machine's format. + +`ranlib' +     This should be a program to construct a symbol table in an archive +     file. + +   The installation of GNU CC will find these programs in that +directory, and copy or link them to the proper place to for the +cross-compiler to find them when run later. + +   The easiest way to provide these files is to build the Binutils +package and GAS.  Configure them with the same `--host' and `--target' +options that you use for configuring GNU CC, then build and install +them.  They install their executables automatically into the proper +directory.  Alas, they do not support all the targets that GNU CC +supports. + +   If you want to install libraries to use with the cross-compiler, +such as a standard C library, put them in the directory +`/usr/local/TARGET/lib'; installation of GNU CC copies all all the +files in that subdirectory into the proper place for GNU CC to find +them and link with them.  Here's an example of copying some libraries +from a target machine: + +     ftp TARGET-MACHINE +     lcd /usr/local/TARGET/lib +     cd /lib +     get libc.a +     cd /usr/lib +     get libg.a +     get libm.a +     quit + +The precise set of libraries you'll need, and their locations on the +target machine, vary depending on its operating system. + +   Many targets require "start files" such as `crt0.o' and `crtn.o' +which are linked into each executable; these too should be placed in +`/usr/local/TARGET/lib'.  There may be several alternatives for +`crt0.o', for use with profiling or other compilation options.  Check +your target's definition of `STARTFILE_SPEC' to find out what start +files it uses.  Here's an example of copying these files from a target +machine: + +     ftp TARGET-MACHINE +     lcd /usr/local/TARGET/lib +     prompt +     cd /lib +     mget *crt*.o +     cd /usr/lib +     mget *crt*.o +     quit + +`libgcc.a' and Cross-Compilers +------------------------------ + +   Code compiled by GNU CC uses certain runtime support functions +implicitly.  Some of these functions can be compiled successfully with +GNU CC itself, but a few cannot be.  These problem functions are in the +source file `libgcc1.c'; the library made from them is called +`libgcc1.a'. + +   When you build a native compiler, these functions are compiled with +some other compiler-the one that you use for bootstrapping GNU CC. +Presumably it knows how to open code these operations, or else knows how +to call the run-time emulation facilities that the machine comes with. +But this approach doesn't work for building a cross-compiler.  The +compiler that you use for building knows about the host system, not the +target system. + +   So, when you build a cross-compiler you have to supply a suitable +library `libgcc1.a' that does the job it is expected to do. + +   To compile `libgcc1.c' with the cross-compiler itself does not work. +The functions in this file are supposed to implement arithmetic +operations that GNU CC does not know how to open code for your target +machine.  If these functions are compiled with GNU CC itself, they will +compile into infinite recursion. + +   On any given target, most of these functions are not needed.  If GNU +CC can open code an arithmetic operation, it will not call these +functions to perform the operation.  It is possible that on your target +machine, none of these functions is needed.  If so, you can supply an +empty library as `libgcc1.a'. + +   Many targets need library support only for multiplication and +division.  If you are linking with a library that contains functions for +multiplication and division, you can tell GNU CC to call them directly +by defining the macros `MULSI3_LIBCALL', and the like.  These macros +need to be defined in the target description macro file.  For some +targets, they are defined already.  This may be sufficient to avoid the +need for libgcc1.a; if so, you can supply an empty library. + +   Some targets do not have floating point instructions; they need other +functions in `libgcc1.a', which do floating arithmetic.  Recent +versions of GNU CC have a file which emulates floating point.  With a +certain amount of work, you should be able to construct a floating +point emulator that can be used as `libgcc1.a'.  Perhaps future +versions will contain code to do this automatically and conveniently. +That depends on whether someone wants to implement it. + +   Some embedded targets come with all the necessary `libgcc1.a' +routines written in C or assembler.  These targets build `libgcc1.a' +automatically and you do not need to do anything special for them. +Other embedded targets do not need any `libgcc1.a' routines since all +the necessary operations are supported by the hardware. + +   If your target system has another C compiler, you can configure GNU +CC as a native compiler on that machine, build just `libgcc1.a' with +`make libgcc1.a' on that machine, and use the resulting file with the +cross-compiler.  To do this, execute the following on the target +machine: + +     cd TARGET-BUILD-DIR +     ./configure --host=sparc --target=sun3 +     make libgcc1.a + +And then this on the host machine: + +     ftp TARGET-MACHINE +     binary +     cd TARGET-BUILD-DIR +     get libgcc1.a +     quit + +   Another way to provide the functions you need in `libgcc1.a' is to +define the appropriate `perform_...' macros for those functions.  If +these definitions do not use the C arithmetic operators that they are +meant to implement, you should be able to compile them with the +cross-compiler you are building.  (If these definitions already exist +for your target file, then you are all set.) + +   To build `libgcc1.a' using the perform macros, use +`LIBGCC1=libgcc1.a OLDCC=./xgcc' when building the compiler. +Otherwise, you should place your replacement library under the name +`libgcc1.a' in the directory in which you will build the +cross-compiler, before you run `make'. + +Cross-Compilers and Header Files +-------------------------------- + +   If you are cross-compiling a standalone program or a program for an +embedded system, then you may not need any header files except the few +that are part of GNU CC (and those of your program).  However, if you +intend to link your program with a standard C library such as `libc.a', +then you probably need to compile with the header files that go with +the library you use. + +   The GNU C compiler does not come with these files, because (1) they +are system-specific, and (2) they belong in a C library, not in a +compiler. + +   If the GNU C library supports your target machine, then you can get +the header files from there (assuming you actually use the GNU library +when you link your program). + +   If your target machine comes with a C compiler, it probably comes +with suitable header files also.  If you make these files accessible +from the host machine, the cross-compiler can use them also. + +   Otherwise, you're on your own in finding header files to use when +cross-compiling. + +   When you have found suitable header files, put them in +`/usr/local/TARGET/include', before building the cross compiler.  Then +installation will run fixincludes properly and install the corrected +versions of the header files where the compiler will use them. + +   Provide the header files before you build the cross-compiler, because +the build stage actually runs the cross-compiler to produce parts of +`libgcc.a'.  (These are the parts that *can* be compiled with GNU CC.) +Some of them need suitable header files. + +   Here's an example showing how to copy the header files from a target +machine.  On the target machine, do this: + +     (cd /usr/include; tar cf - .) > tarfile + +   Then, on the host machine, do this: + +     ftp TARGET-MACHINE +     lcd /usr/local/TARGET/include +     get tarfile +     quit +     tar xf tarfile + +Actually Building the Cross-Compiler +------------------------------------ + +   Now you can proceed just as for compiling a single-machine compiler +through the step of building stage 1.  If you have not provided some +sort of `libgcc1.a', then compilation will give up at the point where +it needs that file, printing a suitable error message.  If you do +provide `libgcc1.a', then building the compiler will automatically +compile and link a test program called `libgcc1-test'; if you get +errors in the linking, it means that not all of the necessary routines +in `libgcc1.a' are available. + +   You must provide the header file `float.h'.  One way to do this is +to compile `enquire' and run it on your target machine.  The job of +`enquire' is to run on the target machine and figure out by experiment +the nature of its floating point representation.  `enquire' records its +findings in the header file `float.h'.  If you can't produce this file +by running `enquire' on the target machine, then you will need to come +up with a suitable `float.h' in some other way (or else, avoid using it +in your programs). + +   Do not try to build stage 2 for a cross-compiler.  It doesn't work to +rebuild GNU CC as a cross-compiler using the cross-compiler, because +that would produce a program that runs on the target machine, not on the +host.  For example, if you compile a 386-to-68030 cross-compiler with +itself, the result will not be right either for the 386 (because it was +compiled into 68030 code) or for the 68030 (because it was configured +for a 386 as the host).  If you want to compile GNU CC into 68030 code, +whether you compile it on a 68030 or with a cross-compiler on a 386, you +must specify a 68030 as the host when you configure it. + +   To install the cross-compiler, use `make install', as usual. + +Installing GNU CC on the Sun +============================ + +   On Solaris (version 2.1), do not use the linker or other tools in +`/usr/ucb' to build GNU CC.  Use `/usr/ccs/bin'. + +   Make sure the environment variable `FLOAT_OPTION' is not set when +you compile `libgcc.a'.  If this option were set to `f68881' when +`libgcc.a' is compiled, the resulting code would demand to be linked +with a special startup file and would not link properly without special +pains. + +   There is a bug in `alloca' in certain versions of the Sun library. +To avoid this bug, install the binaries of GNU CC that were compiled by +GNU CC.  They use `alloca' as a built-in function and never the one in +the library. + +   Some versions of the Sun compiler crash when compiling GNU CC.  The +problem is a segmentation fault in cpp.  This problem seems to be due to +the bulk of data in the environment variables.  You may be able to avoid +it by using the following command to compile GNU CC with Sun CC: + +     make CC="TERMCAP=x OBJS=x LIBFUNCS=x STAGESTUFF=x cc" + +Installing GNU CC on VMS +======================== + +   The VMS version of GNU CC is distributed in a backup saveset +containing both source code and precompiled binaries. + +   To install the `gcc' command so you can use the compiler easily, in +the same manner as you use the VMS C compiler, you must install the VMS +CLD file for GNU CC as follows: + +  1. Define the VMS logical names `GNU_CC' and `GNU_CC_INCLUDE' to +     point to the directories where the GNU CC executables +     (`gcc-cpp.exe', `gcc-cc1.exe', etc.) and the C include files are +     kept respectively.  This should be done with the commands: + +          $ assign /system /translation=concealed - +            disk:[gcc.] gnu_cc +          $ assign /system /translation=concealed - +            disk:[gcc.include.] gnu_cc_include + +     with the appropriate disk and directory names.  These commands can +     be placed in your system startup file so they will be executed +     whenever the machine is rebooted.  You may, if you choose, do this +     via the `GCC_INSTALL.COM' script in the `[GCC]' directory. + +  2. Install the `GCC' command with the command line: + +          $ set command /table=sys$common:[syslib]dcltables - +            /output=sys$common:[syslib]dcltables gnu_cc:[000000]gcc +          $ install replace sys$common:[syslib]dcltables + +  3. To install the help file, do the following: + +          $ library/help sys$library:helplib.hlb gcc.hlp + +     Now you can invoke the compiler with a command like `gcc /verbose +     file.c', which is equivalent to the command `gcc -v -c file.c' in +     Unix. + +   If you wish to use GNU C++ you must first install GNU CC, and then +perform the following steps: + +  1. Define the VMS logical name `GNU_GXX_INCLUDE' to point to the +     directory where the preprocessor will search for the C++ header +     files.  This can be done with the command: + +          $ assign /system /translation=concealed - +            disk:[gcc.gxx_include.] gnu_gxx_include + +     with the appropriate disk and directory name.  If you are going to +     be using libg++, this is where the libg++ install procedure will +     install the libg++ header files. + +  2. Obtain the file `gcc-cc1plus.exe', and place this in the same +     directory that `gcc-cc1.exe' is kept. + +     The GNU C++ compiler can be invoked with a command like `gcc /plus +     /verbose file.cc', which is equivalent to the command `g++ -v -c +     file.cc' in Unix. + +   We try to put corresponding binaries and sources on the VMS +distribution tape.  But sometimes the binaries will be from an older +version than the sources, because we don't always have time to update +them.  (Use the `/version' option to determine the version number of +the binaries and compare it with the source file `version.c' to tell +whether this is so.)  In this case, you should use the binaries you get +to recompile the sources.  If you must recompile, here is how: + +  1. Execute the command procedure `vmsconfig.com' to set up the files +     `tm.h', `config.h', `aux-output.c', and `md.', and to create files +     `tconfig.h' and `hconfig.h'.  This procedure also creates several +     linker option files used by `make-cc1.com' and a data file used by +     `make-l2.com'. + +          $ @vmsconfig.com + +  2. Setup the logical names and command tables as defined above.  In +     addition, define the VMS logical name `GNU_BISON' to point at the +     to the directories where the Bison executable is kept.  This +     should be done with the command: + +          $ assign /system /translation=concealed - +            disk:[bison.] gnu_bison + +     You may, if you choose, use the `INSTALL_BISON.COM' script in the +     `[BISON]' directory. + +  3. Install the `BISON' command with the command line: + +          $ set command /table=sys$common:[syslib]dcltables - +            /output=sys$common:[syslib]dcltables - +            gnu_bison:[000000]bison +          $ install replace sys$common:[syslib]dcltables + +  4. Type `@make-gcc' to recompile everything (alternatively, submit +     the file `make-gcc.com' to a batch queue).  If you wish to build +     the GNU C++ compiler as well as the GNU CC compiler, you must +     first edit `make-gcc.com' and follow the instructions that appear +     in the comments. + +  5. In order to use GCC, you need a library of functions which GCC +     compiled code will call to perform certain tasks, and these +     functions are defined in the file `libgcc2.c'.  To compile this +     you should use the command procedure `make-l2.com', which will +     generate the library `libgcc2.olb'.  `libgcc2.olb' should be built +     using the compiler built from the same distribution that +     `libgcc2.c' came from, and `make-gcc.com' will automatically do +     all of this for you. + +     To install the library, use the following commands: + +          $ library gnu_cc:[000000]gcclib/delete=(new,eprintf) +          $ library gnu_cc:[000000]gcclib/delete=L_* +          $ library libgcc2/extract=*/output=libgcc2.obj +          $ library gnu_cc:[000000]gcclib libgcc2.obj + +     The first command simply removes old modules that will be replaced +     with modules from `libgcc2' under different module names.  The +     modules `new' and `eprintf' may not actually be present in your +     `gcclib.olb'--if the VMS librarian complains about those modules +     not being present, simply ignore the message and continue on with +     the next command.  The second command removes the modules that +     came from the previous version of the library `libgcc2.c'. + +     Whenever you update the compiler on your system, you should also +     update the library with the above procedure. + +  6. You may wish to build GCC in such a way that no files are written +     to the directory where the source files reside.  An example would +     be the when the source files are on a read-only disk.  In these +     cases, execute the following DCL commands (substituting your +     actual path names): + +          $ assign dua0:[gcc.build_dir.]/translation=concealed, - +                   dua1:[gcc.source_dir.]/translation=concealed  gcc_build +          $ set default gcc_build:[000000] + +     where the directory `dua1:[gcc.source_dir]' contains the source +     code, and the directory `dua0:[gcc.build_dir]' is meant to contain +     all of the generated object files and executables.  Once you have +     done this, you can proceed building GCC as described above.  (Keep +     in mind that `gcc_build' is a rooted logical name, and thus the +     device names in each element of the search list must be an actual +     physical device name rather than another rooted logical name). + +  7. *If you are building GNU CC with a previous version of GNU CC, you +     also should check to see that you have the newest version of the +     assembler*.  In particular, GNU CC version 2 treats global constant +     variables slightly differently from GNU CC version 1, and GAS +     version 1.38.1 does not have the patches required to work with GCC +     version 2.  If you use GAS 1.38.1, then `extern const' variables +     will not have the read-only bit set, and the linker will generate +     warning messages about mismatched psect attributes for these +     variables.  These warning messages are merely a nuisance, and can +     safely be ignored. + +     If you are compiling with a version of GNU CC older than 1.33, +     specify `/DEFINE=("inline=")' as an option in all the +     compilations.  This requires editing all the `gcc' commands in +     `make-cc1.com'.  (The older versions had problems supporting +     `inline'.)  Once you have a working 1.33 or newer GNU CC, you can +     change this file back. + +  8. If you want to build GNU CC with the VAX C compiler, you will need +     to make minor changes in `make-cccp.com' and `make-cc1.com' to +     choose alternate definitions of `CC', `CFLAGS', and `LIBS'.  See +     comments in those files.  However, you must also have a working +     version of the GNU assembler (GNU as, aka GAS) as it is used as +     the back-end for GNU CC to produce binary object modules and is +     not included in the GNU CC sources.  GAS is also needed to compile +     `libgcc2' in order to build `gcclib' (see above); `make-l2.com' +     expects to be able to find it operational in +     `gnu_cc:[000000]gnu-as.exe'. + +     To use GNU CC on VMS, you need the VMS driver programs `gcc.exe', +     `gcc.com', and `gcc.cld'.  They are distributed with the VMS +     binaries (`gcc-vms') rather than the GNU CC sources.  GAS is also +     included in `gcc-vms', as is Bison. + +     Once you have successfully built GNU CC with VAX C, you should use +     the resulting compiler to rebuild itself.  Before doing this, be +     sure to restore the `CC', `CFLAGS', and `LIBS' definitions in +     `make-cccp.com' and `make-cc1.com'.  The second generation +     compiler will be able to take advantage of many optimizations that +     must be suppressed when building with other compilers. + +   Under previous versions of GNU CC, the generated code would +occasionally give strange results when linked with the sharable +`VAXCRTL' library.  Now this should work. + +   Even with this version, however, GNU CC itself should not be linked +with the sharable `VAXCRTL'.  The version of `qsort' in `VAXCRTL' has a +bug (known to be present in VMS versions V4.6 through V5.5) which +causes the compiler to fail. + +   The executables are generated by `make-cc1.com' and `make-cccp.com' +use the object library version of `VAXCRTL' in order to make use of the +`qsort' routine in `gcclib.olb'.  If you wish to link the compiler +executables with the shareable image version of `VAXCRTL', you should +edit the file `tm.h' (created by `vmsconfig.com') to define the macro +`QSORT_WORKAROUND'. + +   `QSORT_WORKAROUND' is always defined when GNU CC is compiled with +VAX C, to avoid a problem in case `gcclib.olb' is not yet available. + +`collect2' +========== + +   Many target systems do not have support in the assembler and linker +for "constructors"--initialization functions to be called before the +official "start" of `main'.  On such systems, GNU CC uses a utility +called `collect2' to arrange to call these functions at start time. + +   The program `collect2' works by linking the program once and looking +through the linker output file for symbols with particular names +indicating they are constructor functions.  If it finds any, it creates +a new temporary `.c' file containing a table of them, compiles it, and +links the program a second time including that file. + +   The actual calls to the constructors are carried out by a subroutine +called `__main', which is called (automatically) at the beginning of +the body of `main' (provided `main' was compiled with GNU CC).  Calling +`__main' is necessary, even when compiling C code, to allow linking C +and C++ object code together.  (If you use `-nostdlib', you get an +unresolved reference to `__main', since it's defined in the standard +GCC library.  Include `-lgcc' at the end of your compiler command line +to resolve this reference.) + +   The program `collect2' is installed as `ld' in the directory where +the passes of the compiler are installed.  When `collect2' needs to +find the *real* `ld', it tries the following file names: + +   * `real-ld' in the directories listed in the compiler's search +     directories. + +   * `real-ld' in the directories listed in the environment variable +     `PATH'. + +   * The file specified in the `REAL_LD_FILE_NAME' configuration macro, +     if specified. + +   * `ld' in the compiler's search directories, except that `collect2' +     will not execute itself recursively. + +   * `ld' in `PATH'. + +   "The compiler's search directories" means all the directories where +`gcc' searches for passes of the compiler.  This includes directories +that you specify with `-B'. + +   Cross-compilers search a little differently: + +   * `real-ld' in the compiler's search directories. + +   * `TARGET-real-ld' in `PATH'. + +   * The file specified in the `REAL_LD_FILE_NAME' configuration macro, +     if specified. + +   * `ld' in the compiler's search directories. + +   * `TARGET-ld' in `PATH'. + +   `collect2' explicitly avoids running `ld' using the file name under +which `collect2' itself was invoked.  In fact, it remembers up a list +of such names--in case one copy of `collect2' finds another copy (or +version) of `collect2' installed as `ld' in a second place in the +search path. + +   `collect2' searches for the utilities `nm' and `strip' using the +same algorithm as above for `ld'. + +Standard Header File Directories +================================ + +   `GCC_INCLUDE_DIR' means the same thing for native and cross.  It is +where GNU CC stores its private include files, and also where GNU CC +stores the fixed include files.  A cross compiled GNU CC runs +`fixincludes' on the header files in `$(tooldir)/include'.  (If the +cross compilation header files need to be fixed, they must be installed +before GNU CC is built.  If the cross compilation header files are +already suitable for ANSI C and GNU CC, nothing special need be done). + +   `GPLUS_INCLUDE_DIR' means the same thing for native and cross.  It +is where `g++' looks first for header files.  `libg++' installs only +target independent header files in that directory. + +   `LOCAL_INCLUDE_DIR' is used only for a native compiler.  It is +normally `/usr/local/include'.  GNU CC searches this directory so that +users can install header files in `/usr/local/include'. + +   `CROSS_INCLUDE_DIR' is used only for a cross compiler.  GNU CC +doesn't install anything there. + +   `TOOL_INCLUDE_DIR' is used for both native and cross compilers.  It +is the place for other packages to install header files that GNU CC will +use.  For a cross-compiler, this is the equivalent of `/usr/include'. +When you build a cross-compiler, `fixincludes' processes any header +files in this directory. + diff --git a/contrib/gcc/config/i386/freebsd.h.fixed b/contrib/gcc/config/i386/freebsd.h.fixed deleted file mode 100644 index b8e0bc7d52e6..000000000000 --- a/contrib/gcc/config/i386/freebsd.h.fixed +++ /dev/null @@ -1,302 +0,0 @@ -/* Definitions of target machine for GNU compiler for Intel 80386 -   running FreeBSD. -   Copyright (C) 1988, 1992, 1994 Free Software Foundation, Inc. -   Contributed by Poul-Henning Kamp <phk@login.dkuug.dk> - -This file is part of GNU CC. - -GNU CC is free software; you can redistribute it and/or modify -it under the terms of the GNU General Public License as published by -the Free Software Foundation; either version 2, or (at your option) -any later version. - -GNU CC is distributed in the hope that it will be useful, -but WITHOUT ANY WARRANTY; without even the implied warranty of -MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the -GNU General Public License for more details. - -You should have received a copy of the GNU General Public License -along with GNU CC; see the file COPYING.  If not, write to -the Free Software Foundation, 59 Temple Place - Suite 330, -Boston, MA 02111-1307, USA.  */ - -/* This is tested by i386gas.h.  */ -#define YES_UNDERSCORES - -/* Don't assume anything about the header files. */ -#define NO_IMPLICIT_EXTERN_C - -#include "i386/gstabs.h" - -/* Get perform_* macros to build libgcc.a.  */ -#include "i386/perform.h" - -/* This was cloned from ../netbsd.h.  It and several other things in -   this file should be in ../freebsd.h.  */ -/* FREEBSD_NATIVE is defined when gcc is integrated into the FreeBSD -   source tree so it can be configured appropriately without using -   the GNU configure/build mechanism. */ - -#ifdef FREEBSD_NATIVE - -/* Look for the include files in the system-defined places.  */ - -#define GPLUSPLUS_INCLUDE_DIR		"/usr/include/g++" - -#define GCC_INCLUDE_DIR			"/usr/include" - -/* FreeBSD has GCC_INCLUDE_DIR first.  */ -#define INCLUDE_DEFAULTS		\ -  {					\ -    { GCC_INCLUDE_DIR, 0, 0 },		\ -    { GPLUSPLUS_INCLUDE_DIR, 1, 1 },	\ -    { 0, 0, 0 }				\ -  } - -/* Under FreeBSD, the normal location of the compiler back ends is the -   /usr/libexec directory.  */ - -#define STANDARD_EXEC_PREFIX		"/usr/libexec/" - -/* Under FreeBSD, the normal location of the various *crt*.o files is the -   /usr/lib directory.  */ - -#define STANDARD_STARTFILE_PREFIX	"/usr/lib/" - -/* On FreeBSD, gcc is called 'cc' */ -#define GCC_NAME			"cc" - -/* FreeBSD is 4.4BSD derived */ -#define bsd4_4 - -#endif /* FREEBSD_NATIVE */ - -#define MASK_PROFILER_EPILOGUE	010000000000 - -#define TARGET_PROFILER_EPILOGUE (target_flags & MASK_PROFILER_EPILOGUE) - -#undef	SUBTARGET_SWITCHES -#define SUBTARGET_SWITCHES						\ -     { "profiler-epilogue",	 MASK_PROFILER_EPILOGUE},		\ -     { "no-profiler-epilogue",	-MASK_PROFILER_EPILOGUE}, - - -#undef CPP_PREDEFINES -#define CPP_PREDEFINES "-Dunix -Di386 -D__FreeBSD__=2 -Asystem(unix) -Asystem(FreeBSD) -Acpu(i386) -Amachine(i386)" - -#define ASM_SPEC   " %| %{fpic:-k} %{fPIC:-k}" - -/* Like the default, except no -lg, and no -p.  */ -#define LIB_SPEC "%{!shared:%{!pg:%{!pthread:-lc}%{pthread:-lc_r}}%{pg:%{!pthread:-lc_p}%{pthread:-lc_r_p}}}" - -#define LINK_SPEC \ -  "%{p:%e`-p' not supported; use `-pg' and gprof(1)} \ -   %{shared:-Bshareable} \ -   %{!shared:%{!nostdlib:%{!r:%{!e*:-e start}}} -dc -dp %{static:-Bstatic} \ -   %{pg:-Bstatic} %{Z}} \ -   %{assert*} %{R*}" - -#define LINK_LIBGCC_SPECIAL_1	1 - -#define STARTFILE_SPEC  \ -  "%{shared:c++rt0.o%s} \ -   %{!shared:%{pg:gcrt0.o%s}%{!pg:%{static:scrt0.o%s}%{!static:crt0.o%s}}}" - -/* This goes away when the math emulator is fixed.  */ -#undef TARGET_DEFAULT -#define TARGET_DEFAULT	(MASK_NO_FANCY_MATH_387 | 0301) - -#undef SIZE_TYPE -#define SIZE_TYPE "unsigned int" - -#undef PTRDIFF_TYPE -#define PTRDIFF_TYPE "int" - -#undef WCHAR_TYPE -#define WCHAR_TYPE "int" - -#define WCHAR_UNSIGNED 0 - -#undef WCHAR_TYPE_SIZE -#define WCHAR_TYPE_SIZE BITS_PER_WORD - -#define HAVE_ATEXIT - -#define HAVE_PUTENV - -/* Override the default comment-starter of "/".  */ - -#undef ASM_COMMENT_START -#define ASM_COMMENT_START "#" - -#undef ASM_APP_ON -#define ASM_APP_ON "#APP\n" - -#undef ASM_APP_OFF -#define ASM_APP_OFF "#NO_APP\n" - -/* The following macros are stolen from i386v4.h */ -/* These have to be defined to get PIC code correct */ - -/* This is how to output an element of a case-vector that is relative. -   This is only used for PIC code.  See comments by the `casesi' insn in -   i386.md for an explanation of the expression this outputs. */ - -#undef ASM_OUTPUT_ADDR_DIFF_ELT -#define ASM_OUTPUT_ADDR_DIFF_ELT(FILE, VALUE, REL) \ -  fprintf (FILE, "\t.long _GLOBAL_OFFSET_TABLE_+[.-%s%d]\n", LPREFIX, VALUE) - -/* Indicate that jump tables go in the text section.  This is -   necessary when compiling PIC code.  */ - -#define JUMP_TABLES_IN_TEXT_SECTION - -/* Don't default to pcc-struct-return, because gcc is the only compiler, and -   we want to retain compatibility with older gcc versions.  */ -#define DEFAULT_PCC_STRUCT_RETURN 0 - -/* Tell final.c that we don't need a label passed to mcount.  */ - -#define NO_PROFILE_DATA - -/* Redefine this to not pass an unused label in %edx.  */ - -#undef FUNCTION_PROFILER -#define FUNCTION_PROFILER(FILE, LABELNO)  \ -{									\ -  if (flag_pic)								\ -    fprintf (FILE, "\tcall *mcount@GOT(%%ebx)\n");			\ -  else									\ -    fprintf (FILE, "\tcall mcount\n");					\ -} - -#define FUNCTION_PROFILER_EPILOGUE(FILE)  \ -{									\ -  if (TARGET_PROFILER_EPILOGUE)						\ -    {									\ -      if (flag_pic)							\ -	fprintf (FILE, "\tcall *mexitcount@GOT(%%ebx)\n");		\ -      else								\ -	fprintf (FILE, "\tcall mexitcount\n");				\ -    }									\ -} - -/* - * Some imports from svr4.h in support of shared libraries. - * Currently, we need the DECLARE_OBJECT_SIZE stuff. - */ - -#define HANDLE_SYSV_PRAGMA - -/* Define the strings used for the special svr4 .type and .size directives. -   These strings generally do not vary from one system running svr4 to -   another, but if a given system (e.g. m88k running svr) needs to use -   different pseudo-op names for these, they may be overridden in the -   file which includes this one.  */ - -#define TYPE_ASM_OP	".type" -#define SIZE_ASM_OP	".size" -#define SET_ASM_OP	".set" - -/* This is how we tell the assembler that a symbol is weak.  */ -#define ASM_WEAKEN_LABEL(FILE,NAME) \ -  do { fputs ("\t.weak\t", FILE); assemble_name (FILE, NAME); \ -       fputc ('\n', FILE); } while (0) - -/* The following macro defines the format used to output the second -   operand of the .type assembler directive.  Different svr4 assemblers -   expect various different forms for this operand.  The one given here -   is just a default.  You may need to override it in your machine- -   specific tm.h file (depending upon the particulars of your assembler).  */ - -#define TYPE_OPERAND_FMT	"@%s" - -/* Write the extra assembler code needed to declare a function's result. -   Most svr4 assemblers don't require any special declaration of the -   result value, but there are exceptions.  */ - -#ifndef ASM_DECLARE_RESULT -#define ASM_DECLARE_RESULT(FILE, RESULT) -#endif - -/* These macros generate the special .type and .size directives which -   are used to set the corresponding fields of the linker symbol table -   entries in an ELF object file under SVR4.  These macros also output -   the starting labels for the relevant functions/objects.  */ - -/* Write the extra assembler code needed to declare a function properly. -   Some svr4 assemblers need to also have something extra said about the -   function's return value.  We allow for that here.  */ - -#define ASM_DECLARE_FUNCTION_NAME(FILE, NAME, DECL)			\ -  do {									\ -    fprintf (FILE, "\t%s\t ", TYPE_ASM_OP);				\ -    assemble_name (FILE, NAME);						\ -    putc (',', FILE);							\ -    fprintf (FILE, TYPE_OPERAND_FMT, "function");			\ -    putc ('\n', FILE);							\ -    ASM_DECLARE_RESULT (FILE, DECL_RESULT (DECL));			\ -    ASM_OUTPUT_LABEL(FILE, NAME);					\ -  } while (0) - -/* Write the extra assembler code needed to declare an object properly.  */ - -#define ASM_DECLARE_OBJECT_NAME(FILE, NAME, DECL)			\ -  do {									\ -    fprintf (FILE, "\t%s\t ", TYPE_ASM_OP);				\ -    assemble_name (FILE, NAME);						\ -    putc (',', FILE);							\ -    fprintf (FILE, TYPE_OPERAND_FMT, "object");				\ -    putc ('\n', FILE);							\ -    size_directive_output = 0;						\ -    if (!flag_inhibit_size_directive && DECL_SIZE (DECL))		\ -      {									\ -        size_directive_output = 1;					\ -	fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);				\ -	assemble_name (FILE, NAME);					\ -	fprintf (FILE, ",%d\n",  int_size_in_bytes (TREE_TYPE (DECL)));	\ -      }									\ -    ASM_OUTPUT_LABEL(FILE, NAME);					\ -  } while (0) - -/* Output the size directive for a decl in rest_of_decl_compilation -   in the case where we did not do so before the initializer. -   Once we find the error_mark_node, we know that the value of -   size_directive_output was set -   by ASM_DECLARE_OBJECT_NAME when it was run for the same decl.  */ - -#define ASM_FINISH_DECLARE_OBJECT(FILE, DECL, TOP_LEVEL, AT_END)        \ -do {                                                                    \ -     char *name = XSTR (XEXP (DECL_RTL (DECL), 0), 0);                  \ -     if (!flag_inhibit_size_directive && DECL_SIZE (DECL)	        \ -         && ! AT_END && TOP_LEVEL                                       \ -         && DECL_INITIAL (DECL) == error_mark_node                      \ -         && !size_directive_output)                                     \ -       {                                                                \ -         fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);                        \ -	 assemble_name (FILE, name);                                    \ -	 fprintf (FILE, ",%d\n",  int_size_in_bytes (TREE_TYPE (DECL)));\ -	}								\ -   } while (0) - - -/* This is how to declare the size of a function.  */ - -#define ASM_DECLARE_FUNCTION_SIZE(FILE, FNAME, DECL)			\ -  do {									\ -    if (!flag_inhibit_size_directive)					\ -      {									\ -        char label[256];						\ -	static int labelno;						\ -	labelno++;							\ -	ASM_GENERATE_INTERNAL_LABEL (label, "Lfe", labelno);		\ -	ASM_OUTPUT_INTERNAL_LABEL (FILE, "Lfe", labelno);		\ -	fprintf (FILE, "\t%s\t ", SIZE_ASM_OP);				\ -	assemble_name (FILE, (FNAME));					\ -        fprintf (FILE, ",");						\ -	assemble_name (FILE, label);					\ -        fprintf (FILE, "-");						\ -	assemble_name (FILE, (FNAME));					\ -	putc ('\n', FILE);						\ -      }									\ -  } while (0) diff --git a/contrib/gdb/bfd/ChangeLog b/contrib/gdb/bfd/ChangeLog new file mode 100644 index 000000000000..0c84449f0a5e --- /dev/null +++ b/contrib/gdb/bfd/ChangeLog @@ -0,0 +1,3385 @@ +Sun Apr  7 18:23:36 1996  Fred Fish  <fnf@cygnus.com> + +	From: Miles Bader  <miles@gnu.ai.mit.edu> +	* configure.in: Use AC_CHECK_TOOL to find ar & ranlib. +	* configure: Regenerate with autoconf. +	 +Wed Apr  3 16:22:16 1996  Fred Fish  <fnf@cygnus.com> + +	* configure.in (mips-sony-bsd*): Fix typo in AC_DEFINE. +	(AC_CHECK_HEADERS): Check for sys/time.h +	(AC_HEADER_TIME): Add macro. +	* configure: Regenerate with autoconf. +	* config.in: Regenerate with autoheader. +	* sysdep.h: Use TIME_WITH_SYS_TIME and HAVE_SYS_TIME_H +	to control what combination of <time> and <sys/time.h> +	get included. +	 +Wed Mar 20 16:53:12 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_add_missing_symbols): Ifdef out. +	(coff_write_object_contents): Don't call coff_add_missing_symbols. +	* coffgen.c (coff_section_symbol): Ifdef out. + +Mon Mar 18 12:54:41 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf32-mips.c (mips_elf_gprel32_reloc): Initialize gp if +	output_bfd is not NULL. + +Thu Mar 14 17:12:06 1996  Doug Evans  <dje@charmed.cygnus.com> + +	* coffgen.c (coff_get_normalized_symtab): Call bfd_zalloc instead +	of bfd_alloc (fixes fix_line not being initialized). +	Delete zeroing of fix_{value,tag,end,scnlen} fields. + +Thu Mar 14 16:06:06 1996  Jeffrey A Law  (law@cygnus.com) + +	* coffcode.h: Allow specific backends to override the +	bfd_link_add_symbols routine. + +	* coff-h8300.c: Include genlink.h. +	(howto_table): Add R_MEM_INDIRECT. +	(rtype2howto): Support R_MEM_INDIRECT. +	(h8300_reloc16_extra_cases): Handle R_MEM_INDIRECT like R_RELBYTE +	for now. +	 +Tue Mar 12 12:41:17 1996  David Mosberger-Tang  <davidm@koala.azstarnet.com> + +	* coff-alpha.c (alpha_relocate_section): Use +	info->callbacks_warning, rather than _bfd_error_handler, for +	"multiple gp" warning. + +Tue Mar 12 12:10:55 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* linker.c (bfd_wrapped_link_hash_lookup): New function. +	(_bfd_generic_link_add_one_symbol): Remove BFD_ASSERT on hash +	table string.  Use bfd_wrapped_link_hash_lookup. +	(_bfd_generic_link_write_global_symbol): Remove BFD_ASSERT on hash +	table string. +	* aoutx.h (aout_link_write_symbols): Use the name from the hash +	table, if any, when writing out symbols. +	(aout_link_input_section_std): Use the name from the hash table, +	if any, when reporting undefined symbols. +	(aout_link_input_section_ext): Likewise. +	(aout_link_reloc_link_order): Use bfd_wrapped_link_hash_lookup. +	* bout.c (get_value): Likewise. +	* cofflink.c (_bfd_coff_reloc_link_order): Likewise. +	* ecoff.c (ecoff_reloc_link_order): Likewise. +	* elflink.h (elf_link_add_object_symbols): Likewise. +	(elf_reloc_link_order): Likewise.	 +	* linker.c (_bfd_generic_link_output_symbols): Likewise. +	(_bfd_generic_reloc_link_order): Likewise. +	(default_indirect_link_order): Likewise. +	* reloc16.c (bfd_coff_reloc16_get_value): Likewise. +	* sunos.c (sunos_add_one_symbol): Likewise. +	* xcofflink.c (xcoff_link_add_symbols): Likewise. +	(bfd_xcoff_link_count_reloc): Likewise. +	(xcoff_reloc_link_order): Likewise. + +	* ecoffswap.h (ecoff_swap_fdr_in): If ECOFF_64, turn 0xffffffff +	into -1 for intern->rss. + +	* configure: Rebuild with autoconf 2.8. + +Mon Mar 11 12:28:31 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* stab-syms.c (__define_stab_duplicate): Define. +	(bfd_get_stab_name): Rename from aout_stab_name.  Rewrite to use a +	switch. +	* bfd-in.h (bfd_get_stab_name): Declare. +	* bfd-in2.h: Rebuild. +	* Makefile.in: Rebuild dependencies. +	(BFD_LIBS): Add stab-syms.o. +	(BFD_LIBS_CFILES): Add stab-syms.c. +	(BFD32_BACKENDS): Remove stab-syms.o. +	(BFD32_BACKENDS_CFILES): Remove stab-syms.c. +	* configure.in: Don't list stab-syms.o in bfd_backends. +	* configure: Rebuild. +	* libaout.h (aout_stab_name): Don't declare. +	* aoutx.h (NAME(aout,get_symbol_info)): Call bfd_get_stab_name, +	not aout_stab_name. + +Fri Mar  8 11:26:20 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf.c (assign_file_positions_for_segments): Adjust file offset +	for section alignment even if SEC_LOAD is not set. + +Tue Mar  5 12:02:23 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.in: Don't set SHLIB or SHLINK to an empty string, +	since they appear as targets in Makefile.in. +	* configure: Rebuild. + +	* sunos.c (sunos_scan_ext_relocs): If not making a shared library, +	don't fiddle with a symbol which is not defined anywhere. + +Mon Mar  4 12:49:16 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (xcoff_mark): Treat undefined imported symbols as +	though they are defined in a shared library. +	(xcoff_build_ldsyms): Likewise. + +	* coffgen.c (coff_find_nearest_line): Don't look at the line +	numbers for the section if section->lineno is NULL. + +	* elf.c (_bfd_elf_symbol_from_bfd_symbol): Print a useful error +	message rather than calling BFD_ASSERT. +	* elfcode.h (write_relocs): Check return value of +	_bfd_elf_symbol_from_bfd_symbol. + +Fri Mar  1 09:42:59 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_add_symbol_hook): Don't set SEC_LOAD flag +	for .sbss section. + +Wed Feb 28 11:25:47 1996  Jeffrey A Law  (law@cygnus.com) + +	* libhppa.h (hppa_reloc_field_selector_type): Add R_HPPA_NLSEL +	and R_HPPA_NLRSEL. +	(e_nsel, e_nlsel, e_nlrsel): Undefine.  Add to +	hppa_reloc_field_selector_type_alt. +	(hppa_field_adjust): Handle e_nlsel, e_nlrsel.  Fix e_nsel handling. +	* som.c (hppa_som_gen_reloc_type): Handle N', NL' NLR' field +	selectors. +	(som_write_fixups): Finish handling of R_N0SEL and R_N1SEL. + +Wed Feb 28 11:00:24 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf.c (assign_file_positions_for_segments): Adjust the segment +	memory size for the alignment of a SEC_ALLOC section, not just a +	SEC_LOAD section. + +Tue Feb 27 14:17:31 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> + +	* m68klinux.c: New file. +	* hosts/m68klinux.h: New file. +	* config.bfd (m68*-*-linuxaout*, m68*-*-linux*): New targets. +	* configure.in (m68*-*-linux*): New native host. +	(m68klinux_vec): New vector. +	* configure: Rebuild. +	* targets.c (m68klinux_vec): Declare. +	* i386linux.c (bfd_i386linux_size_dynamic_sections): Renamed from +	bfd_linux_size_dynmic_sections to avoid clash with m68klinux.c. +	* bfd-in.h (bfd_i386linux_size_dynamic_sections): Rename +	declaration from bfd_linux_size_dynamic_sections. +	(bfd_m68klinux_size_dynamic_sections): Declare. +	* bfd-in2.h: Rebuild. +	* Makefile.in: Rebuild dependencies. +	(BFD32_BACKENDS): Add m68klinux.o. +	(BFD32_BACKENDS_CFILES): Add m68klinux.c. + +Tue Feb 27 11:31:34 1996  Jeffrey A Law  (law@cygnus.com) + +	* libhppa.h (pa_arch): Add pa20. +	(hppa_reloc_field_selector_type): Add R_HPPA_NSEL. +	(e_nsel): Undefine.  Add to hppa_reloc_field_selector_type_alt. +	(hppa_field_adjust): Handle e_nsel. +	* som.c: Provide default definitions for many new relocs found only +	in hpux10 include files. +	(som_fixup_formats): Add several new relocs from hpux10. +	(som_hppa_howto_table): Add hpux10 relocs. +	(som_write_fixups): Handle R_N0SEL and R_N1SEL hpux10 relocs. + +Mon Feb 26 12:52:48 1996  Stan Shebs  <shebs@andros.cygnus.com> + +	* mpw-make.sed: Edit out recent shared library support, and +	rules to rebuild .h files using doc/chew. + +Mon Feb 26 14:48:39 1996  David Mosberger-Tang  <davidm@AZStarNet.com> + +	* ecoff.c (ecoff_compute_section_file_positions): Adjust the file +	size even of sections with no contents. + +Mon Feb 26 14:01:13 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* cofflink.c (_bfd_coff_link_input_bfd): When merging, skip names +	starting with '$' the way we skip names starting with '.'.  When +	updating x_endndx, don't be fooled by an index which has been +	merged. + +	* cofflink.c (_bfd_coff_link_input_bfd): Don't try to optimize a +	struct/union/enum type with no elements. + +Sat Feb 24 11:38:58 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* bfd.c (bfd_errmsg): Handle a NULL return from strerror. + +	* archive.c (bfd_generic_archive_p): If the first file in the +	archive can not be recognized as an object, don't assume that this +	is the wrong format. + +	* elf.c (bfd_elf_set_dt_needed_name): Don't do anything if the +	format is not bfd_object. +	(bfd_elf_get_dt_soname): Likewise. + +Wed Feb 21 13:58:04 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coff-sh.c (sh_relax_delete_bytes): Correct range of R_SH_USES +	reloc. + +Tue Feb 20 16:22:44 1996  J.T. Conklin  <jtc@rtl.cygnus.com> + +	* bfd.c (tdata): Add netbsd_core_data. +	* bfd-in2.h: Regenerated. + +Tue Feb 20 16:50:02 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* sunos.c (SUNOS_CONSTRUCTOR): Define. +	(sunos_add_one_symbol): Don't let a symbol from a dynamic object +	override a constructor symbol.  Set SUNOS_CONSTRUCTOR when +	appropriate. + +	* bout.c (b_out_squirt_out_relocs): Use udata.i rather than flags +	to get the symbol index, matching 14 Jul 95 change. + +Tue Feb 20 08:26:27 1996  Fred Fish  <fnf@phydeaux.cygnus.com> + +	* coff-alpha.c (alpha_ecoff_get_relocated_section_contents): +	Remove duplicate definition of gp. + +Mon Feb 19 12:37:41 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coff-alpha.c (alpha_ecoff_get_relocated_section_contents): Don't +	assume that we can set the GP value and then get the same value, +	since it won't be true if the output file is neither ELF nor +	ECOFF. +	* coff-mips.c (mips_adjust_reloc_in): Don't bother to use +	_bfd_get_gp_value here. +	(mips_gprel_reloc): Don't assume we can set and get the GP value. +	* elf32-mips.c (mips_elf_hi16_reloc): Get gp value from +	mips_elf_final_gp. +	(mips_elf_lo16_reloc): Likewise. +	(mips_elf_final_gp): Add pgp parameter.  Set it to the GP value. +	Don't require that the BFD be ELF. +	(mips_elf_gprel16_reloc): Get gp value from mips_elf_final_gp. +	(mips_elf_gprel32_reloc): Likewise. +	(mips_elf_relocate_section): Don't assume we can set and get the +	GP value. +	(mips_elf_finish_dynamic_symbol): Don't bother to use +	_bfd_get_gp_value here. + +	* elf32-mips.c (mips_elf_create_procedure_table): Initialize sv. +	Don't change epdr between malloc and free.  Be careful not to free +	NULL pointers.  Zero out the first RPDR. + +	* configure.host: On Linux, only pass -rpath option if $(libdir) +	is neither /lib nor /usr/lib.  From Alan Modra +	<alan@mullet.Levels.UniSA.Edu.Au>. + +	* elf-bfd.h (struct elf_obj_tdata): Rename dt_needed_name to +	dt_name. +	(elf_dt_name): Rename from elf_dt_needed_name. +	* elf.c (bfd_elf_set_dt_needed_name): Use elf_dt_name, not +	elf_dt_needed_name. +	(bfd_elf_get_dt_soname): New function. +	* elflink.h (elf_link_add_object_symbols): Use elf_dt_name, not +	elf_dt_needed_name.  Save the SONAME back in elf_dt_name. +	* bfd-in.h (bfd_elf_get_dt_soname): Declare. +	* bfd-in2.h: Rebuild. + +Mon Feb 19 02:50:23 1996  Doug Evans  <dje@charmed.cygnus.com> + +	* elf32-sparc.c (elf32_sparc_reloc_type_lookup): Renamed from +	_bfd_sparc_elf_reloc_type_lookup. +	(bfd_elf32_bfd_reloc_type_lookup): Update. +	* elf64-sparc.c (SPARC64_OLD_RELOCS): Define. +	(sparc64_elf_howto_table): Define. +	(sparc_reloc_map): Define. +	(sparc64_elf_reloc_type_lookup): New function. +	(sparc_elf_wdisp16_reloc): New function. +	(elf_info_to_howto): Use sparc64_elf_howto_table. +	(sparc64_elf_relocate_section): Likewise. +	(bfd_elf64_bfd_reloc_type_lookup): Update. + +Sun Feb 18 15:02:25 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.host: Check for 'do not mix' from native linker before +	trying to use -rpath. + +Fri Feb 16 12:46:18 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* bfd.c (_bfd_get_gp_value): New function. +	(_bfd_set_gp_value): New function. +	* libbfd-in.h (_bfd_get_gp_value): Declare. +	(_bfd_set_gp_value): Declare. +	* libbfd.h: Rebuild. +	* coff-alpha.c (alpha_ecoff_get_relocated_section_contents): Use +	_bfd_get_gp_value and _bfd_set_gp_value rather than referring +	directly to the fields in the tdata information. +	(alpha_relocate_section): Likewise. +	* coff-mips.c (mips_adjust_reloc_in): Likewise. +	(mips_gprel_reloc): Likewise. +	(mips_relocate_section): Likewise. +	* elf32-mips.c (mips_elf_hi16_reloc): Likewise. +	(mips_elf_lo16_reloc): Likewise. +	(mips_elf_final_gp): Likewise. +	(mips_elf_gprel16_reloc): Likewise. +	(mips_elf_gprel32_reloc): Likewise. +	(mips_elf_relocate_section): Likewise. +	(mips_elf_finish_dynamic_symbol): Likewise. + +	* bout.c (b_out_set_arch_mach): Recognize bfd_mach_i960_jx. + +Thu Feb 15 11:29:13 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.in: Call AC_PROG_CC before configure.host. +	* configure: Rebuild. +	* configure.host: Don't set information which autoconf should +	figure out, namely CC, CFLAGS, LDFLAGS, AR, and RANLIB. + +	* configure.host: Remove go32 and win32 host information, since it +	should no longer be needed. + +	* elf.c (map_sections_to_segments): If we have a .dynamic section, +	then start a new segment rather than put a writable section in a +	readonly segment. + +	* configure.host: Set RPATH_ENVVAR. + +	* Makefile.in: Rebuild dependencies. + +	* elflink.c (_bfd_elf_create_linker_section): Remove unused +	zero_section variable. + +Thu Feb 15 10:39:17 1996  H.J. Lu  <hjl@zoom.com> + +	* Makefile.in ($(srcdir)/bfd-in2.h): Rename target from bfd-in2.h. +	($(srcdir)/libbfd.h): Rename from libbfd.h. +	($(srcdir)/libcoff.h): Rename from libcoff.h. + +Wed Feb 14 16:29:07 1996  Martin Anantharaman  <martin@mail.imech.uni-duisburg.de> + +	* ieee.c (ieee_write_expression): Only use an R variable for a +	local symbol.  Don't output a zero offset.  Handle a zero address. +	(SRC_MASK, PCREL_OFFSET): Define based on KEEPMINUSPCININST. +	(rel32_howto, rel16_howto, rel8_howto): Use SRC_MASK and +	PCREL_OFFSET. +	(parse_expression): Don't try to handle multiple occurrences of a +	P variable.  Handle I variables differently from X variables.  Fix +	the order of minus expressions. +	(ieee_slurp_external_symbols): Generate an I variable for an NN +	record.  Fix handling of ATI and ATX records. +	(ieee_slurp_sections): Only set minimal section attributes. +	Adjust them later, based on the section contents. +	(ieee_object_p): Read in the file until just after the ME record. +	Call ieee_slurp_section_data to set the section flags. +	(do_one): Add iterations parameter.  Only repeat the first load +	item.  Set the section and file reloc flags. +	(ieee_slurp_section_data): Set section flags.  Pass iterations to +	do_one. +	(ieee_canonicalize_reloc): Handle I variables. +	(do_with_relocs): Only emit relocation size when necessary. +	Increase MAXRUN to 127.  Change ov to be assigned, and take +	src_mask and pcrel_offset into account. +	(ieee_write_data_part): Skip sections that are not loaded. +	(ieee_write_external_part): Don't output optional last entry of WX +	records. +	(ieee_write_me_part): Make setting of me_record neater. +	(ieee_generic_stat_arch_elt): Get the size of an archive element. + +	* syms.c (stt): Add entries for zerovars, vars, and code. + +	* elfcode.h (validate_reloc): New static function. +	(write_relocs): Call validate_reloc for non ELF relocs. + +	* elfxx-target.h (elf_symbol_leading_char): Define if not defined. +	(TARGET_BIG_SYM): Use elf_symbol_leading_char. +	(TARGET_LITTLE_SYM): Likewise. + +	* config.bfd (m68*-*-psos*): New target. + +Tue Feb 13 15:56:22 1996  Bryan Ford  <baford@snake.cs.utah.edu> + +	* i386msdos.c: Remove some #if 0 code. +	(msdos_write_object_contents): Don't include empty sections in the +	size computation, regardless of their address. + +Tue Feb 13 15:36:37 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_relocate_section): Don't segfault if dynboj +	is NULL, ie, the -r switch is used. + +Tue Feb 13 14:35:15 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* reloc.c (BFD_RELOC_MIPS_GOT_HI16): Define. +	(BFD_RELOC_MIPS_GOT_LO16): Define. +	(BFD_RELOC_MIPS_CALL_HI16, BFD_RELOC_MIPS_CALL_LO16): Define. +	* bfd-in2.h, libbfd.h: Rebuild. +	* elf32-mips.c (mips_reloc_map): Map new relocs. + +	* configure.host: Set HDLFLAGS for *-*-hpux with --enable-shared. + +	* Makefile.in ($(SHLINK)): Check ts against $(SHLIB), not +	$(SHLINK). + +	* ieee.c (get_symbol): Set the section to bfd_abs_section. +	(do_with_relocs): If EXEC_P is set and there are no relocs, use a +	simple number for the section address, rather than an expression. +	Limit the number of bytes between relocs to MAXRUN. +	(ieee_write_me_part): Set me_record to the file offset after the +	start address. +	(ieee_write_processor): New static function. +	(ieee_write_object_contents): Use ieee_write_processor. + +Fri Feb  9 10:53:00 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.host: Use ${CC-gcc} when testing for -rpath on SunOS. + +	* coff-aux.c: Change include of aux.h to aux-coff.h. + +Thu Feb  8 14:01:03 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> + +	* elf32-m68k.c (elf_m68k_relocate_section): For a R_68K_RELATIVE +	relocation put the addend both in the reloc entry and the data. +	(elf_m68k_finish_dynamic_symbol): Likewise.  Mask out marker in +	GOT offset value. + +	* elf32-m68k.c (elf_m68k_relocate_section): If -Bsymbolic, resolve +	a R_68K_PCxx reloc against a defined global symbol directly. +	(elf_m68k_check_relocs): Don't count such a reloc. + +	* elf32-m68k.c (elf_m68k_check_relocs): Don't record a symbol with +	a PLTxx reloc as dynamic.  Disallow PLTxxO reloc against a local +	symbol for now, otherwise always record the symbol as dynamic. +	(elf_m68k_adjust_dynamic_symbol): If a symbol with a PLTxx reloc +	is not referenced by a dynamic object, and we are not making a +	shared object, then don't make a PLT entry.  If we do make a PLT +	entry, make sure the symbol has been recorded as dynamic. + +Wed Feb  7 13:56:06 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.host: When making a shared library, set HLDFLAGS to +	pass an appropriate -rpath option.  Use the make variable SONAME +	as the shared library soname, rather than computing it here.  On +	SunOS, build stamp-tshlink in place of $(SHLINK). +	* Makefile.in (SONAME): New variable. +	($(SHLINK)): Make a link to the transformed name, as well. +	(stamp-tshlink): New target. +	(install): Skip stamp-tshlink during install. + +Wed Feb  7 13:37:39 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_add_symbol_hook): Do not assume that the +	linker sections have been set up yet. + +	* elf.c (make_mapping): Add an additional argument to suppress +	making the first section include the program headers. +	(map_sections_to_segments): If the user used -Ttext such that the +	program headers are on a different page, do not set the flags +	saying that this section includes the program headers. + +Tue Feb  6 14:04:49 1996  J.T. Conklin  <jtc@rtl.cygnus.com> + +	* configure.in (*-*-netbsd*): Set COREFILE to netbsd-core.c. +	don't define TRAD_HEADER. +	* configure: Rebuild. + +	* netbsd-core.c: New file, support for NetBSD core files. +	* hosts/*nbsd.h: Removed. + +Tue Feb  6 11:47:49 1996  Doug Evans  <dje@charmed.cygnus.com> + +	* reloc.c (BFD_RELOC_SPARC_[567]): New reloc types. +	(BFD_RELOC_SPARC_LO7 reloc type): Deleted. +	* libbfd.h, bfd-in2.h: Regenerated. +	* elf32-sparc.c (_bfd_sparc_elf_reloc_type_lookup): Renamed from +	bfd_elf32_bfd_reloc_type_lookup. +	(reloc_type{,_names}): Deleted. +	(_bfd_sparc_elf_howto_table): Renamed from elf_sparc_howto_table. +	Add sparc64 relocs. +	(sparc_reloc_map): Add sparc64 relocs. +	(sparc_elf_notsupported_reloc): New static function. +	(sparc_elf_wdisp16_reloc): New static function. +	(elf32_sparc_check_relocs): Handle R_SPARC_WDISP{16,19}. +	(elf32_sparc_relocate_section): Likewise. +	(bfd_elf32_bfd_reloc_type_lookup): Define. +	* elf64-sparc.c (sparc64_elf_wdisp16_reloc): Deleted. +	(reloc_type{,_names}): Deleted. +	(elf_sparc_howto_table): Deleted. +	(sparc_reloc_map): Deleted. +	(_bfd_sparc_elf_howto_table): Renamed from elf_sparc_howto_table. +	(bfd_elf64_bfd_reloc_type_lookup): Change from function to #define. + +Tue Feb  6 12:12:22 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.host: Make SHLIB_CFLAGS include $(PICFLAG) on a +	*-*-hpux* host. + +	* Makefile.in (program_transform_name): New variable. +	(install): Transform library name before installing it. + +Mon Feb  5 10:38:27 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* archures.c (bfd_mach_i960_hx): Define. +	* bfd-in2.h: Rebuild. +	* cpu-i960.c (scan_960_mach): Accept machine "hx". +	(MATRIX): Expand entries for HX. +	(arch_info_struct): Add i960:hx entry. +	* bout.c (b_out_set_arch_mach): Handle bfd_mach_i960_hx. +	* coffcode.h (coff_set_arch_mach_hook): Handle F_I960HX. +	(coff_set_flags): Handle bfd_mach_i960_hx. + +	Support for building as a shared library, based on patches from +	Alan Modra <alan@spri.levels.unisa.edu.au>: +	* configure.in: Add AC_ARG_ENABLE for shared and commonbfdlib. +	New substitutions: ALLLIBS, PICFLAG, SHLIB, SHLIB_CC, +	SHLIB_CFLAGS, COMMON_SHLIB, PICLIST, SHLINK. +	* configure: Rebuild. +	* configure.host: If --enable-shared, adjust shared library stuff +	based on the host.  If the host is SunOS, and the linker supports +	-rpath, set HLDFLAGS to use it. +	* Makefile.in (ALLLIBS): New variable. +	(PICFLAG, SHLIB, SHLIB_CC, SHLIB_CFLAGS): New variables. +	(COMMON_SHLIB, SHLINK): New variables. +	(.c.o): If PICFLAG is set, compile twice, once PIC, once normal. +	(STAGESTUFF): Remove variable. +	(all): Depend upon $(ALLLIBS) and @PICLIST@ rather than +	$(TARGETLIB). +	(stamp-ofiles): New target, like old ofiles target, but build +	using a temporary file and move-if-change, and touch stamp-ofiles +	when done. +	(ofiles): Just depend upon stamp-ofiles. +	(stamp-piclist, piclist): New targets. +	($(SHLIB), $(SHLINK)): New targets. +	(targets.o, archures.o): Build twice if PICFLAG is set. +	(do_mostlyclean): Remove pic/*.o. +	(do_clean): Remove stamp-ofiles, $(SHLIB), $(SHLINK), piclist, and +	stamp-piclist. +	(do_distclean): Remove pic and stamp-picdir. +	(install): Install shared libraries. +	($(OFILES)): Depend upon stamp-picdir. +	(stamp-picdir): New target. + +	* libcoff-in.h: Add comment reminding people that libcoff.h is a +	generated file. +	* libcoff.h: Rebuild. + +	* elflink.h (elf_adjust_dynamic_symbol): Don't try to get the +	flavour of a section with no owner. + +	* elf32-mips.c (mips_elf_create_dynamic_sections): Clear +	ELF_LINK_NON_ELF flag. +	(mips_elf_create_got_section): Likewise. + +	* elf.c: Revert last change, since it breaks dynamic linking. +	* elf-bfd.h (struct elf_backend_data): Remove want_hdr_in_seg +	field. +	* elf32-mips.c (elf_backend_want_hdr_in_seg): Don't define. +	* elfxx-target.h (elf_backend_want_hdr_in_seg): Don't define. +	(elfNN_bed): Don't initialize want_hdr_in_seg field. + +Sun Feb  4 20:45:13 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf.c (assign_file_positions_for_segments): If the backend does +	not want the elf header or the program headers in the address +	space, do not include them in the calculations. + +	* elf32-ppc.c (ppc_elf_additional_program_headers): New hook +	function to determine if we need additional program headers. +	(ppc_elf_modify_segment_map): Define as a NOP function for now. +	(ppc_elf_create_linker_section): .sdata2 is a read-only section. + +Sat Feb  3 23:00:03 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h: Move today's libcoff.h change into coffcode.h. + +Sat Feb  3 15:43:44 1996  Fred Fish  <fnf@cygnus.com> + +	* libcoff.h (bfd_coff_link_add_one_symbol): Combine macro args +	back into one line.  Some compilers (sunos 4.1.3 for example) +	won't accept args split across more than one line. + +Fri Feb  2 11:42:15 1996  Steve Chamberlain  <sac@slash.cygnus.com> + +	* aclocal.m4 (BFD_BINARY_FOPEN): Understand cygwin32. +	* configure: Regenerate. + +Fri Feb  2 12:12:16 1996  Jeffrey A Law  (law@cygnus.com) + +	* elf32-hppa.c (elf32_hppa_backend_symbol_table_processing): Don't +	try to do arithmetic on a void *, cast it to a unsigned char * first. + +Thu Feb  1 16:04:06 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf-bfd.h (ELF_LINK_NON_ELF): Define. +	* elf.c (_bfd_elf_link_hash_newfunc): Set elf_link_hash_flags to +	ELF_LINK_NON_ELF. +	* elflink.h (elf_link_add_object_symbols): Reset ELF_LINK_NON_ELF +	flag for a newly defined symbol. +	(NAME(bfd_elf,record_link_assignment)): Likewise. +	(elf_adjust_dynamic_symbol): If ELF_LINK_NON_ELF is set, try to +	set the DEF or REF_REGULAR flags correctly. + +	* Makefile.in (bfd-in2.h): Make bfd.h, not protos, in docdir. +	(libbfd.h, libcoff.h): Corresponding change. + +	* elf32-i386.c (elf_i386_check_relocs): Don't record a symbol with +	a PLT32 reloc as dynamic. +	(elf_i386_adjust_dynamic_symbol): If a symbol with a PLT32 reloc +	is not referenced by a dynamic object, and we are not making a +	shared object, then don't make a PLT entry.  If we do make a PLT +	entry, make sure the symbol has been recorded as dynamic. + +Wed Jan 31 17:23:32 1996  Steve Chamberlain  <sac@slash.cygnus.com> + +	* coff-i386.c (coff_i386_reloc_type_lookup): Add BFD_RELOC_32_PCREL. +	* config.bfd (i[345]86-*-win32): Becomes i[345]86-*-cygwin32. +	(powerpcle-*-cygwin32): New. +	* peicode.h (add_data_entry): Get address from vma. + +Wed Jan 31 16:23:57 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elflink.c (_bfd_elf_create_linker_section): If the symbol +	attached to the section has already been created as an undefined +	symbol, treat it as if it hasn't been created yet. + +Wed Jan 31 16:16:53 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elflink.h (elf_bfd_final_link): Don't output initial dummy +	symbol or section symbols if stripping all symbols and this is not +	a relocateable link.  Don't output the symbol string table if +	there are no symbols. +	(elf_link_flush_output_syms): Don't do anything if there are no +	symbols to flush. + +Wed Jan 31 12:55:49 1996  Richard Henderson  <rth@tamu.edu> + +	* coff-aux.c: New file. +	* hosts/m68kaux.h: New file. +	* config.bfd (m68*-apple-aux*): New target. +	* configure.in (m68*-apple-aux*): New native host. +	(m68kaux_coff_vec): New vector. +	* configure: Rebuild. +	* targets.c (m68kaux_coff_vec): Declare. +	* coffcode.h (bfd_coff_backend_data): Add field +	_bfd_coff_link_add_one_symbol. +	(bfd_coff_link_add_one_symbol): Define. +	(compare_arelent_ptr): New static function if TARG_AUX. +	(coff_write_relocs): If TARG_AUX, sort the relocs. +	(coff_write_object_contents): Set A/UX aouthdr magic number. +	(coff_link_add_one_symbol): Define if not defined. +	(bfd_coff_std_swap_table): Initialize new field. +	* libcoff.h: Rebuild. +	* cofflink.c (coff_link_add_symbols): Call +	bfd_coff_link_add_one_symbol rather than +	_bfd_generic_link_add_one_symbol. +	* coff-m68k.c (COFF_PAGE_SIZE): Don't define if already defined. +	* coff-alpha.c (alpha_ecoff_backend_data): Initialize new field. +	* coff-mips.c (mips_ecoff_backend_data): Likewise. +	* Makefile.in: Rebuild dependencies. +	(BFD32_BACKENDS): Add coff-aux.o. +	(BFD32_BACKENDS_CFILES): Add coff-aux.c. + +Wed Jan 31 11:37:46 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> + +	* elf32-m68k.c (elf_m68k_relocate_section): Fix R_68K_GOT* +	relocation; ignore addend with R_68K_{GOT,PLT}*O relocation. + +Tue Jan 30 12:09:04 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* Makefile.in (do_maintainer_clean): Remove $(srcdir)/bfd-in2.h, +	$(srcdir)/libbfd.h and $(srcdir)/libcoff.h. +	(maintainer-clean): Warn about deleting special files. +	(bfd-in2.h, libbfd.h, libcoff.h): New targets. + +	* elf32-hppa.c (elf32_hppa_relocate_section): Handle indirect and +	warning symbols correctly. +	* elf32-i386.c (elf_i386_relocate_section): Likewise. +	* elf32-m68k.c (elf_m68k_relocate_section): Likewise. +	* elf32-mips.c (mips_elf_relocate_section): Likewise. +	* elf32-ppc.c (ppc_elf_relocate_section): Likewise. +	* elf32-sparc.c (elf32_sparc_relocate_section): Likewise. +	* elf64-sparc.c (sparc64_elf_relocate_section): Likewise. + +	* syms.c (_bfd_stab_section_find_nearest_line): Add casts to avoid +	warnings. + +Mon Jan 29 14:27:24 1996  Kim Knuttila  <krk@cygnus.com> + +	* libcoff-in.h: aligned newly exported names with bfd naming  +	conventions. Removed an erroneous define of POWERPC_LE_PE. + 	* libcoff.h: Rebuild. +	* cofflink.c, coff-ppc.c: the above function name changes + +Mon Jan 29 13:06:28 1996  Ian Lance Taylor  <ian@cygnus.com> + +	From Basim Kadhim <kadhim@spock.cs.colorado.edu>: +	* ecoff.c (struct extsym_info): Define. +	(_bfd_ecoff_bfd_final_link): Pass a pointer to struct extsym_info +	to ecoff_link_write_external. +	(ecoff_link_write_external): Accept a struct extsym_info pointer. +	Strip symbols when appropriate. + +	Based on patches from Ronald F. Guilmette <rfg@monkeys.com>: +	* syms.c (BSF_OBJECT): Define. +	(bfd_print_symbol_vandf): Print 'O' for BSF_OBJECT. +	* bfd-in2.h: Rebuild. +	* elfcode.h (elf_slurp_symbol_table): Set BSF_OBJECT for an +	STT_OBJECT symbol. +	* elf.c (swap_out_syms): Only set type to STT_OBJECT if BSF_OBJECT +	is set. + +	* elf32-i386.c (elf_i386_relocate_section): If -Bsymbolic, when +	copying relocs into a shared object, treat a defined global symbol +	as a local symbol. +	* elf32-m68k.c (elf_m68k_relocate_section): Likewise. +	* elf32-mips.c (mips_elf_relocate_section): Likewise. +	* elf32-sparc.c (elf32_sparc_relocate_section): Likewise. + +	* elflink.h (elf_link_add_object_symbols): Only set weakdef to a +	real defined symbol, not to a weak defined symbol. + +Mon Jan 29 11:34:36 1996  Kim Knuttila  <krk@cygnus.com> + +	* cofflink.c: removed the POWERPC_LE_PE hack, promoted some types +	and made a few static functions externs. + +	* coff-ppc.c (ppc_bfd_coff_final_link): new function, replaces the +	POWERPC_LE_PE hack in cofflink. + +	* libcoff-in.h: promoted the following from cofflink.c to allow +	_bfd_coff_final_link to be overridden -  STRING_SIZE_SIZE, +	coff_debug_merge_element, struct coff_debug_merge_type,  +	coff_debug_merge_hash_entry, coff_debug_merge_hash_table, +	coff_debug_merge_hash_table_init,  coff_debug_merge_hash_table_free, +	coff_debug_merge_hash_lookup, coff_link_section_info,  +	coff_final_link_info, coff_debug_merge_hash_newfunc, +	coff_write_global_sym, coff_link_input_bfd, coff_reloc_link_order. + +	* libcoff.h: re-gen'd + +Fri Jan 26 18:33:35 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* syms.c: Include "bfdlink.h". +	(struct stab_find_info): Define. +	(_bfd_stab_section_find_nearest_line): New function. +	* libbfd-in.h (_bfd_stab_section_find_nearest_line): Declare. +	* libbfd.h: Rebuild. +	* elf-bfd.h (struct elf_obj_tdata): Add line_info field. +	* elf.c (_bfd_elf_find_nearest_line): Try calling +	_bfd_stab_section_find_nearest_line before searching the ELF +	symbol table.  Find the closest STT_FUNC symbol, not the last one. +	* libcoff-in.h (coff_data_type): Add line_info field. + 	* libcoff.h: Rebuild. +	* coffgen.c (coff_find_nearest_line): Try calling +	_bfd_stab_section_find_nearest_line before searching the COFF +	symbol table. +	* Makefile.in: Rebuild dependencies. + +Fri Jan 26 16:11:19 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (R_PPC_EMB_SDA21 relocations): Make relocation size +	4 bytes, so we get the correct value when updating the register +	field in little endian mode. + +Thu Jan 25 12:14:16 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* libcoff-in.h (struct xcoff_tdata): Remove toc_section and +	entry_section fields.  Add sntoc and snentry fields. +	* libcoff.h: Rebuild. +	* coffcode.h (coff_mkobject_hook): Initialize sntoc and snentry, +	not toc_section and entry_section (the COFF file does not have any +	sections at this point). +	(coff_write_object_contents): Set o_snentry and o_sntoc from +	snentry and sntoc rather than entry_section and toc_section. +	* coff-rs6000.c (xcoff_copy_private_bfd_data): Copy sntoc and +	snentry, not toc_section and entry_section. +	* xcofflink.c (bfd_xcoff_size_dynamic_sections): Don't set +	entry_section from hentry. +	(xcoff_link_input_bfd): If a defined symbol has XCOFF_ENTRY set, +	set snenty. +	(xcoff_link_input_bfd): Set sntoc, not toc_section. +	(xcoff_write_global_symbol): Get toc_section from sntoc, rather +	than using toc_section directly. + +	* archures.c: Add missing `.' in enum bfd_architecture. +	* bfd-in2.h: Rebuild. + +	* config.bfd (i[345]86-*-sco*elf*): Use bfd_elf32_i386_vec.  From +	Robert Lipe <robertl@arnet.com>. + +Thu Jan 25 12:08:51 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_size_dynamic_sections): Add .rela.sdata{,2} +	to sections we allocate.  Use bfd_zalloc to allocate initialial +	sections, not bfd_alloc. +	(ppc_elf_check_relocs): Remove BFD_ASSERTs for !shared from +	SDA{,2}I16 relocations. +	(ppc_elf_add_symbol_hook): Use the value of -G nn to determine +	whether to put something in .sbss or not. +	(ppc_elf_relocate_section): Add support for more relocations.  Add +	in sec->output_offset where appropriate.  Make error messages +	include the symbol name. + +	* elflink.c (_bfd_elf_create_linker_section): Lookup symbol before +	trying to add it to the symbol table, so _GLOBAL_OFFSET_TABLE_ +	doesn't get redefined messages if -shared. + +	* elflink.h (elf_create_pointer_linker_section) Only bump RELA +	section if the rel_section field has been set up. + +Wed Jan 24 20:40:26 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_relocate_section): Fix typo in eabi +	relocations. + +Wed Jan 24 10:38:34 1996  Doug Evans  <dje@charmed.cygnus.com> + +	* elf32-sparc.c (elf32_sparc_merge_private_bfd_data): Delete checking +	of flags, only flags used are controlled by mach number.  Bump up +	output file mach number to highest of input file mach numbers. +	(elf32_sparc_object_p): Watch for EF_SPARC_SUN_US1. +	(elf32_sparc_final_write_processing): Set EF_SPARC_SUN_US1 if v8plusa. + +	* config.bfd (sparc64-*-{sysv4*,solaris2*}): Comment out +	bfd_elf64_sparc_vec support. + +Tue Jan 23 14:33:05 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_copy_private_bfd_data): Don't complain if +	the embedded bit is set on some objects and not on others.  Just +	or it together. +	(ppc_elf_relocate_section): Implement R_PPC_EMB_{SDA21,RELSDA} +	relocations. + +Tue Jan 23 14:22:45 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_new_section_hook): Don't try to align the +	.stabstr section. + +	* coffcode.h (coff_set_section_contents): Fix the handling of the +	.lib section to work even if the entire section contents are +	written at once.  From Gvran Uddeborg <gvran@uddeborg.pp.se> and +	Robert Lipe <robertl@arnet.com>. + +Mon Jan 22 18:45:51 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elflink.h (elf_finish_pointer_linker_section): Don't allocate +	memory here for contents. + +	* elf32-ppc.c (ppc_elf_relocate_section): Bump up _SDA_BASE_ and +	_SDA2_BASE_ by 32768. +	(ppc_elf_size_dynamic_sections): #if out PLT code which we haven't +	started using.  Allocate contents for .sdata and .sdata2 sections +	also. +	(ppc_elf_check_relocs): Use bfd_get_section_name in debug message, +	rather than _name. +	(ppc_elf_finish_dynamic_symbol): Remove code that attempted to +	size _SDA{,2}_BASE_. +	(ppc_elf_relocate_section): Change how sdata{,2} relocations are +	done. + +Mon Jan 22 08:52:04 1996  Doug Evans  <dje@charmed.cygnus.com> + +	* elflink.h (elf_finish_pointer_linker_section): Fix typo. + +	* archures.c (bfd_mach_sparc_v9): Renamed from bfd_mach_sparc64. +	(bfd_mach_sparc_{v8plus,v8plusa}): Define. +	(bfd_mach_sparc_v9a): Define. +	(bfd_mach_sparc_v9_p): Define. +	* bfd-in2.h: Regenerated. +	* aoutx.h (aout,machine_type): bfd_mach_sparc64 renamed to +	bfd_mach_sparc_v9. +	* elf64-sparc.c (sparc64_elf_object_p): Likewise. +	* config.bfd (sparc64-*-sysv4*,sparc64-*-solaris2*): Set targ_defvec +	to bfd_elf32_sparc_vec. +	* cpu-sparc.c (arch_info_struct): Renamed from sparc_arch_info. +	Add v8plus{,a} support. +	Add v9a support. +	(sparc_compatible): New function. +	* elf32-sparc.h: #include "elf/sparc.h". +	(elf32_sparc_merge_private_bfd_data, elf32_sparc_object_p, +	elf32_sparc_final_write_processing): New functions. +	(bfd_elf32_bfd_merge_private_bfd_data, elf_backend_object_p, +	elf_backend_final_write_processing): Define. + +Mon Jan 22 11:21:51 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf-bfd.h (struct elf_link_hash_entry): Add +	linker_section_pointer field. +	(enum elf_linker_section_enum): Enumeration for new way of +	creating linker dynamic sections and symbols. +	(elf_linker_section{,_pointers}): New structures for creating +	dynamic sections and symbols. +	(elf_obj_tdata): Add linker_section_pointers and linker_section +	fields. +	(elf_local_ptr_offsets,elf_linker_section): New accessor macros. +	(_bfd_elf_create_linker_section): New declarations. +	(_bfd_elf_find_pointer_linker_section): Ditto. +	(bfd_elf{32,64}_{create,finish}_pointer_linker_section): Ditto. +	(_bfd_elf_make_linker_section_rela): Ditto. + +	* elf.c (_bfd_elf_link_hash_newfunc): Initialize new fields. + +	* elf32-ppc.c (ppc_elf_create_dynamic_sections): Delete. +	(ppc_elf_create_linker_section): New function to create the +	sections .got, .sdata, and .sdata2. +	(ppc_elf_size_dynamic_sections): Zap .rela.{sdata,sdata2} if +	needed. +	(ppc_elf_check_relocs): Support more of the eabi relocations. +	(ppc_elf_relocate_section): Ditto. +	(ppc_elf_finish_dynamic_symbols): Adjust _SDA{,2}_BASE_ by 32768 +	if the .sdata{,2} + .sbss{,2} section size is > 32k. + +	* elflink.h (elf_create_pointer_linker_section): New function to +	create initialized pointers in dynamic linker sections. +	(elf_finish_pointer_linker_section): Actually intialize the +	pointers created above. + +	* elfcode.h (bfd_elf{32,64}_create_pointer_linker_section): New +	macros to provide both 32 and 64 bit versions of +	elf_create_pointer_linker_section. +	(bfd_elf{32,64}_finish_pointer_linker_section): New macros to +	provide both 32 and 64 bit versions of +	elf_finish_pointer_linker_section. + +	* elflink.c (_bfd_elf_create_linker_section): New function to +	create a linker section. +	(_bfd_elf_find_pointer_linker_section): Find a unique pointer to a +	given address in the linker pointer offsets created for a given +	symbol. +	(_bfd_elf_make_linker_section_rela): Make a RELA section +	corresponding to the generated linker section. + +Sat Jan 20 08:36:10 1996  Doug Evans  <dje@canuck.cygnus.com> + +	* elf32-sparc.c (ELF_MACHINE_ALT1): Define. + +Thu Jan 18 18:25:34 1996  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (coff_ppc_relocate_section): changed TOCDEFN relocs. +	(coff_ppc_relocate_section): Handle special values for gcc built dlls. +	(dump_toc): fix diagnosing code to identify out-of-toc-bounds entries. +	Also begin the toc at 4 as an eye catcher ('31313131' marks the first +	toc entry in an objdump) for now. +	(ppc_do_last, ppc_get_last): New function - needed to save processing  +	the toc owner to the end. +	(ppc_coff_swap_sym_in_hook): Removed an incorrect hack for doing the  +	toc owner last. + +	* cofflink.c (_bfd_coff_final_link): Added a new hack to keep the  +	toc owner from being done till last. Must define POWERPC_LE_PC  +	to enable it. + +	* coffcode.h (coff_set_alignment_hook): alignment setting for .stab + +	* peicode.h (coff_swap_scnhdr_out): set section flags for stab/str +	to INFO. +	(coff_swap_aouthdr_out): Removed a non-working hack for computing the +	SizeOfImage for PowerPC. Ignore the size of the .junk section. + +Thu Jan 18 17:42:12 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elfcore.h: Include <signal.h> before <sys/procfs.h>. + +Wed Jan 17 12:40:14 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* cpu-powerpc.c (arch_info_struct): Change last entry to not point +	back to first. +	(bfd_powerpc_arch): Point at first entry in arch_info_struct. + +Tue Jan 16 15:10:49 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf.c (assign_file_positions_for_segments): Don't increment file +	offset for a segment which contains no loadable sections. + +Mon Jan 15 17:46:27 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* reloc.c: Add new PowerPC relocations. +	* {bfd-in2,libbfd}.h: Regenerate. + +	* elf32-ppc.c (ppc_elf_howto_raw): Add more PPC relocations. +	(ppc_elf_reloc_type_lookup): Lookup new relocations. + +Mon Jan 15 14:29:44 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* aoutx.h (howto_table_ext): Fix RELOC_BASE10 and RELOC_BASE22 +	entries. + +	* sunos.c (sunos_scan_ext_relocs): Don't fail assert if +        info->shared. + +	* coffgen.c (coff_find_nearest_line): Don't try to cache +	information in sections that are not owned by a BFD.  From Richard +	Henderson <richard@atheist.tamu.edu>. + +	* elf32-mips.c: Numerous changes to dynamic linking code, mostly +	from Kazumoto Kojima <kkojima@info.kanagawa-u.ac.jp>. +	* elflink.h (elf_link_output_extsym): Remove special check for +	_rld_new_interface. + +	* ecoffswap.h: Add prototypes for static functions. + +Sun Jan 14 21:36:08 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_{unsupported,std}_reloc): Remove functions. +	(ppc_elf_howto_raw): Remove ppc_elf_{unsupported,std}_reloc +	references. +	(ppc_elf_relocate_section):  No longer allow .sdata/.sbss sections +	to satisfy a TOC16 relocation. 	Rewrite unsupported relocation +	support.  Begin support for R_PPC_SDA{2,}REL. + +Sat Jan 13 09:36:52 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_create_dynamic_sections): New function to +	create the .got and .got.neg sections. +	(ppc_elf_size_dynamic_sections): Call it. +	(ppc_elf_check_relocs): Call it. +	(ppc_elf_size_dynamic_sections): Support .got.neg, just like .got. +	(ppc_elf_check_relocs): Add error messages for relocations we +	don't yet support.  Do not include R_PPC_SDAREL16 like a GOT +	relocation. + +Fri Jan 12 15:27:59 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_fake_sections): Define, and handle the new +	section flags for V.4 and eabi. + +Fri Jan 12 13:59:16 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* elf.c (assign_file_positions_for_segments): If a segment +	contains no sections, don't mark it as readable. + +	* elf-bfd.h (_bfd_elf_section_from_bfd_section): Declare. +	* elfcode.h (_bfd_elf_section_from_bfd_section): Don't declare. + +	* elf.c (_bfd_elf_print_private_bfd_data): Dump contents of +	dynamic section, if there is one. +	* elf-bfd.h (struct elf_size_info): Add swap_dyn_in field. +	(bfd_elf32_swap_dyn_in): Change type of second parameter to PTR. +	(bfd_elf64_swap_dyn_in): Likewise. +	* elfcode.h (elf_swap_dyn_in): Change type of second parameter to +	PTR. +	(NAME(_bfd_elf,size_info)): Initialize swap_dyn_in field. + +	* elf32-i386.c (elf_i386_size_dynamic_sections): Don't create a +	DT_TEXTREL entry because of .rel.plt.  From Martin Pirker +	<pirker@eiunix.tuwien.ac.at>. + +Thu Jan 11 17:06:14 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* section.c (SEC_{EXCLUDE,SORT_ENTRIES}): New section flags for +	PowerPC V.4 and eabi. + 	* bfd-in2.h: Regenerate. +	* libfd.h: Regenerate. + +	* elfxx-target.h (TARGET_{BIG,LITTLE}_SYM): Add new flags. + +	* elf32-ppc.c (ppc_elf_section_from_shdr): Support SHT_ORDERED +	section type and SHF_EXCLUDE section flag, turning them into the +	appropriate bfd section flag. + +Thu Jan 11 11:23:30 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (xcoff_link_add_symbols): Create the special +	sections if we see a DYNAMIC object, in case that is the only +	XCOFF input object we see. +	 +	* elf32-mips.c: Extensive changes for a start at dynamic linking +	support, from Kazumoto Kojima <kkojima@info.kanagawa-u.ac.jp>. + +	* elf-bfd.h (struct elf_backend_data): Add type_change_ok field. +	(struct elf_backend_data): Remove +	elf_backend_create_program_headers field.  Add +	elf_backend_additional_program_headers and +	elf_backend_modify_segment_map fields. +	* elfxx-target.h (elf_backend_type_change_ok): Define if not +	defined. +	(elf_backend_additional_program_headers): Likewise. +	(elf_backend_modify_segment_map): Likewise. +	(elf_backend_create_program_headers): Don't define. +	(elfNN_bed): Change to account for field changes. +	* elf.c (assign_file_positions_for_segments): Call new +	modify_segment_map backend function.  Don't call old +	create_program_headers backend function. +	(get_program_header_size): Call additional_program_headers rather +	than create_program_headers. +	* elflink.h (elf_link_add_object_symbols): Initialize +	type_change_ok from new backend field. +	(elf_link_output_extsym): Don't warn if _rld_new_interface is +	defined. +	(elf_reloc_link_order): Treat a reloc against a defined symbol as +	a reloc against the appropriate section. + +	* elf-bfd.h (struct bfd_elf_section_data): Add tdata field. +	(struct elf_obj_tdata): Rename ppc_flags_init field to flags_init. +	(elf_flags_init): Rename from elf_ppc_flags_init. +	* elf32-ppc.c (ppc_elf_set_private_flags): Use elf_flags_init, not +	elf_ppc_flags_init. +	(ppc_elf_copy_private_bfd_data): Likewise. +	(ppc_elf_merge_private_bfd_data): Likewise. + +	* elf32-m68k.c (howto_table): Change src_mask to 0 for all +	relocation entries. + +Tue Jan  9 15:22:53 1996  David Mosberger-Tang  <davidm@azstarnet.com> + +	* coff-alpha.c (alpha_relocate_section): During final link, allow + 	output .lita section to be bigger than 64k by adjusting gp value + 	on a per-input section basis. +	* libecoff.h (struct ecoff_tdata): Add issued_multiple_gp_warning +	field. +	(struct ecoff_section_tdata): Add gp field. + +Tue Jan  9 12:00:36 1996  Ian Lance Taylor  <ian@cygnus.com> + +	Handle Alpha ECOFF changes in OSF/1 3.2. +	* libecoff.h (struct ecoff_backend_data): Add get_elt_at_filepos +	field. +	* coff-alpha.c: Include "aout/ar.h". +	(alpha_ecoff_get_relocated_section_contents): Don't require an +	ALPHA_R_IGNORE reloc after an ALPHA_R_GPDISP reloc, since OSF/1 +	3.2 doesn't generate one. +	(alpha_relocate_section): Likewise. +	(alpha_ecoff_slurp_armap): Define. +	(alpha_ecoff_slurp_extended_name_table): Define. +	(alpha_ecoff_construct_extended_name_table): Define. +	(alpha_ecoff_truncate_arname): Define. +	(alpha_ecoff_write_armap): Define. +	(alpha_ecoff_generic_stat_arch_elt): Define. +	(alpha_ecoff_update_armap_timestamp): Define. +	(ARFZMAG): Define. +	(alpha_ecoff_read_ar_hdr): New static function. +	(alpha_ecoff_get_elt_at_filepos): New static function. +	(alpha_ecoff_openr_next_archived_file): New static function. +	(alpha_ecoff_get_elt_at_index): New static function. +	(alpha_ecoff_backend_data): Initialize get_elt_at_filepos field. +	(ecoffalpha_little_vec): Change BFD_JUMP_TABLE_ARCHIVE from +	_bfd_ecoff to alpha_ecoff. +	* ecoff.c (ecoff_link_add_archive_symbols): Use get_elt_at_filepos +	field from backend structure, rather than always calling +	_bfd_get_elt_at_filepos. +	* coff-mips.c (mips_ecoff_backend_data): Initialize +	get_elt_at_filepos field. +	* archive.c (_bfd_generic_read_ar_hdr_mag): New function, copied +	from _bfd_generic_read_ar_hdr with minor changes. +	(_bfd_generic_read_ar_hdr): Use _bfd_generic_read_ar_hdr_mag. +	* libbfd-in.h (_bfd_generic_read_ar_hdr_mag): Declare. +	* libbfd.h: Rebuild. + +	* bfd-in.h (BFD_IN_MEMORY): Define. +	* libbfd-in.h (struct bfd_in_memory): Define. +	* libbfd.c (bfd_read): Handle BFD_IN_MEMORY flag. +	(bfd_get_file_window): Don't try to map a BFD_IN_MEMORY file. +	(bfd_write, bfd_stat): Abort if BFD_IN_MEMORY is set. +	(bfd_tell, bfd_flush, bfd_seek): Handle BFD_IN_MEMORY flag. +	* bfd.c (struct _bfd): Change iostream field from char * to PTR. +	(bfd_get_size): Handle BFD_IN_MEMORY flag. +	* cache.c (bfd_cache_close): Ignore BFD_IN_MEMORY files. +	(bfd_open_file): Cast to PTR, not char *, when setting iostream. +	(bfd_cache_lookup_worker): Abort if BFD_IN_MEMORY is set. +	* opncls.c (bfd_fdopenr): Cast to PTR, not char *, when setting +	iostream. +	(bfd_openstreamr): Likewise. +	* aoutx.h (NAME(aout,some_aout_object_p)): Only fstat iostream if +	BFD_IN_MEMORY is not set. +	* riscix.c (riscix_some_aout_object_p): Likewise. +	* bfd-in2.h, libbfd.h: Rebuild. + +	* targets.c (bfd_target): Add _bfd_get_elt_at_index field. +	(BFD_JUMP_TABLE_ARCHIVE): Add _get_elt_at_index. +	(bfd_get_elt_at_index): Define. +	* archive.c (_bfd_generic_get_elt_at_index): Rename from +	bfd_get_elt_at_index.  Change index parameter from int to +	symindex. +	* libbfd-in.h (_bfd_generic_get_elt_at_index): Declare. +	(_bfd_noarchive_get_elt_at_index): Define. +	(_bfd_archive_bsd_get_elt_at_index): Define. +	(_bfd_archive_coff_get_elt_at_index): Define. +	* bfd-in2.h, libbfd.h: Rebuild. +	* aout-target.h (MY_get_elt_at_index): Define if not defined. +	* coff-rs6000.c (xcoff_get_elt_at_index): Define. +	* ieee.c (ieee_get_elt_at_index): Define. +	* libecoff.h (_bfd_ecoff_get_elt_at_index): Define. +	* oasys.c (oasys_get_elt_at_index): Define. +	* som.c (som_get_elt_at_index): Define. + +	* ecoff.c (_bfd_ecoff_find_nearest_line): Don't restrict line +	numbers to the .text section. + +Mon Jan  8 17:00:57 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* ieee.c (ieee_write_debug_part): Change return type to boolean. +	If there is a SEC_DEBUGGING section, get the contents of the debug +	information part from it. +	(ieee_set_section_contents): Store the contents of a SEC_DEBUGGING +	section in memory. +	(ieee_write_object_contents): Check ieee_write_debug_part return. + +Thu Jan  4 17:12:37 1996  Fred Fish  <fnf@cygnus.com> + +	* config.bfd (i[345]86-*-freebsd*): Add target. +	* configure.in (i386freebsd_vec): Add vec. +	* configure: Regenerate. +	* Makefile.in (BFD32_BACKENDS): Add i386freebsd.o. +	(BFD32_BACKENDS_CFILES): Add i386freebsd.c. +	Rebuild dependencies.. +	* freebsd.h: New file. +	* i386freebsd.c: New file. +	* targets.c (i386freebsd_vec): Declare. +	(bfd_target_vector): Add i386freebsd_vec. +	* i386linux.c (SEGMENT_SIZE): Define as TARGET_PAGE_SIZE +	* i386netbsd.c (SEGMENT_SIZE):  Define as TARGET_PAGE_SIZE +	 +Thu Jan  4 16:27:46 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* ieee.c (ieee_slurp_debug): New static function. +	(ieee_object_p): Call it. +	(ieee_slurp_section_data): Skip debugging sections. +	(ieee_get_reloc_upper_bound): Likewise. +	(ieee_get_section_contents): Likewise. +	(ieee_canonicalize_reloc): Likewise. +	(ieee_write_section_part): Likewise. +	(ieee_write_debug_part): Likewise. +	(ieee_write_data_part): Likewise. +	(init_for_output): Likewise. + +Wed Jan  3 19:42:47 1996  Michael Meissner  <meissner@wogglebug.tiac.net> + +	* elf32-ppc.c (ppc_elf_relocate_section): Make @GOT relocations +	work. +	(ppc_elf_howto_raw): Just use bfd_elf_generic_reloc for all howto +	relocs, since ppc_elf_relocate_section handles the linker case. +	(ppc_elf_{addr16_ha,got16,toc16,brtaken}_reloc): Delete, no longer +	used. +	(ppc_elf_{addr16_ha,got16,toc16,brtaken}_inner): Merge these into +	ppc_elf_relocate_section since that is now the only caller. +	(ppc_elf_relocate_section): Ditto. + +Wed Jan  3 15:11:30 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_write_object_contents): If we don't know the +	section of the entry point for an XCOFF executable, always set the +	entry address to -1. + +Tue Jan  2 14:17:15 1996  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf.c (bfd_section_from_shdr): Add support for note sections. + +Tue Jan  2 13:10:25 1996  Ian Lance Taylor  <ian@cygnus.com> + +	* bfd-in.h (struct _symbol_info): Add stab_type field. +	* bfd-in2.h: Rebuild. +	* aoutx.h (NAME(aout,get_symbol_info)): Set stab_type. + +	* elf32-ppc.c: Remove trailing newline from calls to +        _bfd_error_handler. +	(ppc_elf_merge_private_bfd_data): Only warn about endianness +	difference if target endianness is known. + +Thu Dec 21 12:43:49 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_howto_raw): Add a phony reloc to handle the +	old style TOC16 references without using R_PPC_GOT. +	(ppc_reloc_type): Ditto. +	(ppc_elf_reloc_type_lookup): Add support for TOC16. +	(ppc_elf_toc16_inner): Renamed from ppc_elf_got16_inner. +	(ppc_elf_toc16_reloc): Renamed from ppc_elf_toc16_reloc. +	(ppc_elf_got16_{inner,reloc}): Stubs for real GOT support. +	(ppc_elf_check_relocs): New function for GOT/PLT support that is +	work in progress. +	(ppc_elf_adjust_dynamic_symbol): Ditto. +	(ppc_elf_adjust_dynindx): Ditto. +	(ppc_elf_size_dynamic_sections): Ditto. +	(ppc_elf_finish_dynamic_symbol): Ditto. +	(ppc_elf_finish_dynamic_sections): Ditto. +	(ELF_DYNAMIC_INTERPRETER): Define. + +Wed Dec 20 19:14:18 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* elf.c (copy_private_bfd_data): When attaching sections to +	segments ignore sections that won't be allocated.  Patch from +	Andreas Schwab. + +Tue Dec 19 20:01:43 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* config.bfd: Match on m68k-cbm-* only if OS doesn't match +	anything else. + +Tue Dec 19 16:38:59 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coff-i960.c (CALC_ADDEND): Define. +	(coff_i960_relocate_section): Add the input section VMA to the +	addend for PC relative relocs. + +Sun Dec 17 20:11:55 1995  Kim Knuttila  <krk@cygnus.com> + +	* peicode.h (pe_print_pdata): Must test the entire entry for zero +	to correctly terminate. + +Fri Dec 15 12:05:57 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* targets.c (enum bfd_endian): Define. +	(bfd_target): Rename byteorder_big_p to byteorder, and change it +	from boolean to enum bfd_endian.  Change header_byteorder_big_p +	correspondingly. +	* bfd-in.h (bfd_big_endian, bfd_little_endian): New macros. +	(bfd_header_big_endian, bfd_header_little_endian): New macros. +	* bfd-in2.h: Rebuild. +	* All targets: Change initialization of byteorder and +	header_byteorder to use enum bfd_endian values rather than +	booleans. +	* All files: Change all references to byteorder_big_p and +	header_byteorder_big_p to use new bfd_*_endian macros. + +	* coffgen.c (make_a_section_from_file): Set lma to s_paddr, not +	s_vaddr. +	* coffcode.h (coff_write_object_contents): Set s_paddr to lma, not +	vma. +	* ecoff.c (_bfd_ecoff_write_object_contents): Likewise. + +Fri Dec 15 07:32:09 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* pe[i]-i386.c (TARGET_UNDERSCORE): Define to '_'. + +Thu Dec 14 13:45:37 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* ieee.c: Lots of minor cleanups.  Make many functions return +	errors rather than calling abort.  Also: +	(ieee_write_twobyte): Remove; change callers to call existing +	ieee_write_2bytes function. +	(ieee_write_expression): Don't output the section twice when +	outputting a local symbol.  Don't emit an extraneous zero if there +	is only one term. +	(ieee_slurp_sections): Set the lma as well as the vma. +	(ieee_archive_p): Use bfd_alloc_grow rather than an obstack. + +	* ihex.c (ihex_set_arch_mach): Don't accept any architecture, just +	a recognized one or bfd_arch_unknown. +	(ihex_get_symtab_upper_bound): Define as bfd_0l, to permit objcopy +	to succeed. +	(ihex_get_symtab): Likewise. + +Wed Dec 13 15:44:06 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* aoutx.h: Include <ctype.h>. +	(struct aout_link_includes_table): Define. +	(struct aout_link_includes_totals): Define. +	(struct aout_link_includes_entry): Define. +	(aout_link_includes_lookup): Define macro. +	(struct aout_final_link_info): Add includes field. +	(aout_link_includes_newfunc): New static function. +	(NAME(aout,final_link)): Initialize includes hash table. +	(aout_link_write_symbols): Eliminate duplicate N_BINCL entries. + +Wed Dec 13 10:52:14 1995  Stan Shebs  <shebs@andros.cygnus.com> + +	* mpw-config.in: Match on mips-*-* instead of mips-idt-ecoff. + +Wed Dec 13 11:07:45 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (coff_ppc_relocate_section): removed debugging code. + +Tue Dec 12 17:42:06 1995  Kim Knuttila  <krk@cygnus.com> + +	* peicode.h (pe_print_reloc): New function to dump the .reloc section. +	(pe_print_private_bfd_data): call pe_print_reloc. +	* coffcode.h (coff_set_alignment_hook): .reloc section alignment. +	* coff-ppc.c (in_reloc_p): Added missing non-eligible relocs. Spiffed +	up some debugging as well. + +Tue Dec 12 11:34:23 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* config.bfd: Handle sparc-*-elf*.  From Ronald F. Guilmette +	<rfg@monkeys.com>. + +Fri Dec  8 17:47:07 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elflink.h (elf_link_add_object_symbols): Set section_count to 0 +	when setting sections to NULL. + +Wed Dec  6 17:05:37 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (struct xcoff_loader_info): Add export_defineds +	field. +	(bfd_xcoff_size_dynamic_sections): Add export_defineds parameter. +	(xcoff_build_ldsyms): If export_defineds is set, set XCOFF_EXPORT +	for all symbols. +	* bfd-in.h (bfd_xcoff_size_dynamic_sections): Update declaration. +	* bfd-in2.h: Rebuild. + +Mon Dec  4 16:40:47 1995  Kim Knuttila  <krk@cygnus.com> + +	* coffcode.h (coff_set_alignment_hook): Removed some debugging printf's + +Mon Dec  4 11:25:39 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* ihex.c (ihex_scan): Handle record types 4 and 5. +	(ihex_object_p): Permit types 4 and 5. +	(ihex_set_section_contents): Remove check for out of range +	addresses. +	(ihex_write_object_contents): Generate types 4 and 5. + +	* elflink.h (elf_link_output_extsym): Just ignore warning and +	indirect references to symbols which don't really exist. + +Sun Dec  3 19:00:27 1995  Kim Knuttila  <krk@cygnus.com> + +	* peicode.h (pe_print_idata): Minor format fixes +	(pe_print_edata): New function. Under private printing, this formats +	the edata section of a PE file. +	(pe_print_private_bfd_data): Added call to pe_print_edata. + +Sun Dec  3 16:46:54 1995  Richard Earnshaw (rearnsha@armltd.co.uk) + +	* aout-arm.c (MY_swap_std_reloc_out): Use KEEPIT to get the symbol +	index, don't call stoi. + +Fri Dec  1 14:46:51 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* srec.c (srec_scan): Set lma as well as vma. + +	* ihex.c: New file; support for Intel Hex format. +	* targets.c (enum bfd_flavour): Add bfd_target_ihex_flavour. +	(ihex_vec): Declare. +	(bfd_target_vector): Always include ihex_vec. +	* bfd.c (struct _bfd): Add ihex_data field to tdata union. +	* Makefile.in: Rebuild dependencies. +	(BFD_LIBS): Add ihex.o +	(BFD_LIBS_CFILES): Add ihex.c. +	* bfd-in2.h: Rebuild. + +	* elf.c (assign_file_positions_for_segments): Sort the sections in +	each segment. +	(get_program_header_size): Return the right size if segment_map is +	not NULL. +	(copy_private_bfd_data): Don't bother to sort the sections. + +	* bfd.c (bfd_record_phdr): New function. +	* bfd-in.h (bfd_record_phdr): Declare. +	* bfd_in2.h: Rebuild. + +	* elf32-sparc.c (elf32_sparc_relocate_section): Remove bogus +	BFD_ASSERT. + +	* libbfd.c (bfd_malloc, bfd_realloc): New functions. +	(bfd_zmalloc): Return PTR, not char *.  Take size_t, not +	bfd_size_type. +	* libbfd-in.h (bfd_malloc, bfd_realloc): Declare. +	(bfd_zmalloc): Change declaration. +	* libbfd.h: Rebuild. +	* Many files: Use bfd_malloc and bfd_realloc rather than malloc +	and realloc.  Don't set bfd_error_no_memory if they fail. + +Thu Nov 30 19:32:26 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c: Added macros to tidy up toc cell treatment. Numerous +	uses as well. Added a new howto to deal with TOCREL16 relocs that  +	are TOCDEFN as well. +	(coff_ppc_relocate_section): Expanded treatment of ADDR32NB relocs +	to handle RVA relocs from dlltool. +	(ppc_coff_rtype2howto): TOCDEFN reloc addition. +	(coff_ppc_rtype_to_howto): TOCDEFN reloc addition. +	(ppc_coff_reloc_type_lookup): TOCDEFN reloc addition. + +	* coffcode.h (coff_set_alignment_hook): check idata$X sections  +	to get the right section alignment. + +Thu Nov 30 16:48:18 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elf.c (_bfd_elf_make_section_from_shdr): Don't set lma based on +	p_paddr if p_paddr is zero. +	(make_mapping): Set includes_filehdr and includes_phdrs for first +	PT_LOAD segment. +	(map_sections_to_segments): Set includes_phdrs for PT_PHDR +	segment. +	(assign_file_positions_for_segments): Handle includes_filehdr and +	includes_phdrs.  Remove special handling of PT_PHDR and first +	PT_LOAD segments. +	(copy_private_bfd_data): Set includes_filehdr and includes_phdr +	when appropriate.  Remove special handling of PT_PHDR segment. +	Use a more complex condition for when a section is included in a +	segment to handle Solaris linker oddities. + +Thu Nov 30 11:17:33 1995  Manfred Hollstein KS/EF4A 60/1F/110 #40283  <manfred@lts.sel.alcatel.de> + +	* coff-m88k.c (howto_table): Reformatted for easier reading; +	special_function now points to new function m88k_special_reloc. +	(howto_hvrt16): Function previously used for handling HVRT16 relocs +	removed. +	(rtype2howto): Do not add reloc's r_offset to the addend, this will +	be done correctly by m88k_special_reloc. +	(reloc_processing): New function to be used by RELOC_PROCESSING. +	(RELOC_PROCESSING): Define to call reloc_processing. + +Wed Nov 29 12:42:36 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* peicode.h (pe_print_idata): Call malloc rather than xmalloc. +	(pe_print_pdata): Likewise. + +	* opncls.c (bfd_alloc_by_size_t): Set bfd_error_no_memory if +	obstack_alloc fails. +	(bfd_alloc_finish): Set bfd_error_no_memory if obstack_finish +	fails. +	* libbfd.c (bfd_zmalloc): Set bfd_error_no_memory if malloc fails. +	* Many files: don't set bfd_error_no_memory if one of the above +	routines fails. + +	* elf.c (assign_file_positions_for_segments): Don't adjust p_paddr +	if p_paddr_valid is set. +	(copy_private_bfd_data): New static function. +	(_bfd_elf_copy_private_section_data): Call copy_private_bfd_data. + +	* elf.c (assign_file_positions_for_segments): Fix case where extra +	program headers were allocated. + +	* elf.c (_bfd_elf_print_private_bfd_data): New function. +	* elf-bfd.h (_bfd_elf_print_private_bfd_data): Declare. +	* elfxx-target.h (bfd_elfNN_bfd_print_private_bfd_data): Define to +	_bfd_elf_print_private_bfd_data. + +	* coff-alpha.c (alpha_ecoff_swap_reloc_in): Don't abort if +	r_symndx is RELOC_SECTION_NONE for an ALPHA_R_IGNORE reloc. +	Change a RELOC_SECTION_LITA symndx to RELOC_SECTION_ABS. +	(alpha_ecoff_swap_reloc_out): Change RELOC_SECTION_ABS to +	RELOC_SECTION_LITA for ALPHA_R_IGNORE. +	(alpha_adjust_reloc_out): For ALPHA_R_IGNORE, don't change +	RELOC_SECTION_ABS to RELOC_SECTION_NONE. + +Tue Nov 28 16:59:50 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elf-bfd.h (struct elf_obj_tdata): Add segment_map field. +	* elf.c (make_mapping): New static function. +	(map_sections_to_segments): New static function. +	(elf_sort_sections): New static function. +	(assign_file_positions_for_segments): New static function. +	(map_program_segments): Remove. +	(get_program_header_size): Remove sorted_hdrs, count, and +	maxpagesize parameters.  Simplify. +	(assign_file_positions_except_relocs): When generating an +	executable, use assign_file_positions_for_segments. +	(elf_sort_hdrs): Remove. +	(_bfd_elf_sizeof_headers): Remove eliminated parameters from call +	to get_program_header_size. + +Mon Nov 27 12:27:46 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* hp300hpux.c (MY(callback)): Set lma as well as vma. + +	* configure, config.in: Regenerate with autoconf 2.7. + +	* elf32-i386.c (elf_backend_plt_readonly): Set correctly, to 1. +	* elf32-sparc.c (elf_backend_plt_readonly): Set correctly, to 0. + +Wed Nov 22 12:02:09 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* ecoff.c (_bfd_ecoff_new_section_hook): Handle .rconst section. +	(ecoff_sec_to_styp_flags): Likewise. +	(_bfd_ecoff_styp_to_sec_flags): Handle STYP_RCONST. +	(ecoff_set_symbol_info): Handle scRConst. +	(ecoff_slurp_reloc_table): Handle RELOC_SECTION_RCONST. +	(ecoff_compute_section_file_positions): Handle .rconst section. +	(_bfd_ecoff_write_object_contents): Likewise. +	(ecoff_link_check_archive_element): Handle scRConst. +	(ecoff_link_add_externals): Likewise. +	(ecoff_link_write_external): Handle .rconst section. +	(ecoff_reloc_link_order): Likewise. +	* ecofflink.c (bfd_ecoff_debug_accumulate): Handle scRConst. +	* coff-alpha.c (alpha_convert_external_reloc): Handle .rconst +	section. +	(alpha_relocate_section): Handle RELOC_SECTION_RCONST. + +	* sunos.c (sunos_scan_dynamic_symbol): Only set written if the +	DEF_DYNAMIC flag is set. + +Tue Nov 21 13:25:29 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* host-aout.c: If TRAD_HEADER is defined, include it. + +Tue Nov 21 13:03:57 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* aclocal.m4 (AC_PROG_CC): Remove local definition. +	(BFD_BINARY_FOPEN): Require AC_CANONICAL_SYSTEM. +	(BFD_NEED_DECLARATION): New function. +	* configure.in: Use BFD_NEED_DECLARATION. +	* acconfig.h: Put NEED_DECLARATION_* in @TOP@ section. +	* configure, config.in: Rebuild with autoconf 2.6. + +	* xcofflink.c (bfd_xcoff_size_dynamic_sections): Clear +	special_sections before returning when called with a non XCOFF +	BFD. + +	* coffgen.c (coff_renumber_symbols): Sort common symbols with +	global symbols. + +	* coffcode.h (coff_compute_section_file_positions): Only pad the +	previous section to force file alignment when creating an +	executable. + +Mon Nov 20 14:54:09 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_compute_section_file_positions): If +	RS6000COFF_C, set up the .debug section. + +	* xcofflink.c (xcoff_link_input_bfd): Adjust the TOC anchor value +	if it is not large enough to accomodate the entire TOC area with +	signed 16 bit offsets. +	(xcoff_write_global_symbol): Handle negative TOC offsets in global +	linkage code. +	(_bfd_ppc_xcoff_relocate_section): Adjust relocations against a +	TOC anchor to use the TOC value used in the output file. + +Sat Nov 18 18:01:41 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffgen.c (_bfd_coff_get_external_symbols): Cast malloc return. +	(_bfd_coff_read_string_table): Likewise. + +Sat Nov 18 19:43:04 1995  Richard Earnshaw (rearnsha@armltd.co.uk) + +	* pe-arm.c: Fix typos. +	* coff-arm.c: Likewise. + +Fri Nov 17 16:22:04 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (list_ele): Added "cat"egory member. +	(record_toc): New category parameter (priv or pub). +	(ppc_record_toc_entry): Check to see if toc bounds exceeded. +	(ppc_process_before_allocation): Removed embrionic data-in-toc from +	the mainline. It addes extra toc cells in error. +	(ppc_coff_swap_sym_in_hook): Added some documentation. +	(dump_toc): Can now diagnose "virtual toc" chicanery. + +Fri Nov 17 10:41:25 1995  Philippe De Muyter  <phdm@info.ucl.ac.be> + +	* elf-bfd.h (struct elf_link_hash_table): Change type of +	dynsymcount and bucketcount fields from size_t to bfd_size_type. + +Fri Nov 17 10:02:58 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_pointerize_aux_hook): I960 version: don't +	pointerize C_LEAFSTAT or C_LEAFEXT entries. + +	* elflink.h (NAME(bfd_elf,size_dynamic_sections)): Only create +	DT_INIT and DT_FINI entries if the _init or _fini symbol is +	defined or mentioned in a regular file. + +Thu Nov 16 15:16:42 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (ppc_record_data_in_toc_entry): new function +	(coff_ppc_relocate_section): Handle TOCDEFN attribute +	(coff_ppc_relocate_section): Correct REL24 handling +	(ppc_process_before_allocation): Correct TOCDEFN handling + +	* peicode.h (dir_names): Added name descriptions + +Thu Nov 16 03:38:03 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* VERSION: Updated to cygnus-2.6. + +Wed Nov 15 19:30:07 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* targets.c (m68k4knetbsd_vec): Declare. + +Wed Nov 15 18:05:52 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* targets.c (bfd_target): Change type of second argument to +	_bfd_print_private_bfd_data from void * to PTR. +	* libbfd-in.h (_bfd_generic_bfd_print_private_bfd_data): Cast +	using PTR rather than void *. +	* bfd-in2, libbfd.h: Rebuild. +	* peicode.h (pe_print_private_bfd_data): Change vfile from void * +	to PTR. +	* elfxx-target.h (bfd_elfNN_bfd_print_private_bfd_data): Define as +	_bfd_generic_bfd_print_private_bfd_data rather than casting +	bfd_true. + +Wed Nov 15 04:09:14 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* Makefile.in (.dep1): Fix stupid typo in last change.  Remove any +	"DO NOT DELETE" lines or blank lines that mkdep writes on some +	systems. +	(BFD_LIBS_CFILES, ALL_MACHINES_CFILES, BFD32_BACKENDS_CFILES, +	BFD64_BACKENDS_CFILES): New variables. +	(CFILES): Use them. +	 +Tue Nov 14 11:52:23 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* peicode.h (coff_swap_aouthdr_out): For PPC PE, start isize at 0, +	not at the file position of the first section. +	* coffcode.h (coff_compute_section_file_positions): Avoid using +	unportable #elif. +	(coff_write_object_contents): When generating a PPC PE executable +	with no symbols, round up the file size to a COFF_PAGE_SIZE +	boundary. +	* cofflink.c (_bfd_coff_final_link): If there are no symbols, +	don't write out a string table. + +	* elf.c (bfd_section_from_shdr): When using a different section +	header, pass the new one to _bfd_elf_make_section_from_shdr. +	(elf_fake_sections): Don't set sh_info and sh_entsize fields. +	(elf_map_symbols): Add section VMA to symbol value when comparing +	against 0. +	(_bfd_elf_compute_section_file_positions): Only build symbol table +	if there are some symbols.  Set file offset of symtab and strtab +	sections. +	(assign_file_positions_except_relocs): Remove dosyms parameter. +	Change all callers.  Never set file offset of symtab and strtab +	sections. +	(_bfd_elf_copy_private_section_data): New function. +	(MAP_ONESYMTAB, MAP_DYNSYMTAB, MAP_STRTAB, MAP_SHSTRTAB): Define. +	(_bfd_elf_copy_private_symbol_data): New function. +	(swap_out_syms): Check for special mapping of st_shndx created by +	copy_private_symbol_data. +	* elfxx-target.h: Use new copy routines. +	* elf-bfd.h (_bfd_elf_copy_private_symbol_data): Declare. +	(_bfd_elf_copy_private_section_data): Declare. + +	* config.bfd (sh-*-*): Set targ_defvec to shcoff_vec. + +	* coffcode.h (coff_slurp_symbol_table): If COFF_WITH_PE, handle +	C_NT_WEAK. + +	* coff-sh.c (shlcoff_vec): Use _bfd_generic_archive_p, not +	_bfd_dummy_target, matching the recent change to archive +	recognition. + +Mon Nov 13 13:24:38 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* libbfd.c (bfd_get_file_window): Use casts to avoid doing +	arithmetic on PTR types. + +	* aout-target.h (MY(callback)): Set the lma of the sections. + +	* ecoff.c (ecoff_reloc_link_order): Turn a reloc against a defined +	symbol into a reloc against the section. + +Mon Nov 13 07:31:35 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (ppc_coff_link_hash_entry): added support for inline +	glue for the relocs: IMGLUE and IFGLUE. +	(record_toc): new function - tracks toc contents +	(ppc_mark_symbol_as_glue): new function - supports the IMGLUE reloc +	(coff_ppc_relocate_section): Added support and fixes for IMGLUE/IFGLUE +	(ppc_coff_rtype2howto): removed invalid IMGLUE hack +	(coff_ppc_rtype_to_howto): removed invalid IMGLUE hack +	(ppc_record_toc_entry): Removed a debug define (duh) + +	* peicode.h (coff_swap_scnhdr_out): Fixed invalid strcmp for ".reldata" +	(pe_print_idata): New function - formats the idata section data +	(pe_print_pdata): New function - formats the pdata section data +	(pe_print_private_bfd_data): calls to above + +Sun Nov 12 12:23:24 1995  Stan Shebs  <shebs@andros.cygnus.com> + +	* Makefile.in (bfd_libs_here, etc): Provide empty definitions. +	* coff-rs6000.c (rs6000coff_vec): Add conditional defines +	TARGET_SYM and TARGET_NAME for vector and BFD name. +	* coff-pmac.c (pmac_xcoff_vec): Remove. +	(TARGET_SYM, TARGET_NAME): Define. +	* coffcode.h (coff_set_arch_mach_hook) [POWERMAC]: Set the +	machine to 0, not all PowerMacs are 601s. + +Fri Nov 10 12:10:14 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elfcode.h (elf_object_p): Read in any program headers. +	* elf.c (_bfd_elf_make_section_from_shdr): Adjust section lma +	based on the program headers, if any. +	(elf_fake_sections): Set sh_addr from the vma, not the lma. +	(map_program_segments): Set p_paddr of program headers based on +	the lma. + +Thu Nov  9 13:01:31 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* archive.c (bfd_generic_archive_p): Preserve tdata in case of +	failure. + +	* aoutx.h (NAME(aout,final_link)): Report a reasonable error when +	trying to do a relocateable link with a non-a.out object file. + +	* archive.c (bfd_generic_archive_p): Check the first object file +	in an archive even if target_defaulted is set.  If the object file +	has the wrong xvec, reject it. + +	* aoutx.h (NAME(aout,set_section_contents)): If a section can not +	be represented, report the name via _bfd_error_handler. +	(translate_to_native_sym_flags): Likewise. +	* elf32-mips.c (mips_elf_final_link): Likewise. +	* oasys.c (oasys_write_sections): Likewise. + +	* coffcode.h (coff_set_alignment_hook): Write RS6000COFF_C version +	which checks for STYP_OVRFLO sections. +	(coff_compute_section_file_positions): If RS6000COFF_C, handle +	reloc and lineno count overflows. +	(coff_write_object_contents): Call coff_count_linenumbers before +	coff_compute_section_file_positions.  If RS6000COFF_C, handle +	reloc and lineno count overflows. +	* xcofflink.c (_bfd_xcoff_bfd_final_link): Count line numbers and +	relocs before dealing with .pad sections.  Count overflow section +	headers when handling .pad sections. + +	* coffcode.h (coff_write_object_contents): Set a.out vstamp to 1 +	if RS6000COFF_C. + +	* xcofflink.c (XCOFF_DESCRIPTOR): Define. +	(struct xcoff_link_hash_table): Add descriptor_section and +	special_sections fields. +	(_bfd_xcoff_bfd_link_hash_table_create): Initialize new fields. +	(xcoff_link_add_symbols): Set linkage section alignment.  Create +	descriptor section.  Check for magic symbol names (_text, etc.), +	and record them in special_sections if found.  Set +	XCOFF_DESCRIPTOR flag for a function descriptor, and set its +	descriptor field to point back to the function code symbol. +	(xcoff_sweep): Always mark the special descriptor_section. +	(bfd_xcoff_export_symbol): Check whether the symbol might be a +	function descriptor, and mark it if it is. +	(bfd_xcoff_size_dynamic_sections): Add new special_sections +	parameter, and fill it in.  Allocate space for the descriptor +	section. +	(xcoff_build_ldsyms): Set XCOFF_DEF_REGULAR flag when defining +	global linkage code.  If an undefined function descriptor is +	exported, arrange to define it.  Warn about any other undefined +	exported symbol. +	(_bfd_xcoff_bfd_final_link): Write out the descriptor section. +	(xcoff_write_global_symbol): Create a function descriptor when +	necessary. +	* bfd-in.h (bfd_xcoff_size_dynamic_sections): Update declaration. +	* bfd-in2.h: Rebuild. + +Thu Nov  9 08:40:23 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (ppc_coff_link_hash_entry): new types for hashing +	(ppc_coff_link_hash_table): new types for hashing +	(ppc_coff_link_hash_newfunc): hash entry constructor +	(ppc_coff_link_hash_table_init): hash table initializer +	(ppc_coff_link_hash_table_create): hash table constructor +	(ppc_record_toc_entry): changed references to hash table +	(coff_ppc_relocate_section): changed references to hash table + +	* libcoff-in.h (coff_link_hash_entry): removed toc_offset +	* libcoff.h: Rebuild + +	* cofflink.c (_bfd_coff_link_hash_newfunc): removed toc_offset init +	(coff_link_add_symbols): removed toc_offset init + +Thu Nov  9 04:00:38 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* Makefile.in (.dep1): Make sure the file mkdep is to write exists +	first. + +	* configure.in: Added new option --with[out]-mmap.  Set USE_MMAP +	if it is given and mmep is available. +	* acconfig.h: Undef USE_MMAP. +	* configure, config.in: Regenerated. +	* aoutx.h: If USE_MMAP is not defined, do all symbol and string +	table handling the old way. +	(aout_get_external_symbols): Don't complain if last byte of string +	table is nonzero. +	* libbfd.c [HAVE_MADVISE]: Include sys/types.h and sys/mman.h. +	(bfd_free_window) [! USE_MMAP]: Don't define. +	(bfd_get_file_window, +	_bfd_generic_get_section_contents_in_window) [! USE_MMAP]: Abort. + +Wed Nov  8 20:03:44 1995  Eric Freudenthal <freudenthal@nyu.edu> + +	* coff-a29k.c (SIGN_EXTEND_HWORD): Use ~0xffff rather than +	0xffff0000. + +Wed Nov  8 11:31:11 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coff-a29k.c (a29k_reloc): Change handling of R_IREL reloc to be +	compatible with AMD generated COFF files.  Try to support both AMD +	and GNU formats simultaneously. +	(coff_a29k_relocate_section): Likewise. + +	* libbfd.c (bfd_get_file_window): Change writable parameter from +	int to boolean; update all callers.  Pass MAP_SHARED if not +	writable--it's required on Solaris.  Cast fprintf argument to +	avoid warning. +	* bfd-in.h (bfd_get_file_window): Update declaration. +	* bfd-in2.h: Rebuild. +	* aoutx.h: Update calls to bfd_get_file_window. + +	* xcofflink.c (XCOFF_DEF_DYNAMIC): Rename from XCOFF_REF_DYNAMIC. +	Change all uses. +	(xcoff_swap_ldhdr_in): New static function. +	(xcoff_swap_ldsym_in): New static function. +	(xcoff_find_reloc): Handle the case of a single reloc correctly. +	(xcoff_link_add_symbols): If we just created a descriptor, pass it +	to _bfd_generic_link_add_one_symbol, to save a hash lookup. +	Handle XTY_ER/XMC_XO symbols correctly. +	(xcoff_link_add_dynamic_symbols): Rewrite to read .loader symbols +	rather than normal symbol table. +	(bfd_xcoff_import_symbol): It's not an error if the symbol is +	already defined with the same absolute value. +	(xcoff_mark): When considering called symbols, check whether the +	descriptor is from a dynamic object, rather than the symbol +	itself. +	(xcoff_build_ldsyms): Likewise. + +	* libbfd.c (bfd_get_file_window): Change return type to boolean. +	Cast realloc and malloc return values.  If malloc or realloc fail, +	set bfd_error_no_memory. +	* bfd-in.h (bfd_get_file_window): Change type to boolean. +	* bfd-in2.h: Rebuild. + +Tue Nov  7 11:53:48 1995  Kim Knuttila  <krk@cygnus.com> + +	* coff-ppc.c (ppc_record_toc_entry): new function. +	(in_reloc_p): changed return value. +	(coff_ppc_relocate_section): much rework. +	(ppc_allocate_toc_section): new function. +	(ppc_process_before_allocation): new function. +	(ppc_coff_swap_sym_in_hook): new function. + +	* cofflink.c (_bfd_coff_link_hash_newfunc): initialize toc_offset. +	(coff_link_add_symbols): initialize toc_offset. + +	* peicode.h (coff_swap_sym_in): Added coff_swap_sym_in_hook +	(coff_swap_aouthdr_out): Added more sections to the data +	dictionary for the pe file header. Also changed linker version +	number on the ppc side. +	(dir_names): small improvements to the dictionary printing. +	(pe_mkobject_hook): save the file level flags. + +	* libcoff-in.h (coff_link_hash_entry): added toc_offset field +	(pe_tdata): added real_flags field +	(coff_tdata): added local_toc_sym_map and access macro + +	* libcoff.h (coff_link_hash_entry): added toc_offset field +	(pe_tdata): added real_flags field +	(coff_tdata): added local_toc_sym_map and access macro + +	* coffcode.h (coff_set_alignment_hook): added hook for PE. +	(coff_mkobject): init for local_toc_sym_map +	(coff_write_object_contents): set the internal_a.magic to +        IMAGE_NT_OPTIONAL_HDR_MAGIC which appears to be what other +	ppc compilers use. + +Tue Nov  7 13:48:58 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* ecofflink.c (_bfd_ecoff_locate_line): Keep looking through stabs +	entries until both the line number address and the function name +	address are too large. + +	* configure.in: Call AC_CHECK_PROG to find and cache AR. +	* configure: Rebuilt. + +	* aclocal.m4 (BFD_CC_FOR_BUILD): Don't define CC_FOR_BUILD if it +	is defined in the environment. + +Tue Nov  7 10:57:24 1995  Jeffrey A Law  (law@cygnus.com) + +	* som.c (som_get_section_contents_in_window): Define to use +	generic version. + +Mon Nov  6 17:13:15 1995  Harry Dolan  <dolan@ssd.intel.com> + +	* coff-i860.c: New file, based on coff-i386.c. +	* cpu-i860.c: New file, based on cpu-i386.c. +	* hosts/i860mach3.h: New file, based on hosts/i386mach3.h. +	* config.bfd (i860-*-mach3*, i860-*-osf1*, i860-*-coff*): New +	targets, using i860coff_vec. +	* configure.in (i860-*-mach3*, i860-*-osf1*): New hosts, using +	trad-core.o and hosts/i860mach3.h. +	(i860coff_vec): Use coff-i860.o and cofflink.o. +	* configure: Rebuild. +	* Makefile.in: Rebuild dependencies. +	(ALL_MACHINES): Add cpu-i860.o. +	(BFD32_BACKENDS): Add coff-i860.o. +	(CFILES): Add cpu-i860.c and coff-i860.c. +	* targets.c (i860coff_vec): Declare. +	(bfd_target_vector): Add &i860coff_vec.	 +	* archures.c (bfd_i860_arch): Declare. +	(bfd_archures_list): Add &bfd_i860_arch. +	* coffcode.h (coff_set_arch_mach_hook): Handle I860 magic number. +	(coff_set_flags): Handle bfd_arch_i860. +	(coff_write_object_contents): Handle I860 a.out magic number. + +Mon Nov  6 14:34:07 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (xcoff_link_add_symbols): Set the alignment power of +	the created .tc section to 2. +	(xcoff_mark): Don't keep a .loader reloc for a call to an +	undefined symbol when creating a shared library. +	(xcoff_build_ldsyms): When creating a shared library, generate +	global linkage code for a call to an undefined symbol. + +Sun Nov  5 21:44:13 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* Makefile.in (CFILES): Rebuild list from BFD_LIBS, ALL_MACHINES, +	BFD32_BACKENDS, BFD64_BACKENDS. +	(.dep1): Put mkdep output in a separate file. +	Rebuilt dependencies. + +	* ecoff.c (_bfd_ecoff_slurp_armap): Cast _bfd_read_ar_hdr return +	value. + +	Permit use of mmap when available: + +	* configure.in: Check for mmap, madvise, mprotect. +	* config.in, configure: Regenerated. + +	* libbfd.c (struct _bfd_window_internal): Define type. +	(bfd_init_window, bfd_free_window, bfd_get_file_window): New +	functions. +	(ok_to_map): New static variable for debugging. +	(_bfd_generic_get_section_contents_in_window): New function. +	* bfd-in.h (bfd_window_internal): Declare type. +	(bfd_window): Define type. +	(bfd_init_window, bfd_free_window, bfd_get_file_window): Declare. +	* libbfd-in.h (_bfd_generic_get_section_contents_in_window): +	Declare. + +	* libaout.h (struct aoutdata): Add two window fields. +	(obj_aout_sym_window, obj_aout_string_window): New macros. +	* aoutx.h (some_aout_object_p): Initialize windows. +	(aout_get_external_symbols): Get symbol data and strings in +	windows instead of explicitly allocated buffers. +	(slurp_symbol_table): Free window instead of memory. +	(bfd_free_cached_info): Release windows instead of freeing storage +	directly. +	(aout_link_free_symbols): Ditto. + +	* targets.c (bfd_target): Add new field for +	get_section_contents_in_window. +	(BFD_JUMP_TABLE_GENERIC): Updated. +	* aout-adobe.c, aout-target.h, binary.c, bout.c, coff-alpha.c, +	coff-mips.c, elfxx-target.h, i386msdos.c, i386os9k.c, ieee.c, +	libcoff-in.h, oasys.c, srec.c, tekhex.c, versados.c: Added new +	macros for get_section_contents_in_window field. + +Sat Nov  4 12:23:26 1995  Fred Fish  <fnf@cygnus.com> + +	* core.c: Renamed to corefile.c +	* makefile.dos (OBJS): Change core.o to corefile.o +	* Makefile.in (CFILES, BFD_LIBS): Use corefile.c instead of core.c +	 +Fri Nov  3 15:54:59 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (xcoff_link_add_symbols): Rename local variable sub +	to o.  Clobber and restore the list of new csects around the call +	to _bfd_generic_link_add_one_symbol, in case it wants to report a +	linker error and the linker wants to read the symbol table.  Reset +	the line number count of a real section even if it has no relocs. +	(_bfd_xcoff_bfd_final_link): If shared, set the DYNAMIC flag. + +	* coffgen.c (_bfd_coff_read_string_table): Warn if the string size +	is too small. + +Thu Nov  2 23:16:39 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (_bfd_ppc_xcoff_relocate_section): Don't warn about +	an undefined symbol in a shared link. + +	* linker.c (_bfd_generic_link_add_one_symbol): Correct type of +	oldtype from bfd_link_order_type to bfd_link_hash_type.  From +	phdm@info.ucl.ac.be (Philippe De Muyter). + +Wed Nov  1 14:26:02 1995  Manfred Hollstein KS/EF4A 60/1F/110 #40283  <manfred@lts.sel.alcatel.de> + +	* coff-m88k.c (rtype2howto): New static function. +	(RTYPE2HOWTO): Use it rather than a macro definition. + +	* coffcode.h (coff_write_object_contents): set internal_a.magic +	to PAGEMAGICPEXECPAGED #if defined (M68) && !defined (LYNXOS). + +	* configure.in: m68*-motorola-sysv* does not use ptrace-core.o; +	define TRAD_HEADER to new file hosts/delta68.h. +	m88*-motorola-sysv*, however, does use ptrace-core.o. +	* hosts/delta68.h: New file. + +	* ptrace-core.c (ptrace_unix_core_file_p): change bfd_zmalloc to +	bfd_zalloc; provide proper parm abfd to calls to bfd_zalloc. + +Wed Nov  1 13:51:54 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* i386linux.c (MY(vec)): Declare before use. + +Wed Nov  1 11:45:07 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* reloc16.c (bfd_coff_reloc16_get_relocated_section_contents): +	Pass input_bfd, not in_bfd, to bfd_coff_reloc16_extra_cases. + +	* elf.c (bfd_elf_set_dt_needed_name): Don't do anything if the +	BFD is not of the right type. +	(bfd_elf_get_needed_list): Likewise. +	* i386linux.c (bfd_linux_size_dynamic_sections): Likewise. +	* sunos.c (bfd_sunos_get_needed_list): Likewise. +	* xcofflink.c (XCOFF_XVECP): Define. +	(bfd_xcoff_link_record_set): Don't do anything if the BFD is not +	of the right type. +	(bfd_xcoff_import_symbol): Likewise. +	(bfd_xcoff_export_symbol): Likewise. +	(bfd_xcoff_link_count_reloc): Likewise. +	(bfd_xcoff_record_link_assignment): Likewise. +	(bfd_xcoff_size_dynamic_sections): Likewise. + +	* sunos.c (sunos_scan_ext_relocs): Only check the reloc symbol +	table index against the number of symbols for a base relative +	reloc. + +	* coff-rs6000.c (_bfd_xcoff_sizeof_headers): Change from macro to +	static function. +	* xcofflink.c (_bfd_xcoff_bfd_link_hash_table_create): Set +	full_aouthdr flag here... +	(_bfd_xcoff_bfd_final_link): ...not here. + +Tue Oct 31 12:52:02 1995  Fred Fish  <fnf@cygnus.com> + +	* libelf.h:  Rename to elf-bfd.h to avoid conflict with +	systems that have a system <libelf.h>. +	* Makefile.in: Globally replace libelf.h with elf-bfd.h. +	* bfd.c, elf.c, elf32-arc.c, elf32-gen.c, elf32-hppa.c, +	elf32-hppa.h, elf32-i386.c, elf32-i860.c, elf32-m68k.c, +	elf32-m88k.c, elf32-mips.c, elf32-ppc.c, elf32-sparc.c, +	elf64-gen.c, elf64-sparc.c, elfcode.h, elflink.c, +	elfxx-target.h: Include elf-bfd.h rather than libelf.h. +	* elfxx-target.h: Change libelf.h reference to elf-bfd.h. + +Tue Oct 31 15:30:07 1995  David Mosberger-Tang  <davidm@azstarnet.com> + +	* ecoff.c (ecoff_set_symbol_info): Add new parameter weak.  If +	set, set BSF_WEAK in symbol.  Change all callers. +	(ecoff_get_extr): Set weakext based on BSF_WEAK. +	(ecoff_link_add_externals): If weakext is set, pass BSF_WEAK to +	_bfd_generic_link_add_one_symbol. +	(ecoff_indirect_link_order): Check that the section tdata relocs +	are not NULL before using them. + +	* configure.in (alpha*-*-linux*): Set COREFILE to trad-core.o and +	define TRAD_HEADER as hosts/alphalinux.h. +	* configure: Rebuild. +	* hosts/alphalinux.h: New file. +	* trad-core.c (trad_unix_core_file_p): Cast u.u_ar0 to bfd_vma, +	not int. + +Tue Oct 31 12:34:11 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_slurp_symbol_table): Accept C_BCOMM and +	C_ECOMM storage classes. + +	* xcofflink.c (xcoff_mark_symbol): New static function, broken out +	of xcoff_mark. +	(xcoff_mark): Call xcoff_mark_symbol. +	(bfd_xcoff_export_symbol): Call xcoff_mark_symbol. +	(bfd_xcoff_link_count_reloc): Call xcoff_mark_symbol rather than +	doing it by hand. +	(xcoff_build_ldsyms): Build a .loader symbol for an export symbol. + +Mon Oct 30 14:53:48 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (struct xcoff_final_link_info): Add new line_filepos +	field. +	(xcoff_find_reloc): New static function. +	(xcoff_link_add_symbols): Use it. +	(_bfd_xcoff_bfd_final_link): Set finfo.line_filepos. +	(xcoff_link_input_bfd): Handle C_BINCL and C_EINCL.  Don't +	relocate the value of C_DECL. + +	* elf.c (elf_fake_sections): Remove bogus BFD_ASSERT. + +Sat Oct 28 01:25:34 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* cofflink.c (_bfd_coff_generic_relocate_section): Make +	callback decide what goes in .relocs. +	* pe[i]-i386.c (TARGET_UNDERSCORE): Define. +	* peicode.h (pe_mkobject_hook): Only copy aouthdr if +	there is one. + +Sat Oct 28 01:51:02 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c (xcoff_link_add_symbols): Handle csects in the +	absolute section. + +Fri Oct 27 18:14:39 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c: More improvements, mostly to fix handling of +	constructors and a few other special cases. +	* coff-rs6000.c (rs6000coff_vec): Set symbol_leading_char back to +	zero, reverting yesterday's change. +	* bfd-in.h (bfd_xcoff_link_record_set): Declare. +	(bfd_xcoff_link_count_reloc): Declare. +	(bfd_xcoff_record_link_assignment): Declare. +	* bfd-in2.h: Rebuild. + +Fri Oct 27 14:42:15 1995  Niklas Hallqvist  <niklas@appli.se> + +	* PORTING, aout-arm.c, aout-encap.c, aout-rce.c, aout-target.h, +	aoutx.h, gen-aout.c, host-aout.c, hp300bsd.c, i386aout.c +	i386bsd.c, i386dynix.c, i386linux.c, i386lynx.c, i386mach3.c, +	i386netbsd.c, m68klynx.c, m88kmach3.c, mipsbsd.c, newsos3.c, +	ns32knetbsd.c, pc532-mach.c, riscix.c, sparclynx.c, sparcnetbsd.c: +	Change PAGE_SIZE to TARGET_PAGE_SIZE. + +	* m68knetbsd.c: Ditto as well as add support for the m68k4k object +	format. + +	* netbsd.h: Double ditto (incl. m68k4k support).  NetBSD's text +	segments includes the a.out header.  See to that the magic number +	*always* is big-endian. + +	* config.bfd: Add m68*-hp*-netbsd* case.  Cross-pollinate m68k and +	m68k4k NetBSD configurations. + +	* configure.in, configure: Separate i386 & mips NetBSD +	configurations from other BSD ones.  Don't assume DEC is the only +	thing NetBSD/mips run on.  Add {m68k,ns32k,sparc}-*-netbsd* +	configurations.  Add support for m68k4k NetBSD object format. + +	* libaout.h: Added M_68K4K_NETBSD magic. + +	* m68k4knetbsd.c: New file. +	 +	* hosts/{m68k,sparc}nbsd.h: Don't define HOST_BIG_ENDIAN_P. + +	* hosts/nbsd.h: Define HOST_BIG_ENDIAN_P according to +	<machine/endian.h>. + +	* hosts/mipsnbsd.h: New file. +	 +Thu Oct 26 14:16:47 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* xcofflink.c: Numerous changes to get closer to a working XCOFF +	linker. +	* libcoff-in.h (struct xcoff_tdata): Add full_aouthdr, +	toc_section, and entry_section fields. +	(struct xcoff_section_tdata): Remove ldrel_count field. +	* libcoff.h: Rebuild. +	* coffcode.h (coff_mkobject_hook): Initialize new xcoff_data +	fields. +	(coff_compute_section_file_positions): If RS6000COFF_C, generate +	full a.out header if full_aouthdr is set in xcoff_data. +	(coff_write_object_contents): Likewise.  Set o_snentry and o_sntoc +	based on sections stored in xcoff_data. +	* coff-rs6000.c (xcoff_copy_private_bfd_data): Copy new xcoff_data +	fields. +	(xcoff_reloc_type_lookup): Handle BFD_RELOC_CTOR. +	(rs6000coff_vec): Set symbol_leading_char to '.'. +	* coffgen.c (coff_get_symbol_info): If fix_value is set, fix the +	value stored in ret rather than returning a pointer value. +	 +Wed Oct 25 23:10:39 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* config.bfd (powerpc{,le}-{elf,sysv4,eabi,solaris2}): Remove MAC +	format for now. + +Wed Oct 25 16:19:27 1995  Jeffrey A Law  (law@cygnus.com) + +	* som.c (som_slurp_string_table): Allocate the strings with malloc +	since they're free'd by free_cached_info. +	(som_slurp_symbol_table): Similarly for the symbol table. + +Wed Oct 25 14:59:22 1995  Per Bothner  <bothner@kalessin.cygnus.com> + +	* Makefile.in (diststuff):  Don't make headers. + +Wed Oct 25 11:32:54 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* Makefile.in: Rebuild dependencies. + +	* sunos.c (bfd_sunos_record_link_assignment): Don't do anything if +	output_bfd is not SunOS. +	(bfd_sunos_size_dynamic_sections): Likewise.  Don't scan relocs of +	non-SunOS input files. + +	* xcofflink.c: Extensive changes to support linking shared objects +	and generating a .loader section. +	* libcoff-in.h (struct xcoff_tdata): Add import_file_id field. +	(struct xcoff_section_tdata): Add lineno_count, first_symndx, +	last_symndx, and ldrel_count fields. +	* libcoff.h: Rebuild. +	* coff-rs6000.c (xcoff_howto_table): Correct reloc names. +	* coffcode.h (styp_to_sec_flags): Don't set any flags if STYP_PAD +	is set. +	* bfd-in.h (bfd_xcoff_import_symbol): Declare. +	(bfd_xcoff_export_symbol): Declare. +	(bfd_xcoff_size_dynamic_sections): Declare. +	* bfd-in2.h: Rebuild. + +Tue Oct 24 17:44:20 1995  Stan Shebs  <shebs@andros.cygnus.com> + +	* configure.in: Add xcofflink.o to pmac_xcoff_vec. +	* configure: Rebuild. +	* mpw-config.in: Add xcofflink.c.o to powerpc-apple-macos. +	* coff-pmac.c: Include coff-rs6000.c instead of duplicating its +	contents. +	(pmac_xcoff_vec): Update to use new xcoff support. +	* coff-rs6000.c (xcoff_generic_stat_arch_elt): Make static. +	(xcoff_write_armap): Declare buf as unsigned char. +	* xcofflink.c (xcoff_link_add_symbols): Declare a local as PTR. + +	* mpw-make.sed: Generalize subdir_do edit. +	 +Tue Oct 24 10:25:01 1995  Jeffrey A Law  (law@cygnus.com) + +	* hppabsd-core.c (make_bfd_asection): Initialize asect->filepos +	correctly.  Don't initialize asect->vma. + +Fri Oct 20 13:23:48 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* opncls.c (_bfd_new_bfd): If _bfd_chunksize wasn't preset, use +	something a little less than the page size. + +Thu Oct 19 13:06:09 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coff-i960.c (coff_i960_adjust_symndx): Clear *adjustedp. + +Wed Oct 18 16:20:08 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* coff-i386.c (coff_i386_reloc_type_lookup): New. +	* coffcode.h (coff_write_object_contents): If .bss is before +	.data us that as data_start. +	* cofflink.c (_bfd_coff_generic_relocate_section): Get reloc +	calc correct. +	* peicode.h (add_data_entry): Use _cooked_size of data directory. +	(coff_swap_outhdr_out): Hardwire in version number. +	 +Wed Oct 18 16:50:54 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* sunos.c (sunos_add_dynamic_symbols): Rename local variables +	major and minor to *_vno, since the former are also macros in +	SunOS header files.  Cast result of bfd_alloc to appropriate +	type. + +	* coffgen.c (coff_find_nearest_line): Cast used_by_bfd value +	before assigning to sec_data. + +Wed Oct 18 13:25:17 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* ecoff.c (_bfd_ecoff_find_nearest_line): The offset argument is +	now relative to the section, not absolute. +	* ecofflink.c (_bfd_ecoff_locate_line): Use the right symbol to +	get the file name when there is a N_SO directory name.  When +	handling stabs, remember that section->vma was added to the +	offset. + +Tue Oct 17 18:24:54 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* sunos.c (struct sunos_link_hash_table): Add needed field. +	(sunos_link_hash_table_create): Call bfd_release, not free. +	(sunos_link_hash_table_create): Initialize needed field. +	(sunos_add_dynamic_symbols): Record needed objects. +	(bfd_sunos_get_needed_list): New function. +	* bfd-in.h (bfd_sunos_get_needed_list): Declare. +	* bfd-in2.h: Rebuild. + +Mon Oct 16 14:43:59 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* libcoff-in.h (pe_data_type.in_reloc_p): New. + +Mon Oct 16 10:52:50 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* bfd-in.h (struct bfd_link_needed_list): Rename from +	bfd_elf_link_needed_list. +	* bfd-in2.h: Rebuild. +	* elf.c, elflink.h, libelf.h: Corresponding changes. + +	Add start at AIX linker support; no shared libraries yet. +	* xcofflink.c: New file. +	* configure.in (rs600coff_vec): Use xcofflink.o. +	* configure: Rebuild. +	* libcoff-in.h (struct xcoff_tdata): Add csects and debug_indices +	fields. +	(struct xcoff_section_tdata): Define. +	(xcoff_section_data): Define macro. +	(_bfd_xcoff_bfd_link_hash_table_create): Declare. +	(_bfd_xcoff_bfd_link_add_symbols): Declare. +	(_bfd_xcoff_bfd_final_link): Declare. +	(_bfd_ppc_xcoff_relocate_section): Declare. +	* libcoff.h: Rebuild. +	* coff-rs6000.c: Clean up a bit. +	(xcoff_mkobject): Default modtype to 1L, not RE.  Initialize +	cputype, csects, and debug_indices. +	(xcoff_copy_private_bfd_data): Copy cputype. +	(xcoff_howto_table): Rename from rs6000coff_howto_table. +	(xcoff_rtype2howto): Rename from rs6000coff_rtype2howto. +	(xcoff_reloc_type_lookup): Rename from +	rs6000coff_reloc_type_lookup. +	(coff_relocate_section): Define. +	(_bfd_xcoff_sizeof_headers): Define. +	(_bfd_xcoff_bfd_get_relocated_section_contents): Define. +	(_bfd_xcoff_bfd_relax_section): Define. +	(_bfd_xcoff_bfd_link_split_section): Define. +	(rs6000coff_vec): For BFD_JUMP_TABLE_LINK, use _bfd_xcoff, not +	coff. +	* coffcode.h (coff_compute_section_file_positions): If AIX, +	increment sofar by SMALL_AOUTSZ if not executable. +	(coff_write_object_contents): If AIX, always output an a.out +	header; if not executable, header size of SMALL_AOUTSZ. +	* hash.c (struct bfd_strtab_hash): Add xcoff field. +	(_bfd_stringtab_init): Initialize xcoff field. +	(_bfd_xcoff_stringtab_init): New function. +	(_bfd_stringtab_add): In XCOFF mode, leave two bytes for length. +	(_bfd_stringtab_emit): In XCOFF mode, write out length. +	* libbfd-in.h (_bfd_xcoff_stringtab_init): Declare. +	* libbfd.h: Rebuild. +	* Makefile.in: Rebuild dependencies. +	(BFD32_BACKENDS): Add xcofflink.o. +	(CFILES): Add xcofflink.c. + +	* elf32-mips.c (mips_elf_symbol_processing): Set SEC_ALLOC, not +	SEC_NO_FLAGS, for .acommon section.  From Peter Schauer +	<Peter.Schauer@Regent.E-Technik.TU-Muenchen.DE>. + +Sat Oct 14 21:36:02 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* coff-ppc.c (in_reloc_p): Add, clone from coff-i386.c. + +Fri Oct 13 17:48:43 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* acconfig.h (HAVE_SYS_PROCFS_H): Undef, with comment. +	* config.in: Regenerated. + +	* opncls.c (getpagesize) [!HAVE_GETPAGESIZE]: Define as 2048. +	(_bfd_chunksize): New variable. +	(_bfd_new_bfd): Set it to getpagesize() if negative, and use it +	for obstack chunk size. +	* configure.in: Check for getpagesize. +	* configure: Regenerated. + +	Mon Sep 25 22:49:32 1995  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> + +	* trad-core.c (rawptr): Make it a local variable of + 	ptrace_unix_core_file_p. + +Fri Oct 13 11:22:01 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* coff-arm.c (in_reloc_p): New. +	* coff-i386.c (in_reloc_p): New. +	* coffcode.h: Allways include peicode.h if COFF_WITH_PE. +	(coff_write_object_contents): Only set has_reloc_section +	if PE_IMAGE. +	* cofflink.c (_bfd_coff_generic_relocate_section): Call +	in_reloc_p to decide if reloc should be emitted. +	* libcoff.h (pe_data_type.in_reloc_p): New. +	* peicode.h (pe_mkobject): Initialize in_reloc_p. + +Wed Oct 11 00:49:29 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* cofflink.c (_bfd_coff_internal_syment_name): Move to coffgen.c. +	(_bfd_coff_read_internal_relocs): Likewise. +	* coffgen.c (_bfd_coff_internal_syment_name): Copy from coffgen.c. +	(_bfd_coff_read_internal_relocs): Likewise. + +	* elflink.h (elf_link_add_object_symbols): Correct conditions +	under which type and size change warnings are issued. + +Tue Oct 10 18:32:46 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffgen.c (coff_count_linenumbers): Don't count line numbers for +	a symbol which is not in a real section. +	(coff_write_native_symbol): Corresponding change. + +	* cofflink.c (_bfd_coff_link_hash_newfunc): Rename from +	coff_link_hash_newfunc and make non-static. +	(_bfd_coff_link_hash_table_init): New function, broken out of +	_bfd_coff_link_hash_table_create. +	(_bfd_coff_link_hash_table_create): Use it. +	(process_embedded_commands): Make static. +	* libcoff-in.h ((_bfd_coff_link_hash_newfunc): Declare. +	(_bfd_coff_link_hash_table_init): Declare. +	* libcoff.h: Rebuild. + +	* coffcode.h (coff_mkobject_hook): If RS6000COFF_C, set cputype +	field in XCOFF tdata. +	(coff_set_arch_mach_hook): Check ifdef RS6000COFF_C, not ifdef +	U802ROMAGIC, for clarity.  Try to set arch and machine correctly +	based on cputype stored in a.out header, or in n_type of initial +	.file symbol. +	(coff_write_object_contents): Set cputype correctly in a.out +	header. +	(coff_slurp_symbol_table): Add casts to file_ptr to avoid +	warnings. +	* coffswap.h (coff_swap_aouthdr_in): Swap in cputype field. +	(coff_swap_aouthdr_out): Swap out cputype field.  Don't clear +	old resv1 field. +	* libcoff-in.h (struct xcoff_tdata): Add cputype field. +	* libcoff.h: Rebuild. + +	* cpu-rs6000.c (rs6000_compatible): New static function. +	(bfd_rs6000_arch): Use it. +	* cpu-powerpc.c (powerpc_compatible): New static function. +	(arch_info_struct): Define various flavours of PowerPC. +	(bfd_powerpc_arch): Use powerpc_compatible.  Point at +	arch_info_struct. + +Tue Oct 10 10:50:46 1995  Fred Fish  <fnf@cygnus.com> + +	* Makefile.in (FLAGS_TO_PASS):  Remove BISON. + +Tue Oct 10 01:28:29 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elflink.h (elf_link_add_object_symbols): Don't warn about +	changing the size or type if the old definition was weak. + +Mon Oct  9 11:24:08 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (combined_entry_type): Add fix_line field. +	(coff_slurp_line_table): Warn if we try to set the lineno field of +	a symbol twice. +	(coff_slurp_symbol_table): If RS6000COFF_C, handle C_BINCL and +	C_EINCL by setting fix_line.  Fix C_BSTAT symbol value. +	* coffgen.c (coff_mangle_symbols): Handle fix_line. +	(coff_write_symbol): Only use N_DEBUG if the symbol is in the +	absolute section. +	(coff_print_symbol): Print fix_value symbols in a useful fashion. +	* libcoff.h: Rebuild. + +	* libcoff-in.h (struct xcoff_tdata): Define. +	(xcoff_data): Define. +	* bfd.c (struct _bfd): Add xcoff_obj_data field to tdata union. +	* bfd-in2.h, libcoff.h: Rebuild. +	* coff-rs6000.c (xcoff_mkobject): New static function. +	(coff_mkobject): Define. +	(xcoff_copy_private_bfd_data): New static function. +	(coff_bfd_copy_private_bfd_data): Define. +	(rs6000coff_howto_table): Change R_TOC complain_on_overflow from +	signed to bitfield. +	(rs6000coff_vec): Add DYNAMIC to object_flags. +	* coffcode.h (sec_to_styp_flags): If RS6000COFF_C, handle .pad and +	.loader sections specially. +	(coff_new_section_hook): If RS6000COFF_C, get the .text and .data +	section alignment from the XCOFF tdata information. +	(coff_mkobject_hook): If RS6000COFF_C, set DYNAMIC based on +	F_SHROBJ, and copy the extra a.out header information into the +	XCOFF tdata structure. +	(coff_write_object_contents): If RS6000COFF_C, set F_SHROBJ, +	F_DYNLOAD and the extra a.out header information. +	(coff_slurp_symbol_table): Set BSF_NOT_AT_END for a C_EXT or +	C_HIDEXT symbol with attached csect information. +	* coffswap.h (coff_swap_aouthdr_in): If RS6000COFF_C, swap +	in the o_maxdata field. +	(coff_swap_aouthdr_out): If RS6000COFF_C, swap extra XCOFF fields. +	* coffgen.c (coff_renumber_symbols): Don't move any symbol to the +	end if BSF_NOT_AT_END is set. + +	* targets.c (bfd_target): Rename _bfd_read_ar_hdr field to +	_bfd_read_ar_hdr_fn. +	* libbfd-in.h (_bfd_read_ar_hdr): Update accordingly. +	* bfd-in2.h, libbfd.h: Rebuild. +	* archive.c (_bfd_get_elt_at_filepos): Cast _bfd_read_ar_hdr +	return value. +	(do_slurp_bsd_armap, do_slurp_coff_armap): Likewise. +	(bfd_slurp_bsd_armap_f2): Likewise. +	(_bfd_slurp_extended_name_table): Likewise. + +Fri Oct  6 16:18:35 1995  Ken Raeburn  <raeburn@cygnus.com> + +	Mon Sep 25 22:49:32 1995  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> + +	* archive.c (bfd_get_next_mapent): Return BFD_NO_MORE_SYMBOLS +	when the symbol table is empty. + +	* elf32-m68k.c (elf_m68k_size_dynamic_sections): Don't reserve +	space for section symbols, since we don't output them either. +	(elf_m68k_adjust_dynindx): Removed. + +	* ptrace-core.c (rawptr): Make it a local variable of + 	ptrace_unix_core_file_p. + +Fri Oct  6 12:24:47 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* coff-rs6000.c (xcoff_write_archive_contents): Return false, not +	NULL. + +	* config.bfd (powerpc{,le}-{elf,sysv4,eabi,solaris2}): Add NT, and +	Mac object file formats. + +Fri Oct  6 12:04:02 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffgen.c (coff_fix_symbol_name): Don't try to set up file +	auxent if there isn't one. +	(coff_write_symbols): If there is no file auxent, use SYMNMLEN +	rather than FILNMLEN as the maximum name length. + +	* coffcode.h (bfd_coff_backend_data): Add new field +	_bfd_coff_print_aux. +	(bfd_coff_print_aux): New static function. +	(coff_pointerize_aux_hook (RS6000COFF_C version)): Pointerize the +	scnlen field of an XTY_LD csect aux entry. +	(coff_print_aux): New static function. +	(coff_slurp_symbol_table): Don't pointerize scnlen field; now done +	in coff_pointerize_aux_hook. +	(bfd_coff_std_swap_table): Initialize new field. +	* coffgen.c (coff_print_symbol): Call bfd_coff_print_aux. +	* libcoff.h: Rebuild. +	* coff-alpha.c (alpha_ecoff_backend_data): Initialize new field. +	* coff-mips.c (mips_ecoff_backend_data): Likewise. + +	* coffcode.h (coff_write_object_contents): On AIX, clear F_RELFLG +	if there are symbols, for native AIX ld compatibility. + +	* coffcode.h (bfd_coff_backend_data): Add new field +	_bfd_coff_pointerize_aux_hook. +	(coff_pointerize_aux_hook): Define as a function if RS6000COFF_C +	or I960, and as 0 otherwise. +	(bfd_coff_std_swap_table): Initialize new field. +	* libcoff.h: Rebuild. +	* coffgen.c (coff_pointerize_aux): Change parameters  to take +	symbol pointer instead of type and class, and to take aux index. +	Call _bfd_coff_pointerize_aux_hook if it is defined. +	(coff_get_normalized_symtab): Always call coff_pointerize_aux. +	* coff-alpha.c (alpha_ecoff_backend_data): Initialize all fields. +	* coff-mips.c (mips_ecoff_backend_data): Likewise. + +	* coff-rs6000.c: Add full support for AIX archives.  Rewrite old +	read-only/host-only support. + +	* coffcode.h (coff_slurp_symbol_table): Set C_HIDEXT symbols to be +	BSF_LOCAL. +	(OTHER_GLOBAL_CLASS): Do not define to be C_HIDEXT if +	RS6000COFF_C. + +	* targets.c (bfd_target): Add _bfd_read_ar_hdr field.  Modify +	BFD_JUMP_TABLE_ARCHIVE accordingly. +	* libbfd-in.h (_bfd_snarf_ar_hdr): Don't declare. +	(_bfd_compute_and_write_armap): Declare. +	(_bfd_generic_read_ar_hdr): Declare. +	(_bfd_read_ar_hdr): Define. +	(_bfd_noarchive_read_ar_hdr): Define. +	(_bfd_archive_bsd_read_ar_hdr): Define. +	(_bfd_archive_coff_read_ar_hdr): Define. +	* archive.c: Change all callers of _bfd_snarf_ar_hdr to call +	_bfd_read_ar_hdr instead. +	(_bfd_generic_read_ar_hdr): Rename from _bfd_snarf_ar_hdr. +	(_bfd_compute_and_write_armap): Rename from +	compute_and_write_armap.  Make non-static.  Change all callers. +	* ecoff.c (_bfd_ecoff_slurp_armap): Call _bfd_read_ar_hdr rather +	than _bfd_snarf_ar_hdr. +	* aout-target.h (MY_read_ar_hdr): Define if not defined. +	* ieee.c (ieee_read_ar_hdr): Define. +	* libecoff.h (_bfd_ecoff_read_ar_hdr): Define. +	* oasys.c (oasys_read_ar_hdr): Define. +	* som.c (som_read_ar_hdr): Define. +	* bfd-in2.h, libbfd.h: Rebuild. + +Thu Oct  5 14:04:07 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* peicode.c (coff_swap_filehdr_in): If symptr is +	zero, there aren't any symbols, even if nsyms is set. + +Thu Oct  5 11:45:02 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* libecoff.h (struct ecoff_backend_data): Add adjust_headers +	field. +	* ecoff.c (ecoff_sec_to_styp_flags): Check for various Alpha +	sections, and set styp correctly for them: .got, .hash, .dynamic, +	.liblist, .rel.dyn, .conflic, .dynstr, .dynsym, .comment. +	(_bfd_ecoff_styp_to_sec_flags): Check for various Alpha section +	types. +	(ecoff_sort_hdrs): New static function. +	(ecoff_compute_section_file_positions): Return boolean, not void. +	Sort the sections by VMA before looking through them.  Put the +	first non SEC_ALLOC section on a new page.  Put every SEC_ALLOC +	section on an appropriate boundary within the page. +	(ecoff_compute_reloc_file_positions): Check return value of +	ecoff_compute_section_file_positions. +	(_bfd_ecoff_set_section_contents): Likewise. +	(_bfd_ecoff_write_object_contents): Check for various Alpha +	section types when incrementing text_size and data_size.  Call +	adjust_headers backend function if it exists. +	* coff-alpha.c (alpha_adjust_headers): New static function. +	(alpha_ecoff_backend_data): Initialize adjust_headers field. +	* coff-mips.c (mips_ecoff_backend_data): Likewise. + +	* hosts/i386bsd.h: Restore file incorrectly deleted on Sep 6. + +Wed Oct  4 18:15:02 1995  Jeff Law  (law@hurl.cygnus.com) + +	* rs6000-core.c (CORE_VERSION_1): Use CORE_VERSION_1 instead +	of ALTERNATE_AIX_CORE_FORMAT. +	* configure.in (aix4): No longer need CORE_FLAGS. +	* configure: Updated. + +Wed Oct  4 15:36:36 1995  Ken Raeburn  <raeburn@cygnus.com> + +	NS32k changes from Ian Dall: +	* aoutx.h (MY_final_link_relocate, MY_relocate_contents): New +	macros. +	(aout_link_input_section_std, aout_link_input_section_ext, +	aout_link_reloc_link_order): Call them instead of _bfd_* +	versions. +	* aout-target.h (MY_exec_header_not_counted): New macro, defaults +	to zero. +	(backend_data): Use it instead of hardcoded zero. + +	* aout-ns32k.c (CTOR_TABLE_RELOC_HOWTO): New macro. +	(MY_swap_std_reloc_out): Use udata.i for KEEPIT, don't call stoi. + +	* ns32knetbsd.c: Include bfd.h. +	(MY_text_includes_header, MY_bfd_reloc_type_lookup): New macros. +	(MY_bfd_reloc_type_lookup): Declare function too. +	* pc532-mach.c (set_sizes): Don't declare. +	(MY_text_includes_header, MY_exec_header_not_counted): Define. +	(backend_data, MY_backend_data): Don't define. + +	* config.bfd: Treat ns32k-pc532-ux* like ns32k-pc532-mach*, and +	ns32k-*-lites* like ns32k-*-netbsd*. + +	* hosts/nbsd.h: Swap order of sys/vmparam.h and sys/param.h, to +	compile on lites. + +Wed Oct  4 14:15:52 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_write_object_contents): Restore setting +	f_timdat to 0, deleted on August 22. + +Tue Oct  3 16:28:32 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* coffcode.h (coff_bfd_copy_private_symbol_data, +	coff_bfd_copy_private_section_data, +	coff_bfd_copy_private_bfd_data): ifdef to allow overrides. +	* peicode.h (coff_bfd_copy_private_bfd_data): New +	(pe_bfd_copy_private_bfd_data): New. +	(coff_swap_scnhdr_in): Swap bss size into the right place. +	(pe_print_private_bfd_data): Add some newlines. + +Tue Oct  3 11:53:04 1995  Jeff Law  (law@hurl.cygnus.com) + +	* som.c (setup_sections): Don't die if a space has no subspaces. + +Mon Oct  2 14:08:55 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elflink.h (elf_link_add_object_symbols): Don't let a weak +	dynamic symbol override a common symbol.  Don't change the size or +	type if they have been set and the new symbol is not a definition. +	Warn if the size or type changes. + +Sun Oct  1 01:34:41 1995  Jeff Law  (law@hurl.cygnus.com) + +        * som.c (som_begin_writing): Don't write the symbol table or +	symbol	strings. +	(som_finish_writing): Write them here.  Place them after the +	subspace data, but before the relocs. + +Fri Sep 29 11:01:55 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* sunos.c (sunos_add_one_symbol): Just pass false, not +	info->shared_library, to sunos_create_dynamic_sections. +	(sunos_scan_ext_relocs): Don't warn about a reloc in the .text +	section. +	(sunos_check_dynamic_reloc): Remove .text section assertion. + +Thu Sep 28 18:48:47 1995  Stan Shebs  <shebs@andros.cygnus.com> + +	* config.bfd: Add powerpc-*-macos*, powerpc-*-mpw*. +	* configure, configure.in: Add pmac_xcoff_vec case. +	* Makefile.in (BFD32_BACKENDS): Add coff-pmac.o. +	* coff-pmac.c: New file, PowerMac XCOFF support. +	* coffcode.h (coff_set_arch_mach_hook): Add PowerMac case. +	* targets.c (pmac_xcoff_vec): Declare. + +	* mpw-config.in: Various changes to be compatible with the +	autoconf-based configury. +	* mpw-make.sed: New file, sed commands to translate Unix +	makefile into MPW syntax. +	* mpw-make.in: Remove. +	* hosts/mpw.h: Remove. +	* bfd-in.h, bfd-in2.h: If MPW, include the file that defines +	true and false as enums, then define TRUE_FALSE_ALREADY_DEFINED. + +Thu Sep 28 17:06:23 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* binary.c (binary_get_symtab): Return an empty string on error. +	* opncls.c (bfd_fdpenr): Change WIN32 restriction to WINGDB. + +Thu Sep 28 15:30:44 1995  Kim Knuttila  <krk@nellie> + +	* coff-ppc.c: Reformatted according to gnu conventions +	              Removed irrelevant "if 0" code + +Thu Sep 28 11:19:53 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* hp300hpux.c (convert_sym_type): Treat secondary symbols as weak +	symbols rather than as indirect symbols. +	(MY(slurp_symbol_table)): Don't do anything special about +	secondary symbols. + +	* coffcode.h (coff_new_section_hook): Make sure that the alignment +	of .ctors and .dtors sections is no larger than 2. + +	* sunos.c (sunos_add_one_symbol): Don't change +	bfd_link_hash_common to bfd_link_hash_new, since it may be on the +	undef list. +	(bfd_sunos_record_link_assignment): Don't put __DYNAMIC in the +	dynamic symbols when creating a shared library. +	(sunos_scan_ext_relocs): Handle relocs correctly when creating a +	shared library. +	(sunos_scan_dynamic_symbol): Don't mark the __DYNAMIC symbol as +	written even if it is not defined in a regular object. +	(sunos_write_dynamic_symbol): Use plt_offset for the address of +	the jump table reloc.  Add an assertion.  Use RELOC_JMP_SLOT +	rather than the constant 22. +	(sunos_check_dynamic_reloc): Handle creating a shared library. +	(sunos_finish_dynamic_link): Set the first entry in the GOT to +	zero when creating a shared library. +	* aoutx.h (NAME(aout,final_link)): If there is a symbol __DYNAMIC, +	write it out at the start of the symbol table. + +	* Makefile.in (BFD32_BACKENDS): Add coff-arm.o. + +Thu Sep 28 00:58:05 1995  Doug Evans  <dje@deneb.cygnus.com> + +	* config.bfd: Add arm-*-coff. +	* configure.in, configure: Add armcoff_{little,big}_vec. +	* targets.c (armcoff_{little,big}_vec): Declare. +	(bfd_target_vector): Add armcoff_{little,big}_vec. +	* coff-arm.c (armcoff_{little,big}_vec): Always define. + +Wed Sep 27 10:37:14 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* targets.c (bfd_find_target): Remove debugging code. + +Wed Sep 27 07:23:39 1995  Kim Knuttila  <krk@nellie> + +	* coff-ppc.c, pe-ppc.c, pei-ppc.c: Initial bfd for coff/PE  +        support on powerpc. +	* Makefile.in: added *-ppc files +	* coffcode.h: ppc MAGIC, and use peicode.h rather than coffswap.h to +        allow pe based .o's to be shared with other tools on ppc/NT +	* config.bfd: added powerpc[le]-[pe|winnt] config support +	* configure, configure.in: added bfd_powerpc[le]_pe[i]_vec  +	* peicode.h: Added more section flags for PE on ppc +	             Added coff_swap_filehdr_out to allow peicode.h to be +		     used for non-image PE files on ppc. +		     Check for image, or not, before copying pe_opthdr +	* targets.c: Added new bfd's +	* targets.c: Removed two inactive bfds that shouldn't have made it this +                     far. + +Tue Sep 26 14:06:41 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_reloc_type): Rename from reloc_type, and use +	explicit values to initialize all relocs.  Change all users. +	(ppc_elf_brtaken_inner): New function to handle branch predicition +	relocs. +	(ppc_elf_brtaken_reloc): Ditto. +	(ppc_elf_howto_raw): Use new functions.  Make sure all unsupported +	relocs use ppc_elf_unsupported_reloc. +	(ppc_elf_merge_private_bfd_data): Keep track of whether an error +	needs to be reported. +	(ppc_elf_relocate_section): Support branch prediction relocs. + +Tue Sep 26 12:48:05 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* bfd.c (bfd_assert): Remove \n from string passed to +        _bfd_error_handler. + +	* coff-i386.c: (TWO_DATA_SECS): Don't define. +	* coffcode.h (bfd_coff_backend_data): Remove _bfd_make_section_hook. +	(bfd_coff_make_section_hook): Don't define. +	(coff_make_section_hook): Remove. +	(sec_to_styp_flags): Remove TWO_DATA_SECS case. +	(styp_to_sec_flags): Likewise. +	(coff_write_object_contents): Likewise. +	(bfd_coff_std_swap_table): Don't initialize make_section_hook +	field. +	* libcoff.h: Rebuild. +	* coffgen.c (make_a_section_from_file): Just call +	bfd_make_section_anyway, not bfd_make_section or +	bfd_coff_make_section_hook. +	* ecoff.c (_bfd_ecoff_make_section_hook): Remove. +	* libecoff.h (_bfd_ecoff_make_section_hook): Don't declare. +	* coff-alpha.c (alpha_ecoff_backend_data): Don't initialize +	make_section_hook field. +	* coff-mips.c (mips_ecoff_backend_data): Likewise. + +	* aoutx.h (translate_from_native_sym_flags): Don't try to stuff +	pointers into value field for warning and indirect symbols; just +	leave the value field alone. +	* linker.c (generic_link_add_symbol_list): Use next symbol for +	warning and indirect symbols, rather than looking in symbol value. +	* ecoff.c (ecoff_set_symbol_info): Remove indirect_ptr_ptr +	parameter.  Change all callers.  Remove support for indirect +	symbols; it didn't work anyhow. +	(_bfd_ecoff_slurp_symbol_table): Remove indirect_ptr variable. +	* syms.c: Change comments about BSF_WARNING and BSF_INDIRECT. +	* bfd-in2.h: Rebuild. + +Mon Sep 25 16:04:09 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* elf32-ppc.c (ppc_elf_howto_raw): For all 14-bit branch relocs, +	go back to telling the tools this reloc operates on 32 bits. + +Mon Sep 25 11:48:02 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* aout-adobe.c (aout_adobe_callback): Use _bfd_error_handler +	rather than a direct fprintf. +	* archive.c (_bfd_write_archive_contents): Likewise. +	* coffcode.h (coff_slurp_symbol_table): Likewise. +	* elf32-ppc.c (ppc_elf_merge_private_bfd_data): Likewise. +	(ppc_elf_unsupported_reloc): Likewise. +	(ppc_elf_relocate_section): Likewise. +	* i386linux.c (linux_tally_symbols): Likewise. +	(linux_finish_dynamic_link): Likewise. +	* osf-core.c (osf_core_core_file_p): Likewise. +	* rs6000-core.c (rs6000coff_get_section_contents): Likewise. +	* som.c (som_sizeof_headers): Likewise. +	* srec.c (srec_bad_byte): Likewise. +	* bfd.c (bfd_assert): Likewise.  Also change file to be const. +	* libbfd-in.h (bfd_assert): Declare first parameter const. +	* libbfd.h: Rebuild. +	* coff-a29k.c (a29k_reloc): Don't bother to fprintf; returning +	bfd_reloc_overflow is enough. +	* coff-h8300.c (rtype2howto): Don't bother to fprintf; just abort. +	* coff-h8500.c (rtype2howto): Likewise. +	* coff-z8k.c (rtype2howto): Likewise. +	* coffcode.h (dummy_reloc16_extra_cases): Likewise. +	* elf.c (_bfd_elf_get_lineno): Likewise. +	(_bfd_elf_no_info_to_howto): Likewise. +	(_bfd_elf_no_info_to_howto_rel): Likewise. +	* hp300hpux.c (convert_sym_type): Likewise. +	(MY(swap_std_reloc_in)): Likewise. +	* elf.c (bfd_section_from_shdr): Remove #if 0 sections. + +	* libaout.h (struct aoutdata): Add line_buf field. +	* aoutx.h (NAME(aout,find_nearest_line)): Remove statics buffer +	and filename_buffer.  Instead, use a malloc buffer stored in the +	new line_buf field.  Remove length restrictions. + +	* coffgen.c (string_size): Remove static variable. +	(debug_string_size, debug_string_section): Likewise. +	(coff_fix_symbol_name): Add string_size_p, debug_string_section_p, +	and debug_string_size_p parameters.  Use them instead of the +	global variables.  Change all callers. +	(coff_write_symbol): Likewise. +	(coff_write_alien_symbol, coff_write_native_symbol): Likewise. +	(coff_write_symbols): Add local variables to replace removed +	global variables. + +	* libcoff-in.h (struct coff_section_tdata): Add offset, i, +	function, and line_base fields. +	* libcoff.h: Rebuild. +	* coffgen.c (coff_find_nearest_line): Use section tdata to cache +	information, rather than using static variables. + +	* sunos.c (sunos_read_dynamic_info): Adjust offsets in an NMAGIC +	file.  From Peter DeWolf <pld@amt.tay1.dec.com>. + +	* init.c (initialized): Remove static variable. +	(bfd_init): Don't bother setting initialized. +	(bfd_check_init): Remove. +	* opncls.c (_bfd_new_bfd): Don't call bfd_check_init. +	* libbfd.h: Rebuild. + +Sat Sep 23 01:22:23 1995  Peter Schauer  (pes@regent.e-technik.tu-muenchen.de) + +	* rs6000-core.c (rs6000coff_core_p):  Don't check the core file +	size for full core dumps. Copy core file header to private data. +	(rs6000coff_core_file_failing_command, +	rs6000coff_core_file_failing_signal):  New functions to extract +	the file name and terminating signal from the core file. +	* coff-rs6000.c:  Use them. + +Fri Sep 22 17:44:47 1995  Ian Lance Taylor  <ian@cygnus.com> + +	Change arch info to be const, initialized at compile time. +	* archures.c: Reindent many functions.  Change CONST to const. +	(bfd_arch_info_type): Make arch_name const.  Remove disassemble; +	nothing set it anyhow.  Make next const. +	(bfd_arch_info_list): Remove. +	(bfd_archures_list): Rename from archures_init_table.  Change from +	a table of function pointers to a table of bfd_arch_info_type +	structure addresses. +	(bfd_scan_arch): Rewrite accordingly.  Return a const pointer. +	(bfd_lookup_arch): Likewise. +	(bfd_set_arch_info): Rewrite accordingly.  Change argument to be a +	const pointer. +	(bfd_default_arch_struct): Make const. +	(bfd_arch_init, bfd_arch_linkin): Remove. +	(bfd_get_arch_info): Return a const pointer. +	* init.c (bfd_init): Don't call bfd_arch_init. +	* bfd.c (struct _bfd): Make arch_info const. +	* bfd-in2.h: Rebuild. +	* libbfd.h: Rebuild. +	* configure.in: Put & before everything in $selarchs. +	* configure: Rebuild. +	* cpu-*.c: Change bfd_*_arch from a function which calls +	bfd_arch_linkin to a const structure. +	* ieee.c (ieee_object_p): Make arch const. + +Fri Sep 22 16:23:18 1995  Michael Meissner  <meissner@tiktok.cygnus.com> + +	* reloc.c (bfd_reloc_code_type): Add relocations to support all of +	PowerPC V.4. +	* bfd-in2.h: Regenerate. +	* libbfd.h: Regenerate. + +	* elf32-ppc.c (reloc_type): Update names to match current draft. +	(ppc_elf_howto_raw): Mark 14 bit relocs as short sized and PC +	relative.  Update names to current V.4 draft. +	(ppc_elf_reloc_type_lookup): Add support for more relocations. +	(ppc_elf_relocate_section): Rename relocations to match draft. + +Thu Sep 21 21:53:18 1995  Michael Meissner  <meissner@cygnus.com> + +	* elf32-ppc.c (ppc_elf_merge_private_bfd_data): Allow modules +	compiled with -mrelocatable-lib to be linked with either normal +	modules or -mrelocatable modules. + +Wed Sep 20 12:03:26 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* coffcode.h (coff_write_object_contents): Clear the vstamp field +	in the a.out header. + +	* aoutx.h (NAME(aout,swap_ext_reloc_out)): Don't set r_extern for +	a reloc against a local symbol, even if it's not a section. + +Tue Sep 19 17:02:26 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* targets.c (bfd_target): Remove unused align_power_min field. +	* bfd-in2.h: Rebuild. +	* All backends: Remove initialization of align_power_min. + +Tue Sep 19 14:02:21 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* peicode.h (coff_swap_scnhdr_out): Get sizes for BSS right. + +Mon Sep 18 14:35:01 1995  Arne H. Juul  <arnej@pvv.unit.no> + +	* config.bfd (mips-dec-netbsd*): New target. +	* configure.host (mips-dec-netbsd*): New host. +	* configure.in (mips-dec-netbsd*): New native. +	* configure: Rebuild. + +Fri Sep 15 10:24:36 1995  Ian Lance Taylor  <ian@cygnus.com> + +	Make the COFF backend linker merge common types: +	* cofflink.c (struct coff_debug_merge_element): Define. +	(struct coff_debug_merge_type): Define. +	(struct coff_debug_merge_hash_entry): Define. +	(struct coff_debug_merge_hash_table): Define. +	(coff_debug_merge_hash_table_init): Define. +	(coff_debug_merge_hash_table_free): Define. +	(coff_debug_merge_hash_lookup): Define. +	(struct coff_final_link_info): Add debug_merge field. +	(coff_debug_merge_hash_newfunc): New static function. +	(_bfd_coff_final_link): Allocate and free debug_merge table. +	(coff_link_input_bfd): Merge identical enum, struct and union +	types. + +Thu Sep 14 14:53:58 1995  Ian Lance Taylor  <ian@cygnus.com> + +	Convert i960 COFF to use COFF backend linker. +	* coff-i960.c (coff_i960_relocate): Use a coff_section_data +	structure to store the symbol being used. +	(coff_i960_start_final_link): New static function. +	(coff_i960_relocate_section): New static function. +	(coff_i960_adjust_symndx): New static function. +	(coff_start_final_link): Define. +	(coff_relocate_section): Define. +	(coff_adjust_symndx): Define. +	* coffcode.h (bfd_coff_backend_data): Add new callback function +	_bfd_coff_start_final_link. +	(bfd_coff_start_final_link): Define. +	(coff_start_final_link): Define if not defined. +	(bfd_coff_std_swap_table): Add coff_start_final_link. +	* cofflink.c (_bfd_coff_internal_syment_name): Make globally +	visible. +	(_bfd_coff_final_link): Call bfd_coff_start_final_link if the +	function callback is not NULL. +	* libcoff-in.h (struct coff_section_tdata): Add tdata field. +	(_bfd_coff_internal_syment_name): Declare. +	* libcoff.h: Rebuild. +	* configure.in (icoff_big_vec): Add cofflink.o. +	(icoff_little_vec): Likewise. +	* configure: Rebuild. + +Wed Sep 13 17:38:23 1995  Fred Fish  <fnf@rtl.cygnus.com> + +	* Makefile.in (clean-info): Remove extraneous tab from line +	following action. + +Wed Sep 13 13:27:53 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* cofflink.c (coff_link_input_bfd): Fail if a section with no +	contents has relocs. + +Thu Sep 12 12:45:34 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* coffcode.h (coff_compute_section_file_positions): Keep the +	raw size safe.  +	(coff_write_object_contents): Remember if it's a relocatable +	file. +	* libcoff-in.h (pe_data_type): New member 'has_reloc_section' +	* peicode.h (coff_swap_filehdr_out): Clear not-reloc flag +	if relocatable file. Swap out saved raw size. + +Tue Sep 12 12:14:33 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* Makefile.in (do_maintainer_clean): Rename from do_realclean. +	(maintainer-clean): Rename from realclean, passing +	maintainer-clean down to subdirectories, but leave realclean as a +	synonym. + +	* linker.c (_bfd_generic_link_add_one_symbol): Pass symbol name to +	warning callback. + +	* dep-in.sed: Remove config.h from generated dependencies. + +	* sunos.c (sunos_slurp_dynamic_symtab): New static function, +	broken out of sunos_canonicalize_dynamic_symtab. +	(sunos_canonicalize_dynamic_symtab): Call new function +	sunos_slurp_dynamic_symtab. +	(sunos_add_dynamic_symbols): Add three new parameters.  Return the +	dynamic symbol table to the caller. +	* aoutx.h (aout_link_add_symbols): Permit add_dynamic_symbols +	callback to override the symbols being read. +	* libaout.h (struct aout_backend_data): Add three new parameters +	to add_dynamic_symbols callback. + +	Extensive minor changes to avoid various gcc warnings.  Also: +	* Makefile.in (BFD32_BACKENDS): Remove coff-arm.o. +	* archures.c (bfd_arch_info_type): Change mach field from long to +	unsigned long. +	(bfd_lookup_arch): Change machine parameter from long to unsigned +	long. + +Mon Sep 11 10:55:47 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* sunos.c (sunos_scan_std_relocs): Fix BFD_ASSERT: it's OK to find +	a symbol with a non-zero plt_offset. + +Fri Sep  8 11:47:24 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* elfcode.h (align_file_position): Remove; not used. + +	* configure.in: Only check for <sys/procfs.h> on a native system, +	and make sure it defines prstatus_t. +	* configure: Rebuild. + +Thu Sep  7 12:48:01 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* sunos.c (sunos_write_dynamic_symbol): Correct m68k abort test. + +	* config.in: Rename from config.h.in. +	* configure.in: Call AC_CONFIG_HEADER with config.h:config.in. +	Check for config.h:config.in when creating stamp-h. +	* configure: Rebuild. +	* Makefile.in (stamp-h): Depend upon config.in rather than +	config.h.in.  Set CONFIG_HEADERS to config.h:config.in when +	calling config.status. + +	* Makefile.in (do_distclean): Remove config.h and stamp-h. +	(Makefile): Just rebuild Makefile. +	(config.h, stamp-h): New targets. +	* configure.in: Create stamp-h when rebuilding config.h. +	* configure: Rebuild. + +Wed Sep  6 15:00:33 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.in: Call AC_CONFIG_HEADER.  Substitute +	HOST_64BIT_LONG.  Check that various header files exist.  Check +	that fcntl exists.  Call BFD_BINARY_FOPEN.  Check whether malloc +	and/or free need to be declared.  Don't make a link to sysdep.h. +	Define TRAD_HEADER for various hosts. +	* configure: Rebuild. +	* configure.host: Don't set my_host.  Add definitions taken from +	host header files for various entries.  Remove entries which now +	do nothing. +	* acconfig.h: New file. +	* config.h.in: New file, built by autoheader. +	* sysdep.h: New file. +	* Makefile.in (do_distclean): Don't remove sysdep.h. +	(RECONFIG): Remove. +	(LOCAL_H_DEPS): New variable. +	($(BFD_LIBS)): Use $(LOCAL_H_DEPS) rather than libbfd.h and +	$(RECONFIG). +	($(BFD_MACHINES), $(BFD_BACKENDS)): Likewise. +	($(OPTIONAL_BACKENDS)): Likewise. +	(stmp-bfd.h): Just substitute for BFD_HOST_64BIT_LONG, rather than +	looking through sysdep.h. +	* bfd-in.h (BFD_HOST_64BIT_LONG): Define; set by Makefile. +	(BFD_HOST_64_BIT): Define based on BFD_HOST_64BIT_LONG. +	(fprintf_vma, sprintf_vma): Likewise. +	(int64_type, uint64_type): Don't define. +	* bfd-in2.h: Rebuild. +	* archures.c, bfd.c, srec.c: Include <ctype.h>. +	* elfcore.h: Check HAVE_SYS_PROCFS_H rather than HAVE_PROCFS. +	* lynx-core.c: Include stuff from old hosts/lynx.h. +	* opncls.c (bfd_fdopenr): Check HAVE_FNCTL and defined (F_GETFL), +	rather than NO_FCNTL. +	* targets.c (bfd_target_list): Check HOST_HPPAHPUX and ! __STDC__ +	rather than NATIVE_HPPAHPUX_COMPILER. +	* trad-core.c: Don't include <errno.h>.  Include TRAD_HEADER if it +	is defined. +	* hosts/*.h: Remove all header files which merely include, +	declare, and define things.  Leave header files which define +	information needed by trad-core.c. + +	* aclocal.m4 (BFD_BINARY_FOPEN): Define. +	(BFD_CC_FOR_BUILD): Define. +	* configure.in: Use BFD_CC_FOR_BUILD. +	* configure: Rebuild. + +Tue Sep  5 19:35:28 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* aclocal.m4: Don't try to grep ../Makefile if it doesn't exist. +	* configure: Rebuild. + +	* coff-sparc.c (CALC_ADDEND): Don't set the addend to the value of +	a global symbol. + +Tue Sep  5 12:48:26 1995  Jason Molenda   (crash@phydeaux.cygnus.com) + +	* config.bfd: i386pe_ve -> i386pe_vec. + +Mon Sep  4 14:02:43 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* configure.host: Incorporate host Makefile fragments by setting +	shell variables. +	* configure.in: Call AC_PROG_CC.  Substitute CFLAGS, HDEFINES and +	AR.  Call AC_PROG_INSTALL.  Substitute CC_FOR_BUILD, choosing a +	value based on whether the code is being compiled by a cross +	compiler.  Don't substitute host_makefile_frag or frags. +	* aclocal.m4: New file to define local AC_PROG_CC. +	* configure: Rebuild. +	* Makefile.in (INSTALL): Set to @INSTALL@. +	(INSTALL_PROGRAM): Set to @INSTALL_PROGRAM@. +	(INSTALL_DATA): Set to @INSTALL_DATA@. +	(AR): Set to @AR@. +	(CC): Define as @CC@. +	(CFLAGS): Set to @CFLAGS@. +	(CC_FOR_BUILD): Set to @CC_FOR_BUILD@. +	(@host_makefile_frag@): Remove. +	(ALL_CFLAGS): Change $(HDEFINES) to @HDEFINES@.  Move $(CFLAGS) +	after other options. +	(config.status): Remove dependency upon @frags@. +	* config/*.mh, config/README: Remove. + +	* config.bfd: Rewrite to incorporate the contents of the Makefile +	fragments by setting shell variables, rather than merely returning +	the name of a Makefile fragment. +	* configure.in: Use shell variables set by config.bfd rather than +	looking at the target Makefile fragment files.  Don't substitute +	target_makefile_frag.  Do substitute TDEFINES. +	* configure: Rebuild. +	* Makefile.in (@target_makefile_frag@): Remove. +	(ALL_CFLAGS): Change $(TDEFINES) to @TDEFINES@. +	* config/*.mt: Remove. + +Mon Sep  4 03:13:28 1995  Ken Raeburn  <raeburn@cygnus.com> + +	* configure.in: Put changequote lines around "i[345]86" patterns +	section of core file support. + +Sun Sep  3 11:31:58 1995  Jeff Law  (law@snake.cs.utah.edu) + +	* som.c (som_bfd_print_private_bfd_data): Define to use the +	generic version. + +Fri Sep  1 17:08:40 1995  steve chamberlain  <sac@slash.cygnus.com> + +	* peicode.h (coff_swap_aouthdr_in): Add ImageBase to +	entry, text_start and data_start. + +Fri Sep  1 18:06:28 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* Makefile.in (OFILES): Remove $(TDEPFILES). +	* config/apollo.mt (TDEPFILES): Remove. +	* config/README: Update. + +	* configure.in: For a native configuration, set COREFILE and +	COREFLAG based on the canonical host name. +	* configure: Rebuild. +	* Makefile.in: Rebuild dependencies. +	(ALL_CFLAGS): Add @COREFLAG@. +	(OFILES): Replace $(HDEPFILES) with @COREFILE@. +	* coff-rs6000.c: Check AIX_CORE rather than HOST_AIX for core file +	support routines.  Check LYNX_CORE rather than HOST_LYNX. +	* lynx-core.c: Check LYNX_CORE rather than HOST_LYNX. +	* i386lynx.c: Likewise. +	* m68klynx.c: Likewise. +	* sparclynx.c: Likewise. +	* rs6000-core.c: Check AIX_CORE rather than HOST_AIX. +	* *-core.c: Comment changes. +	* config/decstation.mh (HDEPFILES): Remove. +	(HDEFINES): Remove -DTRAD_CORE. +	* config/irix3.mh (RANLIB): Remove. +	* config/irix4.mh (HDEPFILES, RANLIB): Remove. +	(HDEFINES): Remove -DIRIX_CORE. +	* config/riscos.mh (RANLIB, HDEPFILES): Remove. +	(HDEFINES): Remove -DTRAD_CORE. +	* config/ncr3000.mh (AR_FLAGS, RANLIB): Remove. +	* config/ultra3.mh (RANLIB): Remove. +	* config/aix4.mh, config/alphaosf.mh, config/amix.mh: Remove. +	* config/apollo.mh, config/delta68.mh, config/delta88.mh: Remove. +	* config/dpx2.mh, config/esix.mh, config/harris.mh: Remove. +	* config/hp300.mh, config/hp300bsd.mh, config/hppabsd.mh: Remove. +	* config/hppahpux.mh, config/hppaosf.mh: Remove. +	* config/i386aix.mh, config/i386bsd.mh: Remove. +	* config/i386linux.mh, config/i386mach3.mh: Remove. +	* config/i386sco.mh, config/i386v.mh, config/i386v4.mh: Remove. +	* config/irix5.mh, config/m88kmach3.mh, config/mipsbsd.mh: Remove. +	* config/mipsmach3.mh, config/news-mips.mh: Remove. +	* config/news.mh, config/pc532mach.mh, config/riscix.mh: Remove. +	* config/rs600.mh, config/rs6000lynx.mh: Remove. +	* config/solaris2.mh, config/stratus.mh: Remove. +	* config/symmetry.mh, config/sysv4.mh, config/tahoe.mh: Remove. +	* config/vaxbsd.mh, config/vaxult.mh, config/vaxult2.mh: Remove. + +Fri Sep  1 15:18:50 1995  Kazumoto Kojima  <kkojima@info.kanagawa-u.ac.jp> + +	* elflink.h (elf_bfd_final_link): Don't change a DT_INIT or +	DT_FINI entry if the appropriate symbol is not in the hash table. + +	* libelf.h (struct elf_backend_data): Add create_program_headers +	and want_hdr_in_seg fields. +	* elfxx-target.h (elf_backend_want_hdr_in_seg): Define if not +	defined. +	(elf_backend_create_program_headers): Likewise. +	(elfNN_bed): Initialize create_program_headers and +	want_hdr_in_seg. +	* elf.c (get_program_header_size): Call create_program_headers +	backend routine. +	(map_program_segments): Check want_hdr_in_seg backend field.  Call +	create_program_headers backend routine. + +	* elf.c (assign_file_positions_except_relocs): Align non allocated +	sections when creating an executable. + +	* elfcode.h (elf_swap_phdr_in): Make non static. +	(elf_swap_phdr_out): Make non static. +	* libelf.h (bfd_elf32_swap_phdr_in): Declare. +	(bfd_elf32_swap_phdr_out): Declare. +	(bfd_elf64_swap_phdr_in): Declare. +	(bfd_elf64_swap_phdr_out): Declare. + +	* ecofflink.c (ecoff_collect_shuffle): New static function. +	(_bfd_ecoff_get_accumulated_pdr): New function. +	(_bfd_ecoff_get_accumulated_sym): New function. +	(_bfd_ecoff_get_accumulated_ss): New function. +	* libbfd-in.h (_bfd_ecoff_get_accumulated_pdr): Declare. +	(_bfd_ecoff_get_accumulated_sym): Declare. +	(_bfd_ecoff_get_accumulated_ss): Declare. +	* libbfd.h: Rebuild. + +Fri Sep  1 13:20:25 1995  Ian Lance Taylor  <ian@cygnus.com> + +	* libecoff.h (_bfd_ecoff_bfd_print_private_bfd_data): Fix typo. + +	* elflink.h (elf_link_add_object_symbols): Handle indirect and +	warning symbols.  If any section is named .gnu.warning.XXX, treat +	the contents as a warning to be issued if the symbol XXX is +	referenced. +	(elf_link_output_extsym): For an indirect or warning symbol, just +	output the symbol it points to. + +	* linker.c (_bfd_link_hash_newfunc): Don't bother to set bfd_error +	if bfd_hash_allocate fails, since it will already be set. +	(generic_link_hash_newfunc): Likewise. +	(archive_hash_newfunc): Likewise. +	(hash_entry_bfd): New static function. +	(_bfd_generic_link_add_one_symbol): Pass new arguments to warning +	callback.  Allocate a new warning using the hash table newfunc. +	Use bfd_hash_replace to update the entry in the hash table, rather +	than assuming we can copy the fields with structure assignment. + +	* hash.c (bfd_hash_replace): New function. +	* bfd-in.h (bfd_hash_replace): Declare. +	* bfd-in2.h: Rebuild. + +Fri Sep  1 08:12:50 1995  James G. Smith  <jsmith@beauty.cygnus.com> + +	* config.bfd: Add mips*vr4300-*-elf* target. +	* config/mipsbvr4300.mt: Added. + +See file ChangeLog.2 + + +Local Variables: +mode: indented-text +left-margin: 8 +fill-column: 74 +version-control: never +End: diff --git a/contrib/global/gctags/ctags.c b/contrib/global/gctags/ctags.c index f5f952c22e96..8de24d8ee360 100644 --- a/contrib/global/gctags/ctags.c +++ b/contrib/global/gctags/ctags.c @@ -39,7 +39,7 @@ static const char copyright[] =  #if defined(LIBC_SCCS) && !defined(lint)  static const char rcsid[] = -	"$Id: ctags.c,v 1.1.1.3 1998/02/02 05:38:07 cwt Exp $"; +	"$Id: ctags.c,v 1.1.1.3.2.1 1998/02/05 04:41:39 cwt Exp $";  #endif /* LIBC_SCCS and not lint */  #include <limits.h> diff --git a/contrib/libg++/libg++/genclass/genclass.1 b/contrib/libg++/libg++/genclass/genclass.1 index 4988cd6d7230..85769172002c 100644 --- a/contrib/libg++/libg++/genclass/genclass.1 +++ b/contrib/libg++/libg++/genclass/genclass.1 @@ -1,4 +1,4 @@ -.\" $Id$ +.\" $Id: genclass.1,v 1.1 1997/09/15 19:18:59 wosch Exp $  .TH GENCLASS 1 "\*(Dt" "GNU Tools" "GNU Tools"  .SH NAME  genclass \- generate c++ classes from prototypes diff --git a/contrib/libgmp/configure b/contrib/libgmp/configure index 1554506225e1..5737ec51102d 100755 --- a/contrib/libgmp/configure +++ b/contrib/libgmp/configure @@ -80,7 +80,7 @@ subdirs=  target_alias=NOTARGET  target_makefile_frag=  undefs=NOUNDEFS -version="$Revision: 1.218 (modified for gmp) $" +version="$Revision: 1.1.1.1 $"  x11=default  ### we might need to use some other shell than /bin/sh for running subshells diff --git a/contrib/libgmp/texinfo.tex b/contrib/libgmp/texinfo.tex index 1536ac3f0845..ada46cd94168 100644 --- a/contrib/libgmp/texinfo.tex +++ b/contrib/libgmp/texinfo.tex @@ -35,7 +35,7 @@  % This automatically updates the version number based on RCS.  \def\deftexinfoversion$#1: #2 ${\def\texinfoversion{#2}} -\deftexinfoversion$Revision: 2.172 $ +\deftexinfoversion$Revision: 1.1.1.1 $  \message{Loading texinfo package [Version \texinfoversion]:}  % If in a .fmt file, print the version number diff --git a/contrib/libpcap/nlpid.h b/contrib/libpcap/nlpid.h index c033da224fd1..047f292b8e9a 100644 --- a/contrib/libpcap/nlpid.h +++ b/contrib/libpcap/nlpid.h @@ -15,7 +15,7 @@   * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF   * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.   * - * @(#) $Header$ (Juniper) + * @(#) $Header: /home/ncvs/src/contrib/libpcap/nlpid.h,v 1.1 1996/08/21 20:01:07 pst Exp $ (Juniper)   */  /* Types missing from some systems */ diff --git a/contrib/pnpinfo/pnpinfo.8 b/contrib/pnpinfo/pnpinfo.8 index a966df855329..05032e8cccd5 100644 --- a/contrib/pnpinfo/pnpinfo.8 +++ b/contrib/pnpinfo/pnpinfo.8 @@ -28,7 +28,7 @@  .\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF  .\" SUCH DAMAGE.  .\" -.\"      $Id: pnpinfo.8,v 1.4 1996/05/06 00:00:18 smpatel Exp smpatel $ +.\"      $Id: pnpinfo.8,v 1.1.1.1 1997/09/19 15:36:00 jmg Exp $  .\"  .Dd January 7, 1996  .Dt PNPINFO 8 diff --git a/contrib/pnpinfo/pnpinfo.c b/contrib/pnpinfo/pnpinfo.c index 0e811f235836..b1b578c67e28 100644 --- a/contrib/pnpinfo/pnpinfo.c +++ b/contrib/pnpinfo/pnpinfo.c @@ -23,7 +23,7 @@   * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF   * SUCH DAMAGE.   * - *      $Id: pnpinfo.c,v 1.1.1.1 1997/09/19 15:36:00 jmg Exp $ + *      $Id: pnpinfo.c,v 1.2 1997/11/12 08:48:13 jmg Exp $   */  #include <sys/time.h> diff --git a/contrib/pnpinfo/pnpinfo.h b/contrib/pnpinfo/pnpinfo.h index 5469891e259c..ff6b0b7b8a2f 100644 --- a/contrib/pnpinfo/pnpinfo.h +++ b/contrib/pnpinfo/pnpinfo.h @@ -29,7 +29,7 @@   * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF   * SUCH DAMAGE.   * - *      $Id: pnpinfo.h,v 1.1 1996/01/08 00:48:32 smpatel Exp $ + *      $Id: pnpinfo.h,v 1.1.1.1 1997/09/19 15:36:00 jmg Exp $   */ diff --git a/contrib/tcpdump/print-fr.c b/contrib/tcpdump/print-fr.c index f0824881f895..a4d3f09d7d1f 100644 --- a/contrib/tcpdump/print-fr.c +++ b/contrib/tcpdump/print-fr.c @@ -21,7 +21,7 @@  #ifndef lint  static  char rcsid[] = -	"@(#)$Header: /cvs/juniper/src/freebsd/contrib/tcpdump/print-fr.c,v 1.2 1997/07/18 20:24:15 boonmark Exp $ (LBL)"; +	"@(#)$Header: /home/ncvs/src/contrib/tcpdump/print-fr.c,v 1.1 1997/12/31 21:50:31 pst Exp $ (LBL)";  #endif  #ifdef PPP diff --git a/contrib/traceroute/CHANGES b/contrib/traceroute/CHANGES index b825594077fb..1652a9c4c96a 100644 --- a/contrib/traceroute/CHANGES +++ b/contrib/traceroute/CHANGES @@ -1,4 +1,4 @@ -@(#) $Header: CHANGES,v 1.12 96/09/28 18:24:35 leres Exp $ (LBL) +@(#) $Header: /home/ncvs/src/contrib/traceroute/CHANGES,v 1.1.1.1 1996/09/30 19:09:53 fenner Exp $ (LBL)  v1.3.2 Thu Sep 26 18:06:16 PDT 1996 diff --git a/contrib/traceroute/INSTALL b/contrib/traceroute/INSTALL index 6f1be4fe9aa0..6dc514cfb8ba 100644 --- a/contrib/traceroute/INSTALL +++ b/contrib/traceroute/INSTALL @@ -1,4 +1,4 @@ -@(#) $Header: INSTALL,v 1.7 96/09/18 21:09:56 leres Exp $ (LBL) +@(#) $Header: /home/ncvs/src/contrib/traceroute/INSTALL,v 1.1.1.1 1996/09/30 19:09:53 fenner Exp $ (LBL)  Traceroute is known to build and run under SunOS 4.1.4 and Solaris 5.4.  If you are running a really old kernel, see the instructions under the diff --git a/contrib/traceroute/Makefile.in b/contrib/traceroute/Makefile.in index 3320abfb0f6c..d312bc11c407 100644 --- a/contrib/traceroute/Makefile.in +++ b/contrib/traceroute/Makefile.in @@ -17,7 +17,7 @@  #  WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF  #  MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.  # -# @(#) $Header: Makefile.in,v 1.21 96/09/16 18:49:46 leres Exp $ (LBL) +# @(#) $Header: /home/ncvs/src/contrib/traceroute/Makefile.in,v 1.1.1.1 1996/09/30 19:09:53 fenner Exp $ (LBL)  #  # Various configurable paths (remember to edit Makefile.in, not Makefile) diff --git a/contrib/traceroute/README b/contrib/traceroute/README index fa789ed52b43..ac9f55f4302d 100644 --- a/contrib/traceroute/README +++ b/contrib/traceroute/README @@ -1,4 +1,4 @@ -@(#) $Header: README,v 1.7 96/07/06 02:08:32 leres Exp $ (LBL) +@(#) $Header: /home/ncvs/src/contrib/traceroute/README,v 1.1.1.1 1996/09/30 19:09:53 fenner Exp $ (LBL)  TRACEROUTE 1.3  Lawrence Berkeley National Laboratory diff --git a/contrib/traceroute/acsite.m4 b/contrib/traceroute/acsite.m4 index 19dca475ce3d..07f6dd1cefb3 100644 --- a/contrib/traceroute/acsite.m4 +++ b/contrib/traceroute/acsite.m4 @@ -1,4 +1,4 @@ -dnl @(#) $Header: acsite.m4,v 1.38 96/09/26 21:18:41 leres Exp $ (LBL) +dnl @(#) $Header: /home/ncvs/src/contrib/traceroute/acsite.m4,v 1.1.1.1 1996/09/30 19:09:53 fenner Exp $ (LBL)  dnl  dnl Copyright (c) 1995, 1996  dnl	The Regents of the University of California.  All rights reserved. diff --git a/contrib/traceroute/configure.in b/contrib/traceroute/configure.in index 5561baa3e78c..e4a0776f9135 100644 --- a/contrib/traceroute/configure.in +++ b/contrib/traceroute/configure.in @@ -1,4 +1,4 @@ -dnl @(#) $Header: configure.in,v 1.10 96/09/24 18:44:24 leres Exp $ (LBL) +dnl @(#) $Header: /home/ncvs/src/contrib/traceroute/configure.in,v 1.1.1.1 1996/09/30 19:09:54 fenner Exp $ (LBL)  dnl  dnl Copyright (c) 1995, 1996  dnl	The Regents of the University of California.  All rights reserved. diff --git a/contrib/traceroute/lbl/gnuc.h b/contrib/traceroute/lbl/gnuc.h index 9a3200c83632..3761c44dd8d9 100644 --- a/contrib/traceroute/lbl/gnuc.h +++ b/contrib/traceroute/lbl/gnuc.h @@ -1,4 +1,4 @@ -/* @(#) $Header: gnuc.h,v 1.3 95/10/09 02:47:01 leres Exp $ (LBL) */ +/* @(#) $Header: /home/ncvs/src/contrib/traceroute/lbl/gnuc.h,v 1.1.1.1 1996/09/30 19:09:55 fenner Exp $ (LBL) */  /* Define __P() macro, if necessary */  #ifndef __P diff --git a/contrib/traceroute/lbl/os-solaris2.h b/contrib/traceroute/lbl/os-solaris2.h index fb13516038fe..54d24334c907 100644 --- a/contrib/traceroute/lbl/os-solaris2.h +++ b/contrib/traceroute/lbl/os-solaris2.h @@ -18,7 +18,7 @@   * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF   * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.   * - * @(#) $Header: os-solaris2.h,v 1.16 96/07/05 22:11:23 leres Locked $ (LBL) + * @(#) $Header: /home/ncvs/src/contrib/traceroute/lbl/os-solaris2.h,v 1.1.1.1 1996/09/30 19:09:55 fenner Exp $ (LBL)   */  /* Signal routines are this type */ diff --git a/contrib/traceroute/lbl/os-sunos4.h b/contrib/traceroute/lbl/os-sunos4.h index 7733d9414ba1..7ea9eac0db7c 100644 --- a/contrib/traceroute/lbl/os-sunos4.h +++ b/contrib/traceroute/lbl/os-sunos4.h @@ -18,7 +18,7 @@   * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF   * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.   * - * @(#) $Header: os-sunos4.h,v 1.31 96/06/24 02:39:07 leres Exp $ (LBL) + * @(#) $Header: /home/ncvs/src/contrib/traceroute/lbl/os-sunos4.h,v 1.1.1.1 1996/09/30 19:09:55 fenner Exp $ (LBL)   */  #define SIGRET void diff --git a/contrib/traceroute/traceroute.8 b/contrib/traceroute/traceroute.8 index d4f1bc2004bb..e5ff5558abb0 100644 --- a/contrib/traceroute/traceroute.8 +++ b/contrib/traceroute/traceroute.8 @@ -13,7 +13,7 @@  .\" IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED  .\" WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.  .\" -.\"	$Header: /home/ncvs/src/contrib/traceroute/traceroute.8,v 1.2 1996/10/08 02:44:23 sef Exp $ +.\"	$Header: /home/ncvs/src/contrib/traceroute/traceroute.8,v 1.2.2.1 1998/01/09 18:51:35 steve Exp $  .\"  .TH TRACEROUTE 8 "27 September 1996"  .UC 6 diff --git a/contrib/traceroute/traceroute.c b/contrib/traceroute/traceroute.c index ba870539a73c..954eea976950 100644 --- a/contrib/traceroute/traceroute.c +++ b/contrib/traceroute/traceroute.c @@ -24,7 +24,7 @@ static const char copyright[] =      "@(#) Copyright (c) 1988, 1989, 1991, 1994, 1995, 1996\n\  The Regents of the University of California.  All rights reserved.\n";  static const char rcsid[] = -    "@(#)$Header: /home/ncvs/src/contrib/traceroute/traceroute.c,v 1.4 1996/10/08 02:44:26 sef Exp $ (LBL)"; +    "@(#)$Header: /home/ncvs/src/contrib/traceroute/traceroute.c,v 1.5 1996/10/08 19:16:24 sef Exp $ (LBL)";  #endif  /* | 
