summaryrefslogtreecommitdiff
path: root/gnu/usr.bin/binutils/ld/emulparams
AgeCommit message (Collapse)Author
2004-11-02Merge glitches.Miod Vallat
2004-11-02Merge conflicts, bringing our changes back in:Miod Vallat
- extra $(SHELL) and sugar for make (so that files not mode +x still work) - safer temp file handling - our W^X binary layout changes in ld - OpenBSD policy for library file selection in ld - arm and m88k changes which were not merged in time for official 2.15 - bfd core file handling - a couple typos New for 2.15: - ld(1) and as(1) manpages now generated at build time - binutils/stabs.c reverted to use our in-tree libiberty for now - we still use our VIA C3 crypto code over stock binutils, as it recognizes more instructions - new emulations for OpenBSD on mips64 machines, to help OpenBSD/sgi - relaxed %f# handling in gas on OpenBSD/sparc64 (same as was in 2.14) Tested on all platforms by various people; special thanks to sturm@ and otto@.
2004-11-02Binutils 2.15, with testsuites removed, and without gdb and libiberty.Miod Vallat
2004-07-31eliminate portion for 3.2, there was no 3.2 release.Brad Smith
ok mickey@
2004-05-30emacs undump is very sensative to the section ordering, For W^X a coupleDale Rahn
of sections were moved for protections purposes. This causes problems with emacs undump. Only move the sections if the W^X padding is active. Generate the scripts properly for newer binutils, on i386 if -Z is active, move the executable start address back to the classic base address.
2004-05-25provide a way data plt prepending got; drahn@ okMichael Shalayeff
2004-05-17Resolve merge conflicts, adjust method of W^X handing (.sh files)Dale Rahn
remove testsuites (not useable) remove mmalloc (not part of new binutils).
2004-05-17import binutils 2.14 (excluding testsuites, .info files, and .po files)Dale Rahn
2004-02-10configs for amd64; brad@ okMichael Shalayeff
2003-06-02somehow duplicate lines had gotten in thereMichael Shalayeff
2003-05-05Move exec base to 0x1c000000, exe/data gap to 512MB. Allows betterDale Rahn
interleave of exe/shared libs. Raise MAXDSIZ back to 1G. This change REQUIRES a binary update on i386.
2003-04-17Switch i386 to new binutils, i386 tools now do ELF.Dale Rahn
RODATA_* align macros to preserve current behavior on other archs and allow for 1G sep between beginning of exe and beginning of data DARPA funded work.
2003-04-09fix bad entry definitionMichael Shalayeff
2003-02-06use common elf.sc instead of own hppaobsd.sc, catch up w/ dale's elf work ↵Michael Shalayeff
for hppa; drahn@ lots of helps and ok
2003-01-30ELF security enhancement: put .rodata into it's own load section insteadDale Rahn
of putting it with the text. This removes the execute permission from readonly data. This constrains the executable region to portions of the executable which need to be executable. Note: not all processors or mmus are capable of -X protection at the page level, but should handle ELF images which specify specific RWX protections on each section.
2003-01-17This is a project to modify executables so that they do not have anyDale Rahn
executable regions which are writable. If a section of an executable is writable and executable, it is much easier for errant code to modify the executable's behavior. Two current areas in shared library environments which have this critical problem are the GOT (Global Offset Table) and PLT (Procedure Linkage Table). The PLT is required to be executable and both GOT and PLT are writable on most architectures. On most ELF architecture machines this would cause shared libraries to have data and BSS marked as executable. Padding to the linker script for programs and shared libraries/objects to isolate the GOT and PLT into their own load sections in the executables. This allows only the text(readonly) region and the PLT region to be marked executable with the normal data and BSS not marked as executable. The PLT region is still marked executable on most architectures because the PLT lives in the "data" or "BSS" regions and the dynamic loader will need to modify it. Since the GOT and PLT should only ever be written by the dynamic linker, it will be modified to mprotect those regions so that they are not writable during normal execution. If the dynamic linker needs to modify the regions later, (eg for lazy binding), it will mprotect the region, make the necessary changes, and mprotect it back. Since it is possible to receive a signal which would interrupt the program flow and perhaps cause the dynamic linker to modify the same (or nearby) PLT references, it is now necessary for signals to be blocked for the duration of the mprotect.
2002-09-23In an ELF binary the end of the text segment and the start of the dataArtur Grabowski
segment can share the same page in the file. Since we can't mmap it with the same permissions, the data segment is loaded offset by a constant so that it ends up in a different page. On sparc that's not really enough. To avoid cache aliases we have to make the offset big enough to make sure that we don't get incoherent aliases that would have to be mapped uncached. This offset has been 64k this far and noone noticed until some change actually made us fault in those pages at the same time and incoherent aliases reduced make build time on some hypersparcs (only hypersparcs have big enough caches to notice this) from 14 hours to 23 hours. Bump that offset (MAXPAGESIZE) to 1MB. deraadt@ ok
2002-06-05provide our own path for generating the ldscripts and tweak it accordingly; ↵Michael Shalayeff
fgsch@ ok
2002-05-14no longer needed; byebye.Federico G. Schwindt
2002-05-13import binutils 2.14 (excluding testsuites, .info files, and .po files)Federico G. Schwindt
2002-05-13resolve conflicts.Federico G. Schwindt
2002-05-13Import binutils-2.11.2Federico G. Schwindt
- only the binutils package (no gdb here) - don't import libiberty and texinfo, they are elsewhere - remove all .info* generated files
2001-03-07Revert my bfd change, and instead make ld match bfd, which isNiklas Hallqvist
the way Red hat choose. Both ways work, the important thing is that things match. However if we use the red hat solution we will not need to merge local changes when importing new binutils releases; espie made me aware of the import issues which I forgot due to lack of sleep :-).
2000-11-20Make new binutils compile on Alpha again; ok espie@tomo
2000-09-12Resolve other problems that dumb cvs can't find out by itself.Marc Espie
(trivial part done, `interesting' patches remain)
2000-09-12Help stupid cvs fixing basic conflicts.Marc Espie
2000-09-12Import binutils-2.10Marc Espie
- only the binutils package (no gdb here) - don't import libiberty and texinfo, they are elsewhere - remove all .info* generated files
1997-05-29Import of binutils-2.8.1 from Cygnus/FSFNiklas Hallqvist
1997-04-13More consistent MIPS configPer Fogelstrom
1996-11-23Merge to Cygnus 961112 + add some support (not ready) for shared libsNiklas Hallqvist
1996-10-31Alpha support based on Chris Demetriou's <cgd@cs.cmu.edu> workNiklas Hallqvist
1996-09-28another filePer Fogelstrom
1996-09-04Merge the Cygnus 960904 sourcesNiklas Hallqvist
1996-09-04Import of binutils, gas, ld & gprof from Cygnus 960904 treeNiklas Hallqvist
1996-07-14Fixes to make MIPS arc port to use in tree binutils.Per Fogelstrom
1996-06-10Bring Cygnus versions into the trunk, keeping our local patchesNiklas Hallqvist
1996-06-09Import of binutils, gas, ld & gprof from Cygnus 960609 treeNiklas Hallqvist
1996-01-08Initial GNU binutils 2.6 importNiklas Hallqvist