fscrypt: use ENOTDIR when setting encryption policy on nondirectory
authorEric Biggers <ebiggers@google.com>
Mon, 5 Dec 2016 19:12:45 +0000 (11:12 -0800)
committerTheodore Ts'o <tytso@mit.edu>
Sat, 31 Dec 2016 21:26:20 +0000 (16:26 -0500)
As part of an effort to clean up fscrypt-related error codes, make
FS_IOC_SET_ENCRYPTION_POLICY fail with ENOTDIR when the file descriptor
does not refer to a directory.  This is more descriptive than EINVAL,
which was ambiguous with some of the other error cases.

I am not aware of any users who might be relying on the previous error
code of EINVAL, which was never documented anywhere, and in some buggy
kernels did not exist at all as the S_ISDIR() check was missing.

This failure case will be exercised by an xfstest.

Signed-off-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
fs/crypto/policy.c

index d6cd7ea4851da877b13c7af306fd07f8468a54f4..40ecd7173e3479531752663db7473521d5013536 100644 (file)
@@ -116,7 +116,7 @@ int fscrypt_ioctl_set_policy(struct file *filp, const void __user *arg)
 
        if (!inode_has_encryption_context(inode)) {
                if (!S_ISDIR(inode->i_mode))
-                       ret = -EINVAL;
+                       ret = -ENOTDIR;
                else if (!inode->i_sb->s_cop->empty_dir)
                        ret = -EOPNOTSUPP;
                else if (!inode->i_sb->s_cop->empty_dir(inode))