Subject: port-arm32/15303: Crosscompiling Alpha->arm32 fails due to LP64 -> LP32 trouble
To: None <gnats-bugs@gnats.netbsd.org>
From: None <reinoud@netbsd.org>
List: netbsd-bugs
Date: 01/19/2002 23:10:39
>Number:         15303
>Category:       port-arm32
>Synopsis:       Crosscompiling Alpha->arm32 fails due to LP64 -> LP32 trouble
>Confidential:   no
>Severity:       critical
>Priority:       high
>Responsible:    port-arm32-maintainer
>State:          open
>Class:          sw-bug
>Submitter-Id:   net
>Arrival-Date:   Sat Jan 19 14:11:01 PST 2002
>Closed-Date:
>Last-Modified:
>Originator:     Reinoud Zandijk
>Release:        NetBSD starbuck 1.5ZA NetBSD 1.5ZA (config.starbuck) #0: Sat Jan 19 15:08:37 CET 2002
>Organization:
NetBSD
	
>Environment:

cvs.netbsd.org sources dating from a few minutes ago. i.e. 19 jan 2002,
23:02 CET. Crosscompiling on a 1.5ZA kernel with 1.5.2 libs (AFAIK!).

>Description:

In my efford to get arch/acorn32 fully ELF operatable i've tried
cross-compiling acorn32 in ELF on an Alpha.

To compile it this way cross compile with the following line :

./build.sh -a arm -m acorn32 -D /mnt/bigstuff/acorn32/snapshot/ -T 
/mnt/bigstuff/acorn32/toolset/ -O /mnt/bigstuff/acorn32/obj -R 
/mnt/bigstuff/acorn32/release/ -u

Unfortunataly I got the assembler errors prolly connected to ints getting 
zero or rotating after shifting or so wich breaks on LP64 ...

I think its a relative small patch in the offset calculation of PC relative
loading or so ... here is the data ... happy hacking ;)

-----

dependall ===> gnu/usr.bin/groff/hpftodit
/usr/tmp/acorn32-toolset//bin/arm--netbsdelf-c++ -O2  -Werror   
-DHAVE_STDLIB_H=1 -DHAVE_UNISTD_H=1 -DHAVE_DIRENT_H=1 -DHAVE_LIMITS_H=1 -D
HAVE_SYS_DIR_H=1 -DHAVE_STRING_H=1 -DHAVE_STRINGS_H=1 -DHAVE_MATH_H=1 
-DRET_TYPE_SRAND_IS_VOID=1 -DHAVE_SYS_NERR=1 -DHAVE_SYS_ERRLIST=1 -D
HAVE_CC_LIMITS_H=1 -DRETSIGTYPE=void -DHAVE_STRUCT_EXCEPTION=1 
-DHAVE_UNISTD_H=1 -DHAVE_GETPAGESIZE=1 -DHAVE_MMAP=1 -DHAVE_FMOD=1 -DHAVE_S
TRTOL=1 -DHAVE_GETCWD=1 -DHAVE_STRERROR=1 -DHAVE_PUTENV=1 -DHAVE_RENAME=1 
-DHAVE_MKSTEMP=1 -DHAVE_STRCASECMP=1 -DHAVE_STRNCASECMP=1 -DHAVE
_STRSEP=1 -DHAVE_STRDUP=1 -DSYS_SIGLIST_DECLARED=1 
-I/usr/sources/cvs.netbsd.org/src/gnu/usr.bin/groff/hpftodit/../include 
-I/usr/sources/
cvs.netbsd.org/src/gnu/usr.bin/groff/hpftodit/../../../dist/groff/src/include 
-nostdinc -isystem /usr/tmp/acorn32-snapshot/usr/include  -c
 
