linux/include/linux/oid_registry.h
<<
>>
Prefs
   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 */
 145