summaryrefslogtreecommitdiffstats
path: root/asn1/asn1c/ber_tlv_length.h
blob: 239d35bb60b539d69d82d023b042a7c7cedfe37f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51

/*-
 * Copyright (c) 2003 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(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_ */