Support for the H8/500
authorSteve Chamberlain <sac@cygnus>
Fri, 9 Apr 1993 17:46:13 +0000 (17:46 +0000)
committerSteve Chamberlain <sac@cygnus>
Fri, 9 Apr 1993 17:46:13 +0000 (17:46 +0000)
ld/.Sanitize
ld/config/.Sanitize
ld/config/coff-h8500.mt [new file with mode: 0644]
ld/h8300xray.sc-sh [deleted file]
ld/h8300xray.sh [deleted file]
ld/h8500hms.em [moved from ld/h8300xray.em with 68% similarity]
ld/h8500hms.sc-sh [new file with mode: 0755]
ld/h8500hms.sh [new file with mode: 0755]

index 91ee664..3f46399 100644 (file)
@@ -59,9 +59,9 @@ hp300bsd.sh
 h8300hms.em
 h8300hms.sc-sh
 h8300hms.sh
-h8300xray.em
-h8300xray.sc-sh
-h8300xray.sh
+h8500hms.em
+h8500hms.sc-sh
+h8500hms.sh
 i386aout.sh
 i386bsd.sh
 i386coff.sc-sh
@@ -163,7 +163,10 @@ fi
 #
 #
 # $Log$
-# Revision 1.55  1993/03/30 23:24:53  pesch
+# Revision 1.56  1993/04/09 17:44:54  sac
+# Support for the H8/500
+#
+# Revision 1.55  1993/03/30  23:24:53  pesch
 # ld.texinfo:
 # Conditionalize manual to maintain Cygnus, Hitachi versions in parallel.
 # (Texinfo conditionals are stable enough to permit this, at last!)
index 42495a0..bde7b6d 100644 (file)
@@ -25,6 +25,7 @@ Things-to-keep:
 
 coff-a29k.mt
 coff-h8300.mt
+coff-h8500.mt
 delta88.mh
 dgux.mh
 ebmon29k.mt
diff --git a/ld/config/coff-h8500.mt b/ld/config/coff-h8500.mt
new file mode 100644 (file)
index 0000000..4981d21
--- /dev/null
@@ -0,0 +1 @@
+EMUL=h8500hms
diff --git a/ld/h8300xray.sc-sh b/ld/h8300xray.sc-sh
deleted file mode 100755 (executable)
index b0a4622..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-cat <<EOF
-OUTPUT_FORMAT("${OUTPUT_FORMAT}")
-OUTPUT_ARCH(${ARCH})
-
-
-SECTIONS                               
-{                                      
-.text :
-       {                                       
-         *(.text)                              
-         *(.strings)
-         _etext = .;
-       *(.data)
-       _edata = .;
-       *(.bss)
-       *(COMMON)
-        _end = .;
-_stack = 0xe000;       
-}
-
-}
-EOF
-
-
-
-
diff --git a/ld/h8300xray.sh b/ld/h8300xray.sh
deleted file mode 100755 (executable)
index ee84e70..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-EMULATION_NAME=h8300xray
-SCRIPT_NAME=h8300xray
-OUTPUT_FORMAT="ieee"
-TEXT_START_ADDR=0x0
-PAGE_SIZE=128
-ARCH=h8300
-TEMPLATE_NAME=h8300xray
-
similarity index 68%
rename from ld/h8300xray.em
rename to ld/h8500hms.em
index 8b9bf22..2b009c1 100644 (file)
@@ -1,5 +1,5 @@
 cat >em_${EMULATION_NAME}.c <<EOF
-/* Copyright (C) 1991 Free Software Foundation, Inc.
+/* Copyright (C) 1993 Free Software Foundation, Inc.
 
 This file is part of GLD, the Gnu Linker.
 
@@ -18,10 +18,10 @@ along with GLD; see the file COPYING.  If not, write to
 the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.  */
 
 /* 
- Written by Steve Chamberlain steve@cygnus.com
+ Written by Steve Chamberlain sac@cygnus.com
 
  The controller which tells the gnu linker how to behave like one for
- the Hitach H8/300 with IEEE records.
+ the Hitach H8/500.
 */
 
 #include "bfd.h"
