On Mon, Feb 06, 2006 at 12:25:22PM -0700, Dan Williams (dan.j.williams@xxxxxxxxx) wrote: > On 2/5/06, Neil Brown <neilb@xxxxxxx> wrote: > > I've looked through the patches - not exhaustively, but hopefully > > enough to get a general idea of what is happening. > > There are some things I'm not clear on and some things that I could > > suggest alternates too... > > I have a few questions to check that I understand your suggestions. > > > - Each ADMA client (e.g. a raid5 array) gets a dedicated adma thread > > to handle all its requests. And it handles them all in series. I > > wonder if this is really optimal. If there are multiple adma > > engines, then a single client could only make use of one of them > > reliably. > > It would seem to make more sense to have just one thread - or maybe > > one per processor or one per adma engine - and have any ordering > > between requests made explicit in the interface. > > > > Actually as each processor could be seen as an ADMA engine, maybe > > you want one thread per processor AND one per engine. If there are > > no engines, the per-processor threads run with high priority, else > > with low. > > ...so the engine thread would handle explicit client requested > ordering constraints and then hand the operations off to per processor > worker threads in the "pio" case or queue directly to hardware in the > presence of such an engine. In md_thread you talk about priority > inversion deadlocks, do those same concerns apply here? Just for reference: the more threads you have, the less stable your system is. Ping-ponging work between several completely independent entities is always a bad idea. Even completion of the request postponed to workqueue from current execution unit introduces noticeble latencies. System should be able to process as much as possible of it's work in one flow. > Dan -- Evgeniy Polyakov - To unsubscribe from this list: send the line "unsubscribe linux-raid" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html