Path: blob/main/crypto/openssl/providers/common/include/prov/der_ec.h
48535 views
/*1* WARNING: do not edit!2* Generated by Makefile from providers/common/include/prov/der_ec.h.in3*4* Copyright 2020-2021 The OpenSSL Project Authors. All Rights Reserved.5*6* Licensed under the Apache License 2.0 (the "License"). You may not use7* this file except in compliance with the License. You can obtain a copy8* in the file LICENSE in the source distribution or at9* https://www.openssl.org/source/license.html10*/1112#include "crypto/ec.h"13#include "internal/der.h"1415/* Well known OIDs precompiled */1617/*18* ecdsa-with-SHA1 OBJECT IDENTIFIER ::= { id-ecSigType 1 }19*/20#define DER_OID_V_ecdsa_with_SHA1 DER_P_OBJECT, 7, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, 0x0121#define DER_OID_SZ_ecdsa_with_SHA1 922extern const unsigned char ossl_der_oid_ecdsa_with_SHA1[DER_OID_SZ_ecdsa_with_SHA1];2324/*25* id-ecPublicKey OBJECT IDENTIFIER ::= { id-publicKeyType 1 }26*/27#define DER_OID_V_id_ecPublicKey DER_P_OBJECT, 7, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x02, 0x0128#define DER_OID_SZ_id_ecPublicKey 929extern const unsigned char ossl_der_oid_id_ecPublicKey[DER_OID_SZ_id_ecPublicKey];3031/*32* c2pnb163v1 OBJECT IDENTIFIER ::= { c-TwoCurve 1 }33*/34#define DER_OID_V_c2pnb163v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0135#define DER_OID_SZ_c2pnb163v1 1036extern const unsigned char ossl_der_oid_c2pnb163v1[DER_OID_SZ_c2pnb163v1];3738/*39* c2pnb163v2 OBJECT IDENTIFIER ::= { c-TwoCurve 2 }40*/41#define DER_OID_V_c2pnb163v2 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0242#define DER_OID_SZ_c2pnb163v2 1043extern const unsigned char ossl_der_oid_c2pnb163v2[DER_OID_SZ_c2pnb163v2];4445/*46* c2pnb163v3 OBJECT IDENTIFIER ::= { c-TwoCurve 3 }47*/48#define DER_OID_V_c2pnb163v3 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0349#define DER_OID_SZ_c2pnb163v3 1050extern const unsigned char ossl_der_oid_c2pnb163v3[DER_OID_SZ_c2pnb163v3];5152/*53* c2pnb176w1 OBJECT IDENTIFIER ::= { c-TwoCurve 4 }54*/55#define DER_OID_V_c2pnb176w1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0456#define DER_OID_SZ_c2pnb176w1 1057extern const unsigned char ossl_der_oid_c2pnb176w1[DER_OID_SZ_c2pnb176w1];5859/*60* c2tnb191v1 OBJECT IDENTIFIER ::= { c-TwoCurve 5 }61*/62#define DER_OID_V_c2tnb191v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0563#define DER_OID_SZ_c2tnb191v1 1064extern const unsigned char ossl_der_oid_c2tnb191v1[DER_OID_SZ_c2tnb191v1];6566/*67* c2tnb191v2 OBJECT IDENTIFIER ::= { c-TwoCurve 6 }68*/69#define DER_OID_V_c2tnb191v2 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0670#define DER_OID_SZ_c2tnb191v2 1071extern const unsigned char ossl_der_oid_c2tnb191v2[DER_OID_SZ_c2tnb191v2];7273/*74* c2tnb191v3 OBJECT IDENTIFIER ::= { c-TwoCurve 7 }75*/76#define DER_OID_V_c2tnb191v3 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0777#define DER_OID_SZ_c2tnb191v3 1078extern const unsigned char ossl_der_oid_c2tnb191v3[DER_OID_SZ_c2tnb191v3];7980/*81* c2onb191v4 OBJECT IDENTIFIER ::= { c-TwoCurve 8 }82*/83#define DER_OID_V_c2onb191v4 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0884#define DER_OID_SZ_c2onb191v4 1085extern const unsigned char ossl_der_oid_c2onb191v4[DER_OID_SZ_c2onb191v4];8687/*88* c2onb191v5 OBJECT IDENTIFIER ::= { c-TwoCurve 9 }89*/90#define DER_OID_V_c2onb191v5 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0991#define DER_OID_SZ_c2onb191v5 1092extern const unsigned char ossl_der_oid_c2onb191v5[DER_OID_SZ_c2onb191v5];9394/*95* c2pnb208w1 OBJECT IDENTIFIER ::= { c-TwoCurve 10 }96*/97#define DER_OID_V_c2pnb208w1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0A98#define DER_OID_SZ_c2pnb208w1 1099extern const unsigned char ossl_der_oid_c2pnb208w1[DER_OID_SZ_c2pnb208w1];100101/*102* c2tnb239v1 OBJECT IDENTIFIER ::= { c-TwoCurve 11 }103*/104#define DER_OID_V_c2tnb239v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0B105#define DER_OID_SZ_c2tnb239v1 10106extern const unsigned char ossl_der_oid_c2tnb239v1[DER_OID_SZ_c2tnb239v1];107108/*109* c2tnb239v2 OBJECT IDENTIFIER ::= { c-TwoCurve 12 }110*/111#define DER_OID_V_c2tnb239v2 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0C112#define DER_OID_SZ_c2tnb239v2 10113extern const unsigned char ossl_der_oid_c2tnb239v2[DER_OID_SZ_c2tnb239v2];114115/*116* c2tnb239v3 OBJECT IDENTIFIER ::= { c-TwoCurve 13 }117*/118#define DER_OID_V_c2tnb239v3 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0D119#define DER_OID_SZ_c2tnb239v3 10120extern const unsigned char ossl_der_oid_c2tnb239v3[DER_OID_SZ_c2tnb239v3];121122/*123* c2onb239v4 OBJECT IDENTIFIER ::= { c-TwoCurve 14 }124*/125#define DER_OID_V_c2onb239v4 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0E126#define DER_OID_SZ_c2onb239v4 10127extern const unsigned char ossl_der_oid_c2onb239v4[DER_OID_SZ_c2onb239v4];128129/*130* c2onb239v5 OBJECT IDENTIFIER ::= { c-TwoCurve 15 }131*/132#define DER_OID_V_c2onb239v5 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x0F133#define DER_OID_SZ_c2onb239v5 10134extern const unsigned char ossl_der_oid_c2onb239v5[DER_OID_SZ_c2onb239v5];135136/*137* c2pnb272w1 OBJECT IDENTIFIER ::= { c-TwoCurve 16 }138*/139#define DER_OID_V_c2pnb272w1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x10140#define DER_OID_SZ_c2pnb272w1 10141extern const unsigned char ossl_der_oid_c2pnb272w1[DER_OID_SZ_c2pnb272w1];142143/*144* c2pnb304w1 OBJECT IDENTIFIER ::= { c-TwoCurve 17 }145*/146#define DER_OID_V_c2pnb304w1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x11147#define DER_OID_SZ_c2pnb304w1 10148extern const unsigned char ossl_der_oid_c2pnb304w1[DER_OID_SZ_c2pnb304w1];149150/*151* c2tnb359v1 OBJECT IDENTIFIER ::= { c-TwoCurve 18 }152*/153#define DER_OID_V_c2tnb359v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x12154#define DER_OID_SZ_c2tnb359v1 10155extern const unsigned char ossl_der_oid_c2tnb359v1[DER_OID_SZ_c2tnb359v1];156157/*158* c2pnb368w1 OBJECT IDENTIFIER ::= { c-TwoCurve 19 }159*/160#define DER_OID_V_c2pnb368w1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x13161#define DER_OID_SZ_c2pnb368w1 10162extern const unsigned char ossl_der_oid_c2pnb368w1[DER_OID_SZ_c2pnb368w1];163164/*165* c2tnb431r1 OBJECT IDENTIFIER ::= { c-TwoCurve 20 }166*/167#define DER_OID_V_c2tnb431r1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x00, 0x14168#define DER_OID_SZ_c2tnb431r1 10169extern const unsigned char ossl_der_oid_c2tnb431r1[DER_OID_SZ_c2tnb431r1];170171/*172* prime192v1 OBJECT IDENTIFIER ::= { primeCurve 1 }173*/174#define DER_OID_V_prime192v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x01175#define DER_OID_SZ_prime192v1 10176extern const unsigned char ossl_der_oid_prime192v1[DER_OID_SZ_prime192v1];177178/*179* prime192v2 OBJECT IDENTIFIER ::= { primeCurve 2 }180*/181#define DER_OID_V_prime192v2 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x02182#define DER_OID_SZ_prime192v2 10183extern const unsigned char ossl_der_oid_prime192v2[DER_OID_SZ_prime192v2];184185/*186* prime192v3 OBJECT IDENTIFIER ::= { primeCurve 3 }187*/188#define DER_OID_V_prime192v3 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x03189#define DER_OID_SZ_prime192v3 10190extern const unsigned char ossl_der_oid_prime192v3[DER_OID_SZ_prime192v3];191192/*193* prime239v1 OBJECT IDENTIFIER ::= { primeCurve 4 }194*/195#define DER_OID_V_prime239v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x04196#define DER_OID_SZ_prime239v1 10197extern const unsigned char ossl_der_oid_prime239v1[DER_OID_SZ_prime239v1];198199/*200* prime239v2 OBJECT IDENTIFIER ::= { primeCurve 5 }201*/202#define DER_OID_V_prime239v2 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x05203#define DER_OID_SZ_prime239v2 10204extern const unsigned char ossl_der_oid_prime239v2[DER_OID_SZ_prime239v2];205206/*207* prime239v3 OBJECT IDENTIFIER ::= { primeCurve 6 }208*/209#define DER_OID_V_prime239v3 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x06210#define DER_OID_SZ_prime239v3 10211extern const unsigned char ossl_der_oid_prime239v3[DER_OID_SZ_prime239v3];212213/*214* prime256v1 OBJECT IDENTIFIER ::= { primeCurve 7 }215*/216#define DER_OID_V_prime256v1 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x03, 0x01, 0x07217#define DER_OID_SZ_prime256v1 10218extern const unsigned char ossl_der_oid_prime256v1[DER_OID_SZ_prime256v1];219220/*221* ecdsa-with-SHA224 OBJECT IDENTIFIER ::= { iso(1) member-body(2)222* us(840) ansi-X9-62(10045) signatures(4) ecdsa-with-SHA2(3) 1 }223*/224#define DER_OID_V_ecdsa_with_SHA224 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, 0x03, 0x01225#define DER_OID_SZ_ecdsa_with_SHA224 10226extern const unsigned char ossl_der_oid_ecdsa_with_SHA224[DER_OID_SZ_ecdsa_with_SHA224];227228/*229* ecdsa-with-SHA256 OBJECT IDENTIFIER ::= { iso(1) member-body(2)230* us(840) ansi-X9-62(10045) signatures(4) ecdsa-with-SHA2(3) 2 }231*/232#define DER_OID_V_ecdsa_with_SHA256 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, 0x03, 0x02233#define DER_OID_SZ_ecdsa_with_SHA256 10234extern const unsigned char ossl_der_oid_ecdsa_with_SHA256[DER_OID_SZ_ecdsa_with_SHA256];235236/*237* ecdsa-with-SHA384 OBJECT IDENTIFIER ::= { iso(1) member-body(2)238* us(840) ansi-X9-62(10045) signatures(4) ecdsa-with-SHA2(3) 3 }239*/240#define DER_OID_V_ecdsa_with_SHA384 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, 0x03, 0x03241#define DER_OID_SZ_ecdsa_with_SHA384 10242extern const unsigned char ossl_der_oid_ecdsa_with_SHA384[DER_OID_SZ_ecdsa_with_SHA384];243244/*245* ecdsa-with-SHA512 OBJECT IDENTIFIER ::= { iso(1) member-body(2)246* us(840) ansi-X9-62(10045) signatures(4) ecdsa-with-SHA2(3) 4 }247*/248#define DER_OID_V_ecdsa_with_SHA512 DER_P_OBJECT, 8, 0x2A, 0x86, 0x48, 0xCE, 0x3D, 0x04, 0x03, 0x04249#define DER_OID_SZ_ecdsa_with_SHA512 10250extern const unsigned char ossl_der_oid_ecdsa_with_SHA512[DER_OID_SZ_ecdsa_with_SHA512];251252/*253* id-ecdsa-with-sha3-224 OBJECT IDENTIFIER ::= { sigAlgs 9 }254*/255#define DER_OID_V_id_ecdsa_with_sha3_224 DER_P_OBJECT, 9, 0x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x03, 0x09256#define DER_OID_SZ_id_ecdsa_with_sha3_224 11257extern const unsigned char ossl_der_oid_id_ecdsa_with_sha3_224[DER_OID_SZ_id_ecdsa_with_sha3_224];258259/*260* id-ecdsa-with-sha3-256 OBJECT IDENTIFIER ::= { sigAlgs 10 }261*/262#define DER_OID_V_id_ecdsa_with_sha3_256 DER_P_OBJECT, 9, 0x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x03, 0x0A263#define DER_OID_SZ_id_ecdsa_with_sha3_256 11264extern const unsigned char ossl_der_oid_id_ecdsa_with_sha3_256[DER_OID_SZ_id_ecdsa_with_sha3_256];265266/*267* id-ecdsa-with-sha3-384 OBJECT IDENTIFIER ::= { sigAlgs 11 }268*/269#define DER_OID_V_id_ecdsa_with_sha3_384 DER_P_OBJECT, 9, 0x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x03, 0x0B270#define DER_OID_SZ_id_ecdsa_with_sha3_384 11271extern const unsigned char ossl_der_oid_id_ecdsa_with_sha3_384[DER_OID_SZ_id_ecdsa_with_sha3_384];272273/*274* id-ecdsa-with-sha3-512 OBJECT IDENTIFIER ::= { sigAlgs 12 }275*/276#define DER_OID_V_id_ecdsa_with_sha3_512 DER_P_OBJECT, 9, 0x60, 0x86, 0x48, 0x01, 0x65, 0x03, 0x04, 0x03, 0x0C277#define DER_OID_SZ_id_ecdsa_with_sha3_512 11278extern const unsigned char ossl_der_oid_id_ecdsa_with_sha3_512[DER_OID_SZ_id_ecdsa_with_sha3_512];279280281/* Subject Public Key Info */282int ossl_DER_w_algorithmIdentifier_EC(WPACKET *pkt, int cont, EC_KEY *ec);283/* Signature */284int ossl_DER_w_algorithmIdentifier_ECDSA_with_MD(WPACKET *pkt, int cont,285EC_KEY *ec, int mdnid);286287288