2  * Copyright (c) 2006-2017 Lev Walkin <vlm@lionet.info>. All rights reserved.
 
   3  * Redistribution and modifications are permitted subject to BSD license.
 
   5 #ifndef _PER_ENCODER_H_
 
   6 #define _PER_ENCODER_H_
 
   8 #include <asn_application.h>
 
   9 #include <per_support.h>
 
  15 struct asn_TYPE_descriptor_s;   /* Forward declaration */
 
  18  * Unaligned PER encoder of any ASN.1 type. May be invoked by the application.
 
  19  * WARNING: This function returns the number of encoded bits in the .encoded
 
  20  * field of the return value. Use the following formula to convert to bytes:
 
  21  *      bytes = ((.encoded + 7) / 8)
 
  23 asn_enc_rval_t uper_encode(
 
  24     const struct asn_TYPE_descriptor_s *type_descriptor,
 
  25     const asn_per_constraints_t *constraints,
 
  26     const void *struct_ptr,                    /* Structure to be encoded */
 
  27     asn_app_consume_bytes_f *consume_bytes_cb, /* Data collector */
 
  28     void *app_key                              /* Arbitrary callback argument */
 
  32  * A variant of uper_encode() which encodes data into the existing buffer
 
  33  * WARNING: This function returns the number of encoded bits in the .encoded
 
  34  * field of the return value.
 
  36 asn_enc_rval_t uper_encode_to_buffer(
 
  37     const struct asn_TYPE_descriptor_s *type_descriptor,
 
  38     const asn_per_constraints_t *constraints,
 
  39     const void *struct_ptr, /* Structure to be encoded */
 
  40     void *buffer,           /* Pre-allocated buffer */
 
  41     size_t buffer_size      /* Initial buffer size (max) */
 
  45  * A variant of uper_encode_to_buffer() which allocates buffer itself.
 
  46  * Returns the number of bytes in the buffer or -1 in case of failure.
 
  47  * WARNING: This function produces a "Production of the complete encoding",
 
  48  * with length of at least one octet. Contrast this to precise bit-packing
 
  49  * encoding of uper_encode() and uper_encode_to_buffer().
 
  51 ssize_t uper_encode_to_new_buffer(
 
  52     const struct asn_TYPE_descriptor_s *type_descriptor,
 
  53     const asn_per_constraints_t *constraints,
 
  54     const void *struct_ptr, /* Structure to be encoded */
 
  55     void **buffer_r         /* Buffer allocated and returned */
 
  59  * Type of the generic PER encoder function.
 
  61 typedef asn_enc_rval_t(per_type_encoder_f)(
 
  62     const struct asn_TYPE_descriptor_s *type_descriptor,
 
  63     const asn_per_constraints_t *constraints, const void *struct_ptr,
 
  64     asn_per_outp_t *per_output);
 
  70 #endif  /* _PER_ENCODER_H_ */