Commit 633e804e authored by David Howells's avatar David Howells Committed by James Morris

KEYS: Add an RCU payload dereference macro

Add an RCU payload dereference macro as this seems to be a common piece of code
amongst key types that use RCU referenced payloads.
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
Signed-off-by: default avatarMimi Zohar <zohar@us.ibm.com>
Signed-off-by: default avatarJames Morris <jmorris@namei.org>
parent 1cc26bad
...@@ -275,6 +275,10 @@ static inline key_serial_t key_serial(struct key *key) ...@@ -275,6 +275,10 @@ static inline key_serial_t key_serial(struct key *key)
return key ? key->serial : 0; return key ? key->serial : 0;
} }
#define rcu_dereference_key(KEY) \
(rcu_dereference_protected((KEY)->payload.rcudata, \
rwsem_is_locked(&((struct key *)(KEY))->sem)))
#ifdef CONFIG_SYSCTL #ifdef CONFIG_SYSCTL
extern ctl_table key_sysctls[]; extern ctl_table key_sysctls[];
#endif #endif
......
...@@ -765,8 +765,7 @@ static long encrypted_read(const struct key *key, char __user *buffer, ...@@ -765,8 +765,7 @@ static long encrypted_read(const struct key *key, char __user *buffer,
size_t asciiblob_len; size_t asciiblob_len;
int ret; int ret;
epayload = rcu_dereference_protected(key->payload.data, epayload = rcu_dereference_key(key);
rwsem_is_locked(&((struct key *)key)->sem));
/* returns the hex encoded iv, encrypted-data, and hmac as ascii */ /* returns the hex encoded iv, encrypted-data, and hmac as ascii */
asciiblob_len = epayload->datablob_len + ivsize + 1 asciiblob_len = epayload->datablob_len + ivsize + 1
......
...@@ -1076,8 +1076,7 @@ static long trusted_read(const struct key *key, char __user *buffer, ...@@ -1076,8 +1076,7 @@ static long trusted_read(const struct key *key, char __user *buffer,
char *bufp; char *bufp;
int i; int i;
p = rcu_dereference_protected(key->payload.data, p = rcu_dereference_key(key);
rwsem_is_locked(&((struct key *)key)->sem));
if (!p) if (!p)
return -EINVAL; return -EINVAL;
if (!buffer || buflen <= 0) if (!buffer || buflen <= 0)
......
...@@ -184,8 +184,7 @@ long user_read(const struct key *key, char __user *buffer, size_t buflen) ...@@ -184,8 +184,7 @@ long user_read(const struct key *key, char __user *buffer, size_t buflen)
struct user_key_payload *upayload; struct user_key_payload *upayload;
long ret; long ret;
upayload = rcu_dereference_protected( upayload = rcu_dereference_key(key);
key->payload.data, rwsem_is_locked(&((struct key *)key)->sem));
ret = upayload->datalen; ret = upayload->datalen;
/* we can return the data as is */ /* we can return the data as is */
......
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