Loading...
1/* SPDX-License-Identifier: GPL-2.0-or-later */
2/* ASN.1 Object identifier (OID) registry
3 *
4 * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
5 * Written by David Howells (dhowells@redhat.com)
6 */
7
8#ifndef _LINUX_OID_REGISTRY_H
9#define _LINUX_OID_REGISTRY_H
10
11#include <linux/types.h>
12
13/*
14 * OIDs are turned into these values if possible, or OID__NR if not held here.
15 *
16 * NOTE! Do not mess with the format of each line as this is read by
17 * build_OID_registry.pl to generate the data for look_up_OID().
18 */
19enum OID {
20 OID_id_dsa_with_sha1, /* 1.2.840.10030.4.3 */
21 OID_id_dsa, /* 1.2.840.10040.4.1 */
22 OID_id_ecPublicKey, /* 1.2.840.10045.2.1 */
23 OID_id_prime192v1, /* 1.2.840.10045.3.1.1 */
24 OID_id_prime256v1, /* 1.2.840.10045.3.1.7 */
25 OID_id_ecdsa_with_sha1, /* 1.2.840.10045.4.1 */
26 OID_id_ecdsa_with_sha224, /* 1.2.840.10045.4.3.1 */
27 OID_id_ecdsa_with_sha256, /* 1.2.840.10045.4.3.2 */
28 OID_id_ecdsa_with_sha384, /* 1.2.840.10045.4.3.3 */
29 OID_id_ecdsa_with_sha512, /* 1.2.840.10045.4.3.4 */
30
31 /* PKCS#1 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-1(1)} */
32 OID_rsaEncryption, /* 1.2.840.113549.1.1.1 */
33 OID_md2WithRSAEncryption, /* 1.2.840.113549.1.1.2 */
34 OID_md3WithRSAEncryption, /* 1.2.840.113549.1.1.3 */
35 OID_md4WithRSAEncryption, /* 1.2.840.113549.1.1.4 */
36 OID_sha1WithRSAEncryption, /* 1.2.840.113549.1.1.5 */
37 OID_sha256WithRSAEncryption, /* 1.2.840.113549.1.1.11 */
38 OID_sha384WithRSAEncryption, /* 1.2.840.113549.1.1.12 */
39 OID_sha512WithRSAEncryption, /* 1.2.840.113549.1.1.13 */
40 OID_sha224WithRSAEncryption, /* 1.2.840.113549.1.1.14 */
41 /* PKCS#7 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-7(7)} */
42 OID_data, /* 1.2.840.113549.1.7.1 */
43 OID_signed_data, /* 1.2.840.113549.1.7.2 */
44 /* PKCS#9 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-9(9)} */
45 OID_email_address, /* 1.2.840.113549.1.9.1 */
46 OID_contentType, /* 1.2.840.113549.1.9.3 */
47 OID_messageDigest, /* 1.2.840.113549.1.9.4 */
48 OID_signingTime, /* 1.2.840.113549.1.9.5 */
49 OID_smimeCapabilites, /* 1.2.840.113549.1.9.15 */
50 OID_smimeAuthenticatedAttrs, /* 1.2.840.113549.1.9.16.2.11 */
51
52 /* {iso(1) member-body(2) us(840) rsadsi(113549) digestAlgorithm(2)} */
53 OID_md2, /* 1.2.840.113549.2.2 */
54 OID_md4, /* 1.2.840.113549.2.4 */
55 OID_md5, /* 1.2.840.113549.2.5 */
56
57 OID_mskrb5, /* 1.2.840.48018.1.2.2 */
58 OID_krb5, /* 1.2.840.113554.1.2.2 */
59 OID_krb5u2u, /* 1.2.840.113554.1.2.2.3 */
60
61 /* Microsoft Authenticode & Software Publishing */
62 OID_msIndirectData, /* 1.3.6.1.4.1.311.2.1.4 */
63 OID_msStatementType, /* 1.3.6.1.4.1.311.2.1.11 */
64 OID_msSpOpusInfo, /* 1.3.6.1.4.1.311.2.1.12 */
65 OID_msPeImageDataObjId, /* 1.3.6.1.4.1.311.2.1.15 */
66 OID_msIndividualSPKeyPurpose, /* 1.3.6.1.4.1.311.2.1.21 */
67 OID_msOutlookExpress, /* 1.3.6.1.4.1.311.16.4 */
68
69 OID_ntlmssp, /* 1.3.6.1.4.1.311.2.2.10 */
70
71 OID_spnego, /* 1.3.6.1.5.5.2 */
72
73 OID_certAuthInfoAccess, /* 1.3.6.1.5.5.7.1.1 */
74 OID_sha1, /* 1.3.14.3.2.26 */
75 OID_id_ansip384r1, /* 1.3.132.0.34 */
76 OID_sha256, /* 2.16.840.1.101.3.4.2.1 */
77 OID_sha384, /* 2.16.840.1.101.3.4.2.2 */
78 OID_sha512, /* 2.16.840.1.101.3.4.2.3 */
79 OID_sha224, /* 2.16.840.1.101.3.4.2.4 */
80
81 /* Distinguished Name attribute IDs [RFC 2256] */
82 OID_commonName, /* 2.5.4.3 */
83 OID_surname, /* 2.5.4.4 */
84 OID_countryName, /* 2.5.4.6 */
85 OID_locality, /* 2.5.4.7 */
86 OID_stateOrProvinceName, /* 2.5.4.8 */
87 OID_organizationName, /* 2.5.4.10 */
88 OID_organizationUnitName, /* 2.5.4.11 */
89 OID_title, /* 2.5.4.12 */
90 OID_description, /* 2.5.4.13 */
91 OID_name, /* 2.5.4.41 */
92 OID_givenName, /* 2.5.4.42 */
93 OID_initials, /* 2.5.4.43 */
94 OID_generationalQualifier, /* 2.5.4.44 */
95
96 /* Certificate extension IDs */
97 OID_subjectKeyIdentifier, /* 2.5.29.14 */
98 OID_keyUsage, /* 2.5.29.15 */
99 OID_subjectAltName, /* 2.5.29.17 */
100 OID_issuerAltName, /* 2.5.29.18 */
101 OID_basicConstraints, /* 2.5.29.19 */
102 OID_crlDistributionPoints, /* 2.5.29.31 */
103 OID_certPolicies, /* 2.5.29.32 */
104 OID_authorityKeyIdentifier, /* 2.5.29.35 */
105 OID_extKeyUsage, /* 2.5.29.37 */
106
107 /* EC-RDSA */
108 OID_gostCPSignA, /* 1.2.643.2.2.35.1 */
109 OID_gostCPSignB, /* 1.2.643.2.2.35.2 */
110 OID_gostCPSignC, /* 1.2.643.2.2.35.3 */
111 OID_gost2012PKey256, /* 1.2.643.7.1.1.1.1 */
112 OID_gost2012PKey512, /* 1.2.643.7.1.1.1.2 */
113 OID_gost2012Digest256, /* 1.2.643.7.1.1.2.2 */
114 OID_gost2012Digest512, /* 1.2.643.7.1.1.2.3 */
115 OID_gost2012Signature256, /* 1.2.643.7.1.1.3.2 */
116 OID_gost2012Signature512, /* 1.2.643.7.1.1.3.3 */
117 OID_gostTC26Sign256A, /* 1.2.643.7.1.2.1.1.1 */
118 OID_gostTC26Sign256B, /* 1.2.643.7.1.2.1.1.2 */
119 OID_gostTC26Sign256C, /* 1.2.643.7.1.2.1.1.3 */
120 OID_gostTC26Sign256D, /* 1.2.643.7.1.2.1.1.4 */
121 OID_gostTC26Sign512A, /* 1.2.643.7.1.2.1.2.1 */
122 OID_gostTC26Sign512B, /* 1.2.643.7.1.2.1.2.2 */
123 OID_gostTC26Sign512C, /* 1.2.643.7.1.2.1.2.3 */
124
125 /* OSCCA */
126 OID_sm2, /* 1.2.156.10197.1.301 */
127 OID_sm3, /* 1.2.156.10197.1.401 */
128 OID_SM2_with_SM3, /* 1.2.156.10197.1.501 */
129 OID_sm3WithRSAEncryption, /* 1.2.156.10197.1.504 */
130
131 /* TCG defined OIDS for TPM based keys */
132 OID_TPMLoadableKey, /* 2.23.133.10.1.3 */
133 OID_TPMImportableKey, /* 2.23.133.10.1.4 */
134 OID_TPMSealedData, /* 2.23.133.10.1.5 */
135
136 OID__NR
137};
138
139extern enum OID look_up_OID(const void *data, size_t datasize);
140extern int parse_OID(const void *data, size_t datasize, enum OID *oid);
141extern int sprint_oid(const void *, size_t, char *, size_t);
142extern int sprint_OID(enum OID, char *, size_t);
143
144#endif /* _LINUX_OID_REGISTRY_H */
1/* ASN.1 Object identifier (OID) registry
2 *
3 * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
4 * Written by David Howells (dhowells@redhat.com)
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public Licence
8 * as published by the Free Software Foundation; either version
9 * 2 of the Licence, or (at your option) any later version.
10 */
11
12#ifndef _LINUX_OID_REGISTRY_H
13#define _LINUX_OID_REGISTRY_H
14
15#include <linux/types.h>
16
17/*
18 * OIDs are turned into these values if possible, or OID__NR if not held here.
19 *
20 * NOTE! Do not mess with the format of each line as this is read by
21 * build_OID_registry.pl to generate the data for look_up_OID().
22 */
23enum OID {
24 OID_id_dsa_with_sha1, /* 1.2.840.10030.4.3 */
25 OID_id_dsa, /* 1.2.840.10040.4.1 */
26 OID_id_ecdsa_with_sha1, /* 1.2.840.10045.4.1 */
27 OID_id_ecPublicKey, /* 1.2.840.10045.2.1 */
28
29 /* PKCS#1 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-1(1)} */
30 OID_rsaEncryption, /* 1.2.840.113549.1.1.1 */
31 OID_md2WithRSAEncryption, /* 1.2.840.113549.1.1.2 */
32 OID_md3WithRSAEncryption, /* 1.2.840.113549.1.1.3 */
33 OID_md4WithRSAEncryption, /* 1.2.840.113549.1.1.4 */
34 OID_sha1WithRSAEncryption, /* 1.2.840.113549.1.1.5 */
35 OID_sha256WithRSAEncryption, /* 1.2.840.113549.1.1.11 */
36 OID_sha384WithRSAEncryption, /* 1.2.840.113549.1.1.12 */
37 OID_sha512WithRSAEncryption, /* 1.2.840.113549.1.1.13 */
38 OID_sha224WithRSAEncryption, /* 1.2.840.113549.1.1.14 */
39 /* PKCS#7 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-7(7)} */
40 OID_data, /* 1.2.840.113549.1.7.1 */
41 OID_signed_data, /* 1.2.840.113549.1.7.2 */
42 /* PKCS#9 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-9(9)} */
43 OID_email_address, /* 1.2.840.113549.1.9.1 */
44 OID_contentType, /* 1.2.840.113549.1.9.3 */
45 OID_messageDigest, /* 1.2.840.113549.1.9.4 */
46 OID_signingTime, /* 1.2.840.113549.1.9.5 */
47 OID_smimeCapabilites, /* 1.2.840.113549.1.9.15 */
48 OID_smimeAuthenticatedAttrs, /* 1.2.840.113549.1.9.16.2.11 */
49
50 /* {iso(1) member-body(2) us(840) rsadsi(113549) digestAlgorithm(2)} */
51 OID_md2, /* 1.2.840.113549.2.2 */
52 OID_md4, /* 1.2.840.113549.2.4 */
53 OID_md5, /* 1.2.840.113549.2.5 */
54
55 /* Microsoft Authenticode & Software Publishing */
56 OID_msIndirectData, /* 1.3.6.1.4.1.311.2.1.4 */
57 OID_msStatementType, /* 1.3.6.1.4.1.311.2.1.11 */
58 OID_msSpOpusInfo, /* 1.3.6.1.4.1.311.2.1.12 */
59 OID_msPeImageDataObjId, /* 1.3.6.1.4.1.311.2.1.15 */
60 OID_msIndividualSPKeyPurpose, /* 1.3.6.1.4.1.311.2.1.21 */
61 OID_msOutlookExpress, /* 1.3.6.1.4.1.311.16.4 */
62
63 OID_certAuthInfoAccess, /* 1.3.6.1.5.5.7.1.1 */
64 OID_sha1, /* 1.3.14.3.2.26 */
65 OID_sha256, /* 2.16.840.1.101.3.4.2.1 */
66 OID_sha384, /* 2.16.840.1.101.3.4.2.2 */
67 OID_sha512, /* 2.16.840.1.101.3.4.2.3 */
68 OID_sha224, /* 2.16.840.1.101.3.4.2.4 */
69
70 /* Distinguished Name attribute IDs [RFC 2256] */
71 OID_commonName, /* 2.5.4.3 */
72 OID_surname, /* 2.5.4.4 */
73 OID_countryName, /* 2.5.4.6 */
74 OID_locality, /* 2.5.4.7 */
75 OID_stateOrProvinceName, /* 2.5.4.8 */
76 OID_organizationName, /* 2.5.4.10 */
77 OID_organizationUnitName, /* 2.5.4.11 */
78 OID_title, /* 2.5.4.12 */
79 OID_description, /* 2.5.4.13 */
80 OID_name, /* 2.5.4.41 */
81 OID_givenName, /* 2.5.4.42 */
82 OID_initials, /* 2.5.4.43 */
83 OID_generationalQualifier, /* 2.5.4.44 */
84
85 /* Certificate extension IDs */
86 OID_subjectKeyIdentifier, /* 2.5.29.14 */
87 OID_keyUsage, /* 2.5.29.15 */
88 OID_subjectAltName, /* 2.5.29.17 */
89 OID_issuerAltName, /* 2.5.29.18 */
90 OID_basicConstraints, /* 2.5.29.19 */
91 OID_crlDistributionPoints, /* 2.5.29.31 */
92 OID_certPolicies, /* 2.5.29.32 */
93 OID_authorityKeyIdentifier, /* 2.5.29.35 */
94 OID_extKeyUsage, /* 2.5.29.37 */
95
96 OID__NR
97};
98
99extern enum OID look_up_OID(const void *data, size_t datasize);
100extern int sprint_oid(const void *, size_t, char *, size_t);
101extern int sprint_OID(enum OID, char *, size_t);
102
103#endif /* _LINUX_OID_REGISTRY_H */