fscrypto: lock inode while setting encryption policy
authorEric Biggers <ebiggers@google.com>
Sat, 15 Oct 2016 13:48:50 +0000 (09:48 -0400)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 22 Mar 2017 11:04:18 +0000 (12:04 +0100)
commit3a19419c50c6ee386ca6d22a23acc2df51583d3d
tree983c5f1b10421ac655ef15533c4efa38f05397ef
parentfd74e8d258da9f9678da6bf88a0b02b2c1b71d0c
fscrypto: lock inode while setting encryption policy

commit 8906a8223ad4909b391c5628f7991ebceda30e52 upstream.

i_rwsem needs to be acquired while setting an encryption policy so that
concurrent calls to FS_IOC_SET_ENCRYPTION_POLICY are correctly
serialized (especially the ->get_context() + ->set_context() pair), and
so that new files cannot be created in the directory during or after the
->empty_dir() check.

Signed-off-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Richard Weinberger <richard@nod.at>
Cc: stable@vger.kernel.org
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/ext4/ioctl.c
fs/f2fs/file.c