diff options
author | Eric Biggers <ebiggers@google.com> | 2019-04-10 22:21:14 +0200 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2019-04-17 18:43:14 +0200 |
commit | 4c4f7c19b3c721aed418bc97907b411608c5c6a0 (patch) | |
tree | f277f0ab8ee56d45ad6ae93950645c405ac7f49c /fs/ext4 | |
parent | fscrypt: fix race where ->lookup() marks plaintext dentry as ciphertext (diff) | |
download | linux-4c4f7c19b3c721aed418bc97907b411608c5c6a0.tar.xz linux-4c4f7c19b3c721aed418bc97907b411608c5c6a0.zip |
vfs: use READ_ONCE() to access ->i_link
Use 'READ_ONCE(inode->i_link)' to explicitly support filesystems caching
the symlink target in ->i_link later if it was unavailable at iget()
time, or wasn't easily available. I'll be doing this in fscrypt, to
improve the performance of encrypted symlinks on ext4, f2fs, and ubifs.
->i_link will start NULL and may later be set to a non-NULL value by a
smp_store_release() or cmpxchg_release(). READ_ONCE() is needed on the
read side. smp_load_acquire() is unnecessary because only a data
dependency barrier is required. (Thanks to Al for pointing this out.)
Acked-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Diffstat (limited to 'fs/ext4')
0 files changed, 0 insertions, 0 deletions