From mboxrd@z Thu Jan 1 00:00:00 1970 Date: Fri, 2 Mar 2007 06:49:44 +0100 From: Nick Piggin Subject: Re: The performance and behaviour of the anti-fragmentation related patches Message-ID: <20070302054944.GE15867@wotan.suse.de> References: <20070301101249.GA29351@skynet.ie> <20070301160915.6da876c5.akpm@linux-foundation.org> <20070302035751.GA15867@wotan.suse.de> <20070302042149.GB15867@wotan.suse.de> <20070302050625.GD15867@wotan.suse.de> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: owner-linux-mm@kvack.org Return-Path: To: Christoph Lameter Cc: Andrew Morton , Mel Gorman , mingo@elte.hu, jschopp@austin.ibm.com, arjan@infradead.org, torvalds@linux-foundation.org, mbligh@mbligh.org, linux-mm@kvack.org, linux-kernel@vger.kernel.org List-ID: On Thu, Mar 01, 2007 at 09:40:45PM -0800, Christoph Lameter wrote: > On Fri, 2 Mar 2007, Nick Piggin wrote: > > > So what do you mean by efficient? I guess you aren't talking about CPU > > efficiency, because even if you make the IO subsystem submit larger > > physical IOs, you still have to deal with 256 billion TLB entries, the > > pagecache has to deal with 256 billion struct pages, so does the > > filesystem code to build the bios. > > You do not have to deal with TLB entries if you do buffered I/O. Where does the data come from? > For mmapped I/O you would want to transparently use 2M TLBs if the > page size is large. > > > So you are having problems with your IO controller's handling of sg > > lists? > > We currently have problems with the kernel limits of 128 SG > entries but the fundamental issue is that we can only do 2 Meg of I/O in > one go given the default limits of the block layer. Typically the number > of hardware SG entrie is also limited. We never will be able to put a Seems like changing the default limits would be the easiest way to fix it then? As far as hardware limits go, I don't think you need to scale that number linearly with the amount of memory you have, or even with the IO throughput. You should reach a point where your command overhead is amortised sufficiently, and the controller will be pipelining the commands. -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@kvack.org. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: email@kvack.org