aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ld/ChangeLog10
-rw-r--r--ld/mpw-esh.c316
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"
+};