blob: bbe1641b63bfe20564c01b03231506e539a23db5 [file] [log] [blame]
Harald Welteec8b4502010-02-20 20:34:29 +01001#ifndef _BITVEC_H
2#define _BITVEC_H
3
4/* bit vector utility routines */
5
6/* (C) 2009 by Harald Welte <laforge@gnumonks.org>
7 *
8 * All Rights Reserved
9 *
10 * This program is free software; you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License along
21 * with this program; if not, write to the Free Software Foundation, Inc.,
22 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23 *
24 */
25
26
27/* In GSM mac blocks, every bit can be 0 or 1, or L or H. L/H are
28 * defined relative to the 0x2b padding pattern */
29enum bit_value {
30 ZERO = 0,
31 ONE = 1,
32 L = 2,
33 H = 3,
34};
35
36struct bitvec {
37 unsigned int cur_bit; /* curser to the next unused bit */
38 unsigned int data_len; /* length of data array in bytes */
39 uint8_t *data; /* pointer to data array */
40};
41
42/* check if the bit is 0 or 1 for a given position inside a bitvec */
Harald Welted9abf012010-03-06 11:28:49 +010043enum bit_value bitvec_get_bit_pos(const struct bitvec *bv, unsigned int bitnr);
Harald Welteec8b4502010-02-20 20:34:29 +010044
Andreas.Eversberg0ebd6882010-05-09 09:36:54 +000045/* check if the bit is L or H for a given position inside a bitvec */
46enum bit_value bitvec_get_bit_pos_high(const struct bitvec *bv,
47 unsigned int bitnr);
48
Harald Welteec8b4502010-02-20 20:34:29 +010049/* get the Nth set bit inside the bit vector */
Harald Welted9abf012010-03-06 11:28:49 +010050unsigned int bitvec_get_nth_set_bit(const struct bitvec *bv, unsigned int n);
Harald Welteec8b4502010-02-20 20:34:29 +010051
52/* Set a bit at given position */
53int bitvec_set_bit_pos(struct bitvec *bv, unsigned int bitnum,
54 enum bit_value bit);
55
56/* Set the next bit in the vector */
57int bitvec_set_bit(struct bitvec *bv, enum bit_value bit);
58
Andreas.Eversberg0ebd6882010-05-09 09:36:54 +000059/* get the next bit (low/high) inside a bitvec */
60int bitvec_get_bit_high(struct bitvec *bv);
61
Harald Welteec8b4502010-02-20 20:34:29 +010062/* Set multiple bits at the current position */
63int bitvec_set_bits(struct bitvec *bv, enum bit_value *bits, int count);
64
65/* Add an unsigned integer (of length count bits) to current position */
66int bitvec_set_uint(struct bitvec *bv, unsigned int in, int count);
67
Andreas.Eversberg0ebd6882010-05-09 09:36:54 +000068/* get multiple bits (based on numeric value) from current pos */
69int bitvec_get_uint(struct bitvec *bv, int num_bits);
70
Pablo Neira Ayuso36bdf2c2011-03-28 19:24:19 +020071/* find the first bit set in bit vector */
72int bitvec_find_bit_pos(const struct bitvec *bv, unsigned int n, enum bit_value val);
Harald Welteec8b4502010-02-20 20:34:29 +010073
74/* Pad the bit vector up to a certain bit position */
75int bitvec_spare_padding(struct bitvec *bv, unsigned int up_to_bit);
76
77#endif /* _BITVEC_H */