summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorjsing <>2021-12-25 12:21:36 +0000
committerjsing <>2021-12-25 12:21:36 +0000
commit69f80604f574c80b09c77c793ad058bbdb4ea21a (patch)
treef9ecccd0fdc61be493a4794641c3fb1db36fc283 /src
parent44295c3a6df64c57f818d4167872c08fefeb15e4 (diff)
downloadopenbsd-69f80604f574c80b09c77c793ad058bbdb4ea21a.tar.gz
openbsd-69f80604f574c80b09c77c793ad058bbdb4ea21a.tar.bz2
openbsd-69f80604f574c80b09c77c793ad058bbdb4ea21a.zip
Merge asn_pack.c into asn1_item.c - these are two ASN1_item_* functions.
No functional change.
Diffstat (limited to 'src')
-rw-r--r--src/lib/libcrypto/Makefile4
-rw-r--r--src/lib/libcrypto/asn1/asn1_item.c49
-rw-r--r--src/lib/libcrypto/asn1/asn_pack.c109
3 files changed, 50 insertions, 112 deletions
diff --git a/src/lib/libcrypto/Makefile b/src/lib/libcrypto/Makefile
index dd5caec219..ad5f4f5876 100644
--- a/src/lib/libcrypto/Makefile
+++ b/src/lib/libcrypto/Makefile
@@ -1,4 +1,4 @@
1# $OpenBSD: Makefile,v 1.62 2021/12/25 12:19:16 jsing Exp $ 1# $OpenBSD: Makefile,v 1.63 2021/12/25 12:21:36 jsing Exp $
2 2
3LIB= crypto 3LIB= crypto
4LIBREBUILD=y 4LIBREBUILD=y
@@ -64,7 +64,7 @@ SRCS+= tasn_prn.c ameth_lib.c
64SRCS+= n_pkey.c 64SRCS+= n_pkey.c
65SRCS+= x_pkey.c x_exten.c bio_asn1.c bio_ndef.c asn_mime.c 65SRCS+= x_pkey.c x_exten.c bio_asn1.c bio_ndef.c asn_mime.c
66SRCS+= asn1_gen.c asn1_par.c asn1_old_lib.c asn1_err.c a_strnid.c 66SRCS+= asn1_gen.c asn1_par.c asn1_old_lib.c asn1_err.c a_strnid.c
67SRCS+= asn_pack.c p5_pbe.c p5_pbev2.c p8_pkey.c asn_moid.c 67SRCS+= p5_pbe.c p5_pbev2.c p8_pkey.c asn_moid.c
68SRCS+= a_time_tm.c asn1_item.c asn1_old.c asn1_types.c asn1_lib.c 68SRCS+= a_time_tm.c asn1_item.c asn1_old.c asn1_types.c asn1_lib.c
69 69
70# bf/ 70# bf/
diff --git a/src/lib/libcrypto/asn1/asn1_item.c b/src/lib/libcrypto/asn1/asn1_item.c
index 8db1713b29..d2819dbb96 100644
--- a/src/lib/libcrypto/asn1/asn1_item.c
+++ b/src/lib/libcrypto/asn1/asn1_item.c
@@ -1,4 +1,4 @@
1/* $OpenBSD: asn1_item.c,v 1.1 2021/12/25 12:00:22 jsing Exp $ */ 1/* $OpenBSD: asn1_item.c,v 1.2 2021/12/25 12:21:36 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 *
@@ -167,6 +167,53 @@ ASN1_item_dup(const ASN1_ITEM *it, void *x)
167 return (ret); 167 return (ret);
168} 168}
169 169
170/* Pack an ASN1 object into an ASN1_STRING. */
171ASN1_STRING *
172ASN1_item_pack(void *obj, const ASN1_ITEM *it, ASN1_STRING **oct)
173{
174 ASN1_STRING *octmp;
175
176 if (!oct || !*oct) {
177 if (!(octmp = ASN1_STRING_new ())) {
178 ASN1error(ERR_R_MALLOC_FAILURE);
179 return NULL;
180 }
181 } else
182 octmp = *oct;
183
184 free(octmp->data);
185 octmp->data = NULL;
186
187 if (!(octmp->length = ASN1_item_i2d(obj, &octmp->data, it))) {
188 ASN1error(ASN1_R_ENCODE_ERROR);
189 goto err;
190 }
191 if (!octmp->data) {
192 ASN1error(ERR_R_MALLOC_FAILURE);
193 goto err;
194 }
195 if (oct)
196 *oct = octmp;
197 return octmp;
198err:
199 if (!oct || octmp != *oct)
200 ASN1_STRING_free(octmp);
201 return NULL;
202}
203
204/* Extract an ASN1 object from an ASN1_STRING. */
205void *
206ASN1_item_unpack(const ASN1_STRING *oct, const ASN1_ITEM *it)
207{
208 const unsigned char *p;
209 void *ret;
210
211 p = oct->data;
212 if (!(ret = ASN1_item_d2i(NULL, &p, oct->length, it)))
213 ASN1error(ASN1_R_DECODE_ERROR);
214 return ret;
215}
216
170int 217int
171ASN1_item_sign(const ASN1_ITEM *it, X509_ALGOR *algor1, X509_ALGOR *algor2, 218ASN1_item_sign(const ASN1_ITEM *it, X509_ALGOR *algor1, X509_ALGOR *algor2,
172 ASN1_BIT_STRING *signature, void *asn, EVP_PKEY *pkey, const EVP_MD *type) 219 ASN1_BIT_STRING *signature, void *asn, EVP_PKEY *pkey, const EVP_MD *type)
diff --git a/src/lib/libcrypto/asn1/asn_pack.c b/src/lib/libcrypto/asn1/asn_pack.c
deleted file mode 100644
index 090beff0f0..0000000000
--- a/src/lib/libcrypto/asn1/asn_pack.c
+++ /dev/null
@@ -1,109 +0,0 @@
1/* $OpenBSD: asn_pack.c,v 1.18 2018/10/24 17:57:22 jsing Exp $ */
2/* Written by Dr Stephen N Henson (steve@openssl.org) for the OpenSSL
3 * project 1999.
4 */
5/* ====================================================================
6 * Copyright (c) 1999 The OpenSSL Project. All rights reserved.
7 *
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions
10 * are met:
11 *
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 *
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in
17 * the documentation and/or other materials provided with the
18 * distribution.
19 *
20 * 3. All advertising materials mentioning features or use of this
21 * software must display the following acknowledgment:
22 * "This product includes software developed by the OpenSSL Project
23 * for use in the OpenSSL Toolkit. (http://www.OpenSSL.org/)"
24 *
25 * 4. The names "OpenSSL Toolkit" and "OpenSSL Project" must not be used to
26 * endorse or promote products derived from this software without
27 * prior written permission. For written permission, please contact
28 * licensing@OpenSSL.org.
29 *
30 * 5. Products derived from this software may not be called "OpenSSL"
31 * nor may "OpenSSL" appear in their names without prior written
32 * permission of the OpenSSL Project.
33 *
34 * 6. Redistributions of any form whatsoever must retain the following
35 * acknowledgment:
36 * "This product includes software developed by the OpenSSL Project
37 * for use in the OpenSSL Toolkit (http://www.OpenSSL.org/)"
38 *
39 * THIS SOFTWARE IS PROVIDED BY THE OpenSSL PROJECT ``AS IS'' AND ANY
40 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
41 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
42 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE OpenSSL PROJECT OR
43 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
44 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
45 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
46 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
48 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
49 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
50 * OF THE POSSIBILITY OF SUCH DAMAGE.
51 * ====================================================================
52 *
53 * This product includes cryptographic software written by Eric Young
54 * (eay@cryptsoft.com). This product includes software written by Tim
55 * Hudson (tjh@cryptsoft.com).
56 *
57 */
58
59#include <stdio.h>
60
61#include <openssl/asn1.h>
62#include <openssl/err.h>
63
64/* Pack an ASN1 object into an ASN1_STRING. */
65ASN1_STRING *
66ASN1_item_pack(void *obj, const ASN1_ITEM *it, ASN1_STRING **oct)
67{
68 ASN1_STRING *octmp;
69
70 if (!oct || !*oct) {
71 if (!(octmp = ASN1_STRING_new ())) {
72 ASN1error(ERR_R_MALLOC_FAILURE);
73 return NULL;
74 }
75 } else
76 octmp = *oct;
77
78 free(octmp->data);
79 octmp->data = NULL;
80
81 if (!(octmp->length = ASN1_item_i2d(obj, &octmp->data, it))) {
82 ASN1error(ASN1_R_ENCODE_ERROR);
83 goto err;
84 }
85 if (!octmp->data) {
86 ASN1error(ERR_R_MALLOC_FAILURE);
87 goto err;
88 }
89 if (oct)
90 *oct = octmp;
91 return octmp;
92err:
93 if (!oct || octmp != *oct)
94 ASN1_STRING_free(octmp);
95 return NULL;
96}
97
98/* Extract an ASN1 object from an ASN1_STRING. */
99void *
100ASN1_item_unpack(const ASN1_STRING *oct, const ASN1_ITEM *it)
101{
102 const unsigned char *p;
103 void *ret;
104
105 p = oct->data;
106 if (!(ret = ASN1_item_d2i(NULL, &p, oct->length, it)))
107 ASN1error(ASN1_R_DECODE_ERROR);
108 return ret;
109}