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

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
Loading
Loading
Loading
Loading
+4 −0
Original line number Original line Diff line number Diff line
@@ -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
+1 −2
Original line number Original line Diff line number Diff line
@@ -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
+1 −2
Original line number Original line Diff line number Diff line
@@ -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)
+1 −2
Original line number Original line Diff line number Diff line
@@ -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 */