Hi,

On Mon, Jan 04, 2016 at 07:13:43PM +0800, Fan Li wrote:
> 
> 
> > -----Original Message-----
> > From: Jaegeuk Kim [mailto:jaeg...@kernel.org]
> > Sent: Monday, January 04, 2016 2:56 PM
> > To: Fan Li
> > Cc: 'Chao Yu'; linux-f2fs-devel@lists.sourceforge.net
> > Subject: Re: [f2fs-dev] [PATCH 2/3] f2fs: support finding extents after 
> > isize
> > 
> > Hello,
> > 
> > On Mon, Jan 04, 2016 at 01:57:27PM +0800, Fan Li wrote:
> > >
> > >
> > > > -----Original Message-----
> > > > From: Chao Yu [mailto:chao2...@samsung.com]
> > > > Sent: Thursday, December 31, 2015 2:34 PM
> > > > To: 'Fan Li'; 'Jaegeuk Kim'
> > > > Cc: linux-f2fs-devel@lists.sourceforge.net
> > > > Subject: RE: [f2fs-dev] [PATCH 2/3] f2fs: support finding extents
> > > > after isize
> > > >
> > > > > -----Original Message-----
> > > > > From: Fan Li [mailto:fanofcode...@samsung.com]
> > > > > Sent: Thursday, December 31, 2015 11:37 AM
> > > > > To: 'Chao Yu'; 'Jaegeuk Kim'
> > > > > Cc: linux-f2fs-devel@lists.sourceforge.net
> > > > > Subject: Re: [f2fs-dev] [PATCH 2/3] f2fs: support finding extents
> > > > > after isize
> > > > >
> > > > >
> > > > >
> > > > > > -----Original Message-----
> > > > > > From: Chao Yu [mailto:c...@kernel.org]
> > > > > > Sent: Wednesday, December 30, 2015 9:28 PM
> > > > > > To: Fan Li; 'Jaegeuk Kim'
> > > > > > Cc: linux-f2fs-devel@lists.sourceforge.net
> > > > > > Subject: Re: [f2fs-dev] [PATCH 2/3] f2fs: support finding
> > > > > > extents after isize
> > > > > >
> > > > > > Hi,
> > > > > >
> > > > > > On 12/30/15 5:17 PM, Fan Li wrote:
> > > > > > > f2fs allows preallocation beyond isize, but f2fs_fiemap only
> > > > > > > look up extents within isize. Therefore add this support.
> > > > > > >
> > > > > > > Note: It's possible that there are holes after isize, for
> > > > > > > example, fallocate  multiple discontinuous extents after isize
> > > > > > > with FALLOC_FL_KEEP_SIZE set. Since I can tell no differences
> > > > > > > between EOF and holes from return of get_data_block, I'm afaid
> > > > > > > this patch can't support such scenarios.
> > > > > >
> > > > > > As you mentioned, preallocated block beyond isize can be
> > > > > > allocated in f2fs, and we are trying
> > > > > to support mapping extents across
> > > > > > whole data space of inode, so why we treat theses extents inside
> > > > > > i_size and outside i_size
> > > > > separately? IMO, instead using i_size, we
> > > > > > should use max blocks as boundary.
> > > > > >
> > > > > > Most important, this interface still can't support finding all
> > > > > > extents after i_size, which
> > > > > looks buggy for our user.
> > > > >
> > > > > Notice that this issue exists before my patch, by adding this
> > > > > patch, at least now it can support more scenarios such as
> > > > > fallocate a range right after isize. I'd say it's an improvement.
> > > >
> > > > Nope, what I'm talking about is *correctness* of our ->fiemap
> > > > interface, but you're trying to avoid it by saying "support more
> > > cases,
> > > > it's an improvement". That doesn't make any sense to me, since 
> > > > correctness issue still not be fixed.
> > >
> > > I'm not sure what you mean by avoiding, I think the comment and reply
> > > I written has already stated the issue and limitation of this patch.
> > > Now there are two suggestions:
> > > 1. support one more scenario, and all old scenarios are dealt like
> > > before, but it still can't support discontinuous extent after isize.
> > > 2. support all scenarios, but sacrifice performance for lots of common 
> > > scenarios by checking about 10^9 blocks.
> > 
> > IMO, we can think about #2 whether there is an efficient way.
> > 
> > How many cases does this incur?
> > One is fallocate with keeping i_size, ana other?
> > 
> > How about adding FADVISE_OVER_ISIZE to represent inode has blocks beyond 
> > i_size?
> > Then, we can set this flag in fallocate and reset it in f2fs_truncate.
> 
> I have a similar idea that add an actual size which marks the end of last 
> extent, so we can 
> know if the current extent is the last one, even without searching for 
> extents behind.

Where do you want to store that size in disk?

> But there is a problem I still can't figure out,  after truncate an extent at 
> the end of file
> beyond isize , how do I know where the new last extent ends or if there are 
> still extents
> beyond isize? after all, the extents beyond isize could be discontinuous.

So, that's why I proposed a flag instead of a kind of i_disksize.
We can just set the flag, only if a file *may* have a extent beyond i_size
in fallocate, and unset it through f2fs_truncate.
Moreover, I don't expect that this happens so frequently.

Thanks,

> 
> > 
> > Thanks,
> > 

------------------------------------------------------------------------------
_______________________________________________
Linux-f2fs-devel mailing list
Linux-f2fs-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel

Reply via email to