From 5c701c1a0264d9d166f0965757efccc50f8dc44d Mon Sep 17 00:00:00 2001 From: itojun Date: Thu, 4 Jan 2001 01:19:29 +0000 Subject: add sh*- and shel*- targets. XXX there seem to be gcc internal issue with sh3 code generator, specifically with -O2. sys/nfs/* bombs with internal error. --- cross/COMMON/patches-binutils/patch-sh | 451 +++++++++++++++++++++++++++ cross/COMMON/patches-egcs/patch-sh | 540 +++++++++++++++++++++++++++++++++ 2 files changed, 991 insertions(+) create mode 100644 cross/COMMON/patches-binutils/patch-sh create mode 100644 cross/COMMON/patches-egcs/patch-sh (limited to 'cross/COMMON') diff --git a/cross/COMMON/patches-binutils/patch-sh b/cross/COMMON/patches-binutils/patch-sh new file mode 100644 index 00000000000..4f166a9347e --- /dev/null +++ b/cross/COMMON/patches-binutils/patch-sh @@ -0,0 +1,451 @@ +$NetBSD: patch-sh,v 1.1 2001/01/04 01:19:29 itojun Exp $ + +ftp://ftp.netbsd.org/pub/NetBSD/arch/sh3/crosskit/ + +diff -u -r -N -x *.orig -x CVS old/bfd/Makefile.am binutils-2.9.1/bfd/Makefile.am +--- bfd/Makefile.am Wed Jan 3 20:40:59 2001 ++++ bfd/Makefile.am Wed Jan 3 20:44:17 2001 +@@ -153,6 +153,7 @@ + elf-m10200.lo \ + elf-m10300.lo \ + elf32-ppc.lo \ ++ elf32-shunx.lo \ + elf32-sh.lo \ + elf32-sparc.lo \ + elf32-v850.lo \ +@@ -260,6 +261,7 @@ + elf-m10200.c \ + elf-m10300.c \ + elf32-ppc.c \ ++ elf32-shunx.c \ + elf32-sh.c \ + elf32-sparc.c \ + elf32-v850.c \ +@@ -797,6 +799,9 @@ + elf32-ppc.lo: elf32-ppc.c $(INCDIR)/bfdlink.h elf-bfd.h \ + $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ + $(INCDIR)/elf/ppc.h elf32-target.h ++elf32-shunx.lo: elf32-shunx.c $(INCDIR)/bfdlink.h elf-bfd.h \ ++ $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ ++ elf32-target.h + elf32-sh.lo: elf32-sh.c $(INCDIR)/bfdlink.h elf-bfd.h \ + $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ + elf32-target.h +diff -u -r -N -x *.orig -x CVS old/bfd/Makefile.in binutils-2.9.1/bfd/Makefile.in +--- bfd/Makefile.in Wed Jan 3 20:40:59 2001 ++++ bfd/Makefile.in Wed Jan 3 20:44:04 2001 +@@ -242,6 +242,7 @@ + elf-m10200.lo \ + elf-m10300.lo \ + elf32-ppc.lo \ ++ elf32-shunx.lo \ + elf32-sh.lo \ + elf32-sparc.lo \ + elf32-v850.lo \ +@@ -349,6 +350,7 @@ + elf-m10200.c \ + elf-m10300.c \ + elf32-ppc.c \ ++ elf32-shunx.c \ + elf32-sh.c \ + elf32-sparc.c \ + elf32-v850.c \ +@@ -1254,6 +1256,9 @@ + elf32-ppc.lo: elf32-ppc.c $(INCDIR)/bfdlink.h elf-bfd.h \ + $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ + $(INCDIR)/elf/ppc.h elf32-target.h ++elf32-shunx.lo: elf32-shunx.c $(INCDIR)/bfdlink.h elf-bfd.h \ ++ $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ ++ elf32-target.h + elf32-sh.lo: elf32-sh.c $(INCDIR)/bfdlink.h elf-bfd.h \ + $(INCDIR)/elf/common.h $(INCDIR)/elf/internal.h $(INCDIR)/elf/external.h \ + elf32-target.h +diff -u -r -N -x *.orig -x CVS old/bfd/config.bfd binutils-2.9.1/bfd/config.bfd +--- bfd/config.bfd Wed Jan 3 20:55:42 2001 ++++ bfd/config.bfd Wed Jan 3 20:46:00 2001 +@@ -40,6 +40,7 @@ + powerpc*) targ_archs="bfd_rs6000_arch bfd_powerpc_arch" ;; + rs6000) targ_archs="bfd_rs6000_arch bfd_powerpc_arch" ;; + sparc*) targ_archs=bfd_sparc_arch ;; ++sh*) targ_archs=bfd_sh_arch ;; + v850*) targ_archs=bfd_v850_arch ;; + z8k*) targ_archs=bfd_z8k_arch ;; + *) targ_archs=bfd_${targ_cpu}_arch ;; +@@ -494,14 +495,34 @@ + targ_defvec=rs6000coff_vec + ;; + ++ sh-*-netbsdelf) ++ targ_defvec=bfd_elf32_shunx_vec ++ targ_selvecs="bfd_elf32_shlunx_vec shcoff_vec shlcoff_vec " ++ targ_underscore=yes ++ ;; ++ shel-*-netbsdelf) ++ targ_defvec=bfd_elf32_shlunx_vec ++ targ_selvecs="bfd_elf32_shunx_vec shcoff_vec shlcoff_vec " ++ targ_underscore=yes ++ ;; + sh-*-elf*) + targ_defvec=bfd_elf32_sh_vec +- targ_selvecs="bfd_elf32_shl_vec shcoff_vec shlcoff_vec shcoff_small_vec shlcoff_small_vec" ++ targ_selvecs="bfd_elf32_shl_vec shcoff_vec shlcoff_vec " ++ targ_underscore=yes ++ ;; ++ sh-*-netbsdcoff) ++ targ_defvec=shcoff_vec ++ targ_selvecs="shlcoff_vec " ++ targ_underscore=yes ++ ;; ++ shel-*-netbsdcoff) ++ targ_defvec=shlcoff_vec ++ targ_selvecs="shcoff_vec " + targ_underscore=yes + ;; + sh-*-* | sh-*-rtems*) + targ_defvec=shcoff_vec +- targ_selvecs="shcoff_vec shlcoff_vec shcoff_small_vec shlcoff_small_vec" ++ targ_selvecs="shlcoff_vec " + targ_underscore=yes + ;; + +diff -u -r -N -x *.orig -x CVS old/bfd/configure binutils-2.9.1/bfd/configure +--- bfd/configure Wed Jan 3 20:40:59 2001 ++++ bfd/configure Wed Jan 3 20:46:23 2001 +@@ -2738,6 +2738,8 @@ + bfd_elf32_mn10300_vec) tb="$tb elf-m10300.lo elf32.lo $elf" ;; + bfd_elf32_powerpc_vec) tb="$tb elf32-ppc.lo elf32.lo $elf" ;; + bfd_elf32_powerpcle_vec) tb="$tb elf32-ppc.lo elf32.lo $elf" ;; ++ bfd_elf32_shunx_vec) tb="$tb elf32-shunx.lo elf32.lo $elf coff-sh.lo" ;; ++ bfd_elf32_shlunx_vec) tb="$tb elf32-shunx.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_sh_vec) tb="$tb elf32-sh.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_shl_vec) tb="$tb elf32-sh.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_sparc_vec) tb="$tb elf32-sparc.lo elf32.lo $elf" ;; +diff -u -r -N -x *.orig -x CVS old/bfd/configure.in binutils-2.9.1/bfd/configure.in +--- bfd/configure.in Wed Jan 3 20:40:59 2001 ++++ bfd/configure.in Wed Jan 3 20:46:30 2001 +@@ -423,6 +423,8 @@ + bfd_elf32_mn10300_vec) tb="$tb elf-m10300.lo elf32.lo $elf" ;; + bfd_elf32_powerpc_vec) tb="$tb elf32-ppc.lo elf32.lo $elf" ;; + bfd_elf32_powerpcle_vec) tb="$tb elf32-ppc.lo elf32.lo $elf" ;; ++ bfd_elf32_shunx_vec) tb="$tb elf32-shunx.lo elf32.lo $elf coff-sh.lo" ;; ++ bfd_elf32_shlunx_vec) tb="$tb elf32-shunx.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_sh_vec) tb="$tb elf32-sh.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_shl_vec) tb="$tb elf32-sh.lo elf32.lo $elf coff-sh.lo" ;; + bfd_elf32_sparc_vec) tb="$tb elf32-sparc.lo elf32.lo $elf" ;; +diff -u -r -N -x *.orig -x CVS old/bfd/elf32-sh.c binutils-2.9.1/bfd/elf32-sh.c +--- bfd/elf32-sh.c Sat May 2 00:48:09 1998 ++++ bfd/elf32-sh.c Wed Jan 3 20:47:15 2001 +@@ -1889,13 +1889,28 @@ + return NULL; + } + ++#ifndef TARGET_BIG_SYM + #define TARGET_BIG_SYM bfd_elf32_sh_vec ++#endif ++ ++#ifndef TARGET_BIG_NAME + #define TARGET_BIG_NAME "elf32-sh" ++#endif ++ ++#ifndef TARGET_LITTLE_SYM + #define TARGET_LITTLE_SYM bfd_elf32_shl_vec ++#endif ++ ++#ifndef TARGET_LITTLE_NAME + #define TARGET_LITTLE_NAME "elf32-shl" ++#endif ++ + #define ELF_ARCH bfd_arch_sh + #define ELF_MACHINE_CODE EM_SH ++ ++#ifndef ELF_MAXPAGESIZE + #define ELF_MAXPAGESIZE 0x1 ++#endif + + #define elf_symbol_leading_char '_' + +diff -u -r -N -x *.orig -x CVS old/bfd/elf32-shunx.c binutils-2.9.1/bfd/elf32-shunx.c +--- bfd/elf32-shunx.c Thu Jan 1 09:00:00 1970 ++++ bfd/elf32-shunx.c Wed Jan 3 20:47:30 2001 +@@ -0,0 +1,7 @@ ++#define TARGET_BIG_SYM bfd_elf32_shunx_vec ++#define TARGET_BIG_NAME "elf32-sh-unx" ++#define TARGET_LITTLE_SYM bfd_elf32_shlunx_vec ++#define TARGET_LITTLE_NAME "elf32-shl-unx" ++#define ELF_MAXPAGESIZE 0x1000 ++ ++#include "elf32-sh.c" +diff -u -r -N -x *.orig -x CVS old/bfd/targets.c binutils-2.9.1/bfd/targets.c +--- bfd/targets.c Wed Jan 3 20:40:59 2001 ++++ bfd/targets.c Wed Jan 3 20:47:40 2001 +@@ -504,6 +504,8 @@ + extern const bfd_target bfd_elf32_mn10300_vec; + extern const bfd_target bfd_elf32_powerpc_vec; + extern const bfd_target bfd_elf32_powerpcle_vec; ++extern const bfd_target bfd_elf32_shunx_vec; ++extern const bfd_target bfd_elf32_shlunx_vec; + extern const bfd_target bfd_elf32_sh_vec; + extern const bfd_target bfd_elf32_shl_vec; + extern const bfd_target bfd_elf32_sparc_vec; +diff -u -r -N -x *.orig -x CVS old/config.sub binutils-2.9.1/config.sub +--- config.sub Wed Jan 3 20:41:00 2001 ++++ config.sub Wed Jan 3 20:47:56 2001 +@@ -175,7 +175,7 @@ + | arme[lb] | pyramid | mn10200 | mn10300 \ + | tron | a29k | 580 | i960 | h8300 | hppa | hppa1.0 | hppa1.1 \ + | alpha | alphaev5 | alphaev56 | alphapca56 | alphaev6 \ +- | we32k | ns16k | clipper | i370 | sh | powerpc | powerpcle \ ++ | we32k | ns16k | clipper | i370 | sh | shel | powerpc | powerpcle \ + | 1750a | dsp16xx | pdp11 \ + | mips64 | mipsel | mipseb | mips64el | mips64orion | mips64orionel \ + | mipstx39 | mipstx39el \ +@@ -229,7 +229,7 @@ + | alpha-* | alphaev5-* | alphaev56-* | alphapca56-* \ + | alphaev6-* | we32k-* | cydra-* | ns16k-* | pn-* | np1-* \ + | xps100-* | clipper-* | orion-* \ +- | sparclite-* | pdp11-* | sh-* | powerpc-* | powerpcle-* \ ++ | sparclite-* | pdp11-* | sh-* | shel-* | powerpc-* | powerpcle-* \ + | sparc64-* | mips64-* | mipsel-* | mipseb-* \ + | mips64el-* | mips64orion-* | mips64orionel-* \ + | mipstx39-* | mipstx39el-* \ +diff -u -r -N -x *.orig -x CVS old/ld/Makefile.am binutils-2.9.1/ld/Makefile.am +--- ld/Makefile.am Wed Jan 3 20:40:59 2001 ++++ ld/Makefile.am Wed Jan 3 20:49:44 2001 +@@ -169,6 +169,10 @@ + eshelf.o \ + eshlelf.o \ + eshl.o \ ++ eshunx.o \ ++ eshlunx.o \ ++ eelf32shunx.o \ ++ eelf32shlunx.o \ + esparcaout.o \ + esparclinux.o \ + esparclynx.o \ +@@ -488,6 +492,18 @@ + eshl.c: $(srcdir)/emulparams/shl.sh \ + $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} + ${GENSCRIPTS} shl "$(tdir_shl)" ++eshunx.c: $(srcdir)/emulparams/shunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} shunx "$(tdir_shunx)" ++eshlunx.c: $(srcdir)/emulparams/shlunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} shlunx "$(tdir_shlunx)" ++eelf32shunx.c: $(srcdir)/emulparams/elf32shunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} elf32shunx "$(tdir_elf32shunx)" ++eelf32shlunx.c: $(srcdir)/emulparams/elf32shlunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} elf32shlunx "$(tdir_elf32shlunx)" + esparcaout.c: $(srcdir)/emulparams/sparcaout.sh \ + $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/aout.sc ${GEN_DEPENDS} + ${GENSCRIPTS} sparcaout "$(tdir_sparcaout)" +diff -u -r -N -x *.orig -x CVS old/ld/Makefile.in binutils-2.9.1/ld/Makefile.in +--- ld/Makefile.in Wed Jan 3 20:40:59 2001 ++++ ld/Makefile.in Wed Jan 3 20:49:38 2001 +@@ -245,6 +245,10 @@ + eshelf.o \ + eshlelf.o \ + eshl.o \ ++ eshunx.o \ ++ eshlunx.o \ ++ eelf32shunx.o \ ++ eelf32shlunx.o \ + esparcaout.o \ + esparclinux.o \ + esparclynx.o \ +@@ -998,6 +1002,18 @@ + eshl.c: $(srcdir)/emulparams/shl.sh \ + $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} + ${GENSCRIPTS} shl "$(tdir_shl)" ++eshunx.c: $(srcdir)/emulparams/shunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} shunx "$(tdir_shunx)" ++eshlunx.c: $(srcdir)/emulparams/shlunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} shlunx "$(tdir_shlunx)" ++eelf32shunx.c: $(srcdir)/emulparams/elf32shunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} elf32shunx "$(tdir_elf32shunx)" ++eelf32shlunx.c: $(srcdir)/emulparams/elf32shlunx.sh \ ++ $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/sh.sc ${GEN_DEPENDS} ++ ${GENSCRIPTS} elf32shlunx "$(tdir_elf32shlunx)" + esparcaout.c: $(srcdir)/emulparams/sparcaout.sh \ + $(srcdir)/emultempl/generic.em $(srcdir)/scripttempl/aout.sc ${GEN_DEPENDS} + ${GENSCRIPTS} sparcaout "$(tdir_sparcaout)" +diff -u -r -N -x *.orig -x CVS old/ld/configure.tgt binutils-2.9.1/ld/configure.tgt +--- ld/configure.tgt Wed Jan 3 20:41:00 2001 ++++ ld/configure.tgt Wed Jan 3 20:51:01 2001 +@@ -114,8 +114,16 @@ + targ_extra_emuls="h8500s h8500b h8500m h8500c" + ;; + sh-*-elf*) targ_emul=shelf +- targ_extra_emuls="shlelf sh shl" ++ targ_extra_emuls="shlelf shunx shlunx" + ;; ++sh-*-netbsdelf) targ_emul=elf32shunx ++ targ_extra_emuls="elf32shlunx shunx shlunx" ++ ;; ++shel-*-netbsdelf) targ_emul=elf32shlunx ++ targ_extra_emuls="elf32shunx shunx shlunx" ++ ;; ++sh-*-netbsdcoff) targ_emul=shunx; targ_extra_emuls=shlunx ;; ++shel-*-netbsdcoff) targ_emul=shlunx; targ_extra_emuls=shunx ;; + sh-*-*|sh-*-rtems*) targ_emul=sh; targ_extra_emuls=shl ;; + m68k-sony-*) targ_emul=news ;; + m68k-hp-bsd*) targ_emul=hp300bsd ;; +diff -u -r -N -x *.orig -x CVS old/ld/emulparams/elf32shlunx.sh binutils-2.9.1/ld/emulparams/elf32shlunx.sh +--- ld/emulparams/elf32shlunx.sh Thu Jan 1 09:00:00 1970 ++++ ld/emulparams/elf32shlunx.sh Wed Jan 3 20:51:16 2001 +@@ -0,0 +1,15 @@ ++SCRIPT_NAME=elf ++OUTPUT_FORMAT="elf32-shl-unx" ++TEXT_START_ADDR=0x1000 ++MAXPAGESIZE=0x1000 ++ARCH=sh ++MACHINE= ++TEMPLATE_NAME=elf32 ++GENERATE_SHLIB_SCRIPT=yes ++ ++# These are for compatibility with the COFF toolchain. ++ENTRY=start ++CTOR_START='___ctors = .;' ++CTOR_END='___ctors_end = .;' ++DTOR_START='___dtors = .;' ++DTOR_END='___dtors_end = .;' +diff -u -r -N -x *.orig -x CVS old/ld/emulparams/elf32shunx.sh binutils-2.9.1/ld/emulparams/elf32shunx.sh +--- ld/emulparams/elf32shunx.sh Thu Jan 1 09:00:00 1970 ++++ ld/emulparams/elf32shunx.sh Wed Jan 3 20:51:33 2001 +@@ -0,0 +1,15 @@ ++SCRIPT_NAME=elf ++OUTPUT_FORMAT="elf32-sh-unx" ++TEXT_START_ADDR=0x1000 ++MAXPAGESIZE=0x1000 ++ARCH=sh ++MACHINE= ++TEMPLATE_NAME=elf32 ++GENERATE_SHLIB_SCRIPT=yes ++ ++# These are for compatibility with the COFF toolchain. ++ENTRY=start ++CTOR_START='___ctors = .;' ++CTOR_END='___ctors_end = .;' ++DTOR_START='___dtors = .;' ++DTOR_END='___dtors_end = .;' +diff -u -r -N -x *.orig -x CVS old/ld/emulparams/shlunx.sh binutils-2.9.1/ld/emulparams/shlunx.sh +--- ld/emulparams/shlunx.sh Thu Jan 1 09:00:00 1970 ++++ ld/emulparams/shlunx.sh Wed Jan 3 20:51:54 2001 +@@ -0,0 +1,5 @@ ++SCRIPT_NAME=shunx ++OUTPUT_FORMAT="coff-shl" ++TEXT_START_ADDR=0x1000 ++TARGET_PAGE_SIZE=0x1000 ++ARCH=sh +diff -u -r -N -x *.orig -x CVS old/ld/emulparams/shunx.sh binutils-2.9.1/ld/emulparams/shunx.sh +--- ld/emulparams/shunx.sh Thu Jan 1 09:00:00 1970 ++++ ld/emulparams/shunx.sh Wed Jan 3 20:52:04 2001 +@@ -0,0 +1,5 @@ ++SCRIPT_NAME=shunx ++OUTPUT_FORMAT="coff-sh" ++TEXT_START_ADDR=0x1000 ++TARGET_PAGE_SIZE=0x1000 ++ARCH=sh +diff -u -r -N -x *.orig -x CVS old/ld/scripttempl/shunx.sc binutils-2.9.1/ld/scripttempl/shunx.sc +--- ld/scripttempl/shunx.sc Thu Jan 1 09:00:00 1970 ++++ ld/scripttempl/shunx.sc Wed Jan 3 20:52:24 2001 +@@ -0,0 +1,53 @@ ++TORS=".tors : ++ { ++ ___ctors = . ; ++ *(.ctors) ++ ___ctors_end = . ; ++ ___dtors = . ; ++ *(.dtors) ++ ___dtors_end = . ; ++ }" ++ ++ ++cat < ++ ++#undef CPP_SPEC ++#define CPP_SPEC "%{posix:-D_POSIX_SOURCE} \ ++%{ml:-D__LITTLE_ENDIAN__} \ ++%{m1:-D__sh1__} \ ++%{m2:-D__sh2__} \ ++%{m3:-D__sh3__} \ ++%{m3e:-D__SH3E__} \ ++%{!m1:%{!m2:%{!m3:%{!m3e:-D__sh1__}}}}" ++ ++#undef CPP_PREDEFINES ++#define CPP_PREDEFINES "-D__sh__ -Dunix -Dsh3 -D__NetBSD__ -Asystem(unix) -Asystem(NetBSD) -Acpu(sh) -Amachine(sh)" ++ ++/* XXX -fpic -fPIC? (msaitoh) */ ++#undef ASM_SPEC ++#define ASM_SPEC "%{ml:-little} %{mrelax:-relax}" ++ ++#undef LIB_SPEC ++#define LIB_SPEC "%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}" ++ ++#undef LINK_SPEC ++#define LINK_SPEC \ ++ "%{ml:-m shlunx} %{mrelax:-relax} %{!nostdlib:%{!r*:%{!e*:-e start}}} -dc -dp %{R*} %{static:-Bstatic} %{assert*}" ++ ++/* We have atexit(3). */ ++ ++#define HAVE_ATEXIT ++ ++/* Implicit library calls should use memcpy, not bcopy, etc. */ ++ ++#define TARGET_MEM_FUNCTIONS ++ ++/* Handle #pragma weak and #pragma pack. */ ++ ++#define HANDLE_SYSV_PRAGMA ++ ++ ++/* Make gcc agree with */ ++ ++#undef SIZE_TYPE ++#define SIZE_TYPE "unsigned int" ++ ++#undef PTRDIFF_TYPE ++#define PTRDIFF_TYPE "int" ++ ++#undef WCHAR_TYPE ++#define WCHAR_TYPE "int" ++ ++#undef WCHAR_UNSIGNED ++#define WCHAR_UNSIGNED 0 ++ ++#undef WCHAR_TYPE_SIZE ++#define WCHAR_TYPE_SIZE 32 ++ ++/* Until they use ELF or something that handles dwarf2 unwinds ++ and initialization stuff better. */ ++#undef DWARF2_UNWIND_INFO ++ +diff -uN gcc/config/sh/netbsdelcoff.h gcc/config/sh/netbsdelcoff.h +--- gcc/config/sh/netbsdelcoff.h Thu Jan 1 09:00:00 1970 ++++ gcc/config/sh/netbsdelcoff.h Wed Jan 3 21:43:23 2001 +@@ -0,0 +1,64 @@ ++#include ++ ++#undef CPP_SPEC ++#define CPP_SPEC "%{posix:-D_POSIX_SOURCE} \ ++%{!mb:-D__LITTLE_ENDIAN__} \ ++%{m1:-D__sh1__} \ ++%{m2:-D__sh2__} \ ++%{m3:-D__sh3__} \ ++%{m3e:-D__SH3E__} \ ++%{!m1:%{!m2:%{!m3:%{!m3e:-D__sh1__}}}}" ++ ++#undef CPP_PREDEFINES ++#define CPP_PREDEFINES "-D__sh__ -Dunix -Dsh3 -D__NetBSD__ -Asystem(unix) -Asystem(NetBSD) -Acpu(sh) -Amachine(sh)" ++ ++/* XXX -fpic -fPIC? (msaitoh) */ ++#undef ASM_SPEC ++#define ASM_SPEC "%{!mb:-little} %{mrelax:-relax}" ++ ++#undef LIB_SPEC ++#define LIB_SPEC "%{!p:%{!pg:-lc}}%{p:-lc_p}%{pg:-lc_p}" ++ ++#undef LINK_SPEC ++#define LINK_SPEC \ ++ "%{!mb:-m shlunx} %{mrelax:-relax} %{!nostdlib:%{!r*:%{!e*:-e start}}} -dc -dp %{R*} %{static:-Bstatic} %{assert*}" ++ ++/* set default to little endian */ ++ ++#undef TARGET_DEFAULT ++#define TARGET_DEFAULT LITTLE_ENDIAN_BIT ++ ++/* We have atexit(3). */ ++ ++#define HAVE_ATEXIT ++ ++/* Implicit library calls should use memcpy, not bcopy, etc. */ ++ ++#define TARGET_MEM_FUNCTIONS ++ ++/* Handle #pragma weak and #pragma pack. */ ++ ++#define HANDLE_SYSV_PRAGMA ++ ++ ++/* Make gcc agree with */ ++ ++#undef SIZE_TYPE ++#define SIZE_TYPE "unsigned int" ++ ++#undef PTRDIFF_TYPE ++#define PTRDIFF_TYPE "int" ++ ++#undef WCHAR_TYPE ++#define WCHAR_TYPE "int" ++ ++#undef WCHAR_UNSIGNED ++#define WCHAR_UNSIGNED 0 ++ ++#undef WCHAR_TYPE_SIZE ++#define WCHAR_TYPE_SIZE 32 ++ ++/* Until they use ELF or something that handles dwarf2 unwinds ++ and initialization stuff better. */ ++#undef DWARF2_UNWIND_INFO ++ +diff -uN gcc/config/sh/netbsdelelf.h gcc/config/sh/netbsdelelf.h +--- gcc/config/sh/netbsdelelf.h Thu Jan 1 09:00:00 1970 ++++ gcc/config/sh/netbsdelelf.h Wed Jan 3 21:43:23 2001 +@@ -0,0 +1,142 @@ ++/* Definitions of target machine for gcc for Hitachi Super-H using ELF. ++ Copyright (C) 1996 Free Software Foundation, Inc. ++ Contributed by Ian Lance Taylor . ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING. If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA. */ ++ ++/* Get generic SH definitions. */ ++#include ++ ++/* No SDB debugging info. */ ++#undef SDB_DEBUGGING_INFO ++ ++/* Undefine some macros defined in both sh.h and svr4.h. */ ++#undef IDENT_ASM_OP ++#undef ASM_FILE_END ++#undef ASM_OUTPUT_SOURCE_LINE ++#undef DBX_OUTPUT_MAIN_SOURCE_FILE_END ++#undef CTORS_SECTION_ASM_OP ++#undef DTORS_SECTION_ASM_OP ++#undef ASM_OUTPUT_SECTION_NAME ++#undef ASM_OUTPUT_CONSTRUCTOR ++#undef ASM_OUTPUT_DESTRUCTOR ++#undef ASM_DECLARE_FUNCTION_NAME ++#undef PREFERRED_DEBUGGING_TYPE ++#undef MAX_OFILE_ALIGNMENT ++ ++/* Be ELF-like. */ ++#include ++ ++/* Get generic NetBSD ELF definitions. */ ++#define NETBSD_ELF ++#include ++ ++/* The prefix to add to user-visible assembler symbols. ++ Note that svr4.h redefined it from the original value (that we want) ++ in sh.h */ ++ ++#undef USER_LABEL_PREFIX ++#define USER_LABEL_PREFIX "_" ++ ++#undef LOCAL_LABEL_PREFIX ++#define LOCAL_LABEL_PREFIX "." ++ ++#undef ASM_FILE_START ++#define ASM_FILE_START(FILE) do { \ ++ output_file_directive ((FILE), main_input_filename); \ ++ if (TARGET_LITTLE_ENDIAN) \ ++ fprintf ((FILE), "\t.little\n"); \ ++} while (0) ++ ++#undef CPP_SPEC ++#define CPP_SPEC "%{posix:-D_POSIX_SOURCE} \ ++%{!mb:-D__LITTLE_ENDIAN__} \ ++%{m1:-D__sh1__} \ ++%{m2:-D__sh2__} \ ++%{m3:-D__sh3__} \ ++%{m3e:-D__SH3E__} \ ++%{!m1:%{!m2:%{!m3:%{!m3e:-D__sh1__}}}}" ++ ++/* Let code know that this is ELF. */ ++#define CPP_PREDEFINES \ ++"-D__sh__ -D__sh3__ -D__NetBSD__ -D__ELF__ -D__KPRINTF_ATTRIBUTE__ \ ++-Asystem(unix) -Asystem(NetBSD) -Acpu(sh3) -Amachine(sh3)" ++ ++/* svr4.h undefined DBX_REGISTER_NUMBER, so we need to define it ++ again. */ ++#define DBX_REGISTER_NUMBER(REGNO) \ ++ (((REGNO) >= 22 && (REGNO) <= 39) ? ((REGNO) + 1) : (REGNO)) ++ ++/* SH ELF, unlike most ELF implementations, uses underscores before ++ symbol names. */ ++#undef ASM_OUTPUT_LABELREF ++#define ASM_OUTPUT_LABELREF(STREAM,NAME) \ ++ asm_fprintf (STREAM, "%U%s", NAME) ++ ++#undef ASM_GENERATE_INTERNAL_LABEL ++#define ASM_GENERATE_INTERNAL_LABEL(STRING, PREFIX, NUM) \ ++ sprintf ((STRING), "*%s%s%d", LOCAL_LABEL_PREFIX, (PREFIX), (NUM)) ++ ++#undef ASM_OUTPUT_INTERNAL_LABEL ++#define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \ ++ asm_fprintf ((FILE), "%L%s%d:\n", (PREFIX), (NUM)) ++ ++#undef ASM_OUTPUT_SOURCE_LINE ++#define ASM_OUTPUT_SOURCE_LINE(file, line) \ ++do \ ++ { \ ++ static int sym_lineno = 1; \ ++ asm_fprintf ((file), ".stabn 68,0,%d,%LLM%d-", \ ++ (line), sym_lineno); \ ++ assemble_name ((file), \ ++ XSTR (XEXP (DECL_RTL (current_function_decl), 0), 0));\ ++ asm_fprintf ((file), "\n%LLM%d:\n", sym_lineno); \ ++ sym_lineno += 1; \ ++ } \ ++while (0) ++ ++#undef DBX_OUTPUT_MAIN_SOURCE_FILE_END ++#define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME) \ ++do { \ ++ text_section (); \ ++ fprintf ((FILE), "\t.stabs \"\",%d,0,0,Letext\nLetext:\n", N_SO); \ ++} while (0) ++ ++/* HANDLE_SYSV_PRAGMA (defined by svr4.h) takes precedence over HANDLE_PRAGMA. ++ We want to use the HANDLE_PRAGMA from sh.h. */ ++#undef HANDLE_SYSV_PRAGMA ++ ++#undef ASM_SPEC ++#define ASM_SPEC \ ++ "%{!mb:-little} %{mrelax:-relax} %{fpic:-k} %{fPIC:-k}" ++ ++#undef LINK_SPEC ++#define LINK_SPEC \ ++ "%{!mb:-m elf32shlunx} %{mrelax:-relax} \ ++ %{assert*} \ ++ %{shared:-shared} \ ++ %{!shared: \ ++ -dc -dp \ ++ %{!nostdlib:%{!r*:%{!e*:-e __start}}} \ ++ %{!static: \ ++ %{rdynamic:-export-dynamic} \ ++ %{!dynamic-linker:-dynamic-linker /usr/libexec/ld.elf_so}} \ ++ %{static:-static}}" ++ ++#undef TARGET_DEFAULT ++#define TARGET_DEFAULT LITTLE_ENDIAN_BIT +diff -uN gcc/config/sh/netbsdelf.h gcc/config/sh/netbsdelf.h +--- gcc/config/sh/netbsdelf.h Thu Jan 1 09:00:00 1970 ++++ gcc/config/sh/netbsdelf.h Wed Jan 3 21:43:23 2001 +@@ -0,0 +1,130 @@ ++/* Definitions of target machine for gcc for Hitachi Super-H using ELF. ++ Copyright (C) 1996 Free Software Foundation, Inc. ++ Contributed by Ian Lance Taylor . ++ ++This file is part of GNU CC. ++ ++GNU CC 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, or (at your option) ++any later version. ++ ++GNU CC 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 GNU CC; see the file COPYING. If not, write to ++the Free Software Foundation, 59 Temple Place - Suite 330, ++Boston, MA 02111-1307, USA. */ ++ ++/* Get generic SH definitions. */ ++#include ++ ++/* No SDB debugging info. */ ++#undef SDB_DEBUGGING_INFO ++ ++/* Undefine some macros defined in both sh.h and svr4.h. */ ++#undef IDENT_ASM_OP ++#undef ASM_FILE_END ++#undef ASM_OUTPUT_SOURCE_LINE ++#undef DBX_OUTPUT_MAIN_SOURCE_FILE_END ++#undef CTORS_SECTION_ASM_OP ++#undef DTORS_SECTION_ASM_OP ++#undef ASM_OUTPUT_SECTION_NAME ++#undef ASM_OUTPUT_CONSTRUCTOR ++#undef ASM_OUTPUT_DESTRUCTOR ++#undef ASM_DECLARE_FUNCTION_NAME ++#undef PREFERRED_DEBUGGING_TYPE ++#undef MAX_OFILE_ALIGNMENT ++ ++/* Be ELF-like. */ ++#include ++ ++/* Get generic NetBSD ELF definitions. */ ++#define NETBSD_ELF ++#include ++ ++/* The prefix to add to user-visible assembler symbols. ++ Note that svr4.h redefined it from the original value (that we want) ++ in sh.h */ ++ ++#undef USER_LABEL_PREFIX ++#define USER_LABEL_PREFIX "_" ++ ++#undef LOCAL_LABEL_PREFIX ++#define LOCAL_LABEL_PREFIX "." ++ ++#undef ASM_FILE_START ++#define ASM_FILE_START(FILE) do { \ ++ output_file_directive ((FILE), main_input_filename); \ ++ if (TARGET_LITTLE_ENDIAN) \ ++ fprintf ((FILE), "\t.little\n"); \ ++} while (0) ++ ++/* Let code know that this is ELF. */ ++#define CPP_PREDEFINES \ ++"-D__sh__ -D__sh3__ -D__NetBSD__ -D__ELF__ -D__KPRINTF_ATTRIBUTE__ \ ++-Asystem(unix) -Asystem(NetBSD) -Acpu(sh3) -Amachine(sh3)" ++ ++/* svr4.h undefined DBX_REGISTER_NUMBER, so we need to define it ++ again. */ ++#define DBX_REGISTER_NUMBER(REGNO) \ ++ (((REGNO) >= 22 && (REGNO) <= 39) ? ((REGNO) + 1) : (REGNO)) ++ ++/* SH ELF, unlike most ELF implementations, uses underscores before ++ symbol names. */ ++#undef ASM_OUTPUT_LABELREF ++#define ASM_OUTPUT_LABELREF(STREAM,NAME) \ ++ asm_fprintf (STREAM, "%U%s", NAME) ++ ++#undef ASM_GENERATE_INTERNAL_LABEL ++#define ASM_GENERATE_INTERNAL_LABEL(STRING, PREFIX, NUM) \ ++ sprintf ((STRING), "*%s%s%d", LOCAL_LABEL_PREFIX, (PREFIX), (NUM)) ++ ++#undef ASM_OUTPUT_INTERNAL_LABEL ++#define ASM_OUTPUT_INTERNAL_LABEL(FILE,PREFIX,NUM) \ ++ asm_fprintf ((FILE), "%L%s%d:\n", (PREFIX), (NUM)) ++ ++#undef ASM_OUTPUT_SOURCE_LINE ++#define ASM_OUTPUT_SOURCE_LINE(file, line) \ ++do \ ++ { \ ++ static int sym_lineno = 1; \ ++ asm_fprintf ((file), ".stabn 68,0,%d,%LLM%d-", \ ++ (line), sym_lineno); \ ++ assemble_name ((file), \ ++ XSTR (XEXP (DECL_RTL (current_function_decl), 0), 0));\ ++ asm_fprintf ((file), "\n%LLM%d:\n", sym_lineno); \ ++ sym_lineno += 1; \ ++ } \ ++while (0) ++ ++#undef DBX_OUTPUT_MAIN_SOURCE_FILE_END ++#define DBX_OUTPUT_MAIN_SOURCE_FILE_END(FILE, FILENAME) \ ++do { \ ++ text_section (); \ ++ fprintf ((FILE), "\t.stabs \"\",%d,0,0,Letext\nLetext:\n", N_SO); \ ++} while (0) ++ ++/* HANDLE_SYSV_PRAGMA (defined by svr4.h) takes precedence over HANDLE_PRAGMA. ++ We want to use the HANDLE_PRAGMA from sh.h. */ ++#undef HANDLE_SYSV_PRAGMA ++ ++#undef ASM_SPEC ++#define ASM_SPEC \ ++ "%{ml:-little} %{mrelax:-relax} %{fpic:-k} %{fPIC:-k}" ++ ++#undef LINK_SPEC ++#define LINK_SPEC \ ++ "%{ml:-m elf32shlunx} %{mrelax:-relax} \ ++ %{assert*} \ ++ %{shared:-shared} \ ++ %{!shared: \ ++ -dc -dp \ ++ %{!nostdlib:%{!r*:%{!e*:-e __start}}} \ ++ %{!static: \ ++ %{rdynamic:-export-dynamic} \ ++ %{!dynamic-linker:-dynamic-linker /usr/libexec/ld.elf_so}} \ ++ %{static:-static}}" -- cgit v1.2.3