From owner-freebsd-hackers@FreeBSD.ORG Sun Jan 1 22:48:24 2006 Return-Path: X-Original-To: freebsd-hackers@freebsd.org Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 101E216A420; Sun, 1 Jan 2006 22:48:24 +0000 (GMT) (envelope-from a.pirko@inode.at) Received: from smartmx-04.inode.at (smartmx-04.inode.at [213.229.60.36]) by mx1.FreeBSD.org (Postfix) with ESMTP id 87AA943D62; Sun, 1 Jan 2006 22:48:20 +0000 (GMT) (envelope-from a.pirko@inode.at) Received: from [85.124.24.193] (port=58728 helo=[192.168.1.11]) by smartmx-04.inode.at with esmtp (Exim 4.50) id 1EtBzv-0001EA-NC; Sun, 01 Jan 2006 23:48:19 +0100 Message-ID: <43B85C33.90000@inode.at> Date: Sun, 01 Jan 2006 23:48:19 +0100 From: Armin Pirkovitsch User-Agent: Mozilla Thunderbird 1.0.7 (X11/20051204) X-Accept-Language: en-us, en MIME-Version: 1.0 To: Robert Watson References: <43B6C134.6060802@inode.at> <20060101163522.Y74401@fledge.watson.org> In-Reply-To: <20060101163522.Y74401@fledge.watson.org> Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Cc: freebsd-hackers@freebsd.org Subject: Re: Deadlock FreeBSD 6 / 7 X-BeenThere: freebsd-hackers@freebsd.org X-Mailman-Version: 2.1.5 Precedence: list List-Id: Technical Discussions relating to FreeBSD List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Sun, 01 Jan 2006 22:48:24 -0000 Robert Watson wrote: > > On Sat, 31 Dec 2005, Armin Pirkovitsch wrote: > >> I have some troubles with my notebook and any version of FreeBSD >> (starting with 6 since my sata controller wasn't supported earlier). >> It looks like as it would end up in a deadlock which means i have no >> access to the debugger nor to any other kind of tracing methods. Even >> with KTR, WITTNESS and DIAGNOSTIC enabled in the kerenl I get no >> message what went wrong or what might have caused the trouble. These >> fullstops always turn up when i compile and install programs (or >> sometimes during the installation of FreeBSD itself) Hardware: Intel >> Pentium-M 760 (Centrino, 2GHz) VIA VT 6421 SATA Controller 80GB >> Samsung SATA HD >> >> I guess one of those parts creates the trouble, but I have no idea how >> to trace it... Is there a way to run the whole thing in some kind of >> debugger? Or is there a diffrent way to locate the problem? > > > The usual first step to debug a deadlock, if WITNESS or INVARIANTS > doesn't trigger dropping you into the debugger, is to break into the > debugger using a console or serial break. To do this, you need to compile: > > options BREAK_TO_DEBUGGER > options DDB > > into your kernel. On syscons (not in X11), you can hit Ctrl-Alt-Escape > to try to get to the debugger, or send a serial break. The serial break > is often more reliable, and the nice thing about running DDB on a serial > console from a second machine is that you can easily copy/paste debug > output. Once you're in the debugger, you can list the threads, locks > held, trace stacks, and so on. > > If you can't get into the debugger using a serial break, then usually > the next thing you have to try is using an NMI. Unfortunately, most > hardware doesn't ship with an NMI button, although some server hardware > vendors now provide them. In the vast majority of cases, a serial break > will get to the debugger, and in many cases, so will a console break. I added options BREAK_TO_DEBUGGER and used make buildkernel and make installkernel.debug and was not able to reconstruct the crash. I guess the debug stuff slowed it down enough to not come to the bug... (even installworld worked fine, which usually kills it) So this is what I feared - the debug stuff changes the timing by slowing it down which makes it pretty hard to reconstruct the crash... Is there any other way? (btw. it's a notebook, so there is no old serial bus) -- Armin Pirkovitsch a.pirko@inode.at