| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950 |
- /*-
- * Copyright (c) 2003-2017 Lev Walkin <vlm@lionet.info>. All rights reserved.
- * Redistribution and modifications are permitted subject to BSD license.
- */
- #ifndef _BER_TLV_LENGTH_H_
- #define _BER_TLV_LENGTH_H_
- #ifdef __cplusplus
- extern "C" {
- #endif
- typedef ssize_t ber_tlv_len_t;
- /*
- * This function tries to fetch the length of the BER TLV value and place it
- * in *len_r.
- * RETURN VALUES:
- * 0: More data expected than bufptr contains.
- * -1: Fatal error deciphering length.
- * >0: Number of bytes used from bufptr.
- * On return with >0, len_r is constrained as -1..MAX, where -1 mean
- * that the value is of indefinite length.
- */
- ssize_t ber_fetch_length(int _is_constructed, const void *bufptr, size_t size,
- ber_tlv_len_t *len_r);
- /*
- * This function expects bufptr to be positioned over L in TLV.
- * It returns number of bytes occupied by L and V together, suitable
- * for skipping. The function properly handles indefinite length.
- * RETURN VALUES:
- * Standard {-1,0,>0} convention.
- */
- ssize_t ber_skip_length(
- const struct asn_codec_ctx_s *opt_codec_ctx, /* optional context */
- int _is_constructed, const void *bufptr, size_t size);
- /*
- * This function serializes the length (L from TLV) in DER format.
- * It always returns number of bytes necessary to represent the length,
- * it is a caller's responsibility to check the return value
- * against the supplied buffer's size.
- */
- size_t der_tlv_length_serialize(ber_tlv_len_t len, void *bufptr, size_t size);
- #ifdef __cplusplus
- }
- #endif
- #endif /* _BER_TLV_LENGTH_H_ */
|