diff options
Diffstat (limited to 'src/lib/libcrypto/asn1/x_x509.c')
-rw-r--r-- | src/lib/libcrypto/asn1/x_x509.c | 54 |
1 files changed, 51 insertions, 3 deletions
diff --git a/src/lib/libcrypto/asn1/x_x509.c b/src/lib/libcrypto/asn1/x_x509.c index 0236a0faa2..8fd2d7684b 100644 --- a/src/lib/libcrypto/asn1/x_x509.c +++ b/src/lib/libcrypto/asn1/x_x509.c | |||
@@ -1,4 +1,4 @@ | |||
1 | /* $OpenBSD: x_x509.c,v 1.17 2014/07/11 08:44:47 jsing Exp $ */ | 1 | /* $OpenBSD: x_x509.c,v 1.18 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 | * |
@@ -78,7 +78,31 @@ ASN1_SEQUENCE_enc(X509_CINF, enc, 0) = { | |||
78 | ASN1_EXP_SEQUENCE_OF_OPT(X509_CINF, extensions, X509_EXTENSION, 3) | 78 | ASN1_EXP_SEQUENCE_OF_OPT(X509_CINF, extensions, X509_EXTENSION, 3) |
79 | } ASN1_SEQUENCE_END_enc(X509_CINF, X509_CINF) | 79 | } ASN1_SEQUENCE_END_enc(X509_CINF, X509_CINF) |
80 | 80 | ||
81 | IMPLEMENT_ASN1_FUNCTIONS(X509_CINF) | 81 | |
82 | X509_CINF * | ||
83 | d2i_X509_CINF(X509_CINF **a, const unsigned char **in, long len) | ||
84 | { | ||
85 | return (X509_CINF *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
86 | &X509_CINF_it); | ||
87 | } | ||
88 | |||
89 | int | ||
90 | i2d_X509_CINF(X509_CINF *a, unsigned char **out) | ||
91 | { | ||
92 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &X509_CINF_it); | ||
93 | } | ||
94 | |||
95 | X509_CINF * | ||
96 | X509_CINF_new(void) | ||
97 | { | ||
98 | return (X509_CINF *)ASN1_item_new(&X509_CINF_it); | ||
99 | } | ||
100 | |||
101 | void | ||
102 | X509_CINF_free(X509_CINF *a) | ||
103 | { | ||
104 | ASN1_item_free((ASN1_VALUE *)a, &X509_CINF_it); | ||
105 | } | ||
82 | /* X509 top level structure needs a bit of customisation */ | 106 | /* X509 top level structure needs a bit of customisation */ |
83 | 107 | ||
84 | extern void policy_cache_free(X509_POLICY_CACHE *cache); | 108 | extern void policy_cache_free(X509_POLICY_CACHE *cache); |
@@ -138,7 +162,31 @@ ASN1_SEQUENCE_ref(X509, x509_cb, CRYPTO_LOCK_X509) = { | |||
138 | ASN1_SIMPLE(X509, signature, ASN1_BIT_STRING) | 162 | ASN1_SIMPLE(X509, signature, ASN1_BIT_STRING) |
139 | } ASN1_SEQUENCE_END_ref(X509, X509) | 163 | } ASN1_SEQUENCE_END_ref(X509, X509) |
140 | 164 | ||
141 | IMPLEMENT_ASN1_FUNCTIONS(X509) | 165 | |
166 | X509 * | ||
167 | d2i_X509(X509 **a, const unsigned char **in, long len) | ||
168 | { | ||
169 | return (X509 *)ASN1_item_d2i((ASN1_VALUE **)a, in, len, | ||
170 | &X509_it); | ||
171 | } | ||
172 | |||
173 | int | ||
174 | i2d_X509(X509 *a, unsigned char **out) | ||
175 | { | ||
176 | return ASN1_item_i2d((ASN1_VALUE *)a, out, &X509_it); | ||
177 | } | ||
178 | |||
179 | X509 * | ||
180 | X509_new(void) | ||
181 | { | ||
182 | return (X509 *)ASN1_item_new(&X509_it); | ||
183 | } | ||
184 | |||
185 | void | ||
186 | X509_free(X509 *a) | ||
187 | { | ||
188 | ASN1_item_free((ASN1_VALUE *)a, &X509_it); | ||
189 | } | ||
142 | IMPLEMENT_ASN1_DUP_FUNCTION(X509) | 190 | IMPLEMENT_ASN1_DUP_FUNCTION(X509) |
143 | 191 | ||
144 | int | 192 | int |