Subject: Re: Dynamic linking is go (again)
To: None <port-sh3@netbsd.org>
From: Valeriy E. Ushakov <uwe@ptc.spbu.ru>
List: port-dreamcast
Date: 07/06/2003 00:49:42
On Sun, Jul 06, 2003 at 05:09:29 +0900, Izumi Tsutsui wrote:

> > Hmm, so it doesn't work.  Apparently it crashes in _rtld_setup.
> 
> Maybe it's _start vs __start ENTRY problem in ld(1) which I posted.
> You have to fix ld in binutils or add -e __start in bsd.prog.mk.
> http://mail-index.netbsd.org/port-sh3/2003/07/05/0004.html
> http://mail-index.netbsd.org/port-sh3/2003/07/05/0005.html

I saw your posting, so I changed linker scripts:
s/ENTRY(_start)/ENTRY(__start)/


> FYI, what I tried is:
> 
> (1) Build usual toolchain for sh3el:
> % cd /usr/src
> % sh build.sh -m dreamcast -D [somewhere for ${DESTDIR}] tools

Yes.

Then I built stock binutils-2.14 and tell gcc-3.3 (next step) to use
those.

> (2) Build gcc-3.3:
> % tar jxvf gcc-3.3.tar.bz2
> % cd gcc-3.3
> % ./configure --target=shle--netbsdelf \
> --with-as=/usr/tools/sh3el/bin/shle--netbsdelf-as \
> --with-ld=/usr/tools/sh3el/bin/shle--netbsdelf-ld \
> --disable-shared --enable-languages=c,c++
> % gmake
> [I might see some errors but not sure..]
> % su
> # gmake install

Yes.


> (3) Build binaries with make script
> % cd /usr/src
> % ${TOOLDIR}/bin/make-dreamcast CC=/usr/local/bin/shle--netbsdelf-gcc \
> HAVE_GCC3=yes MKPROFILE=no TOOLCHAIN_MISSING=yes BUILD_tools=no -k build
> 
> (I'm not sure 'make -k build' works. Maybe you should visit
>  directories (lib/csu, lib/libc, libexec/ld.elf_so..) manually)

Yes.  BTW, we have convenient do-* targets in the toplevel Makefile to
build and install each of the above.  I ran nbmake-hpcsh with:

    TOOLCHAIN_MISSING=yes
    EXTERNAL_TOOLCHAIN=/export/netbsd/xtools
    HAVE_GCC3=yes



> > Perhaps, can you send me your working (on the DC) ld.elf_so, libc.so
> > and a sample binary?
> 
> Marcus has already put some binaries, but I'll put other binaries later.

I recompiled ld.elf_so with debugging and now it prints something
like:

<toor@nada:/mnt/distrib/bin> # ldd date
date:
         -lutil.7 => /lib/libutil.so.7
         -lc.12 => /lib/libc.so.12
<toor@nada:/mnt/distrib/bin> # ./date
sp = 0x7fffe954, argc = 1, argv = 0x7fffe960 <./date> relocbase 0x20420000
Memory fault (core dumped) 

Looking at the code in rtld.c:

        dbg(("sp = %p, argc = %ld, argv = %p <%s> relocbase %p", sp,
            (long)sp[2], &sp[3], (char *) sp[3], (void *)relocbase));
        dbg(("got is at %p, dynamic is at %p", _GLOBAL_OFFSET_TABLE_,
            &_DYNAMIC));

it looks like it crashes trying to pass _GLOBAL_OFFSET_TABLE_:

gdb (the one i already have installed on the jornada, 5.0nb1)
complains about that ./date binary:

    Dwarf Error: Cannot handler DW_FORM_strp in DWARF reader.

[... run, get sigsegv ...]
(gdb) x/i $pc
0x2042310c:	mov.l	@(r0,r12),r5
(gdb) disass $pc-4 $pc+2
0x20423108:	mov	r12,r4
0x2042310a:	mov.l	0x204232c8,r0	! 0x17454
0x2042310c:	mov.l	@(r0,r12),r5
(gdb) p/x $r0
$1 = 0x17454
(gdb) p/x $12
$2 = 0x2043a71c

Diassembling the PIC setup at start of that function (_rtld()):

0x204230cc:	mova	0x204232b4,r0
0x204230ce:	mov.l	0x204232b4,r12	! 0x17468
0x204230d0:	add	r0,r12		# uwe: 0x2043a71c

Hmm, actually looking at the build log for the ld.eld_so (with
debugging enabled) I can see

/var/tmp//ccG2h5LE.s:864: Warning: rest of line ignored; first ignored character is `@'

And that's exactly the

    .long   _GLOBAL_OFFSET_TABLE_@GOT

that we pass as the second argument to the debug_printf.

Having no clue about PIC for sh3 I wonder if something is Wrong(TM)
here.

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