|
@@ -785,9 +785,11 @@ void update_dirty_page(struct inode *inode, struct page *page)
|
|
!S_ISLNK(inode->i_mode))
|
|
!S_ISLNK(inode->i_mode))
|
|
return;
|
|
return;
|
|
|
|
|
|
- spin_lock(&sbi->inode_lock[type]);
|
|
|
|
- __add_dirty_inode(inode, type);
|
|
|
|
- spin_unlock(&sbi->inode_lock[type]);
|
|
|
|
|
|
+ if (type != FILE_INODE || test_opt(sbi, DATA_FLUSH)) {
|
|
|
|
+ spin_lock(&sbi->inode_lock[type]);
|
|
|
|
+ __add_dirty_inode(inode, type);
|
|
|
|
+ spin_unlock(&sbi->inode_lock[type]);
|
|
|
|
+ }
|
|
|
|
|
|
inode_inc_dirty_pages(inode);
|
|
inode_inc_dirty_pages(inode);
|
|
SetPagePrivate(page);
|
|
SetPagePrivate(page);
|
|
@@ -803,6 +805,9 @@ void remove_dirty_inode(struct inode *inode)
|
|
!S_ISLNK(inode->i_mode))
|
|
!S_ISLNK(inode->i_mode))
|
|
return;
|
|
return;
|
|
|
|
|
|
|
|
+ if (type == FILE_INODE && !test_opt(sbi, DATA_FLUSH))
|
|
|
|
+ return;
|
|
|
|
+
|
|
spin_lock(&sbi->inode_lock[type]);
|
|
spin_lock(&sbi->inode_lock[type]);
|
|
__remove_dirty_inode(inode, type);
|
|
__remove_dirty_inode(inode, type);
|
|
spin_unlock(&sbi->inode_lock[type]);
|
|
spin_unlock(&sbi->inode_lock[type]);
|