diff options
-rw-r--r-- | ld/ChangeLog | 10 | ||||
-rw-r--r-- | ld/mpw-esh.c | 316 |
2 files changed, 326 insertions, 0 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index 5c69d5a..8b34482 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,13 @@ +Tue Jun 20 17:47:20 1995 Stan Shebs <shebs@andros.cygnus.com> + + * mpw-esh.c: New file, modified for MPW from esh.c. + * scripttempl/sh.sc: Reformatted to simplify MPWification, + use *() to concat stab sections instead of []. + +Thu Jun 15 08:48:16 1995 Steve Chamberlain <sac@slash.cygnus.com> + + * scripttempl/armpe.sc: Add constructor support. + Tue Jun 13 09:11:20 1995 Steve Chamberlain <sac@slash.cygnus.com> * ldlang.c (lang_size_sections): Any section with a DATA diff --git a/ld/mpw-esh.c b/ld/mpw-esh.c new file mode 100644 index 0000000..6aef853 --- /dev/null +++ b/ld/mpw-esh.c @@ -0,0 +1,316 @@ +/* This file is is generated by a shell script. DO NOT EDIT! */ + +/* emulate the original gld for the given sh + Copyright (C) 1991, 1993 Free Software Foundation, Inc. + Written by Steve Chamberlain steve@cygnus.com + +This file is part of GLD, the Gnu Linker. + +This program 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 of the License, or +(at your option) any later version. + +This program 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 this program; if not, write to the Free Software +Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ + +#define TARGET_IS_sh + +#include "libiberty.h" +#include "bfd.h" +#include "sysdep.h" +#include "bfdlink.h" + +#include "ld.h" +#include "config.h" +#include "ldmain.h" +#include "ldemul.h" +#include "ldfile.h" +#include "ldmisc.h" + +static void gldsh_before_parse PARAMS ((void)); +static char *gldsh_get_script PARAMS ((int *isfile)); + +static void +gldsh_before_parse() +{ +#ifndef TARGET_ /* I.e., if not generic. */ + ldfile_output_architecture = bfd_arch_sh; +#endif /* not TARGET_ */ +} + +static char * +gldsh_get_script(isfile) + int *isfile; +{ + *isfile = 0; + + if (link_info.relocateable == true && config.build_constructors == true) + return +concat( +"OUTPUT_FORMAT(\"coff-sh\")\n\ +OUTPUT_ARCH(sh)\n\ +MEMORY\n\ +{\n\ + ram : o = 0x1000, l = 512k\n\ +}\n\ + "," SECTIONS\n\ +{\n\ + "," .text :\n\ + {\n\ + *(.text)\n\ + *(.strings)\n\ + } \n\ + .tors :\n\ + {\n\ + ___ctors = . ;\n\ + *(.ctors)\n\ + ___ctors_end = . ;\n\ + ___dtors = . ;\n\ + *(.dtors)\n\ + ___dtors_end = . ;\n\ + } \n\ + "," .data :\n\ + {\n\ + *(.data)\n\ + } \n\ + "," .bss :\n\ + {\n\ + *(.bss)\n\ + *(COMMON)\n\ + } \n\ + "," .stack :\n\ + {\n\ + *(.stack)\n\ + } \n\ + "," .stab 0 :\n\ + {\n\ + *(.stab)\n\ + }\n\ + "," .stabstr 0 :\n\ + {\n\ + *(.stabstr)\n\ + }\n\ +}\n\n", NULL) + ; else if (link_info.relocateable == true) return +concat ( +"OUTPUT_FORMAT(\"coff-sh\")\n\ +OUTPUT_ARCH(sh)\n\ + "," MEMORY\n\ +{\n\ + ram : o = 0x1000, l = 512k\n\ +}\n\ + "," SECTIONS\n\ +{\n\ + "," .text :\n\ + {\n\ + *(.text)\n\ + *(.strings)\n\ + } \n\ + "," .tors :\n\ + {\n\ + ___ctors = . ;\n\ + *(.ctors)\n\ + ___ctors_end = . ;\n\ + ___dtors = . ;\n\ + *(.dtors)\n\ + ___dtors_end = . ;\n\ + } \n\ + "," .data :\n\ + {\n\ + *(.data)\n\ + } \n\ + "," .bss :\n\ + {\n\ + *(.bss)\n\ + *(COMMON)\n\ + } \n\ + "," .stack :\n\ + {\n\ + *(.stack)\n\ + } \n\ + "," .stab 0 :\n\ + {\n\ + *(.stab)\n\ + }\n\ + "," .stabstr 0 :\n\ + {\n\ + *(.stabstr)\n\ + }\n\ +}\n\n", NULL) + ; else if (!config.text_read_only) return +concat ( +"OUTPUT_FORMAT(\"coff-sh\")\n\ +OUTPUT_ARCH(sh)\n\ +MEMORY\n\ +{\n\ + ram : o = 0x1000, l = 512k\n\ +}\n\ +SECTIONS\n\ +{\n\ + "," .text :\n\ + {\n\ + *(.text)\n\ + *(.strings)\n\ + _etext = . ; \n\ + } > ram\n\ + "," .tors :\n\ + {\n\ + ___ctors = . ;\n\ + *(.ctors)\n\ + ___ctors_end = . ;\n\ + ___dtors = . ;\n\ + *(.dtors)\n\ + ___dtors_end = . ;\n\ + } > ram\n\ + "," .data :\n\ + {\n\ + *(.data)\n\ + _edata = . ; \n\ + } > ram\n\ + "," .bss :\n\ + {\n\ + _bss_start = . ; \n\ + *(.bss)\n\ + *(COMMON)\n\ + _end = . ; \n\ + } > ram\n\ + "," .stack 0x30000 :\n\ + {\n\ + _stack = . ; \n\ + *(.stack)\n\ + } > ram\n\ + "," .stab 0 (NOLOAD) :\n\ + {\n\ + *(.stab)\n\ + }\n\ + "," .stabstr 0 (NOLOAD) :\n\ + {\n\ + *(.stabstr)\n\ + }\n\ +}\n\n", NULL) + ; else if (!config.magic_demand_paged) return +concat ( +"OUTPUT_FORMAT(\"coff-sh\")\n\ +OUTPUT_ARCH(sh)\n\ +MEMORY\n\ +{\n\ + ram : o = 0x1000, l = 512k\n\ +}\n\ +SECTIONS\n\ +{\n\ + "," .text :\n\ + {\n\ + *(.text)\n\ + *(.strings)\n\ + _etext = . ; \n\ + } > ram\n\ + "," .tors :\n\ + {\n\ + ___ctors = . ;\n\ + *(.ctors)\n\ + ___ctors_end = . ;\n\ + ___dtors = . ;\n\ + *(.dtors)\n\ + ___dtors_end = . ;\n\ + } > ram\n\ + "," .data :\n\ + {\n\ + *(.data)\n\ + _edata = . ; \n\ + } > ram\n\ + "," .bss :\n\ + {\n\ + _bss_start = . ; \n\ + *(.bss)\n\ + *(COMMON)\n\ + _end = . ; \n\ + } > ram\n\ + "," .stack 0x30000 :\n\ + {\n\ + _stack = . ; \n\ + *(.stack)\n\ + } > ram\n\ + "," .stab 0 (NOLOAD) :\n\ + {\n\ + *(.stab)\n\ + }\n\ + "," .stabstr 0 (NOLOAD) :\n\ + {\n\ + *(.stabstr)\n\ + }\n\ +}\n\n", NULL) + ; else return +concat ( +"OUTPUT_FORMAT(\"coff-sh\")\n\ +OUTPUT_ARCH(sh)\n\ +MEMORY\n\ +{\n\ + ram : o = 0x1000, l = 512k\n\ +}\n\ +SECTIONS\n\ +{\n\ + "," .text :\n\ + {\n\ + *(.text)\n\ + *(.strings)\n\ + _etext = . ; \n\ + } > ram\n\ + "," .tors :\n\ + {\n\ + ___ctors = . ;\n\ + *(.ctors)\n\ + ___ctors_end = . ;\n\ + ___dtors = . ;\n\ + *(.dtors)\n\ + ___dtors_end = . ;\n\ + } > ram\n\ + "," .data :\n\ + {\n\ + *(.data)\n\ + _edata = . ; \n\ + } > ram\n\ + "," .bss :\n\ + {\n\ + _bss_start = . ; \n\ + *(.bss)\n\ + *(COMMON)\n\ + _end = . ; \n\ + } > ram\n\ + "," .stack 0x30000 :\n\ + {\n\ + _stack = . ; \n\ + *(.stack)\n\ + } > ram\n\ + "," .stab 0 (NOLOAD) :\n\ + {\n\ + *(.stab)\n\ + }\n\ + "," .stabstr 0 (NOLOAD) :\n\ + {\n\ + *(.stabstr)\n\ + }\n\ +}\n\n", NULL) +; } + +struct ld_emulation_xfer_struct ld_sh_emulation = +{ + gldsh_before_parse, + syslib_default, + hll_default, + after_parse_default, + after_open_default, + after_allocation_default, + set_output_arch_default, + ldemul_default_target, + before_allocation_default, + gldsh_get_script, + "sh", + "coff-sh" +}; |