diff options
-rw-r--r-- | fs/ext4/inode.c | 2 | ||||
-rw-r--r-- | fs/ext4/mballoc.c | 7 |
2 files changed, 4 insertions, 5 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 34d7e0703cc6..213d1857a7cf 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -391,7 +391,7 @@ void ext4_da_update_reserve_space(struct inode *inode, | |||
391 | * inode's preallocations. | 391 | * inode's preallocations. |
392 | */ | 392 | */ |
393 | if ((ei->i_reserved_data_blocks == 0) && | 393 | if ((ei->i_reserved_data_blocks == 0) && |
394 | (atomic_read(&inode->i_writecount) == 0)) | 394 | !inode_is_open_for_write(inode)) |
395 | ext4_discard_preallocations(inode); | 395 | ext4_discard_preallocations(inode); |
396 | } | 396 | } |
397 | 397 | ||
diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c index e2248083cdca..6fb76d408093 100644 --- a/fs/ext4/mballoc.c +++ b/fs/ext4/mballoc.c | |||
@@ -4176,9 +4176,8 @@ static void ext4_mb_group_or_file(struct ext4_allocation_context *ac) | |||
4176 | isize = (i_size_read(ac->ac_inode) + ac->ac_sb->s_blocksize - 1) | 4176 | isize = (i_size_read(ac->ac_inode) + ac->ac_sb->s_blocksize - 1) |
4177 | >> bsbits; | 4177 | >> bsbits; |
4178 | 4178 | ||
4179 | if ((size == isize) && | 4179 | if ((size == isize) && !ext4_fs_is_busy(sbi) && |
4180 | !ext4_fs_is_busy(sbi) && | 4180 | !inode_is_open_for_write(ac->ac_inode)) { |
4181 | (atomic_read(&ac->ac_inode->i_writecount) == 0)) { | ||
4182 | ac->ac_flags |= EXT4_MB_HINT_NOPREALLOC; | 4181 | ac->ac_flags |= EXT4_MB_HINT_NOPREALLOC; |
4183 | return; | 4182 | return; |
4184 | } | 4183 | } |
@@ -4258,7 +4257,7 @@ ext4_mb_initialize_context(struct ext4_allocation_context *ac, | |||
4258 | (unsigned) ar->goal, ac->ac_flags, ac->ac_2order, | 4257 | (unsigned) ar->goal, ac->ac_flags, ac->ac_2order, |
4259 | (unsigned) ar->lleft, (unsigned) ar->pleft, | 4258 | (unsigned) ar->lleft, (unsigned) ar->pleft, |
4260 | (unsigned) ar->lright, (unsigned) ar->pright, | 4259 | (unsigned) ar->lright, (unsigned) ar->pright, |
4261 | atomic_read(&ar->inode->i_writecount) ? "" : "non-"); | 4260 | inode_is_open_for_write(ar->inode) ? "" : "non-"); |
4262 | return 0; | 4261 | return 0; |
4263 | 4262 | ||
4264 | } | 4263 | } |