Date: Wed, 12 May 2004 17:54:06 +0200 From: =?ISO-8859-1?Q?S=F8ren_Schmidt?= <sos@DeepCore.dk> To: Scott Long <scottl@freebsd.org> Cc: freebsd-current@freebsd.org Subject: Re: ad0: WARNING - WRITE_DMA interrupt was seen but timeout fired LBA=21267353 Message-ID: <40A2489E.4030008@DeepCore.dk> In-Reply-To: <40A24605.7030908@freebsd.org> References: <20040512145212.62e7db1e@it.buh.cameradicommercio.ro> <Pine.BSF.4.53.0405121431040.66978@e0-0.zab2.int.zabbadoz.net> <40A2387E.1050208@DeepCore.dk> <Pine.BSF.4.53.0405121450320.66978@e0-0.zab2.int.zabbadoz.net> <40A23FEE.3020109@DeepCore.dk> <40A24605.7030908@freebsd.org>
next in thread | previous in thread | raw e-mail | index | archive | help
Scott Long wrote: > Taskqueues work just fine for other drivers. I can't see anything > obviously wrong with your use of the taskqueue (other than what we have > talked about before), though you also use bio_taskqueue(). Looking in > there, it has two additional mutexes that get locked when run. Maybe > there is an LOR or other such problem that is causing the stall. > Running with WITNESS might reveal something. You might also just plain > be missing the interrupt from the drive,, but that is harder to > determine. Well using the bio_taskqueue has made the problem go away on those few situations where I could provoke it, so that is actually a help. I see no LOR's or anything else from witness. I dont miss the interrupt, if you look at the code you will se that I have got the interrupt, read status from the device etc, but its the simple return via the biodone etc thats put on the taskqueue that doesn't get called in time for the timeout to fire... Now the timeout is 5 secs so on a busy machine our lemming syncer can get the disksystem so busy that the first one appears because of that. -- -Søren
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?40A2489E.4030008>