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