diff options
Diffstat (limited to 'src/lib/libcrypto/asn1/x_req.c')
| -rw-r--r-- | src/lib/libcrypto/asn1/x_req.c | 54 |
1 files changed, 51 insertions, 3 deletions
diff --git a/src/lib/libcrypto/asn1/x_req.c b/src/lib/libcrypto/asn1/x_req.c index c876edd7f0..89b2d88d15 100644 --- a/src/lib/libcrypto/asn1/x_req.c +++ b/src/lib/libcrypto/asn1/x_req.c | |||
| @@ -1,4 +1,4 @@ | |||
| 1 | /* $OpenBSD: x_req.c,v 1.10 2014/07/11 08:44:47 jsing Exp $ */ | 1 | /* $OpenBSD: x_req.c,v 1.11 2015/02/09 15:05:59 jsing Exp $ */ |
| 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) | 2 | /* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com) |
| 3 | * All rights reserved. | 3 | * All rights reserved. |
| 4 | * | 4 | * |
| @@ -102,7 +102,31 @@ ASN1_SEQUENCE_enc(X509_REQ_INFO, enc, rinf_cb) = { | |||
| 102 | ASN1_IMP_SET_OF_OPT(X509_REQ_INFO, attributes, X509_ATTRIBUTE, 0) | 102 | ASN1_IMP_SET_OF_OPT(X509_REQ_INFO, attributes, X509_ATTRIBUTE, 0) |
| 103 | } ASN1_SEQUENCE_END_enc(X509_REQ_INFO, X509_REQ_INFO) | 103 | } ASN1_SEQUENCE_END_enc(X509_REQ_INFO, X509_REQ_INFO) |
| 104 | 104 | ||
| 105 | IMPLEMENT_ASN1_FUNCTIONS(X509_REQ_INFO) | 105 | |
| 106 | X509_REQ_INFO * | ||
| 107 | d2i_X509_REQ_INFO(X509_REQ_INFO **a, const unsigned char **in, long len) | ||
| 108 | { | ||
| 109 | return (X509_REQ_INFO *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
| 110 | &X509_REQ_INFO_it); | ||
| 111 | } | ||
| 112 | |||
| 113 | int | ||
| 114 | i2d_X509_REQ_INFO(X509_REQ_INFO *a, unsigned char **out) | ||
| 115 | { | ||
| 116 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &X509_REQ_INFO_it); | ||
| 117 | } | ||
| 118 | |||
| 119 | X509_REQ_INFO * | ||
| 120 | X509_REQ_INFO_new(void) | ||
| 121 | { | ||
| 122 | return (X509_REQ_INFO *)ASN1_item_new(&X509_REQ_INFO_it); | ||
| 123 | } | ||
| 124 | |||
| 125 | void | ||
| 126 | X509_REQ_INFO_free(X509_REQ_INFO *a) | ||
| 127 | { | ||
| 128 | ASN1_item_free((ASN1_VALUE *)a, &X509_REQ_INFO_it); | ||
| 129 | } | ||
| 106 | 130 | ||
| 107 | ASN1_SEQUENCE_ref(X509_REQ, 0, CRYPTO_LOCK_X509_REQ) = { | 131 | ASN1_SEQUENCE_ref(X509_REQ, 0, CRYPTO_LOCK_X509_REQ) = { |
| 108 | ASN1_SIMPLE(X509_REQ, req_info, X509_REQ_INFO), | 132 | ASN1_SIMPLE(X509_REQ, req_info, X509_REQ_INFO), |
| @@ -110,5 +134,29 @@ ASN1_SEQUENCE_ref(X509_REQ, 0, CRYPTO_LOCK_X509_REQ) = { | |||
| 110 | ASN1_SIMPLE(X509_REQ, signature, ASN1_BIT_STRING) | 134 | ASN1_SIMPLE(X509_REQ, signature, ASN1_BIT_STRING) |
| 111 | } ASN1_SEQUENCE_END_ref(X509_REQ, X509_REQ) | 135 | } ASN1_SEQUENCE_END_ref(X509_REQ, X509_REQ) |
| 112 | 136 | ||
| 113 | IMPLEMENT_ASN1_FUNCTIONS(X509_REQ) | 137 | |
| 138 | X509_REQ * | ||
| 139 | d2i_X509_REQ(X509_REQ **a, const unsigned char **in, long len) | ||
| 140 | { | ||
| 141 | return (X509_REQ *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
| 142 | &X509_REQ_it); | ||
| 143 | } | ||
| 144 | |||
| 145 | int | ||
| 146 | i2d_X509_REQ(X509_REQ *a, unsigned char **out) | ||
| 147 | { | ||
| 148 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &X509_REQ_it); | ||
| 149 | } | ||
| 150 | |||
| 151 | X509_REQ * | ||
| 152 | X509_REQ_new(void) | ||
| 153 | { | ||
| 154 | return (X509_REQ *)ASN1_item_new(&X509_REQ_it); | ||
| 155 | } | ||
| 156 | |||
| 157 | void | ||
| 158 | X509_REQ_free(X509_REQ *a) | ||
| 159 | { | ||
| 160 | ASN1_item_free((ASN1_VALUE *)a, &X509_REQ_it); | ||
| 161 | } | ||
| 114 | IMPLEMENT_ASN1_DUP_FUNCTION(X509_REQ) | 162 | IMPLEMENT_ASN1_DUP_FUNCTION(X509_REQ) |
