2 * Copyright (c) 2003, 2004, 2005 Lev Walkin <vlm@lionet.info>.
4 * Redistribution and modifications are permitted subject to BSD license.
13 struct asn_TYPE_descriptor_s; /* Forward declaration */
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.
24 typedef struct asn_codec_ctx_s {
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
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.
36 size_t max_stack_size; /* 0 disables stack bounds checking */
40 * Type of the return value of the encoding functions (der_encode, xer_encode).
42 typedef struct asn_enc_rval_s {
44 * Number of bytes encoded.
45 * -1 indicates failure to encode the structure.
46 * In this case, the members below this one are meaningful.
51 * Members meaningful when (encoded == -1), for post mortem analysis.
54 /* Type which cannot be encoded */
55 struct asn_TYPE_descriptor_s *failed_type;
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->name); \
68 #define _ASN_ENCODED_OK(rval) do { \
69 rval.structure_ptr = 0; \
70 rval.failed_type = 0; \
75 * Type of the return value of the decoding functions (ber_decode, xer_decode)
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).
82 enum asn_dec_rval_code_e {
83 RC_OK, /* Decoded successfully */
84 RC_WMORE, /* More data expected, call again */
85 RC_FAIL /* Failure to decode data */
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->name); \
98 #define _ASN_DECODE_STARVED do { \
99 asn_dec_rval_t tmp_error; \
100 tmp_error.code = RC_WMORE; \
101 tmp_error.consumed = 0; \
109 #endif /* _ASN_CODECS_H_ */