mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-11-24 09:30:52 +07:00
btrfs: remove BTRFS_INODE_READDIO_NEED_LOCK
Since we now perform direct reads using i_rwsem, we can remove this inode flag used to co-ordinate unlocked reads. The truncate call takes i_rwsem. This means it is correctly synchronized with concurrent direct reads. Reviewed-by: Nikolay Borisov <nborisov@suse.com> Reviewed-by: Johannes Thumshirn <jth@kernel.org> Reviewed-by: Josef Bacik <josef@toxicpanda.com> Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Goldwyn Rodrigues <rgoldwyn@suse.com> Reviewed-by: David Sterba <dsterba@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
This commit is contained in:
parent
c33fe275b5
commit
e3c57805f8
@ -33,7 +33,6 @@ enum {
|
|||||||
BTRFS_INODE_NEEDS_FULL_SYNC,
|
BTRFS_INODE_NEEDS_FULL_SYNC,
|
||||||
BTRFS_INODE_COPY_EVERYTHING,
|
BTRFS_INODE_COPY_EVERYTHING,
|
||||||
BTRFS_INODE_IN_DELALLOC_LIST,
|
BTRFS_INODE_IN_DELALLOC_LIST,
|
||||||
BTRFS_INODE_READDIO_NEED_LOCK,
|
|
||||||
BTRFS_INODE_HAS_PROPS,
|
BTRFS_INODE_HAS_PROPS,
|
||||||
BTRFS_INODE_SNAPSHOT_FLUSH,
|
BTRFS_INODE_SNAPSHOT_FLUSH,
|
||||||
};
|
};
|
||||||
@ -334,23 +333,6 @@ struct btrfs_dio_private {
|
|||||||
u8 csums[];
|
u8 csums[];
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
|
||||||
* Disable DIO read nolock optimization, so new dio readers will be forced
|
|
||||||
* to grab i_mutex. It is used to avoid the endless truncate due to
|
|
||||||
* nonlocked dio read.
|
|
||||||
*/
|
|
||||||
static inline void btrfs_inode_block_unlocked_dio(struct btrfs_inode *inode)
|
|
||||||
{
|
|
||||||
set_bit(BTRFS_INODE_READDIO_NEED_LOCK, &inode->runtime_flags);
|
|
||||||
smp_mb();
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void btrfs_inode_resume_unlocked_dio(struct btrfs_inode *inode)
|
|
||||||
{
|
|
||||||
smp_mb__before_atomic();
|
|
||||||
clear_bit(BTRFS_INODE_READDIO_NEED_LOCK, &inode->runtime_flags);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Array of bytes with variable length, hexadecimal format 0x1234 */
|
/* Array of bytes with variable length, hexadecimal format 0x1234 */
|
||||||
#define CSUM_FMT "0x%*phN"
|
#define CSUM_FMT "0x%*phN"
|
||||||
#define CSUM_FMT_VALUE(size, bytes) size, bytes
|
#define CSUM_FMT_VALUE(size, bytes) size, bytes
|
||||||
|
@ -4844,10 +4844,7 @@ static int btrfs_setsize(struct inode *inode, struct iattr *attr)
|
|||||||
|
|
||||||
truncate_setsize(inode, newsize);
|
truncate_setsize(inode, newsize);
|
||||||
|
|
||||||
/* Disable nonlocked read DIO to avoid the endless truncate */
|
|
||||||
btrfs_inode_block_unlocked_dio(BTRFS_I(inode));
|
|
||||||
inode_dio_wait(inode);
|
inode_dio_wait(inode);
|
||||||
btrfs_inode_resume_unlocked_dio(BTRFS_I(inode));
|
|
||||||
|
|
||||||
ret = btrfs_truncate(inode, newsize == oldsize);
|
ret = btrfs_truncate(inode, newsize == oldsize);
|
||||||
if (ret && inode->i_nlink) {
|
if (ret && inode->i_nlink) {
|
||||||
|
Loading…
Reference in New Issue
Block a user