iPXE
rsa_md5.c
Go to the documentation of this file.
1/*
2 * Copyright (C) 2015 Michael Brown <mbrown@fensystems.co.uk>.
3 *
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License as
6 * published by the Free Software Foundation; either version 2 of the
7 * License, or (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful, but
10 * WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
17 * 02110-1301, USA.
18 *
19 * You can also choose to distribute this program under the terms of
20 * the Unmodified Binary Distribution Licence (as given in the file
21 * COPYING.UBDL), provided that you have satisfied its requirements.
22 */
23
24FILE_LICENCE ( GPL2_OR_LATER_OR_UBDL );
25FILE_SECBOOT ( FORBIDDEN );
26
27#include <ipxe/rsa.h>
28#include <ipxe/md5.h>
29#include <ipxe/asn1.h>
30
31/** "md5WithRSAEncryption" object identifier */
34
35/** "md5WithRSAEncryption" OID-identified algorithm */
36struct asn1_algorithm md5_with_rsa_encryption_algorithm __asn1_algorithm = {
37 .name = "md5WithRSAEncryption",
38 .pubkey = &rsa_algorithm,
39 .digest = &md5_algorithm,
41};
42
43/** MD5 digestInfo prefix */
46
47/** MD5 digestInfo prefix */
49 .digest = &md5_algorithm,
50 .data = rsa_md5_prefix_data,
51 .len = sizeof ( rsa_md5_prefix_data ),
52};
unsigned char uint8_t
Definition stdint.h:10
ASN.1 encoding.
#define ASN1_OID_MD5WITHRSAENCRYPTION
ASN.1 OID for md5WithRSAEncryption (1.2.840.113549.1.1.4)
Definition asn1.h:174
#define __asn1_algorithm
Declare an ASN.1 OID-identified algorithm.
Definition asn1.h:436
#define ASN1_CURSOR(value)
Define an ASN.1 cursor for a static value.
Definition asn1.h:402
#define ASN1_OID_MD5
ASN.1 OID for id-md5 (1.2.840.113549.2.5)
Definition asn1.h:216
#define FILE_LICENCE(_licence)
Declare a particular licence as applying to a file.
Definition compiler.h:896
#define FILE_SECBOOT(_status)
Declare a file's UEFI Secure Boot permission status.
Definition compiler.h:926
struct digest_algorithm md5_algorithm
MD5 algorithm.
Definition md5.c:287
MD5 algorithm.
#define MD5_DIGEST_SIZE
MD5 digest size.
Definition md5.h:73
struct pubkey_algorithm rsa_algorithm
RSA public-key algorithm.
Definition rsa.c:661
RSA public-key cryptography.
#define __rsa_digestinfo_prefix
Declare an RSA digestInfo prefix.
Definition rsa.h:57
#define RSA_DIGESTINFO_PREFIX(digest_size,...)
RSA digestInfo prefix.
Definition rsa.h:34
static const uint8_t rsa_md5_prefix_data[]
MD5 digestInfo prefix.
Definition rsa_md5.c:44
static uint8_t oid_md5_with_rsa_encryption[]
"md5WithRSAEncryption" object identifier
Definition rsa_md5.c:32
An ASN.1 OID-identified algorithm.
Definition asn1.h:408
An RSA digestInfo prefix.
Definition rsa.h:43