blob: d1e4d48dd73fecb6d5d1b3cfe5529df7e2975363 [file] [log] [blame]
Peter Szilagyifbc56f92019-07-23 19:29:46 +00001/*-
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 _BER_TLV_LENGTH_H_
6#define _BER_TLV_LENGTH_H_
7
8#ifdef __cplusplus
9extern "C" {
10#endif
11
12typedef ssize_t ber_tlv_len_t;
13
14/*
15 * This function tries to fetch the length of the BER TLV value and place it
16 * in *len_r.
17 * RETURN VALUES:
18 * 0: More data expected than bufptr contains.
19 * -1: Fatal error deciphering length.
20 * >0: Number of bytes used from bufptr.
21 * On return with >0, len_r is constrained as -1..MAX, where -1 mean
22 * that the value is of indefinite length.
23 */
24ssize_t ber_fetch_length(int _is_constructed, const void *bufptr, size_t size,
25 ber_tlv_len_t *len_r);
26
27/*
28 * This function expects bufptr to be positioned over L in TLV.
29 * It returns number of bytes occupied by L and V together, suitable
30 * for skipping. The function properly handles indefinite length.
31 * RETURN VALUES:
32 * Standard {-1,0,>0} convention.
33 */
34ssize_t ber_skip_length(
35 const struct asn_codec_ctx_s *opt_codec_ctx, /* optional context */
36 int _is_constructed, const void *bufptr, size_t size);
37
38/*
39 * This function serializes the length (L from TLV) in DER format.
40 * It always returns number of bytes necessary to represent the length,
41 * it is a caller's responsibility to check the return value
42 * against the supplied buffer's size.
43 */
44size_t der_tlv_length_serialize(ber_tlv_len_t len, void *bufptr, size_t size);
45
46#ifdef __cplusplus
47}
48#endif
49
50#endif /* _BER_TLV_LENGTH_H_ */