Date: Wed, 1 May 2013 14:30:36 -0400 From: John Baldwin <jhb@freebsd.org> To: "Robert N. M. Watson" <rwatson@freebsd.org> Cc: Ian FREISLICH <ianf@clue.co.za>, Glen Barber <gjb@freebsd.org>, freebsd-current@freebsd.org Subject: Re: panic: in_pcblookup_local (?) Message-ID: <201305011430.37106.jhb@freebsd.org> In-Reply-To: <49916D2B-496A-40EA-971F-62951FF6B584@freebsd.org> References: <E1UW0K5-000P7H-36@clue.co.za> <20130501180321.GA44525@glenbarber.us> <49916D2B-496A-40EA-971F-62951FF6B584@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
On Wednesday, May 01, 2013 2:08:57 pm Robert N. M. Watson wrote: > > On 1 May 2013, at 19:03, Glen Barber wrote: > > >> I'll need to catch up on this thread later, but a few questions: > >> > >> Do we know if the application in question is multithreaded, and > >> if so, might it be attempting concurrent operations on this socket? > > > > I do not know if zabbix-agent is multithreaded, but cf-agent is. > > If in DDB, it would be useful to do a "ps" so we can identify threads in the process, and in particular, whether they might be in the kernel around the moment of the panic. > > > I will follow up with this information as soon as possible. > > Thanks. Do keep around as much information as you can from DDB, crashdumps, etc. A useful set of things to keep from DDB includes the initial panic information and trap frame, "show pcpu", "show allpcpu", "trace", "alltrace", "ps", and if WITNESS is compiled in, "show locks" and "show alllocks". On busy systems, all the backtraces add up to a lot of space, so you might hold onto that rather than e-mail it, but contain useful information. Often, debugging this sort of race condition involves looking at what other network-centred threads are doing -- e.g., device-driver ithreads, netisr, other involved user threads. You may be able to extract much of that information using ps on the crashdump (not sure if procstat is there yet for crashdumps) -- if so, be sure to use -H (or whatever the argument is to print thread, not just process, information). You can also grab my kgdb scripts from www.freebsd.org/~jhb/gdb/ Put those in a dir and do 'source gdb6'. You can then run 'ps' to get a good ps listing that includes threads. You can also use 'thread apply all bt' to get stacktraces of all threads in kgdb. I believe there is an 'allpcpu' command that is similar to 'show allpcpu' in DDB. Robert, in this case he has a full crashdump, so we can get quite a bit of information from it. -- John Baldwin
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201305011430.37106.jhb>