Commit ba276ce5 authored by Kent Overstreet's avatar Kent Overstreet

bcachefs: Fix missing locking for dentry->d_parent access

Reported-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 61b85cb0
...@@ -552,6 +552,14 @@ static int bch2_xattr_bcachefs_set(const struct xattr_handler *handler, ...@@ -552,6 +552,14 @@ static int bch2_xattr_bcachefs_set(const struct xattr_handler *handler,
s.v = v + 1; s.v = v + 1;
s.defined = true; s.defined = true;
} else { } else {
/*
* Check if this option was set on the parent - if so, switched
* back to inheriting from the parent:
*
* rename() also has to deal with keeping inherited options up
* to date - see bch2_reinherit_attrs()
*/
spin_lock(&dentry->d_lock);
if (!IS_ROOT(dentry)) { if (!IS_ROOT(dentry)) {
struct bch_inode_info *dir = struct bch_inode_info *dir =
to_bch_ei(d_inode(dentry->d_parent)); to_bch_ei(d_inode(dentry->d_parent));
...@@ -560,6 +568,7 @@ static int bch2_xattr_bcachefs_set(const struct xattr_handler *handler, ...@@ -560,6 +568,7 @@ static int bch2_xattr_bcachefs_set(const struct xattr_handler *handler,
} else { } else {
s.v = 0; s.v = 0;
} }
spin_unlock(&dentry->d_lock);
s.defined = false; s.defined = false;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment