Subject: Re: Strange segmentation fault trying to run postgresql on
To: Alex Pelts <alexp@broadcom.com>
From: Markus W Kilbinger <mk@kilbi.de>
List: port-mips
Date: 04/29/2007 11:16:13
>>>>> "Alex" == Alex Pelts <alexp@broadcom.com> writes:

    Alex> It is not the mapping that is the problem but alignment. It
    Alex> is trying to store word (32 bits) at the address that is
    Alex> aligned on 1 byte (cf). I don't know much about how netbsd
    Alex> translates mips exceptions to signals but I think from your
    Alex> register dump the problem is alignment.

I've investigated this a bit further (I can reproduce this problem on
my qube 2 (running -current kernel and userland) and
pkgsrc/databases/postgresql82(-server)). I've recompiled main/main.c
with -O0, otherwise the SIGSEGV seems to be 'hidden' in a branch delay
slot. Starting such postgres within gdb yields:

  (gdb) run
  Starting program: /usr/obj/pkg/databases/postgresql82-server/work.mipsel/postgresql-8.2.3/src/backend/postgres 
  
  Program received signal SIGSEGV, Segmentation fault.
  0x00573bcc in main ()

  (gdb) disas
  [...]
  0x00573bb8 <main+56>:   jalr    t9
  0x00573bbc <main+60>:   nop
  0x00573bc0 <main+64>:   lw      gp,16(s8)
  0x00573bc4 <main+68>:   move    v1,v0
  0x00573bc8 <main+72>:   lw      v0,-13948(gp)
  0x00573bcc <main+76>:   sw      v1,0(v0)
  0x00573bd0 <main+80>:   lw      v0,-13948(gp)
  0x00573bd4 <main+84>:   lw      v0,0(v0)
  0x00573bd8 <main+88>:   move    a0,v0
  0x00573bdc <main+92>:   lw      v0,-32632(gp)
  0x00573be0 <main+96>:   addiu   t9,v0,16308
  0x00573be4 <main+100>:  jalr    t9

  (gdb) info registers 
            zero       at       v0       v1       a0       a1       a2       a3
   R0   00000000 00000000 007e9f53 00830030 00830039 7fffda1d 00000000 7fffda14 
              t0       t1       t2       t3       t4       t5       t6       t7
   R8   7fffda1c 00000000 00000008 00000000 8000001f ffffffe0 7fffd978 006f9a34 
              s0       s1       s2       s3       s4       s5       s6       s7
   R16  7fffd9c0 7fffd8f8 00000001 7fffd8fc 007e9edc 7fffeff0 7dfb2e80 7dfaa000 
              t8       t9       k0       k1       gp       sp       s8       ra
   R24  000007de 7dbf6da8 00000000 00000000 007ed250 7fffd898 7fffd898 00573bc0 
              sr       lo       hi      bad    cause       pc
        0000ff13 0009f79c 000000b4 007e9f53 00000014 00573bcc 
             fsr      fir
        007b6300 00000000 

The problematic instruction seems to be

  0x00573bcc <main+76>:   sw      v1,0(v0)

whereas 'v0' contains an unaligned address '007e9f53' for a word
access.

Astonishingly:

  (gdb) x 0x007e9f53
  0x7e9f53 <progname>:    0x00000000

... this seems to be the address of

  const char *progname;

defined in main/main.c itself!?

So, how can this happen? Shouldn't be any pointer type variable
adequately aligned by cc/as/ld? (-> Bug within gcc/binutils?)

Maybe one of the mips guru's can help/comment here...

Markus.