Commit 745e8490 authored by Jaegeuk Kim's avatar Jaegeuk Kim

f2fs crypto: add missing locking for keyring_key access

This patch adopts:
	ext4 crypto: add missing locking for keyring_key access
Signed-off-by: default avatarTheodore Ts'o <tytso@mit.edu>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent 1dafa51d
...@@ -202,9 +202,11 @@ int _f2fs_get_encryption_info(struct inode *inode) ...@@ -202,9 +202,11 @@ int _f2fs_get_encryption_info(struct inode *inode)
res = -ENOKEY; res = -ENOKEY;
goto out; goto out;
} }
down_read(&keyring_key->sem);
ukp = user_key_payload(keyring_key); ukp = user_key_payload(keyring_key);
if (ukp->datalen != sizeof(struct f2fs_encryption_key)) { if (ukp->datalen != sizeof(struct f2fs_encryption_key)) {
res = -EINVAL; res = -EINVAL;
up_read(&keyring_key->sem);
goto out; goto out;
} }
master_key = (struct f2fs_encryption_key *)ukp->data; master_key = (struct f2fs_encryption_key *)ukp->data;
...@@ -215,10 +217,12 @@ int _f2fs_get_encryption_info(struct inode *inode) ...@@ -215,10 +217,12 @@ int _f2fs_get_encryption_info(struct inode *inode)
"f2fs: key size incorrect: %d\n", "f2fs: key size incorrect: %d\n",
master_key->size); master_key->size);
res = -ENOKEY; res = -ENOKEY;
up_read(&keyring_key->sem);
goto out; goto out;
} }
res = f2fs_derive_key_aes(ctx.nonce, master_key->raw, res = f2fs_derive_key_aes(ctx.nonce, master_key->raw,
raw_key); raw_key);
up_read(&keyring_key->sem);
if (res) if (res)
goto out; goto out;
......
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