diff options
author | Chao Yu <chao2.yu@samsung.com> | 2013-10-29 02:17:05 -0400 |
---|---|---|
committer | Jaegeuk Kim <jaegeuk.kim@samsung.com> | 2013-10-29 02:56:08 -0400 |
commit | cc3de6a3acce264f4eb0b5bf552478e5f1380bba (patch) | |
tree | 99923af99c4fa2a89ca2affa9786e1f72915601e | |
parent | 5d56b6718a0f4e5c58cdd3cb6b7a472d7c5671b9 (diff) |
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: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
-rw-r--r-- | fs/f2fs/xattr.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/f2fs/xattr.c b/fs/f2fs/xattr.c index 89d506d0b35d..aa7a3f139fe5 100644 --- a/fs/f2fs/xattr.c +++ b/fs/f2fs/xattr.c | |||
@@ -520,7 +520,7 @@ static int __f2fs_setxattr(struct inode *inode, int name_index, | |||
520 | */ | 520 | */ |
521 | free = MIN_OFFSET(inode) - ((char *)last - (char *)base_addr); | 521 | free = MIN_OFFSET(inode) - ((char *)last - (char *)base_addr); |
522 | if (found) | 522 | if (found) |
523 | free = free - ENTRY_SIZE(here); | 523 | free = free + ENTRY_SIZE(here); |
524 | 524 | ||
525 | if (free < newsize) { | 525 | if (free < newsize) { |
526 | error = -ENOSPC; | 526 | error = -ENOSPC; |