Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 12 Oct 2006 13:01:55 -0500
From:      Eric Anderson <anderson@centtech.com>
To:        freebsd-current@freebsd.org
Subject:   yp related ls core dumps (amd64)
Message-ID:  <452E8313.7000808@centtech.com>

next in thread | raw e-mail | index | archive | help
I have two systems, both running FreeBSD 6-STABLE (amd64) (one is 
freshly installed from -BETA2 CD, the other is cvs-up'ed from a few 
weeks ago).  Both these systems will make ls (and several other tools) 
core dump when accessing a directory that had it's gid's from yp.  I'm 
not sure what exactly the trigger is, but if I remove the yp related 
line from /etc/group it works just fine (uid's are resolved, but of 
course gid's are not).  If I put the line back in, I get:

# ls -al /nfsmounts/filesystem/directory/
Segmentation fault: 11 (core dumped)

However an 'ls -aln' of that same directory always works ok.

Here's a snippet of the trailing edge of a ktrace on the failing ls:

...snip...
        0x0000 452f a45e 0000 0000 0000 0002 0001 86a4 0000 0002 0000 
0003 0000  |E/.^......................|
        0x001a 0000 0000 0000 0000 0000 0000 0000 0000 000c 6365 6e74 
7465 6368  |..................ypdomain|
        0x0034 2e63 6f6d 0000 000b 6772 6f75 702e 6279 6769 6400 0000 
0003 3630  |.com....group.bygid.....60|
        0x004e 3800 
          |8.|

    957 ls       RET   sendto 80/0x50
    957 ls       CALL 
kevent(0x7,0x51e110,0x1,0x7fffffffd800,0x1,0x7fffffffd820)
    957 ls       RET   kevent 1
    957 ls       CALL  recvfrom(0x5,0x51e134,0x900,0,0,0)
    957 ls       GIO   fd 5 read 516 bytes
        0x0000 452f a45e 0000 0001 0000 0000 0000 0000 0000 0000 0000 
0000 0000  |E/.^......................|
        0x001a 0001 0000 01e2 6c6f 6769 633a 2a3a 3630 383a 6272 656e 
7462 2c62  |......group:*:608:user1,u|
        0x01ee 2c72 6172 6f73 652c 7374 6572 6e2c 766d 6f68 616e 0000 
          |,user2,user3,user4..|

    957 ls       RET   recvfrom 516/0x204
    957 ls       CALL  close(0x7)
    957 ls       RET   close 0
    957 ls       CALL  gettimeofday(0x7fffffffd900,0)
    957 ls       RET   gettimeofday 0
    957 ls       CALL  gettimeofday(0x7fffffffd930,0)
    957 ls       RET   gettimeofday 0
    957 ls       CALL  close(0x6)
    957 ls       RET   close 0
    957 ls       PSIG  SIGSEGV SIG_DFL
    957 ls       NAMI  "ls.core"

I've replaced any real users/groups with fake ones above.

gdb says something about:
#0  0x000000080095272b in _fseeko () from /lib/libc.so.6
#1  0x0000000800952b78 in fseeko () from /lib/libc.so.6
#2  0x000000080091fde9 in __gr_parse_entry () from /lib/libc.so.6
#3  0x000000080094b971 in nsdispatch () from /lib/libc.so.6
#4  0x000000080091efe4 in getgrgid_r () from /lib/libc.so.6
#5  0x000000080091f0b0 in getgrgid_r () from /lib/libc.so.6
#6  0x00000008008e3aa6 in group_from_gid () from /lib/libc.so.6
#7  0x0000000000402271 in display (p=0x50b100, list=0x50b200, 
options=48) at ls.c:704
#8  0x0000000000402ace in traverse (argc=1, argv=0x0, options=48) at 
ls.c:527
#9  0x0000000000402e44 in main (argc=1, argv=0x7fffffffecb8) at ls.c:457


This same setup causes no issues on a 32bit system.


Eric


-- 
------------------------------------------------------------------------
Eric Anderson        Sr. Systems Administrator        Centaur Technology
Anything that works is better than anything that doesn't.
------------------------------------------------------------------------



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?452E8313.7000808>