@@ -44,37 +44,37 @@ extern bfd *output_bfd;
 
 
 
-static void h8300xray_before_parse()
+static void h8500hms_before_parse()
 {
-  ldfile_output_architecture = bfd_arch_h8300;
+  ldfile_output_architecture = bfd_arch_h8500;
 }
 
-static char *h8300xray_script =  
-#include "h8300xray.x"
+static char *h8500hms_script =  
+#include "h8500hms.x"
 ;
-static char *h8300xray_script_option_Ur  =  
-#include "h8300xray.x"
+static char *h8500hms_script_option_Ur  =  
+#include "h8500hms.xu"
 ;
-static char *h8300xray_script_option_r  =  
-#include "h8300xray.x"
+static char *h8500hms_script_option_r  =  
+#include "h8500hms.xr"
 ;
 
-static char *h8300xray_get_script()
+static char *h8500hms_get_script()
 {                           
   extern ld_config_type config;
   if (config.relocateable_output == true &&
       config.build_constructors == true) {
-    return h8300xray_script_option_Ur;
+    return h8500hms_script_option_Ur;
   }
   if (config.relocateable_output) {
-    return h8300xray_script_option_r;
+    return h8500hms_script_option_r;
   }
        
-  return h8300xray_script;
+  return h8500hms_script;
 }
-struct ld_emulation_xfer_struct ld_h8300xray_emulation = 
+struct ld_emulation_xfer_struct ld_h8500hms_emulation = 
 {
-  h8300xray_before_parse,
+  h8500hms_before_parse,
   syslib_default,
   hll_default,
   after_parse_default,
@@ -82,7 +82,7 @@ struct ld_emulation_xfer_struct ld_h8300xray_emulation =
   set_output_arch_default,
   ldemul_default_target,
   before_allocation_default,
-  h8300xray_get_script,
-  "h8300xray"
+  h8500hms_get_script,
+  "h8500hms"
 };
 EOF
diff --git a/ld/h8500hms.sc-sh b/ld/h8500hms.sc-sh
new file mode 100755 (executable)
index 0000000..ed2d44f
--- /dev/null
@@ -0,0 +1,43 @@
+cat <<EOF
+OUTPUT_FORMAT("${OUTPUT_FORMAT}")
+OUTPUT_ARCH(${ARCH})
+
+MEMORY {
+       rom   : o = 0x0000, l = 0x7fe0 
+       duart : o = 0x7fe0, l = 16
+       ram   : o = 0x8000, l = 28k
+       topram : o = 0x8000+28k, l = 1k
+       hmsram : o = 0xfb80, l = 512
+       }
+
+SECTIONS                               
+{                                      
+.text :
+       {                                       
+         *(.text)                              
+         *(.strings)
+        ${RELOCATING+ _etext = . ; }
+       } ${RELOCATING+ > ram}
+.data  :
+       {
+       *(.data)
+       ${RELOCATING+ _edata = . ; }
+       } ${RELOCATING+ > ram}
+.bss  :
+       {
+       ${RELOCATING+ _bss_start = . ;}
+       *(.bss)
+       *(COMMON)
+       ${RELOCATING+ _end = . ;  }
+       } ${RELOCATING+ >ram}
+.stack : 
+       {
+       ${RELOCATING+ _stack = . ; }
+       *(.stack)
+       } ${RELOCATING+ > topram}
+}
+EOF
+
+
+
+
diff --git a/ld/h8500hms.sh b/ld/h8500hms.sh
new file mode 100755 (executable)
index 0000000..87f1b7d
--- /dev/null
@@ -0,0 +1,7 @@
+EMULATION_NAME=h8500hms
+SCRIPT_NAME=h8500hms
+OUTPUT_FORMAT="coff-h8500"
+TEXT_START_ADDR=0x8000
+PAGE_SIZE=128
+ARCH=h8500
+TEMPLATE_NAME=h8500hms