Skip to content

Commit cc1780f

Browse files
ebiggersJames Morris
authored andcommitted
KEYS: user: Align the payload buffer
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: 2aa349f ("[PATCH] Keys: Export user-defined keyring operations") Fixes: 88bd6cc ("ext4 crypto: add encryption key management facilities") Cc: stable@vger.kernel.org Signed-off-by: Eric Biggers <ebiggers@google.com> Tested-by: Aaro Koskinen <aaro.koskinen@iki.fi> Signed-off-by: David Howells <dhowells@redhat.com> Signed-off-by: James Morris <james.morris@microsoft.com>
1 parent 8a61716 commit cc1780f

File tree

1 file changed

+1
-1
lines changed

1 file changed

+1
-1
lines changed

include/keys/user-type.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@
3131
struct user_key_payload {
3232
struct rcu_head rcu; /* RCU destructor */
3333
unsigned short datalen; /* length of this data */
34-
char data[0]; /* actual data */
34+
char data[0] __aligned(__alignof__(u64)); /* actual data */
3535
};
3636

3737
extern struct key_type key_type_user;

0 commit comments

Comments
 (0)