vfs: use READ_ONCE() to access ->i_link
authorEric Biggers <ebiggers@google.com>
Wed, 10 Apr 2019 20:21:14 +0000 (13:21 -0700)
committerTheodore Ts'o <tytso@mit.edu>
Wed, 17 Apr 2019 16:43:14 +0000 (12:43 -0400)
commit4c4f7c19b3c721aed418bc97907b411608c5c6a0
treef277f0ab8ee56d45ad6ae93950645c405ac7f49c
parentb01531db6cec2aa330dbc91bfbfaaef4a0d387a4
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>
fs/namei.c