| /* Asymmetric public-key cryptography data parser | 
 |  * | 
 |  * See Documentation/crypto/asymmetric-keys.txt | 
 |  * | 
 |  * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved. | 
 |  * Written by David Howells (dhowells@redhat.com) | 
 |  * | 
 |  * 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_PARSER_H | 
 | #define _KEYS_ASYMMETRIC_PARSER_H | 
 |  | 
 | /* | 
 |  * Key data parser.  Called during key instantiation. | 
 |  */ | 
 | struct asymmetric_key_parser { | 
 | 	struct list_head	link; | 
 | 	struct module		*owner; | 
 | 	const char		*name; | 
 |  | 
 | 	/* Attempt to parse a key from the data blob passed to add_key() or | 
 | 	 * keyctl_instantiate().  Should also generate a proposed description | 
 | 	 * that the caller can optionally use for the key. | 
 | 	 * | 
 | 	 * Return EBADMSG if not recognised. | 
 | 	 */ | 
 | 	int (*parse)(struct key_preparsed_payload *prep); | 
 | }; | 
 |  | 
 | extern int register_asymmetric_key_parser(struct asymmetric_key_parser *); | 
 | extern void unregister_asymmetric_key_parser(struct asymmetric_key_parser *); | 
 |  | 
 | #endif /* _KEYS_ASYMMETRIC_PARSER_H */ |