f2fs: sync f2fs_lookup() with ext4_lookup()
As for ext4, now that fscrypt_has_permitted_context() correctly handles the case where we have the key for the parent directory but not the child, f2fs_lookup() no longer has to work around it. Also add the same warning message that ext4 uses. Signed-off-by: Eric Biggers <ebiggers@google.com> Signed-off-by: Theodore Ts'o <tytso@mit.edu>
This commit is contained in:
parent
8c68084bff
commit
faac7fd97e
|
@ -324,9 +324,10 @@ static struct dentry *f2fs_lookup(struct inode *dir, struct dentry *dentry,
|
||||||
if (f2fs_encrypted_inode(dir) &&
|
if (f2fs_encrypted_inode(dir) &&
|
||||||
(S_ISDIR(inode->i_mode) || S_ISLNK(inode->i_mode)) &&
|
(S_ISDIR(inode->i_mode) || S_ISLNK(inode->i_mode)) &&
|
||||||
!fscrypt_has_permitted_context(dir, inode)) {
|
!fscrypt_has_permitted_context(dir, inode)) {
|
||||||
bool nokey = f2fs_encrypted_inode(inode) &&
|
f2fs_msg(inode->i_sb, KERN_WARNING,
|
||||||
!fscrypt_has_encryption_key(inode);
|
"Inconsistent encryption contexts: %lu/%lu",
|
||||||
err = nokey ? -ENOKEY : -EPERM;
|
dir->i_ino, inode->i_ino);
|
||||||
|
err = -EPERM;
|
||||||
goto err_out;
|
goto err_out;
|
||||||
}
|
}
|
||||||
return d_splice_alias(inode, dentry);
|
return d_splice_alias(inode, dentry);
|
||||||
|
|
Loading…
Reference in New Issue