1*5c591343SA. Cody Schuffelen /* Microsoft Reference Implementation for TPM 2.0 2*5c591343SA. Cody Schuffelen * 3*5c591343SA. Cody Schuffelen * The copyright in this software is being made available under the BSD License, 4*5c591343SA. Cody Schuffelen * included below. This software may be subject to other third party and 5*5c591343SA. Cody Schuffelen * contributor rights, including patent rights, and no such rights are granted 6*5c591343SA. Cody Schuffelen * under this license. 7*5c591343SA. Cody Schuffelen * 8*5c591343SA. Cody Schuffelen * Copyright (c) Microsoft Corporation 9*5c591343SA. Cody Schuffelen * 10*5c591343SA. Cody Schuffelen * All rights reserved. 11*5c591343SA. Cody Schuffelen * 12*5c591343SA. Cody Schuffelen * BSD License 13*5c591343SA. Cody Schuffelen * 14*5c591343SA. Cody Schuffelen * Redistribution and use in source and binary forms, with or without modification, 15*5c591343SA. Cody Schuffelen * are permitted provided that the following conditions are met: 16*5c591343SA. Cody Schuffelen * 17*5c591343SA. Cody Schuffelen * Redistributions of source code must retain the above copyright notice, this list 18*5c591343SA. Cody Schuffelen * of conditions and the following disclaimer. 19*5c591343SA. Cody Schuffelen * 20*5c591343SA. Cody Schuffelen * Redistributions in binary form must reproduce the above copyright notice, this 21*5c591343SA. Cody Schuffelen * list of conditions and the following disclaimer in the documentation and/or 22*5c591343SA. Cody Schuffelen * other materials provided with the distribution. 23*5c591343SA. Cody Schuffelen * 24*5c591343SA. Cody Schuffelen * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ""AS IS"" 25*5c591343SA. Cody Schuffelen * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 26*5c591343SA. Cody Schuffelen * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 27*5c591343SA. Cody Schuffelen * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR 28*5c591343SA. Cody Schuffelen * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 29*5c591343SA. Cody Schuffelen * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 30*5c591343SA. Cody Schuffelen * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON 31*5c591343SA. Cody Schuffelen * ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 32*5c591343SA. Cody Schuffelen * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS 33*5c591343SA. Cody Schuffelen * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 34*5c591343SA. Cody Schuffelen */ 35*5c591343SA. Cody Schuffelen 36*5c591343SA. Cody Schuffelen #ifndef _OIDS_H_ 37*5c591343SA. Cody Schuffelen #define _OIDS_H_ 38*5c591343SA. Cody Schuffelen 39*5c591343SA. Cody Schuffelen // All the OIDs in this file are defined as DER-encoded values with a leading tag 40*5c591343SA. Cody Schuffelen // 0x06 (ASN1_OBJECT_IDENTIFIER), followed by a single length byte. This allows the 41*5c591343SA. Cody Schuffelen // OID size to be determined by looking at octet[1] of the OID (total size is 42*5c591343SA. Cody Schuffelen // OID[1] + 2). 43*5c591343SA. Cody Schuffelen 44*5c591343SA. Cody Schuffelen // These macros allow OIDs to be defined (or not) depending on whether the associated 45*5c591343SA. Cody Schuffelen // hash algorithm is implemented. 46*5c591343SA. Cody Schuffelen // NOTE: When one of these macros is used, the NAME needs '_" on each side. The 47*5c591343SA. Cody Schuffelen // exception is when the macro is used for the hash OID when only a single '_' is 48*5c591343SA. Cody Schuffelen // used. 49*5c591343SA. Cody Schuffelen #ifndef ALG_SHA1 50*5c591343SA. Cody Schuffelen # define ALG_SHA1 NO 51*5c591343SA. Cody Schuffelen #endif 52*5c591343SA. Cody Schuffelen #if ALG_SHA1 53*5c591343SA. Cody Schuffelen #define SHA1_OID(NAME) MAKE_OID(NAME##SHA1) 54*5c591343SA. Cody Schuffelen #else 55*5c591343SA. Cody Schuffelen #define SHA1_OID(NAME) 56*5c591343SA. Cody Schuffelen #endif 57*5c591343SA. Cody Schuffelen #ifndef ALG_SHA256 58*5c591343SA. Cody Schuffelen # define ALG_SHA256 NO 59*5c591343SA. Cody Schuffelen #endif 60*5c591343SA. Cody Schuffelen #if ALG_SHA256 61*5c591343SA. Cody Schuffelen #define SHA256_OID(NAME) MAKE_OID(NAME##SHA256) 62*5c591343SA. Cody Schuffelen #else 63*5c591343SA. Cody Schuffelen #define SHA256_OID(NAME) 64*5c591343SA. Cody Schuffelen #endif 65*5c591343SA. Cody Schuffelen #ifndef ALG_SHA384 66*5c591343SA. Cody Schuffelen # define ALG_SHA384 NO 67*5c591343SA. Cody Schuffelen #endif 68*5c591343SA. Cody Schuffelen #if ALG_SHA384 69*5c591343SA. Cody Schuffelen #define SHA384_OID(NAME) MAKE_OID(NAME##SHA384) 70*5c591343SA. Cody Schuffelen #else 71*5c591343SA. Cody Schuffelen #define SHA384_OID(NAME) 72*5c591343SA. Cody Schuffelen #endif 73*5c591343SA. Cody Schuffelen #ifndef ALG_SHA512 74*5c591343SA. Cody Schuffelen # define ALG_SHA512 NO 75*5c591343SA. Cody Schuffelen #endif 76*5c591343SA. Cody Schuffelen #if ALG_SHA512 77*5c591343SA. Cody Schuffelen #define SHA512_OID(NAME) MAKE_OID(NAME##SHA512) 78*5c591343SA. Cody Schuffelen #else 79*5c591343SA. Cody Schuffelen #define SHA512_OID(NAME) 80*5c591343SA. Cody Schuffelen #endif 81*5c591343SA. Cody Schuffelen #ifndef ALG_SM3_256 82*5c591343SA. Cody Schuffelen # define ALG_SM3_256 NO 83*5c591343SA. Cody Schuffelen #endif 84*5c591343SA. Cody Schuffelen #if ALG_SM3_256 85*5c591343SA. Cody Schuffelen #define SM3_256_OID(NAME) MAKE_OID(NAME##SM3_256) 86*5c591343SA. Cody Schuffelen #else 87*5c591343SA. Cody Schuffelen #define SM3_256_OID(NAME) 88*5c591343SA. Cody Schuffelen #endif 89*5c591343SA. Cody Schuffelen #ifndef ALG_SHA3_256 90*5c591343SA. Cody Schuffelen # define ALG_SHA3_256 NO 91*5c591343SA. Cody Schuffelen #endif 92*5c591343SA. Cody Schuffelen #if ALG_SHA3_256 93*5c591343SA. Cody Schuffelen #define SHA3_256_OID(NAME) MAKE_OID(NAME##SHA3_256) 94*5c591343SA. Cody Schuffelen #else 95*5c591343SA. Cody Schuffelen #define SHA3_256_OID(NAME) 96*5c591343SA. Cody Schuffelen #endif 97*5c591343SA. Cody Schuffelen #ifndef ALG_SHA3_384 98*5c591343SA. Cody Schuffelen # define ALG_SHA3_384 NO 99*5c591343SA. Cody Schuffelen #endif 100*5c591343SA. Cody Schuffelen #if ALG_SHA3_384 101*5c591343SA. Cody Schuffelen #define SHA3_384_OID(NAME) MAKE_OID(NAME##SHA3_384) 102*5c591343SA. Cody Schuffelen #else 103*5c591343SA. Cody Schuffelen #define SHA3_384_OID(NAME) 104*5c591343SA. Cody Schuffelen #endif 105*5c591343SA. Cody Schuffelen #ifndef ALG_SHA3_512 106*5c591343SA. Cody Schuffelen # define ALG_SHA3_512 NO 107*5c591343SA. Cody Schuffelen #endif 108*5c591343SA. Cody Schuffelen #if ALG_SHA3_512 109*5c591343SA. Cody Schuffelen #define SHA3_512_OID(NAME) MAKE_OID(NAME##SHA3_512) 110*5c591343SA. Cody Schuffelen #else 111*5c591343SA. Cody Schuffelen #define SHA3_512_OID(NAME) 112*5c591343SA. Cody Schuffelen #endif 113*5c591343SA. Cody Schuffelen 114*5c591343SA. Cody Schuffelen // These are encoded to take one additional byte of algorithm selector 115*5c591343SA. Cody Schuffelen #define NIST_HASH 0x06, 0x09, 0x60, 0x86, 0x48, 1, 101, 3, 4, 2 116*5c591343SA. Cody Schuffelen #define NIST_SIG 0x06, 0x09, 0x60, 0x86, 0x48, 1, 101, 3, 4, 3 117*5c591343SA. Cody Schuffelen 118*5c591343SA. Cody Schuffelen // These hash OIDs used in a lot of places. 119*5c591343SA. Cody Schuffelen #define OID_SHA1_VALUE 0x06, 0x05, 0x2B, 0x0E, 0x03, 0x02, 0x1A 120*5c591343SA. Cody Schuffelen SHA1_OID(_); // Expands to: 121*5c591343SA. Cody Schuffelen // MAKE_OID(_SHA1) 122*5c591343SA. Cody Schuffelen // which expands to: 123*5c591343SA. Cody Schuffelen // EXTERN const BYTE OID_SHA1[] INITIALIZER({OID_SHA1_VALUE}) 124*5c591343SA. Cody Schuffelen // which, depending on the setting of EXTERN and 125*5c591343SA. Cody Schuffelen // INITIALIZER, expands to either: 126*5c591343SA. Cody Schuffelen // extern const BYTE OID_SHA1[] 127*5c591343SA. Cody Schuffelen // or 128*5c591343SA. Cody Schuffelen // const BYTE OID_SHA1[] = {OID_SHA1_VALUE} 129*5c591343SA. Cody Schuffelen // which is: 130*5c591343SA. Cody Schuffelen // const BYTE OID_SHA1[] = {0x06, 0x05, 0x2B, 0x0E, 131*5c591343SA. Cody Schuffelen // 0x03, 0x02, 0x1A} 132*5c591343SA. Cody Schuffelen 133*5c591343SA. Cody Schuffelen 134*5c591343SA. Cody Schuffelen #define OID_SHA256_VALUE NIST_HASH, 1 135*5c591343SA. Cody Schuffelen SHA256_OID(_); 136*5c591343SA. Cody Schuffelen 137*5c591343SA. Cody Schuffelen #define OID_SHA384_VALUE NIST_HASH, 2 138*5c591343SA. Cody Schuffelen SHA384_OID(_); 139*5c591343SA. Cody Schuffelen 140*5c591343SA. Cody Schuffelen #define OID_SHA512_VALUE NIST_HASH, 3 141*5c591343SA. Cody Schuffelen SHA512_OID(_); 142*5c591343SA. Cody Schuffelen 143*5c591343SA. Cody Schuffelen #define OID_SM3_256_VALUE 0x06, 0x08, 0x2A, 0x81, 0x1C, 0xCF, 0x55, 0x01, \ 144*5c591343SA. Cody Schuffelen 0x83, 0x11 145*5c591343SA. Cody Schuffelen SM3_256_OID(_); // (1.2.156.10197.1.401) 146*5c591343SA. Cody Schuffelen 147*5c591343SA. Cody Schuffelen #define OID_SHA3_256_VALUE NIST_HASH, 8 148*5c591343SA. Cody Schuffelen SHA3_256_OID(_); 149*5c591343SA. Cody Schuffelen 150*5c591343SA. Cody Schuffelen #define OID_SHA3_384_VALUE NIST_HASH, 9 151*5c591343SA. Cody Schuffelen SHA3_384_OID(_); 152*5c591343SA. Cody Schuffelen 153*5c591343SA. Cody Schuffelen #define OID_SHA3_512_VALUE NIST_HASH, 10 154*5c591343SA. Cody Schuffelen SHA3_512_OID(_); 155*5c591343SA. Cody Schuffelen 156*5c591343SA. Cody Schuffelen // These are used for RSA-PSS 157*5c591343SA. Cody Schuffelen #if ALG_RSA 158*5c591343SA. Cody Schuffelen 159*5c591343SA. Cody Schuffelen #define OID_MGF1_VALUE 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, \ 160*5c591343SA. Cody Schuffelen 0x01, 0x01, 0x08 161*5c591343SA. Cody Schuffelen MAKE_OID(_MGF1); 162*5c591343SA. Cody Schuffelen 163*5c591343SA. Cody Schuffelen #define OID_RSAPSS_VALUE 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, \ 164*5c591343SA. Cody Schuffelen 0x01, 0x01, 0x0A 165*5c591343SA. Cody Schuffelen MAKE_OID(_RSAPSS); 166*5c591343SA. Cody Schuffelen 167*5c591343SA. Cody Schuffelen // This is the OID to designate the public part of an RSA key. 168*5c591343SA. Cody Schuffelen #define OID_PKCS1_PUB_VALUE 0x06, 0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, 0x0D, \ 169*5c591343SA. Cody Schuffelen 0x01, 0x01, 0x01 170*5c591343SA. Cody Schuffelen MAKE_OID(_PKCS1_PUB); 171*5c591343SA. Cody Schuffelen 172*5c591343SA. Cody Schuffelen // These are used for RSA PKCS1 signature Algorithms 173*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA1_VALUE 0x06,0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, \ 174*5c591343SA. Cody Schuffelen 0x0D, 0x01, 0x01, 0x05 175*5c591343SA. Cody Schuffelen SHA1_OID(_PKCS1_); // (1.2.840.113549.1.1.5) 176*5c591343SA. Cody Schuffelen 177*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA256_VALUE 0x06,0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, \ 178*5c591343SA. Cody Schuffelen 0x0D, 0x01, 0x01, 0x0B 179*5c591343SA. Cody Schuffelen SHA256_OID(_PKCS1_); // (1.2.840.113549.1.1.11) 180*5c591343SA. Cody Schuffelen 181*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA384_VALUE 0x06,0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, \ 182*5c591343SA. Cody Schuffelen 0x0D, 0x01, 0x01, 0x0C 183*5c591343SA. Cody Schuffelen SHA384_OID(_PKCS1_); // (1.2.840.113549.1.1.12) 184*5c591343SA. Cody Schuffelen 185*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA512_VALUE 0x06,0x09, 0x2A, 0x86, 0x48, 0x86, 0xF7, \ 186*5c591343SA. Cody Schuffelen 0x0D, 0x01, 0x01, 0x0D 187*5c591343SA. Cody Schuffelen SHA512_OID(_PKCS1_); //(1.2.840.113549.1.1.13) 188*5c591343SA. Cody Schuffelen 189*5c591343SA. Cody Schuffelen #define OID_PKCS1_SM3_256_VALUE 0x06, 0x08, 0x2A, 0x81, 0x1C, 0xCF, 0x55, \ 190*5c591343SA. Cody Schuffelen 0x01, 0x83, 0x78 191*5c591343SA. Cody Schuffelen SM3_256_OID(_PKCS1_); // 1.2.156.10197.1.504 192*5c591343SA. Cody Schuffelen 193*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA3_256_VALUE NIST_SIG, 14 194*5c591343SA. Cody Schuffelen SHA3_256_OID(_PKCS1_); 195*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA3_384_VALUE NIST_SIG, 15 196*5c591343SA. Cody Schuffelen SHA3_384_OID(_PKCS1_); 197*5c591343SA. Cody Schuffelen #define OID_PKCS1_SHA3_512_VALUE NIST_SIG, 16 198*5c591343SA. Cody Schuffelen SHA3_512_OID(_PKCS1_); 199*5c591343SA. Cody Schuffelen 200*5c591343SA. Cody Schuffelen #endif // ALG_RSA 201*5c591343SA. Cody Schuffelen 202*5c591343SA. Cody Schuffelen #if ALG_ECDSA 203*5c591343SA. Cody Schuffelen 204*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA1_VALUE 0x06, 0x07, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, \ 205*5c591343SA. Cody Schuffelen 0x01 206*5c591343SA. Cody Schuffelen SHA1_OID(_ECDSA_); // (1.2.840.10045.4.1) SHA1 digest signed by an ECDSA key. 207*5c591343SA. Cody Schuffelen 208*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA256_VALUE 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, \ 209*5c591343SA. Cody Schuffelen 0x03, 0x02 210*5c591343SA. Cody Schuffelen SHA256_OID(_ECDSA_); // (1.2.840.10045.4.3.2) SHA256 digest signed by an ECDSA key. 211*5c591343SA. Cody Schuffelen 212*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA384_VALUE 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, \ 213*5c591343SA. Cody Schuffelen 0x03, 0x03 214*5c591343SA. Cody Schuffelen SHA384_OID(_ECDSA_); // (1.2.840.10045.4.3.3) SHA384 digest signed by an ECDSA key. 215*5c591343SA. Cody Schuffelen 216*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA512_VALUE 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, \ 217*5c591343SA. Cody Schuffelen 0x03, 0x04 218*5c591343SA. Cody Schuffelen SHA512_OID(_ECDSA_); // (1.2.840.10045.4.3.4) SHA512 digest signed by an ECDSA key. 219*5c591343SA. Cody Schuffelen 220*5c591343SA. Cody Schuffelen #define OID_ECDSA_SM3_256_VALUE 0x06, 0x08, 0x2A, 0x81, 0x1C, 0xCF, 0x55, 0x01, \ 221*5c591343SA. Cody Schuffelen 0x83, 0x75 222*5c591343SA. Cody Schuffelen SM3_256_OID(_ECDSA_); // 1.2.156.10197.1.501 223*5c591343SA. Cody Schuffelen 224*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA3_256_VALUE NIST_SIG, 10 225*5c591343SA. Cody Schuffelen SHA3_256_OID(_ECDSA_); 226*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA3_384_VALUE NIST_SIG, 11 227*5c591343SA. Cody Schuffelen SHA3_384_OID(_ECDSA_); 228*5c591343SA. Cody Schuffelen #define OID_ECDSA_SHA3_512_VALUE NIST_SIG, 12 229*5c591343SA. Cody Schuffelen SHA3_512_OID(_ECDSA_); 230*5c591343SA. Cody Schuffelen 231*5c591343SA. Cody Schuffelen #endif // ALG_ECDSA 232*5c591343SA. Cody Schuffelen 233*5c591343SA. Cody Schuffelen #if ALG_ECC 234*5c591343SA. Cody Schuffelen 235*5c591343SA. Cody Schuffelen #define OID_ECC_PUBLIC_VALUE 0x06, 0x07, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x02, \ 236*5c591343SA. Cody Schuffelen 0x01 237*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_PUBLIC); 238*5c591343SA. Cody Schuffelen 239*5c591343SA. Cody Schuffelen 240*5c591343SA. Cody Schuffelen #define OID_ECC_NIST_P192_VALUE 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, \ 241*5c591343SA. Cody Schuffelen 0x01, 0x01 242*5c591343SA. Cody Schuffelen #if ECC_NIST_P192 243*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_NIST_P192); // (1.2.840.10045.3.1.1) 'nistP192' 244*5c591343SA. Cody Schuffelen #endif // ECC_NIST_P192 245*5c591343SA. Cody Schuffelen 246*5c591343SA. Cody Schuffelen #define OID_ECC_NIST_P224_VALUE 0x06, 0x05, 0x2B, 0x81, 0x04, 0x00, 0x21 247*5c591343SA. Cody Schuffelen #if ECC_NIST_P224 248*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_NIST_P224); // (1.3.132.0.33) 'nistP224' 249*5c591343SA. Cody Schuffelen #endif // ECC_NIST_P224 250*5c591343SA. Cody Schuffelen 251*5c591343SA. Cody Schuffelen #define OID_ECC_NIST_P256_VALUE 0x06, 0x08, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, \ 252*5c591343SA. Cody Schuffelen 0x01, 0x07 253*5c591343SA. Cody Schuffelen #if ECC_NIST_P256 254*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_NIST_P256); // (1.2.840.10045.3.1.7) 'nistP256' 255*5c591343SA. Cody Schuffelen #endif // ECC_NIST_P256 256*5c591343SA. Cody Schuffelen 257*5c591343SA. Cody Schuffelen #define OID_ECC_NIST_P384_VALUE 0x06, 0x05, 0x2B, 0x81, 0x04, 0x00, 0x22 258*5c591343SA. Cody Schuffelen #if ECC_NIST_P384 259*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_NIST_P384); // (1.3.132.0.34) 'nistP384' 260*5c591343SA. Cody Schuffelen #endif // ECC_NIST_P384 261*5c591343SA. Cody Schuffelen 262*5c591343SA. Cody Schuffelen #define OID_ECC_NIST_P521_VALUE 0x06, 0x05, 0x2B, 0x81, 0x04, 0x00, 0x23 263*5c591343SA. Cody Schuffelen #if ECC_NIST_P521 264*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_NIST_P521); // (1.3.132.0.35) 'nistP521' 265*5c591343SA. Cody Schuffelen #endif // ECC_NIST_P521 266*5c591343SA. Cody Schuffelen 267*5c591343SA. Cody Schuffelen // No OIDs defined for these anonymous curves 268*5c591343SA. Cody Schuffelen #define OID_ECC_BN_P256_VALUE 0x00 269*5c591343SA. Cody Schuffelen #if ECC_BN_P256 270*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_BN_P256); 271*5c591343SA. Cody Schuffelen #endif // ECC_BN_P256 272*5c591343SA. Cody Schuffelen 273*5c591343SA. Cody Schuffelen #define OID_ECC_BN_P638_VALUE 0x00 274*5c591343SA. Cody Schuffelen #if ECC_BN_P638 275*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_BN_P638); 276*5c591343SA. Cody Schuffelen #endif // ECC_BN_P638 277*5c591343SA. Cody Schuffelen 278*5c591343SA. Cody Schuffelen #define OID_ECC_SM2_P256_VALUE 0x06, 0x08, 0x2A, 0x81, 0x1C, 0xCF, 0x55, 0x01, \ 279*5c591343SA. Cody Schuffelen 0x82, 0x2D 280*5c591343SA. Cody Schuffelen #if ECC_SM2_P256 281*5c591343SA. Cody Schuffelen MAKE_OID(_ECC_SM2_P256); // Don't know where I found this OID. It needs checking 282*5c591343SA. Cody Schuffelen #endif // ECC_SM2_P256 283*5c591343SA. Cody Schuffelen 284*5c591343SA. Cody Schuffelen #if ECC_BN_P256 285*5c591343SA. Cody Schuffelen #define OID_ECC_BN_P256 NULL 286*5c591343SA. Cody Schuffelen #endif // ECC_BN_P256 287*5c591343SA. Cody Schuffelen 288*5c591343SA. Cody Schuffelen #endif // ALG_ECC 289*5c591343SA. Cody Schuffelen 290*5c591343SA. Cody Schuffelen #define OID_SIZE(OID) (OID[1] + 2) 291*5c591343SA. Cody Schuffelen 292*5c591343SA. Cody Schuffelen #endif // !_OIDS_H_ 293