Skip site navigation (1)Skip section navigation (2)
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>