All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] KEYS: user: Align the payload buffer
@ 2019-01-15  3:37 ` Eric Biggers
  0 siblings, 0 replies; 17+ messages in thread
From: Eric Biggers @ 2019-01-15  3:37 UTC (permalink / raw)
  To: keyrings, David Howells; +Cc: Aaro Koskinen, linux-fscrypt, linux-kernel

From: Eric Biggers <ebiggers@google.com>

Align the payload of "user" and "logon" keys so that users of the
keyrings service can access it as a struct that requires more than
2-byte alignment.  fscrypt currently does this which results in the read
of fscrypt_key::size being misaligned as it needs 4-byte alignment.

Align to __alignof__(u64) rather than __alignof__(long) since in the
future it's conceivable that people would use structs beginning with
u64, which on some platforms would require more than 'long' alignment.

Reported-by: Aaro Koskinen <aaro.koskinen@iki.fi>
Fixes: 2aa349f6e37c ("[PATCH] Keys: Export user-defined keyring operations")
Fixes: 88bd6ccdcdd6 ("ext4 crypto: add encryption key management facilities")
Cc: stable@vger.kernel.org
Signed-off-by: Eric Biggers <ebiggers@google.com>
---
 include/keys/user-type.h | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/include/keys/user-type.h b/include/keys/user-type.h
index e098cbe27db54..12babe9915944 100644
--- a/include/keys/user-type.h
+++ b/include/keys/user-type.h
@@ -31,7 +31,7 @@
 struct user_key_payload {
 	struct rcu_head	rcu;		/* RCU destructor */
 	unsigned short	datalen;	/* length of this data */
-	char		data[0];	/* actual data */
+	char		data[0] __aligned(__alignof__(u64)); /* actual data */
 };
 
 extern struct key_type key_type_user;
-- 
2.20.1

^ permalink raw reply related	[flat|nested] 17+ messages in thread

end of thread, other threads:[~2019-02-20 21:37 UTC | newest]

Thread overview: 17+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-01-15  3:37 [PATCH] KEYS: user: Align the payload buffer Eric Biggers
2019-01-15  3:37 ` Eric Biggers
2019-01-15 19:19 ` Aaro Koskinen
2019-01-15 19:19   ` Aaro Koskinen
2019-02-07 23:35 ` Eric Biggers
2019-02-07 23:35   ` Eric Biggers
2019-02-19 23:08   ` Eric Biggers
2019-02-19 23:08     ` Eric Biggers
2019-02-20 13:32     ` David Howells
2019-02-20 13:32 ` David Howells
2019-02-20 13:32   ` David Howells
2019-02-20 13:52   ` David Laight
2019-02-20 13:52     ` David Laight
2019-02-20 14:09     ` David Howells
2019-02-20 20:50       ` James Morris
2019-02-20 20:50         ` James Morris
2019-02-20 21:37         ` David Howells

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.