On Wed, 2 Nov 2005, Badari Pulavarty wrote:
> On Wed, 2005-11-02 at 20:54 +0100, Blaisorblade wrote:
> > > + /* XXX - Do we need both i_sem and i_allocsem all the way ? */
> > > + down(&inode->i_sem);
> > > + down_write(&inode->i_alloc_sem);
> > > + unmap_mapping_range(mapping, offset, (end - offset), 1);
> > In my opinion, as already said, unmap_mapping_range can be called without
> > these two locks, as it operates only on mappings for the file.
> >
> > However currently it's called with these locks held in vmtruncate, but I think
> > the locks are held in that case only because we need to truncate the file,
> > and are hold in excess also across this call.
>
> I agree, I can push down the locking only for ->truncate_range - if
> no one has objections. (But again, it so special case - no one really
> cares about the performance of this interface ?).
I can't remember why i_alloc_sem got introduced, and don't have time to
work it out: something to do with direct I/O races, perhaps? Someone
else must advise, perhaps you will be able to drop that one.
But I think you'd be very unwise to drop i_sem too. i_mmap_lock gets
dropped whenever preemption demands here, i_sem is what's preventing
someone else coming along and doing a concurrent truncate or remove.
You don't want that.
Sorry, I've not yet had time to study your patch: I do intend to,
but cannot promise when. I fear it won't be as easy as making
these occasional responses.
Hugh
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]