Re: RFC: Block reservation for hugetlbfs
From: Nick Piggin
Date: Wed Feb 22 2006 - 00:22:35 EST
David Gibson wrote:
On Wed, Feb 22, 2006 at 11:38:42AM +1100, Nick Piggin wrote:
David Gibson wrote:
On Tue, Feb 21, 2006 at 03:18:59PM +1100, Nick Piggin wrote:
This introduces
tree_lock(r) -> hugetlb_lock
And we already have
hugetlb_lock -> lru_lock
So we now have tree_lock(r) -> lru_lock, which would deadlock
against lru_lock -> tree_lock(w), right?
From a quick glance it looks safe, but I'd _really_ rather not
introduce something like this.
Urg.. good point. I hadn't even thought of that consequence - I was
more worried about whether I need i_lock or i_mutex to protect my
updates to i_blocks.
Would hugetlb_lock -> tree_lock(r) be any preferable (I think that's a
possible alternative).
Yes I think that should avoid the introduction of new lock dependency.
Err... "Yes" appears to contradict the rest of you statement, since my
suggestion would still introduce a lock dependency, just a different
one one. It is not at all obvious to me how to avoid a lock
dependency entirely.
I mean a new core mm lock depenency (ie. lru_lock -> tree_lock).
But I must have been smoking something last night: for the life
of me I can't see why I thought there was already a hugetlb_lock
-> lru_lock dependency in there...?!
So I retract my statement. What you have there seems OK.
Also, any thoughts on whether I need i_lock or i_mutex or something
else would be handy..
I'm not much of an fs guy. How come you don't use i_size?
--
SUSE Labs, Novell Inc.
Send instant messages to your online friends http://au.messenger.yahoo.com
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/