Skip to content

Commit

Permalink
vfs, freeze: use ACCESS_ONCE() to guard access to ->mnt_flags
Browse files Browse the repository at this point in the history
The compiler may optimize the while loop and make the check just be done once,
so we should use ACCESS_ONCE() to guard access to ->mnt_flags

Signed-off-by: Miao Xie <[email protected]>
Signed-off-by: Al Viro <[email protected]>
  • Loading branch information
Miao Xie authored and Al Viro committed Dec 20, 2012
1 parent f01af9f commit 1e75529
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion fs/namespace.c
Original file line number Diff line number Diff line change
Expand Up @@ -313,7 +313,7 @@ int __mnt_want_write(struct vfsmount *m)
* incremented count after it has set MNT_WRITE_HOLD.
*/
smp_mb();
while (mnt->mnt.mnt_flags & MNT_WRITE_HOLD)
while (ACCESS_ONCE(mnt->mnt.mnt_flags) & MNT_WRITE_HOLD)
cpu_relax();
/*
* After the slowpath clears MNT_WRITE_HOLD, mnt_is_readonly will
Expand Down

0 comments on commit 1e75529

Please sign in to comment.