Commit cc3de6a3 authored by Chao Yu's avatar Chao Yu Committed by Jaegeuk Kim

f2fs: fix calculating incorrect free size when update xattr in __f2fs_setxattr

During xattr updating, free size should be corrected to remainder free size
+ old entry size.
It can avoid ENOSPC error when we update old entry with the same size new
entry at fully filled xattr.
Signed-off-by: default avatarChao Yu <chao2.yu@samsung.com>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk.kim@samsung.com>
parent 5d56b671
...@@ -520,7 +520,7 @@ static int __f2fs_setxattr(struct inode *inode, int name_index, ...@@ -520,7 +520,7 @@ static int __f2fs_setxattr(struct inode *inode, int name_index,
*/ */
free = MIN_OFFSET(inode) - ((char *)last - (char *)base_addr); free = MIN_OFFSET(inode) - ((char *)last - (char *)base_addr);
if (found) if (found)
free = free - ENTRY_SIZE(here); free = free + ENTRY_SIZE(here);
if (free < newsize) { if (free < newsize) {
error = -ENOSPC; error = -ENOSPC;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment