Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S261939AbUCSIjh (ORCPT ); Fri, 19 Mar 2004 03:39:37 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S261915AbUCSIjh (ORCPT ); Fri, 19 Mar 2004 03:39:37 -0500 Received: from fw.osdl.org ([65.172.181.6]:18884 "EHLO mail.osdl.org") by vger.kernel.org with ESMTP id S261939AbUCSIjf (ORCPT ); Fri, 19 Mar 2004 03:39:35 -0500 Date: Fri, 19 Mar 2004 00:39:37 -0800 From: Andrew Morton To: Jens Axboe Cc: markw@osdl.org, linux-kernel@vger.kernel.org Subject: Re: 2.6.4-mm2 Message-Id: <20040319003937.41b9ede4.akpm@osdl.org> In-Reply-To: <20040319083125.GE22234@suse.de> References: <20040314172809.31bd72f7.akpm@osdl.org> <200403181737.i2IHbCE09261@mail.osdl.org> <20040318100615.7f2943ea.akpm@osdl.org> <20040318192707.GV22234@suse.de> <20040318191530.34e04cb2.akpm@osdl.org> <20040319073919.GY22234@suse.de> <20040318235200.25c376a9.akpm@osdl.org> <20040319075704.GD22234@suse.de> <20040319001921.269380a3.akpm@osdl.org> <20040319083125.GE22234@suse.de> X-Mailer: Sylpheed version 0.9.7 (GTK+ 1.2.10; i386-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2416 Lines: 50 Jens Axboe wrote: > > On Fri, Mar 19 2004, Andrew Morton wrote: > > Jens Axboe wrote: > > > > > > > Is it not the case that two dm maps can refer to the same queue? Say, one > > > > map uses /dev/hda1 and another map uses /dev/hda2? > > > > > > > > If so, then when the /dev/hda queue is plugged we need to tell both the > > > > higher-level maps that this queue needs an unplug. So blk_plug_device() > > > > and the various unplug functions need to perform upcalls to an arbitrary > > > > number of higher-level drivers, and those drivers need to keep track of the > > > > currently-plugged queues without adding data structures to the > > > > request_queue structure. > > > > > > > > It can be done of course, but could get messy. > > > > > > That would get nasty, it's much more natural to track it from the other > > > end. I view it as a dm (or whatever problem) that they need to track who > > > has pending io on their behalf, which is pretty easy to to from eg > > > __map_bio(). > > > > But dm doesn't know enough. Suppose it is managing a map which includes > > /dev/hda1 and I do some I/O against /dev/hda2 which plugs the queue. dm > > needs to know about that plug. > > I don't follow at all. If dm initiates io against /dev/hda2, it's part > of that mapped device and it can trigger and note the unplug just fine. Right. But suppose I have a plain old ext2 fs mounted on /dev/hda1. I do some I/O against /dev/hda1, and that causes the /dev/hda queue to be plugged. Device mapper doesn't know that the queue is currently plugged, because it was some totally unrelated piece of code which caused the plug. > > Frankly, I wouldn't bother. 0.5% CPU when hammering the crap out of a > > 56-disk LVM isn't too bad. I'd suggest you first try to simply reduce the > > number of cache misses in the inner loop, see what that leaves us with. > > Yeah I guess you are right, probably not a worry. At least not now, and > the dm folks can always play with the above if they want. > > I'll send you a small update for -mm with the unconditional unplug > killed (at least it cuts it in half) and analyzed the loop. OK... - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/