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