From mboxrd@z Thu Jan 1 00:00:00 1970 Message-ID: <43212A1F.5040202@yahoo.com.au> Date: Fri, 09 Sep 2005 16:22:23 +1000 From: Nick Piggin MIME-Version: 1.0 Subject: Re: [PATCH 2.6.13] lockless pagecache 5/7 References: <4317F071.1070403@yahoo.com.au> <4317F0F9.1080602@yahoo.com.au> <4317F136.4040601@yahoo.com.au> <4317F17F.5050306@yahoo.com.au> <4317F1A2.8030605@yahoo.com.au> <4317F1BD.8060808@yahoo.com.au> In-Reply-To: Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org Return-Path: To: Christoph Lameter Cc: Linux Memory Management , linux-kernel List-ID: Christoph Lameter wrote: > I wonder if it may not be better to use a seqlock for the tree_lock? A > seqlock requires no writes at all if the tree has not been changed. RCU > still requires the incrementing of a (local) counter. > Ah, but the seqlock's write side will cause cacheline bouncing in the readside. Currently the lockless pagecache patches allow IO to be busily populating one part of the cache while readers can look up another part without any cacheline transfers. Presumably you mean rcu_read_lock's preempt_disable(), however this is a noop on non preempt kernels, and will almost certainly be hot in cache in preempt kernels. What's more it should not cause bouncing. > Using seqlocks would require reworking the readers so that they can > retry. Seqlocks provide already a verification that no update took place > while the operation was in process. Thus we would be using an established > framework that insures that the speculation was successful. > > The problem is then though to guarantee that the radix trees are always > traversable since the seqlock's retry rather than block. This would > require sequencing of inserts and pose a big problem for deletes and > updates. > Well the lockless radix tree read side patches (which I have actually updated to fix some bugs and be rebased on top of your nice cleanup) do provide that the radix trees are always traversable. -- SUSE Labs, Novell Inc. Send instant messages to your online friends http://au.messenger.yahoo.com -- 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