diff options
Diffstat (limited to 'ld')
-rw-r--r-- | ld/ChangeLog | 11 | ||||
-rw-r--r-- | ld/Makefile.in | 5 | ||||
-rw-r--r-- | ld/configure.tgt | 1 | ||||
-rw-r--r-- | ld/emulparams/.Sanitize | 1 | ||||
-rw-r--r-- | ld/scripttempl/.Sanitize | 1 | ||||
-rw-r--r-- | ld/scripttempl/m88kbcs.sc | 28 |
6 files changed, 36 insertions, 11 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index 628b5b6..13f0a68 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,14 @@ +Wed Nov 1 15:42:45 1995 Manfred Hollstein KS/EF4A 60/1F/110 #40283 <manfred@lts.sel.alcatel.de> + + * Makefile.in (ALL_EMULATIONS): Add edelta68.o. + (edelta68.c): New target. + * configure.tgt (m68*-motorola-sysv3*): New target. + * emulparams/delta68.sh: New file. + * scripttempl/delta68.sc: New file. + + * scripttempl/m88kbcs.sc: Handle .init and .fini. Change section + addresses. + Wed Nov 1 11:41:56 1995 Ian Lance Taylor <ian@cygnus.com> * ldgram.y (mri_script_command): Accept ',' as well as '=' in diff --git a/ld/Makefile.in b/ld/Makefile.in index cdfce17..81c1e7d 100644 --- a/ld/Makefile.in +++ b/ld/Makefile.in @@ -203,7 +203,7 @@ ALL_EMULATIONS = ea29k.o ealpha.o earmaoutl.o earmaoutb.o \ eriscix.o esa29200.o eshl.o esh.o esparclynx.o esparcnbsd.o \ est2000.o esun3.o esun4.o evanilla.o evax.o evsta.o \ ez8001.o ez8002.o ei386pe.o earmpe.o eelf32b4300.o eelf32l4300.o \ - eaixppc.o eaixrs6.o + eaixppc.o eaixrs6.o edelta68.o CFILES = ldctor.c ldemul.c ldexp.c ldfile.c ldlang.c \ ldmain.c ldmisc.c ldver.c ldwrite.c lexsup.c \ @@ -500,6 +500,9 @@ eaixppc.c: $(srcdir)/emulparams/aixppc.sh \ eaixrs6.c: $(srcdir)/emulparams/aixrs6.sh \ $(srcdir)/emultempl/aix.em $(srcdir)/scripttempl/aix.sc ${GEN_DEPENDS} ${GENSCRIPTS} aixrs6 +edelta68.c: $(srcdir)/emulparams/delta68.sh \ + $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/delta68.sc ${GEN_DEPENDS} + ${GENSCRIPTS} delta68 # start-sanitize-arc earcelf.c: $(srcdir)/emulparams/arcelf.sh \ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/elf.sc ${GEN_DEPENDS} diff --git a/ld/configure.tgt b/ld/configure.tgt index b099ec8..7a5bccc 100644 --- a/ld/configure.tgt +++ b/ld/configure.tgt @@ -81,6 +81,7 @@ rce-*-aout) targ_emul=rce ;; # end-sanitize-rce m68k-sony-*) targ_emul=news ;; m68k-hp-bsd*) targ_emul=hp300bsd ;; +m68*-motorola-sysv3*) targ_emul=delta68 ;; m68*-*-aout) targ_emul=m68kaout ;; m68*-*-coff) targ_emul=m68kcoff ;; m68*-*-elf) targ_emul=m68kelf ;; diff --git a/ld/emulparams/.Sanitize b/ld/emulparams/.Sanitize index dabd8f6..6af9e29 100644 --- a/ld/emulparams/.Sanitize +++ b/ld/emulparams/.Sanitize @@ -49,6 +49,7 @@ armaoutl.sh armcoff.sh armpe.sh coff_sparc.sh +delta68.sh ebmon29k.sh elf32_sparc.sh elf32bmip.sh diff --git a/ld/scripttempl/.Sanitize b/ld/scripttempl/.Sanitize index 72e6719..55588e1 100644 --- a/ld/scripttempl/.Sanitize +++ b/ld/scripttempl/.Sanitize @@ -38,6 +38,7 @@ alpha.sc armaout.sc armcoff.sc aout.sc +delta68.sc ebmon29k.sc elf.sc elfppc.sc diff --git a/ld/scripttempl/m88kbcs.sc b/ld/scripttempl/m88kbcs.sc index 928d640..b29980e 100644 --- a/ld/scripttempl/m88kbcs.sc +++ b/ld/scripttempl/m88kbcs.sc @@ -1,18 +1,20 @@ +# These are substituted in as variables in order to get '}' in a shell +# conditional expansion. +INIT='.init : { *(.init) }' +FINI='.fini : { *(.fini) }' cat <<EOF -TARGET(m88kbcs) -OUTPUT_FORMAT(m88kbcs) +OUTPUT_FORMAT("${OUTPUT_FORMAT}") OUTPUT_ARCH(${ARCH}) ENTRY(__start) ${RELOCATING+${LIB_SEARCH_DIRS}} SECTIONS { - .text ${RELOCATING+ 0x10000 + SIZEOF_HEADERS} : + .text ${RELOCATING+ (0x20007 + SIZEOF_HEADERS) &~ 7} : { - CREATE_OBJECT_SYMBOLS ${RELOCATING+ __.text.start = .}; ${RELOCATING+ __.init.start = .}; - ${RELOCATING+ LONG(0xf400c001)} + ${RELOCATING+ *(.init)} ${RELOCATING+ __.init.end = .}; *(.text) ${RELOCATING+ __.tdesc_start = .}; @@ -20,14 +22,14 @@ SECTIONS ${RELOCATING+ __.text_end = .} ; ${RELOCATING+ __.initp.start = .}; ${RELOCATING+ __.initp.end =.}; - + ${RELOCATING+ __.fini_start = .}; + ${RELOCATING+ *(.fini) } + ${RELOCATING+ __.fini_end = .}; ${RELOCATING+_etext =.}; } - .data ${RELOCATING+ SIZEOF(.text) + ADDR(.text) + 0x400000} : + .data ${RELOCATING+ NEXT (0x400000) + ((SIZEOF(.text) + ADDR(.text)) % 0x200)} : { *(.data) - ${CONSTRUCTING+CONSTRUCTORS} - *(.comment) ${RELOCATING+_edata = .}; } .bss ${RELOCATING+ SIZEOF(.data) + ADDR(.data)} : @@ -36,6 +38,12 @@ SECTIONS *(COMMON) ${RELOCATING+ _end = .}; ${RELOCATING+ __end = .}; - } + } + ${RELOCATING- ${INIT}} + ${RELOCATING- ${FINI}} + .comment 0 ${RELOCATING+(NOLOAD)} : + { + *(.comment) + } } EOF |