NTFS: Add a missing call to flush_dcache_mft_record_page() in
authorAnton Altaparmakov <aia21@cantab.net>
Thu, 23 Mar 2006 16:21:02 +0000 (16:21 +0000)
committerAnton Altaparmakov <aia21@cantab.net>
Thu, 23 Mar 2006 16:21:02 +0000 (16:21 +0000)
      fs/ntfs/inode.c::ntfs_write_inode().

Signed-off-by: Anton Altaparmakov <aia21@cantab.net>
fs/ntfs/ChangeLog
fs/ntfs/inode.c

index 5fb74e62f535088207ab0ce4611934d7e468e6cd..d20031587bbb5e2fa9d55e5cea41797d69760d79 100644 (file)
@@ -41,6 +41,8 @@ ToDo/Notes:
        - Fix a bug in fs/ntfs/inode.c::ntfs_read_locked_index_inode() where we
          forgot to update a temporary variable so loading index inodes which
          have an index allocation attribute failed.
+       - Add a missing call to flush_dcache_mft_record_page() in
+         fs/ntfs/inode.c::ntfs_write_inode().
 
 2.1.26 - Minor bug fixes and updates.
 
index 5f4b23d213b9f5451bee90fcc44ce8c567ce0086..73791b2d9495118315fc5559ccb905b2732c3487 100644 (file)
@@ -3064,9 +3064,12 @@ int ntfs_write_inode(struct inode *vi, int sync)
         * record will be cleaned and written out to disk below, i.e. before
         * this function returns.
         */
-       if (modified && !NInoTestSetDirty(ctx->ntfs_ino))
-               mark_ntfs_record_dirty(ctx->ntfs_ino->page,
-                               ctx->ntfs_ino->page_ofs);
+       if (modified) {
+               flush_dcache_mft_record_page(ctx->ntfs_ino);
+               if (!NInoTestSetDirty(ctx->ntfs_ino)) {
+                       mark_ntfs_record_dirty(ctx->ntfs_ino->page,
+                                       ctx->ntfs_ino->page_ofs);
+       }
        ntfs_attr_put_search_ctx(ctx);
        /* Now the access times are updated, write the base mft record. */
        if (NInoDirty(ni))