blob: b3928e801b8cbb410bc67ba243a0ee61fc8f28a2 [file] [log] [blame]
David Howellsa9681bf2012-09-21 23:24:55 +01001/* Asymmetric public-key algorithm definitions
2 *
3 * See Documentation/crypto/asymmetric-keys.txt
4 *
5 * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
6 * Written by David Howells (dhowells@redhat.com)
7 *
8 * This program is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU General Public Licence
10 * as published by the Free Software Foundation; either version
11 * 2 of the Licence, or (at your option) any later version.
12 */
13
14#ifndef _LINUX_PUBLIC_KEY_H
15#define _LINUX_PUBLIC_KEY_H
16
David Howellsa9681bf2012-09-21 23:24:55 +010017/*
18 * Cryptographic data for the public-key subtype of the asymmetric key type.
19 *
20 * Note that this may include private part of the key as well as the public
21 * part.
22 */
23struct public_key {
Tadeusz Strukdb6c43b2016-02-02 10:08:53 -080024 void *key;
25 u32 keylen;
David Howells4e8ae722016-03-03 21:49:27 +000026 const char *id_type;
27 const char *pkey_algo;
David Howellsa9681bf2012-09-21 23:24:55 +010028};
29
David Howells3b764562016-04-06 16:13:33 +010030extern void public_key_free(struct public_key *key);
David Howellsa9681bf2012-09-21 23:24:55 +010031
32/*
33 * Public key cryptography signature data
34 */
35struct public_key_signature {
David Howellsa022ec02016-04-06 16:13:33 +010036 struct asymmetric_key_id *auth_ids[2];
Tadeusz Strukdb6c43b2016-02-02 10:08:53 -080037 u8 *s; /* Signature */
38 u32 s_size; /* Number of bytes in signature */
David Howellsa9681bf2012-09-21 23:24:55 +010039 u8 *digest;
Tadeusz Strukd846e782016-02-02 10:09:03 -080040 u8 digest_size; /* Number of bytes in digest */
David Howells4e8ae722016-03-03 21:49:27 +000041 const char *pkey_algo;
42 const char *hash_algo;
David Howellsa9681bf2012-09-21 23:24:55 +010043};
44
David Howells3b764562016-04-06 16:13:33 +010045extern void public_key_signature_free(struct public_key_signature *sig);
46
Tadeusz Strukdb6c43b2016-02-02 10:08:53 -080047extern struct asymmetric_key_subtype public_key_subtype;
David Howells3b764562016-04-06 16:13:33 +010048
David Howells4ae71c12012-09-21 23:25:04 +010049struct key;
50extern int verify_signature(const struct key *key,
51 const struct public_key_signature *sig);
52
David Howells46963b72014-09-16 17:36:13 +010053struct asymmetric_key_id;
David Howells5ce43ad2014-07-28 14:11:32 +010054extern struct key *x509_request_asymmetric_key(struct key *keyring,
David Howells4573b642015-07-20 21:16:26 +010055 const struct asymmetric_key_id *id,
56 const struct asymmetric_key_id *skid,
Dmitry Kasatkinf1b731d2014-10-06 15:21:05 +010057 bool partial);
David Howells5ce43ad2014-07-28 14:11:32 +010058
Tadeusz Strukdb6c43b2016-02-02 10:08:53 -080059int public_key_verify_signature(const struct public_key *pkey,
60 const struct public_key_signature *sig);
61
David Howellsa9681bf2012-09-21 23:24:55 +010062#endif /* _LINUX_PUBLIC_KEY_H */