ext4: atomically set inode->i_flags in ext4_set_inode_flags()
authorTheodore Ts'o <tytso@mit.edu>
Sun, 30 Mar 2014 14:20:01 +0000 (10:20 -0400)
committerJiri Slaby <jslaby@suse.cz>
Thu, 3 Apr 2014 08:32:22 +0000 (10:32 +0200)
commit710e5cbeeb6869bb0f1227ce3cba7374449fdeb4
treee15ae61f7896f560ac39e0bac2073e8fdca64cd7
parentf01b3751f964df3266ed9e52b1676ff52a91b60f
ext4: atomically set inode->i_flags in ext4_set_inode_flags()

commit 00a1a053ebe5febcfc2ec498bd894f035ad2aa06 upstream.

Use cmpxchg() to atomically set i_flags instead of clearing out the
S_IMMUTABLE, S_APPEND, etc. flags and then setting them from the
EXT4_IMMUTABLE_FL, EXT4_APPEND_FL flags, since this opens up a race
where an immutable file has the immutable flag cleared for a brief
window of time.

Reported-by: John Sullivan <jsrhbz@kanargh.force9.co.uk>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
fs/ext4/inode.c
include/linux/bitops.h