|  | /* Asymmetric public-key cryptography key subtype | 
|  | * | 
|  | * See Documentation/security/asymmetric-keys.txt | 
|  | * | 
|  | * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved. | 
|  | * Written by David Howells ([email protected]) | 
|  | * | 
|  | * This program is free software; you can redistribute it and/or | 
|  | * modify it under the terms of the GNU General Public Licence | 
|  | * as published by the Free Software Foundation; either version | 
|  | * 2 of the Licence, or (at your option) any later version. | 
|  | */ | 
|  |  | 
|  | #ifndef _KEYS_ASYMMETRIC_SUBTYPE_H | 
|  | #define _KEYS_ASYMMETRIC_SUBTYPE_H | 
|  |  | 
|  | #include <linux/seq_file.h> | 
|  | #include <keys/asymmetric-type.h> | 
|  |  | 
|  | struct public_key_signature; | 
|  |  | 
|  | /* | 
|  | * Keys of this type declare a subtype that indicates the handlers and | 
|  | * capabilities. | 
|  | */ | 
|  | struct asymmetric_key_subtype { | 
|  | struct module		*owner; | 
|  | const char		*name; | 
|  | unsigned short		name_len;	/* length of name */ | 
|  |  | 
|  | /* Describe a key of this subtype for /proc/keys */ | 
|  | void (*describe)(const struct key *key, struct seq_file *m); | 
|  |  | 
|  | /* Destroy a key of this subtype */ | 
|  | void (*destroy)(void *payload_crypto, void *payload_auth); | 
|  |  | 
|  | /* Verify the signature on a key of this subtype (optional) */ | 
|  | int (*verify_signature)(const struct key *key, | 
|  | const struct public_key_signature *sig); | 
|  | }; | 
|  |  | 
|  | /** | 
|  | * asymmetric_key_subtype - Get the subtype from an asymmetric key | 
|  | * @key: The key of interest. | 
|  | * | 
|  | * Retrieves and returns the subtype pointer of the asymmetric key from the | 
|  | * type-specific data attached to the key. | 
|  | */ | 
|  | static inline | 
|  | struct asymmetric_key_subtype *asymmetric_key_subtype(const struct key *key) | 
|  | { | 
|  | return key->payload.data[asym_subtype]; | 
|  | } | 
|  |  | 
|  | #endif /* _KEYS_ASYMMETRIC_SUBTYPE_H */ |