/usr/sources/cvs.netbsd.org/src/gnu/usr.bin/groff/hpftodit/../../../dist/groff/src/utils/hpftodit/hpftodit.cc
/var/tmp/ccT0aLQB.s: Assembler messages:
/var/tmp/ccT0aLQB.s:765: Error: Value of 4294967296 too large for field of 4 bytes at 2536
/var/tmp/ccT0aLQB.s:836: Error: Value of 4294967392 too large for field of 4 bytes at 2808
/var/tmp/ccT0aLQB.s:904: Error: Value of 4294967548 too large for field of 4 bytes at 3000
/var/tmp/ccT0aLQB.s:978: Error: Value of 4294967344 too large for field of 4 bytes at 3248
/var/tmp/ccT0aLQB.s:1334: Error: Value of 4294967332 too large for field of 4 bytes at 4508
/var/tmp/ccT0aLQB.s:1336: Error: Value of 4294967752 too large for field of 4 bytes at 4516
/var/tmp/ccT0aLQB.s:1337: Error: Value of 4294967716 too large for field of 4 bytes at 4520
/var/tmp/ccT0aLQB.s:1338: Error: Value of 4294967728 too large for field of 4 bytes at 4524
/var/tmp/ccT0aLQB.s:1379: Error: Value of 4294967428 too large for field of 4 bytes at 4636
/var/tmp/ccT0aLQB.s:1407: Error: Value of 4294967440 too large for field of 4 bytes at 4716
/var/tmp/ccT0aLQB.s:1476: Error: Value of 4294967800 too large for field of 4 bytes at 4924
/var/tmp/ccT0aLQB.s:1524: Error: Value of 4294967404 too large for field of 4 bytes at 5072
/var/tmp/ccT0aLQB.s:1525: Error: Value of 4294967464 too large for field of 4 bytes at 5076
/var/tmp/ccT0aLQB.s:1560: Error: Value of 4294967452 too large for field of 4 bytes at 5176
/var/tmp/ccT0aLQB.s:1707: Error: Value of 4294967440 too large for field of 4 bytes at 5532
/var/tmp/ccT0aLQB.s:1831: Error: Value of 4294967764 too large for field of 4 bytes at 5968
/var/tmp/ccT0aLQB.s:2103: Error: Value of 4294967452 too large for field of 4 bytes at 6996
/var/tmp/ccT0aLQB.s:2114: Error: Value of 4294967584 too large for field of 4 bytes at 7048
/var/tmp/ccT0aLQB.s:2122: Error: Value of 4294967620 too large for field of 4 bytes at 7092
/var/tmp/ccT0aLQB.s:2123: Error: Value of 4294967632 too large for field of 4 bytes at 7096
*** Error code 1

Stop.

-----------


I tracked down the first one in the file near :

static
void check_type()
{
  require_tag(type_tag);
  if (tag_info(type_tag).value != 0) {
    if (tag_info(type_tag).value == 2)
      fatal("cannot handle TrueType tfm files");
    fatal("unknown type tag %1", int(tag_info(type_tag).value));
  }
}

with the following functions :

inline
entry &tag_info(tag_type t)
{ 
  return tags[t - min_tag];
}

and
  min_tag = 400,

and

static 

void require_tag(tag_type t)
{
  if (!tag_info(t).present)
    fatal("tag %1 missing", int(t));
}



its the int(tag_info(type_tag).value) thats breaking it ... it gets 
compiled into :



.............
.Lfe9:  
        .size    read_tags__FR4File,.Lfe9-read_tags__FR4File
        .align  2
.LC14:
        .ascii  "cannot handle TrueType tfm files\000"
        .align  2
.LC15:
        .ascii  "unknown type tag %1\000"
        .align  2
        .type    check_type__Fv,%function
check_type__Fv:
        @ args = 0, pretend = 0, frame = 12
        @ frame_needed = 1, current_function_anonymous_args = 0
        mov     ip, sp
        stmfd   sp!, {r4, r5, fp, ip, lr, pc}
        sub     fp, ip, #4
        mov     r0, #400
        ldr     r4, .L124
        sub     sp, sp, #12
        bl      require_tag__F8tag_type
        ldr     r3, [r4, #8]
        cmp     r3, #0
        beq     .L118
        cmp     r3, #2
        ldr     r5, .L124+4
        bne     .L120
        mov     r1, r5
        mov     r2, r5
        mov     r3, r5
        ldr     r0, .L124+8
        bl      fatal__FPCcRC6errargN21
.L120:
        ldr     r1, [r4, #8]
        sub     r4, fp, #32
        mov     r0, r4
        bl      __6errargi
        mov     r1, r4
        mov     r2, r5
        ldr     r0, .L124+12
        mov     r3, r2
        bl      fatal__FPCcRC6errargN21
        b       .L123
.L125:
        .align  2
.L124:
        .word   tags+4294967296	<=== obvious fault ... is this supposed to
                                     be a signed int/wrap ?? on 32 bits 
                                     processors this gets 2^32 => 0
        .word   empty_errarg
        .word   .LC14
        .word   .LC15
.L123:
.L118:
        ldmea   fp, {r4, r5, fp, sp, pc}
.Lfe10:
        .size    check_type__Fv,.Lfe10-check_type__Fv
        .align  2


--------


>How-To-Repeat:
Just try to cross compile :-/

>Fix:
Propably a small bugfix in calculating offsets to be signed 4 byte ints
instead of signed/unsigned 64 bits like it is now ... 

Maybe they made the assumption that a `long' is 32 bits ?

>Release-Note:
>Audit-Trail:
>Unformatted: