Skip site navigation (1)Skip section navigation (2)
Date:      Wed, 3 Dec 2008 11:08:57 -0600
From:      Dan Nelson <dnelson@allantgroup.com>
To:        Vlad GALU <dudu@dudu.ro>
Cc:        freebsd-stable@freebsd.org
Subject:   Re: Weird truss output
Message-ID:  <20081203170857.GE22076@dan.emsphone.com>
In-Reply-To: <ad79ad6b0812030745i5dd344d4qbae54d32579c142c@mail.gmail.com>
References:  <ad79ad6b0812030147x7b9fa194nf86180f89583cdf5@mail.gmail.com> <20081203152330.GD22076@dan.emsphone.com> <ad79ad6b0812030745i5dd344d4qbae54d32579c142c@mail.gmail.com>

next in thread | previous in thread | raw e-mail | index | archive | help
In the last episode (Dec 03), Vlad GALU said:
> On Wed, Dec 3, 2008 at 5:23 PM, Dan Nelson <dnelson@allantgroup.com> wrote:
> > In the last episode (Dec 03), Vlad GALU said:
> >> I'm running a statically linked binary, which I've built inside a
> >> jail. The jail's libc & co are in sync with the host's. Truss then
> >> shows this:
> >>
> >> -- cut here --
> >> -- UNKNOWN SYSCALL 1048532 --
> >> -- UNKNOWN SYSCALL 1048532 --
> >
> > Is this a threaded app that you attached truss to after it was
> > started? The method that truss uses to catch syscall enter/exit
> > events doesn't indicate whether the event is an enter or an exit,
> > so if you attach while a syscall is active, truss handles the exit
> > event as if it were a syscall entry event, and never gets back in
> > synch.  It gets worse with threaded apps because each thread is
> > another chance to get out of synch.  Try this patch:
> 
> You were right, this application was indeed threaded. The messages
> still occur, although at a slightly lower rate. One other thing
> that's not particularly helpful is this:
> 
> -- cut here--
>  read(1074283119,"\M-Ry\^A\0",7356800)            = 4 (0x4)
> -- and here --
> 
> I obviously don't have that many descriptors in my process. I can
> live with the malformed message, but it's a PITA not to know which fd
> the read was actually made from :(

It looks like there's some other problem where truss either drops a
syscall event, or puts some status fields into the wrong thread's
structure.  It seems to happen when two threads call blocking syscalls,
and when they return, truss gets confused as to which thread called
which syscall.  The read syscall is probably still pending, and you're
getting the arguments of the syscall that returned, printed as if it
was the read syscall.  When the read call completes, you'll probably
get an --UNKNOWN SYSCALL-- line, or another mismatched syscall output
line.

An alternative it to use ktrace/kdump to trace the process; it's more
cumbersome to use, but doesn't have problems with threaded processes.

-- 
	Dan Nelson
	dnelson@allantgroup.com



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