xref: /linux-6.15/include/linux/oid_registry.h (revision 3ba2ae36)
1b4d0d230SThomas Gleixner /* SPDX-License-Identifier: GPL-2.0-or-later */
2a77ad6eaSDavid Howells /* ASN.1 Object identifier (OID) registry
3a77ad6eaSDavid Howells  *
4a77ad6eaSDavid Howells  * Copyright (C) 2012 Red Hat, Inc. All Rights Reserved.
5a77ad6eaSDavid Howells  * Written by David Howells ([email protected])
6a77ad6eaSDavid Howells  */
7a77ad6eaSDavid Howells 
8a77ad6eaSDavid Howells #ifndef _LINUX_OID_REGISTRY_H
9a77ad6eaSDavid Howells #define _LINUX_OID_REGISTRY_H
10a77ad6eaSDavid Howells 
11a77ad6eaSDavid Howells #include <linux/types.h>
12a77ad6eaSDavid Howells 
13a77ad6eaSDavid Howells /*
14a77ad6eaSDavid Howells  * OIDs are turned into these values if possible, or OID__NR if not held here.
15a77ad6eaSDavid Howells  *
16a77ad6eaSDavid Howells  * NOTE!  Do not mess with the format of each line as this is read by
17a77ad6eaSDavid Howells  *	  build_OID_registry.pl to generate the data for look_up_OID().
18a77ad6eaSDavid Howells  */
19a77ad6eaSDavid Howells enum OID {
20203a6763SEric Biggers 	OID_id_dsa_with_sha1,		/* 1.2.840.10030.4.3 */
21a77ad6eaSDavid Howells 	OID_id_dsa,			/* 1.2.840.10040.4.1 */
22a77ad6eaSDavid Howells 	OID_id_ecPublicKey,		/* 1.2.840.10045.2.1 */
23299f561aSStefan Berger 	OID_id_prime192v1,		/* 1.2.840.10045.3.1.1 */
24299f561aSStefan Berger 	OID_id_prime256v1,		/* 1.2.840.10045.3.1.7 */
25203a6763SEric Biggers 	OID_id_ecdsa_with_sha1,		/* 1.2.840.10045.4.1 */
267547738dSStefan Berger 	OID_id_ecdsa_with_sha224,	/* 1.2.840.10045.4.3.1 */
277547738dSStefan Berger 	OID_id_ecdsa_with_sha256,	/* 1.2.840.10045.4.3.2 */
287547738dSStefan Berger 	OID_id_ecdsa_with_sha384,	/* 1.2.840.10045.4.3.3 */
297547738dSStefan Berger 	OID_id_ecdsa_with_sha512,	/* 1.2.840.10045.4.3.4 */
30a77ad6eaSDavid Howells 
31a77ad6eaSDavid Howells 	/* PKCS#1 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-1(1)} */
32a77ad6eaSDavid Howells 	OID_rsaEncryption,		/* 1.2.840.113549.1.1.1 */
33203a6763SEric Biggers 	OID_sha1WithRSAEncryption,	/* 1.2.840.113549.1.1.5 */
34a77ad6eaSDavid Howells 	OID_sha256WithRSAEncryption,	/* 1.2.840.113549.1.1.11 */
35a77ad6eaSDavid Howells 	OID_sha384WithRSAEncryption,	/* 1.2.840.113549.1.1.12 */
36a77ad6eaSDavid Howells 	OID_sha512WithRSAEncryption,	/* 1.2.840.113549.1.1.13 */
37a77ad6eaSDavid Howells 	OID_sha224WithRSAEncryption,	/* 1.2.840.113549.1.1.14 */
38a77ad6eaSDavid Howells 	/* PKCS#7 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-7(7)} */
39a77ad6eaSDavid Howells 	OID_data,			/* 1.2.840.113549.1.7.1 */
40a77ad6eaSDavid Howells 	OID_signed_data,		/* 1.2.840.113549.1.7.2 */
41a77ad6eaSDavid Howells 	/* PKCS#9 {iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs-9(9)} */
42a77ad6eaSDavid Howells 	OID_email_address,		/* 1.2.840.113549.1.9.1 */
4399db4435SDavid Howells 	OID_contentType,		/* 1.2.840.113549.1.9.3 */
44a77ad6eaSDavid Howells 	OID_messageDigest,		/* 1.2.840.113549.1.9.4 */
45a77ad6eaSDavid Howells 	OID_signingTime,		/* 1.2.840.113549.1.9.5 */
46a77ad6eaSDavid Howells 	OID_smimeCapabilites,		/* 1.2.840.113549.1.9.15 */
47a77ad6eaSDavid Howells 	OID_smimeAuthenticatedAttrs,	/* 1.2.840.113549.1.9.16.2.11 */
48a77ad6eaSDavid Howells 
490475c365SHyunchul Lee 	OID_mskrb5,			/* 1.2.840.48018.1.2.2 */
500475c365SHyunchul Lee 	OID_krb5,			/* 1.2.840.113554.1.2.2 */
510475c365SHyunchul Lee 	OID_krb5u2u,			/* 1.2.840.113554.1.2.2.3 */
520475c365SHyunchul Lee 
534c0b4b1dSDavid Howells 	/* Microsoft Authenticode & Software Publishing */
544c0b4b1dSDavid Howells 	OID_msIndirectData,		/* 1.3.6.1.4.1.311.2.1.4 */
5599db4435SDavid Howells 	OID_msStatementType,		/* 1.3.6.1.4.1.311.2.1.11 */
5699db4435SDavid Howells 	OID_msSpOpusInfo,		/* 1.3.6.1.4.1.311.2.1.12 */
574c0b4b1dSDavid Howells 	OID_msPeImageDataObjId,		/* 1.3.6.1.4.1.311.2.1.15 */
584c0b4b1dSDavid Howells 	OID_msIndividualSPKeyPurpose,	/* 1.3.6.1.4.1.311.2.1.21 */
59a77ad6eaSDavid Howells 	OID_msOutlookExpress,		/* 1.3.6.1.4.1.311.16.4 */
604c0b4b1dSDavid Howells 
610475c365SHyunchul Lee 	OID_ntlmssp,			/* 1.3.6.1.4.1.311.2.2.10 */
625d153cd1SSteve French 	OID_negoex,			/* 1.3.6.1.4.1.311.2.2.30 */
630475c365SHyunchul Lee 
640475c365SHyunchul Lee 	OID_spnego,			/* 1.3.6.1.5.5.2 */
650475c365SHyunchul Lee 
663d2b50e0SSteve French 	OID_IAKerb,			/* 1.3.6.1.5.2.5 */
673d2b50e0SSteve French 	OID_PKU2U,			/* 1.3.5.1.5.2.7 */
683d2b50e0SSteve French 	OID_Scram,			/* 1.3.6.1.5.5.14 */
694c0b4b1dSDavid Howells 	OID_certAuthInfoAccess,		/* 1.3.6.1.5.5.7.1.1 */
70203a6763SEric Biggers 	OID_sha1,			/* 1.3.14.3.2.26 */
712a8e6154SSaulo Alessandre 	OID_id_ansip384r1,		/* 1.3.132.0.34 */
72*3ba2ae36SStefan Berger 	OID_id_ansip521r1,		/* 1.3.132.0.35 */
732e3fadbfSDavid Howells 	OID_sha256,			/* 2.16.840.1.101.3.4.2.1 */
7407f081fbSDavid Howells 	OID_sha384,			/* 2.16.840.1.101.3.4.2.2 */
7507f081fbSDavid Howells 	OID_sha512,			/* 2.16.840.1.101.3.4.2.3 */
7607f081fbSDavid Howells 	OID_sha224,			/* 2.16.840.1.101.3.4.2.4 */
77a77ad6eaSDavid Howells 
78a77ad6eaSDavid Howells 	/* Distinguished Name attribute IDs [RFC 2256] */
79a77ad6eaSDavid Howells 	OID_commonName,			/* 2.5.4.3 */
80a77ad6eaSDavid Howells 	OID_surname,			/* 2.5.4.4 */
81a77ad6eaSDavid Howells 	OID_countryName,		/* 2.5.4.6 */
82a77ad6eaSDavid Howells 	OID_locality,			/* 2.5.4.7 */
83a77ad6eaSDavid Howells 	OID_stateOrProvinceName,	/* 2.5.4.8 */
84a77ad6eaSDavid Howells 	OID_organizationName,		/* 2.5.4.10 */
85a77ad6eaSDavid Howells 	OID_organizationUnitName,	/* 2.5.4.11 */
86a77ad6eaSDavid Howells 	OID_title,			/* 2.5.4.12 */
87a77ad6eaSDavid Howells 	OID_description,		/* 2.5.4.13 */
88a77ad6eaSDavid Howells 	OID_name,			/* 2.5.4.41 */
89a77ad6eaSDavid Howells 	OID_givenName,			/* 2.5.4.42 */
90a77ad6eaSDavid Howells 	OID_initials,			/* 2.5.4.43 */
91a77ad6eaSDavid Howells 	OID_generationalQualifier,	/* 2.5.4.44 */
92a77ad6eaSDavid Howells 
93a77ad6eaSDavid Howells 	/* Certificate extension IDs */
94a77ad6eaSDavid Howells 	OID_subjectKeyIdentifier,	/* 2.5.29.14 */
95a77ad6eaSDavid Howells 	OID_keyUsage,			/* 2.5.29.15 */
96a77ad6eaSDavid Howells 	OID_subjectAltName,		/* 2.5.29.17 */
97a77ad6eaSDavid Howells 	OID_issuerAltName,		/* 2.5.29.18 */
98a77ad6eaSDavid Howells 	OID_basicConstraints,		/* 2.5.29.19 */
99a77ad6eaSDavid Howells 	OID_crlDistributionPoints,	/* 2.5.29.31 */
100a77ad6eaSDavid Howells 	OID_certPolicies,		/* 2.5.29.32 */
101a77ad6eaSDavid Howells 	OID_authorityKeyIdentifier,	/* 2.5.29.35 */
102a77ad6eaSDavid Howells 	OID_extKeyUsage,		/* 2.5.29.37 */
103a77ad6eaSDavid Howells 
1043d2b50e0SSteve French 	/* Heimdal mechanisms */
1053d2b50e0SSteve French 	OID_NetlogonMechanism,		/* 1.2.752.43.14.2 */
1063d2b50e0SSteve French 	OID_appleLocalKdcSupported,	/* 1.2.752.43.14.3 */
1073d2b50e0SSteve French 
1080d7a7864SVitaly Chikunov 	/* EC-RDSA */
1090d7a7864SVitaly Chikunov 	OID_gostCPSignA,		/* 1.2.643.2.2.35.1 */
1100d7a7864SVitaly Chikunov 	OID_gostCPSignB,		/* 1.2.643.2.2.35.2 */
1110d7a7864SVitaly Chikunov 	OID_gostCPSignC,		/* 1.2.643.2.2.35.3 */
1120d7a7864SVitaly Chikunov 	OID_gost2012PKey256,		/* 1.2.643.7.1.1.1.1 */
1130d7a7864SVitaly Chikunov 	OID_gost2012PKey512,		/* 1.2.643.7.1.1.1.2 */
1140d7a7864SVitaly Chikunov 	OID_gost2012Digest256,		/* 1.2.643.7.1.1.2.2 */
1150d7a7864SVitaly Chikunov 	OID_gost2012Digest512,		/* 1.2.643.7.1.1.2.3 */
1160d7a7864SVitaly Chikunov 	OID_gost2012Signature256,	/* 1.2.643.7.1.1.3.2 */
1170d7a7864SVitaly Chikunov 	OID_gost2012Signature512,	/* 1.2.643.7.1.1.3.3 */
1180d7a7864SVitaly Chikunov 	OID_gostTC26Sign256A,		/* 1.2.643.7.1.2.1.1.1 */
1190d7a7864SVitaly Chikunov 	OID_gostTC26Sign256B,		/* 1.2.643.7.1.2.1.1.2 */
1200d7a7864SVitaly Chikunov 	OID_gostTC26Sign256C,		/* 1.2.643.7.1.2.1.1.3 */
1210d7a7864SVitaly Chikunov 	OID_gostTC26Sign256D,		/* 1.2.643.7.1.2.1.1.4 */
1220d7a7864SVitaly Chikunov 	OID_gostTC26Sign512A,		/* 1.2.643.7.1.2.1.2.1 */
1230d7a7864SVitaly Chikunov 	OID_gostTC26Sign512B,		/* 1.2.643.7.1.2.1.2.2 */
1240d7a7864SVitaly Chikunov 	OID_gostTC26Sign512C,		/* 1.2.643.7.1.2.1.2.3 */
1250d7a7864SVitaly Chikunov 
126254f84f5STianjia Zhang 	/* OSCCA */
127254f84f5STianjia Zhang 	OID_sm2,			/* 1.2.156.10197.1.301 */
128254f84f5STianjia Zhang 	OID_sm3,			/* 1.2.156.10197.1.401 */
129254f84f5STianjia Zhang 	OID_SM2_with_SM3,		/* 1.2.156.10197.1.501 */
130254f84f5STianjia Zhang 	OID_sm3WithRSAEncryption,	/* 1.2.156.10197.1.504 */
131254f84f5STianjia Zhang 
1321c6476e9SJames Bottomley 	/* TCG defined OIDS for TPM based keys */
1331c6476e9SJames Bottomley 	OID_TPMLoadableKey,		/* 2.23.133.10.1.3 */
1341c6476e9SJames Bottomley 	OID_TPMImportableKey,		/* 2.23.133.10.1.4 */
1351c6476e9SJames Bottomley 	OID_TPMSealedData,		/* 2.23.133.10.1.5 */
1361c6476e9SJames Bottomley 
1372ee7c1bcSDimitri John Ledkov 	/* CSOR FIPS-202 SHA-3 */
1382ee7c1bcSDimitri John Ledkov 	OID_sha3_256,                           /* 2.16.840.1.101.3.4.2.8 */
1392ee7c1bcSDimitri John Ledkov 	OID_sha3_384,                           /* 2.16.840.1.101.3.4.2.9 */
1402ee7c1bcSDimitri John Ledkov 	OID_sha3_512,                           /* 2.16.840.1.101.3.4.2.10 */
1412ee7c1bcSDimitri John Ledkov 	OID_id_ecdsa_with_sha3_256,             /* 2.16.840.1.101.3.4.3.10 */
1422ee7c1bcSDimitri John Ledkov 	OID_id_ecdsa_with_sha3_384,             /* 2.16.840.1.101.3.4.3.11 */
1432ee7c1bcSDimitri John Ledkov 	OID_id_ecdsa_with_sha3_512,             /* 2.16.840.1.101.3.4.3.12 */
1442ee7c1bcSDimitri John Ledkov 	OID_id_rsassa_pkcs1_v1_5_with_sha3_256, /* 2.16.840.1.101.3.4.3.14 */
1452ee7c1bcSDimitri John Ledkov 	OID_id_rsassa_pkcs1_v1_5_with_sha3_384, /* 2.16.840.1.101.3.4.3.15 */
1462ee7c1bcSDimitri John Ledkov 	OID_id_rsassa_pkcs1_v1_5_with_sha3_512, /* 2.16.840.1.101.3.4.3.16 */
1472ee7c1bcSDimitri John Ledkov 
148a77ad6eaSDavid Howells 	OID__NR
149a77ad6eaSDavid Howells };
150a77ad6eaSDavid Howells 
151a77ad6eaSDavid Howells extern enum OID look_up_OID(const void *data, size_t datasize);
152d1a303e8SStefan Berger extern int parse_OID(const void *data, size_t datasize, enum OID *oid);
1534f73175dSDavid Howells extern int sprint_oid(const void *, size_t, char *, size_t);
1544f73175dSDavid Howells extern int sprint_OID(enum OID, char *, size_t);
155a77ad6eaSDavid Howells 
156a77ad6eaSDavid Howells #endif /* _LINUX_OID_REGISTRY_H */
157