grpc
third_party
boringssl-with-bazel
src
crypto
asn1
a_d2i_fp.c
Go to the documentation of this file.
1
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
2
* All rights reserved.
3
*
4
* This package is an SSL implementation written
5
* by Eric Young (eay@cryptsoft.com).
6
* The implementation was written so as to conform with Netscapes SSL.
7
*
8
* This library is free for commercial and non-commercial use as long as
9
* the following conditions are aheared to. The following conditions
10
* apply to all code found in this distribution, be it the RC4, RSA,
11
* lhash, DES, etc., code; not just the SSL code. The SSL documentation
12
* included with this distribution is covered by the same copyright terms
13
* except that the holder is Tim Hudson (tjh@cryptsoft.com).
14
*
15
* Copyright remains Eric Young's, and as such any Copyright notices in
16
* the code are not to be removed.
17
* If this package is used in a product, Eric Young should be given attribution
18
* as the author of the parts of the library used.
19
* This can be in the form of a textual message at program startup or
20
* in documentation (online or textual) provided with the package.
21
*
22
* Redistribution and use in source and binary forms, with or without
23
* modification, are permitted provided that the following conditions
24
* are met:
25
* 1. Redistributions of source code must retain the copyright
26
* notice, this list of conditions and the following disclaimer.
27
* 2. Redistributions in binary form must reproduce the above copyright
28
* notice, this list of conditions and the following disclaimer in the
29
* documentation and/or other materials provided with the distribution.
30
* 3. All advertising materials mentioning features or use of this software
31
* must display the following acknowledgement:
32
* "This product includes cryptographic software written by
33
* Eric Young (eay@cryptsoft.com)"
34
* The word 'cryptographic' can be left out if the rouines from the library
35
* being used are not cryptographic related :-).
36
* 4. If you include any Windows specific code (or a derivative thereof) from
37
* the apps directory (application code) you must include an acknowledgement:
38
* "This product includes software written by Tim Hudson (tjh@cryptsoft.com)"
39
*
40
* THIS SOFTWARE IS PROVIDED BY ERIC YOUNG ``AS IS'' AND
41
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
42
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
43
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
44
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
45
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
46
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
48
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
49
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
50
* SUCH DAMAGE.
51
*
52
* The licence and distribution terms for any publically available version or
53
* derivative of this code cannot be changed. i.e. this code cannot simply be
54
* copied and put under another distribution licence
55
* [including the GNU Public Licence.] */
56
57
#include <
openssl/asn1.h
>
58
59
#include <limits.h>
60
61
#include <
openssl/bio.h
>
62
#include <
openssl/err.h
>
63
#include <
openssl/mem.h
>
64
65
66
void
*
ASN1_item_d2i_bio
(
const
ASN1_ITEM
*
it
,
BIO
*
in
,
void
*
x
)
67
{
68
uint8_t
*
data
;
69
size_t
len
;
70
// Historically, this function did not impose a limit in OpenSSL and is used
71
// to read CRLs, so we leave this without an external bound.
72
if
(!
BIO_read_asn1
(
in
, &
data
, &
len
, INT_MAX)) {
73
return
NULL;
74
}
75
const
uint8_t
*
ptr
=
data
;
76
void
*
ret
=
ASN1_item_d2i
(
x
, &
ptr
,
len
,
it
);
77
OPENSSL_free
(
data
);
78
return
ret
;
79
}
80
81
void
*
ASN1_item_d2i_fp
(
const
ASN1_ITEM
*
it
,
FILE
*
in
,
void
*
x
)
82
{
83
BIO
*
b
=
BIO_new_fp
(
in
,
BIO_NOCLOSE
);
84
if
(
b
== NULL) {
85
OPENSSL_PUT_ERROR
(ASN1,
ERR_R_BUF_LIB
);
86
return
NULL;
87
}
88
void
*
ret
=
ASN1_item_d2i_bio
(
it
,
b
,
x
);
89
BIO_free
(
b
);
90
return
ret
;
91
}
ptr
char * ptr
Definition:
abseil-cpp/absl/base/internal/low_level_alloc_test.cc:45
BIO_read_asn1
#define BIO_read_asn1
Definition:
boringssl_prefix_symbols.h:832
BIO_new_fp
#define BIO_new_fp
Definition:
boringssl_prefix_symbols.h:819
regen-readme.it
it
Definition:
regen-readme.py:15
bio_st
Definition:
bio.h:822
OPENSSL_PUT_ERROR
#define OPENSSL_PUT_ERROR(library, reason)
Definition:
err.h:423
bio.h
uint8_t
unsigned char uint8_t
Definition:
stdint-msvc2008.h:78
in
const char * in
Definition:
third_party/abseil-cpp/absl/strings/internal/str_format/parser_test.cc:391
ASN1_ITEM_st
Definition:
asn1t.h:459
err.h
x
int x
Definition:
bloaty/third_party/googletest/googlemock/test/gmock-matchers_test.cc:3610
data
char data[kBufferLength]
Definition:
abseil-cpp/absl/strings/internal/str_format/float_conversion.cc:1006
b
uint64_t b
Definition:
abseil-cpp/absl/container/internal/layout_test.cc:53
ERR_R_BUF_LIB
#define ERR_R_BUF_LIB
Definition:
err.h:335
BIO_free
#define BIO_free
Definition:
boringssl_prefix_symbols.h:787
benchmark.FILE
FILE
Definition:
benchmark.py:21
ret
UniquePtr< SSL_SESSION > ret
Definition:
ssl_x509.cc:1029
BIO_NOCLOSE
#define BIO_NOCLOSE
Definition:
bio.h:373
ASN1_item_d2i_fp
void * ASN1_item_d2i_fp(const ASN1_ITEM *it, FILE *in, void *x)
Definition:
a_d2i_fp.c:81
mem.h
ASN1_item_d2i_bio
void * ASN1_item_d2i_bio(const ASN1_ITEM *it, BIO *in, void *x)
Definition:
a_d2i_fp.c:66
len
int len
Definition:
abseil-cpp/absl/base/internal/low_level_alloc_test.cc:46
OPENSSL_free
#define OPENSSL_free
Definition:
boringssl_prefix_symbols.h:1869
ASN1_item_d2i
#define ASN1_item_d2i
Definition:
boringssl_prefix_symbols.h:737
asn1.h
grpc
Author(s):
autogenerated on Fri May 16 2025 02:57:39