Subject: Getting rid of sh5 support in sh3 binutils and gdb?
To: None <tech-toolchain@NetBSD.org>
From: Valeriy E. Ushakov <uwe@ptc.spbu.ru>
List: port-sh5
Date: 11/24/2006 06:52:06
--Q68bSM7Ycu6FN28Q
Content-Type: text/plain; charset=us-ascii
Content-Disposition: inline

[cc'ed to port lists, reply-to set to tech-toolchain, please follow up there]

GNU toolchain seems to insists on including sh5 support for sh*-*
targets, so we end up with sh5 support in sh3 toolchain.

That adds a bit of bloat, but that's not the main problem.

The problem is trying to make gdb6 build.

See gdb/infptrace.c:child_xfer_memory.  When we configure gdb6 for sh3
target (sh{,le}--netbsdelf) sh5 support gets sucked in, causing
bfd_vma to be 64-bit, hence gdb's CORE_ADDR is 64-bit, and then gcc
complains when CORE_ADDR is passed to ptrace() where a poitner is
expected.

Attached patch teaches gdb to not include sh5 support for sh3 targets.
I don't know why toolchain people made the decision to include sh5
support by default, i don't think this is usually the case for either
sparc (vs sparc64), i386 (vs amd64), ppc (vs ppc64) - where 64 bit
variant needs to be requested explicitely.

With this patch gdb6 for sh3 passes mknative + in-tree cross-build.
I haven't tested sh5 build yet.

I wonder if we should also apply relevant parts to binutils as well.


Summary of changes:

bfd/config.bfd

    Move sh64 vectors ito targ64_selvecs for netbsd targets that are
    not explicitely sh5- or sh64-, so that they are enabled only if
    explicitely requested.  This is what is done for most other arches
    with 32/64 bit variants (grep for targ64_selvecs)

opcodes/configure{,.in}

    Do not add sh5 support for netbsd sh* targets unless the target is
    explicitely sh5* or sh64* (to match the config.bfd change)

gdb/sh-tdep.c

    Wrap the only sh5 reference (calling sh64_gdbarch_init() that is
    in sh64-tdep.c) into #ifdef BFD64.

    BTW, config/sh/nbsd.mt doesn't include sh64-tdep.c anyway.


Comments?

SY, Uwe
-- 
uwe@ptc.spbu.ru                         |       Zu Grunde kommen
http://snark.ptc.spbu.ru/~uwe/          |       Ist zu Grunde gehen

--Q68bSM7Ycu6FN28Q
Content-Type: text/plain; charset=us-ascii
Content-Disposition: attachment; filename="gdb6.diff"

Index: bfd/config.bfd
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/bfd/config.bfd,v
retrieving revision 1.3
diff -u -r1.3 config.bfd
--- bfd/config.bfd	2 Jul 2006 21:04:40 -0000	1.3
+++ bfd/config.bfd	24 Nov 2006 03:02:53 -0000
@@ -1166,14 +1166,14 @@
     targ_defvec=bfd_elf32_shlnbsd_vec
     targ_selvecs="bfd_elf32_shnbsd_vec shcoff_vec shlcoff_vec"
 #ifdef BFD64
-    targ_selvecs="${targ_selvecs} bfd_elf32_sh64lnbsd_vec bfd_elf32_sh64nbsd_vec bfd_elf64_sh64lnbsd_vec bfd_elf64_sh64nbsd_vec"
+    targ64_selvecs="bfd_elf32_sh64lnbsd_vec bfd_elf32_sh64nbsd_vec bfd_elf64_sh64lnbsd_vec bfd_elf64_sh64nbsd_vec"
 #endif
     ;;
   sh*-*-netbsdelf*)
     targ_defvec=bfd_elf32_shnbsd_vec
     targ_selvecs="bfd_elf32_shlnbsd_vec shcoff_vec shlcoff_vec"
 #ifdef BFD64
-    targ_selvecs="${targ_selvecs} bfd_elf32_sh64lnbsd_vec bfd_elf32_sh64nbsd_vec bfd_elf64_sh64lnbsd_vec bfd_elf64_sh64nbsd_vec"
+    targ64_selvecs="bfd_elf32_sh64lnbsd_vec bfd_elf32_sh64nbsd_vec bfd_elf64_sh64lnbsd_vec bfd_elf64_sh64nbsd_vec"
 #endif
     ;;
 
Index: opcodes/configure.in
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/opcodes/configure.in,v
retrieving revision 1.1.1.2
diff -u -r1.1.1.2 configure.in
--- opcodes/configure.in	2 Jul 2006 20:22:09 -0000	1.1.1.2
+++ opcodes/configure.in	24 Nov 2006 03:02:53 -0000
@@ -206,6 +206,14 @@
 	  # specified, as in sh3-elf, sh3b-linux-gnu, etc.
 	  # Include it just for ELF targets, since the SH5 bfd:s are ELF only.
 	  for t in $target $canon_targets; do
+	    # For NetBSD we do NOT want SH5 support unless sh5 or sh64
+	    # is specified
+	    case $t in
+	      sh5*-* | sh64*-*) # let the case below handle it
+				;;
+	      sh*-*-netbsdelf* | sh*l*-*-netbsdelf*)
+				break;;
+	      esac;
 	    case $t in
 	      all |  sh5*-* | sh64*-* | sh-*-*elf* | shl*-*-*elf* | \
 	      sh-*-linux* | shl-*-linux*)
Index: opcodes/configure
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/opcodes/configure,v
retrieving revision 1.1.1.2
diff -u -r1.1.1.2 configure
--- opcodes/configure	2 Jul 2006 20:22:09 -0000	1.1.1.2
+++ opcodes/configure	24 Nov 2006 03:03:01 -0000
@@ -8854,6 +8854,14 @@
 	  # specified, as in sh3-elf, sh3b-linux-gnu, etc.
 	  # Include it just for ELF targets, since the SH5 bfd:s are ELF only.
 	  for t in $target $canon_targets; do
+	    # For NetBSD we do NOT want SH5 support unless sh5 or sh64
+	    # is specified
+	    case $t in
+	      sh5*-* | sh64*-*) # let the case below handle it
+				;;
+	      sh*-*-netbsdelf* | sh*l*-*-netbsdelf*)
+				break;;
+	      esac;
 	    case $t in
 	      all |  sh5*-* | sh64*-* | sh-*-*elf* | shl*-*-*elf* | \
 	      sh-*-linux* | shl-*-linux*)
Index: gdb/sh-tdep.c
===================================================================
RCS file: /cvsroot/src/gnu/dist/gdb6/gdb/sh-tdep.c,v
retrieving revision 1.1.1.2
diff -u -r1.1.1.2 sh-tdep.c
--- gdb/sh-tdep.c	2 Jul 2006 20:15:05 -0000	1.1.1.2
+++ gdb/sh-tdep.c	24 Nov 2006 03:03:02 -0000
@@ -2485,10 +2485,12 @@
       sh_show_regs = sh4_nofpu_show_regs;
       break;
 
+#ifdef BFD64
     case bfd_mach_sh5:
       sh_show_regs = sh64_show_regs;
       /* SH5 is handled entirely in sh64-tdep.c */
       return sh64_gdbarch_init (info, arches);
+#endif
     }
 
   /* If there is already a candidate, use it.  */

--Q68bSM7Ycu6FN28Q--