* [PATCH] f2fs: fix to convert inline inode in ->setattr @ 2015-12-01 3:36 Chao Yu 2015-12-04 20:55 ` Jaegeuk Kim 0 siblings, 1 reply; 3+ messages in thread From: Chao Yu @ 2015-12-01 3:36 UTC (permalink / raw) To: Jaegeuk Kim; +Cc: linux-kernel, linux-f2fs-devel In commit 3c4541452748 ("f2fs: do not trim preallocated blocks when truncating after i_size"), in order to follow the regulation: "truncate(x) where x > i_size will not trim all blocks past i_size." like other file systems, in ->setattr we invoked truncate_setsize instead of f2fs_truncate to avoid unneeded block trimming in such case, but forgot to call f2fs_convert_inline_inode keep consistency of inline data conversion rule. This patch fixes to convert inline data if necessary. Signed-off-by: Chao Yu <chao2.yu@samsung.com> --- fs/f2fs/file.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c index 96e4e04..a018ed3 100644 --- a/fs/f2fs/file.c +++ b/fs/f2fs/file.c @@ -686,6 +686,14 @@ int f2fs_setattr(struct dentry *dentry, struct iattr *attr) * larger than i_size. */ truncate_setsize(inode, attr->ia_size); + + /* should convert inline inode here */ + if (f2fs_has_inline_data(inode) && + !f2fs_may_inline_data(inode)) { + err = f2fs_convert_inline_inode(inode); + if (err) + return err; + } inode->i_mtime = inode->i_ctime = CURRENT_TIME; } } -- 2.6.3 ------------------------------------------------------------------------------ Go from Idea to Many App Stores Faster with Intel(R) XDK Give your users amazing mobile app experiences with Intel(R) XDK. Use one codebase in this all-in-one HTML5 development environment. Design, debug & build mobile apps & 2D/3D high-impact games for multiple OSs. http://pubads.g.doubleclick.net/gampad/clk?id=254741911&iu=/4140 ^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] f2fs: fix to convert inline inode in ->setattr 2015-12-01 3:36 [PATCH] f2fs: fix to convert inline inode in ->setattr Chao Yu @ 2015-12-04 20:55 ` Jaegeuk Kim 2015-12-04 21:18 ` [f2fs-dev] " Jaegeuk Kim 0 siblings, 1 reply; 3+ messages in thread From: Jaegeuk Kim @ 2015-12-04 20:55 UTC (permalink / raw) To: Chao Yu; +Cc: linux-kernel, linux-f2fs-devel Hi Chao, On Tue, Dec 01, 2015 at 11:36:16AM +0800, Chao Yu wrote: > In commit 3c4541452748 ("f2fs: do not trim preallocated blocks when > truncating after i_size"), in order to follow the regulation: "truncate(x) > where x > i_size will not trim all blocks past i_size." like other file > systems, in ->setattr we invoked truncate_setsize instead of f2fs_truncate > to avoid unneeded block trimming in such case, but forgot to call > f2fs_convert_inline_inode keep consistency of inline data conversion rule. > > This patch fixes to convert inline data if necessary. > > Signed-off-by: Chao Yu <chao2.yu@samsung.com> > --- > fs/f2fs/file.c | 8 ++++++++ > 1 file changed, 8 insertions(+) > > diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c > index 96e4e04..a018ed3 100644 > --- a/fs/f2fs/file.c > +++ b/fs/f2fs/file.c > @@ -686,6 +686,14 @@ int f2fs_setattr(struct dentry *dentry, struct iattr *attr) > * larger than i_size. > */ > truncate_setsize(inode, attr->ia_size); > + > + /* should convert inline inode here */ > + if (f2fs_has_inline_data(inode) && > + !f2fs_may_inline_data(inode)) { > + err = f2fs_convert_inline_inode(inode); > + if (err) > + return err; > + } Without this, f2fs handles correctly inline_data when user tries to write something later, right? One corner case is: if the partiton is filled up to 100% with data + inline_data, we cannot truncate one of inline_data after merging this patch. Cause it failed to convert it. Thanks, > inode->i_mtime = inode->i_ctime = CURRENT_TIME; > } > } > -- > 2.6.3 > ------------------------------------------------------------------------------ Go from Idea to Many App Stores Faster with Intel(R) XDK Give your users amazing mobile app experiences with Intel(R) XDK. Use one codebase in this all-in-one HTML5 development environment. Design, debug & build mobile apps & 2D/3D high-impact games for multiple OSs. http://pubads.g.doubleclick.net/gampad/clk?id=254741911&iu=/4140 ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [f2fs-dev] [PATCH] f2fs: fix to convert inline inode in ->setattr 2015-12-04 20:55 ` Jaegeuk Kim @ 2015-12-04 21:18 ` Jaegeuk Kim 0 siblings, 0 replies; 3+ messages in thread From: Jaegeuk Kim @ 2015-12-04 21:18 UTC (permalink / raw) To: Chao Yu; +Cc: linux-kernel, linux-f2fs-devel On Fri, Dec 04, 2015 at 12:55:23PM -0800, Jaegeuk Kim wrote: > Hi Chao, > > On Tue, Dec 01, 2015 at 11:36:16AM +0800, Chao Yu wrote: > > In commit 3c4541452748 ("f2fs: do not trim preallocated blocks when > > truncating after i_size"), in order to follow the regulation: "truncate(x) > > where x > i_size will not trim all blocks past i_size." like other file > > systems, in ->setattr we invoked truncate_setsize instead of f2fs_truncate > > to avoid unneeded block trimming in such case, but forgot to call > > f2fs_convert_inline_inode keep consistency of inline data conversion rule. > > > > This patch fixes to convert inline data if necessary. > > > > Signed-off-by: Chao Yu <chao2.yu@samsung.com> > > --- > > fs/f2fs/file.c | 8 ++++++++ > > 1 file changed, 8 insertions(+) > > > > diff --git a/fs/f2fs/file.c b/fs/f2fs/file.c > > index 96e4e04..a018ed3 100644 > > --- a/fs/f2fs/file.c > > +++ b/fs/f2fs/file.c > > @@ -686,6 +686,14 @@ int f2fs_setattr(struct dentry *dentry, struct iattr *attr) > > * larger than i_size. > > */ > > truncate_setsize(inode, attr->ia_size); > > + > > + /* should convert inline inode here */ > > + if (f2fs_has_inline_data(inode) && > > + !f2fs_may_inline_data(inode)) { > > + err = f2fs_convert_inline_inode(inode); > > + if (err) > > + return err; > > + } > > Without this, f2fs handles correctly inline_data when user tries to write > something later, right? > > One corner case is: > if the partiton is filled up to 100% with data + inline_data, we cannot truncate > one of inline_data after merging this patch. > Cause it failed to convert it. Oh, it turns out this is due to the error handling -ENOSPC of f2fs_truncate. For now, it seems there is no easy workaround this. Please ignore my concern. ;) Thanks, > > Thanks, > > > inode->i_mtime = inode->i_ctime = CURRENT_TIME; > > } > > } > > -- > > 2.6.3 > > > > ------------------------------------------------------------------------------ > Go from Idea to Many App Stores Faster with Intel(R) XDK > Give your users amazing mobile app experiences with Intel(R) XDK. > Use one codebase in this all-in-one HTML5 development environment. > Design, debug & build mobile apps & 2D/3D high-impact games for multiple OSs. > http://pubads.g.doubleclick.net/gampad/clk?id=254741911&iu=/4140 > _______________________________________________ > Linux-f2fs-devel mailing list > Linux-f2fs-devel@lists.sourceforge.net > https://lists.sourceforge.net/lists/listinfo/linux-f2fs-devel ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2015-12-04 21:18 UTC | newest] Thread overview: 3+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2015-12-01 3:36 [PATCH] f2fs: fix to convert inline inode in ->setattr Chao Yu 2015-12-04 20:55 ` Jaegeuk Kim 2015-12-04 21:18 ` [f2fs-dev] " Jaegeuk Kim
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).