asn_codecs.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2003-2017 Lev Walkin <vlm@lionet.info>. All rights reserved.
3  * Redistribution and modifications are permitted subject to BSD license.
4  */
5 #ifndef ASN_CODECS_H
6 #define ASN_CODECS_H
7 
8 #ifdef __cplusplus
9 extern "C" {
10 #endif
11 
12 struct asn_TYPE_descriptor_s; /* Forward declaration */
13 
14 /*
15  * This structure defines a set of parameters that may be passed
16  * to every ASN.1 encoder or decoder function.
17  * WARNING: if max_stack_size member is set, and you are calling the
18  * function pointers of the asn_TYPE_descriptor_t directly,
19  * this structure must be ALLOCATED ON THE STACK!
20  * If you can't always satisfy this requirement, use ber_decode(),
21  * xer_decode() and uper_decode() functions instead.
22  */
23 typedef struct asn_codec_ctx_s {
24  /*
25  * Limit the decoder routines to use no (much) more stack than a given
26  * number of bytes. Most of decoders are stack-based, and this
27  * would protect against stack overflows if the number of nested
28  * encodings is high.
29  * The OCTET STRING, BIT STRING and ANY BER decoders are heap-based,
30  * and are safe from this kind of overflow.
31  * A value from getrlimit(RLIMIT_STACK) may be used to initialize
32  * this variable. Be careful in multithreaded environments, as the
33  * stack size is rather limited.
34  */
35  size_t max_stack_size; /* 0 disables stack bounds checking */
37 
38 /*
39  * Type of the return value of the encoding functions (der_encode, xer_encode).
40  */
41 typedef struct asn_enc_rval_s {
42  /*
43  * Number of bytes encoded.
44  * -1 indicates failure to encode the structure.
45  * In this case, the members below this one are meaningful.
46  */
47  ssize_t encoded;
48 
49  /*
50  * Members meaningful when (encoded == -1), for post mortem analysis.
51  */
52 
53  /* Type which cannot be encoded */
55 
56  /* Pointer to the structure of that type */
57  const void *structure_ptr;
59 #define ASN__ENCODE_FAILED do { \
60  asn_enc_rval_t tmp_error; \
61  tmp_error.encoded = -1; \
62  tmp_error.failed_type = td; \
63  tmp_error.structure_ptr = sptr; \
64  ASN_DEBUG("Failed to encode element %s", td ? td->name : ""); \
65  return tmp_error; \
66 } while(0)
67 #define ASN__ENCODED_OK(rval) do { \
68  rval.structure_ptr = 0; \
69  rval.failed_type = 0; \
70  return rval; \
71 } while(0)
72 
73 /*
74  * Type of the return value of the decoding functions (ber_decode, xer_decode)
75  *
76  * Please note that the number of consumed bytes is ALWAYS meaningful,
77  * even if code==RC_FAIL. This is to indicate the number of successfully
78  * decoded bytes, hence providing a possibility to fail with more diagnostics
79  * (i.e., print the offending remainder of the buffer).
80  */
82  RC_OK, /* Decoded successfully */
83  RC_WMORE, /* More data expected, call again */
84  RC_FAIL /* Failure to decode data */
85 };
86 typedef struct asn_dec_rval_s {
87  enum asn_dec_rval_code_e code; /* Result code */
88  size_t consumed; /* Number of bytes consumed */
90 #define ASN__DECODE_FAILED do { \
91  asn_dec_rval_t tmp_error; \
92  tmp_error.code = RC_FAIL; \
93  tmp_error.consumed = 0; \
94  ASN_DEBUG("Failed to decode element %s", td ? td->name : ""); \
95  return tmp_error; \
96 } while(0)
97 #define ASN__DECODE_STARVED do { \
98  asn_dec_rval_t tmp_error; \
99  tmp_error.code = RC_WMORE; \
100  tmp_error.consumed = 0; \
101  return tmp_error; \
102 } while(0)
103 
104 #ifdef __cplusplus
105 }
106 #endif
107 
108 #endif /* ASN_CODECS_H */
asn_enc_rval_s
Definition: asn_codecs.h:41
RC_WMORE
@ RC_WMORE
Definition: asn_codecs.h:83
asn_enc_rval_s::structure_ptr
const void * structure_ptr
Definition: asn_codecs.h:57
asn_dec_rval_t
struct asn_dec_rval_s asn_dec_rval_t
asn_TYPE_descriptor_s
Definition: constr_TYPE.h:224
asn_enc_rval_s::failed_type
const struct asn_TYPE_descriptor_s * failed_type
Definition: asn_codecs.h:54
RC_OK
@ RC_OK
Definition: asn_codecs.h:82
asn_dec_rval_s::consumed
size_t consumed
Definition: asn_codecs.h:88
asn_codec_ctx_t
struct asn_codec_ctx_s asn_codec_ctx_t
asn_enc_rval_t
struct asn_enc_rval_s asn_enc_rval_t
asn_codec_ctx_s
Definition: asn_codecs.h:23
asn_dec_rval_s
Definition: asn_codecs.h:86
asn_enc_rval_s::encoded
ssize_t encoded
Definition: asn_codecs.h:47
asn_codec_ctx_s::max_stack_size
size_t max_stack_size
Definition: asn_codecs.h:35
asn_dec_rval_code_e
asn_dec_rval_code_e
Definition: asn_codecs.h:81
RC_FAIL
@ RC_FAIL
Definition: asn_codecs.h:84
asn_dec_rval_s::code
enum asn_dec_rval_code_e code
Definition: asn_codecs.h:87


etsi_its_spatem_ts_coding
Author(s): Jean-Pierre Busch , Guido Küppers , Lennart Reiher
autogenerated on Sun May 18 2025 02:29:28