Re: [PATCH][RFC] %pd - for printing dentry name

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On Mon, 1 Feb 2010, Al Viro wrote:
> 
> Ehh...  RCU will save you from stepping on freed memory, but it still will
> leave the joy of half-updated string with length out of sync with it, etc.

Sure. But do we care?

Every printk _should_ be on a dentry that we have a reference to, anyway. 
Otherwise, how did we find it?

So yeah, then there is the race with rename(), but (a) it's not going to 
happen, (b) if we race with rename there is no "one" correct solution 
anyway, so (c) what we really want to protect against is the printk 
causing problems (like an oops from DEBUG_PAGEALLOC and freeing the old 
name).

> We probably can get away with that, but we'll have to be a lot more careful
> with the order of updating these suckers in d_move_locked et.al.

I wouldn't worry about it too much. So what if we get a screwed up name? 
If we use "%.*s" to print the name, we know that we won't overstep the old 
name even if the NUL termination somehow went away (because we're busy 
copying a new, longer, name over it or whatever).

So I would not worry too much about sometimes showing a nonsensical name 
that may be the result of a concurrent rename. I'd only worry about it not 
oopsing or stepping on memory that hasn't had _either_ the old or the new 
name in it.

That's why I think an RCU solution should be sufficient..

			Linus
--
To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html

[Index of Archives]     [Linux Ext4 Filesystem]     [Union Filesystem]     [Filesystem Testing]     [Ceph Users]     [Ecryptfs]     [AutoFS]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux Cachefs]     [Reiser Filesystem]     [Linux RAID]     [Samba]     [Device Mapper]     [CEPH Development]
  Powered by Linux