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 */ 19 enum 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 /* Microsoft Authenticode & Software Publishing */ 58 OID_msIndirectData, /* 1.3.6.1.4.1.311.2.1.4 */ 59 OID_msStatementType, /* 1.3.6.1.4.1.311.2.1.11 */ 60 OID_msSpOpusInfo, /* 1.3.6.1.4.1.311.2.1.12 */ 61 OID_msPeImageDataObjId, /* 1.3.6.1.4.1.311.2.1.15 */ 62 OID_msIndividualSPKeyPurpose, /* 1.3.6.1.4.1.311.2.1.21 */ 63 OID_msOutlookExpress, /* 1.3.6.1.4.1.311.16.4 */ 64 65 OID_certAuthInfoAccess, /* 1.3.6.1.5.5.7.1.1 */ 66 OID_sha1, /* 1.3.14.3.2.26 */ 67 OID_id_ansip384r1, /* 1.3.132.0.34 */ 68 OID_sha256, /* 2.16.840.1.101.3.4.2.1 */ 69 OID_sha384, /* 2.16.840.1.101.3.4.2.2 */ 70 OID_sha512, /* 2.16.840.1.101.3.4.2.3 */ 71 OID_sha224, /* 2.16.840.1.101.3.4.2.4 */ 72 73 /* Distinguished Name attribute IDs [RFC 2256] */ 74 OID_commonName, /* 2.5.4.3 */ 75 OID_surname, /* 2.5.4.4 */ 76 OID_countryName, /* 2.5.4.6 */ 77 OID_locality, /* 2.5.4.7 */ 78 OID_stateOrProvinceName, /* 2.5.4.8 */ 79 OID_organizationName, /* 2.5.4.10 */ 80 OID_organizationUnitName, /* 2.5.4.11 */ 81 OID_title, /* 2.5.4.12 */ 82 OID_description, /* 2.5.4.13 */ 83 OID_name, /* 2.5.4.41 */ 84 OID_givenName, /* 2.5.4.42 */ 85 OID_initials, /* 2.5.4.43 */ 86 OID_generationalQualifier, /* 2.5.4.44 */ 87 88 /* Certificate extension IDs */ 89 OID_subjectKeyIdentifier, /* 2.5.29.14 */ 90 OID_keyUsage, /* 2.5.29.15 */ 91 OID_subjectAltName, /* 2.5.29.17 */ 92 OID_issuerAltName, /* 2.5.29.18 */ 93 OID_basicConstraints, /* 2.5.29.19 */ 94 OID_crlDistributionPoints, /* 2.5.29.31 */ 95 OID_certPolicies, /* 2.5.29.32 */ 96 OID_authorityKeyIdentifier, /* 2.5.29.35 */ 97 OID_extKeyUsage, /* 2.5.29.37 */ 98 99 /* EC-RDSA */ 100 OID_gostCPSignA, /* 1.2.643.2.2.35.1 */ 101 OID_gostCPSignB, /* 1.2.643.2.2.35.2 */ 102 OID_gostCPSignC, /* 1.2.643.2.2.35.3 */ 103 OID_gost2012PKey256, /* 1.2.643.7.1.1.1.1 */ 104 OID_gost2012PKey512, /* 1.2.643.7.1.1.1.2 */ 105 OID_gost2012Digest256, /* 1.2.643.7.1.1.2.2 */ 106 OID_gost2012Digest512, /* 1.2.643.7.1.1.2.3 */ 107 OID_gost2012Signature256, /* 1.2.643.7.1.1.3.2 */ 108 OID_gost2012Signature512, /* 1.2.643.7.1.1.3.3 */ 109 OID_gostTC26Sign256A, /* 1.2.643.7.1.2.1.1.1 */ 110 OID_gostTC26Sign256B, /* 1.2.643.7.1.2.1.1.2 */ 111 OID_gostTC26Sign256C, /* 1.2.643.7.1.2.1.1.3 */ 112 OID_gostTC26Sign256D, /* 1.2.643.7.1.2.1.1.4 */ 113 OID_gostTC26Sign512A, /* 1.2.643.7.1.2.1.2.1 */ 114 OID_gostTC26Sign512B, /* 1.2.643.7.1.2.1.2.2 */ 115 OID_gostTC26Sign512C, /* 1.2.643.7.1.2.1.2.3 */ 116 117 /* OSCCA */ 118 OID_sm2, /* 1.2.156.10197.1.301 */ 119 OID_sm3, /* 1.2.156.10197.1.401 */ 120 OID_SM2_with_SM3, /* 1.2.156.10197.1.501 */ 121 OID_sm3WithRSAEncryption, /* 1.2.156.10197.1.504 */ 122 123 /* TCG defined OIDS for TPM based keys */ 124 OID_TPMLoadableKey, /* 2.23.133.10.1.3 */ 125 OID_TPMImportableKey, /* 2.23.133.10.1.4 */ 126 OID_TPMSealedData, /* 2.23.133.10.1.5 */ 127 128 OID__NR 129 }; 130 131 extern enum OID look_up_OID(const void *data, size_t datasize); 132 extern int parse_OID(const void *data, size_t datasize, enum OID *oid); 133 extern int sprint_oid(const void *, size_t, char *, size_t); 134 extern int sprint_OID(enum OID, char *, size_t); 135 136 #endif /* _LINUX_OID_REGISTRY_H */ 137