libosmocore 1.9.0.196-9975
Osmocom core library
bitvec.h
Go to the documentation of this file.
1/* (C) 2009 by Harald Welte <laforge@gnumonks.org>
2 * (C) 2012 Ivan Klyuchnikov
3 * (C) 2015 sysmocom - s.f.m.c. GmbH
4 *
5 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 */
18
19#pragma once
20
25#include <stdint.h>
26#include <osmocom/core/defs.h>
27#include <stdbool.h>
28
34 ZERO = 0,
35 ONE = 1,
36 L = 2,
37 H = 3,
38};
39
41struct bitvec {
42 unsigned int cur_bit;
43 unsigned int data_len;
44 uint8_t *data;
45};
46
47enum bit_value bitvec_get_bit_pos(const struct bitvec *bv, unsigned int bitnr);
48enum bit_value bitvec_get_bit_pos_high(const struct bitvec *bv,
49 unsigned int bitnr);
50unsigned int bitvec_get_nth_set_bit(const struct bitvec *bv, unsigned int n);
51int bitvec_set_bit_pos(struct bitvec *bv, unsigned int bitnum,
52 enum bit_value bit);
53int bitvec_set_bit(struct bitvec *bv, enum bit_value bit);
54int bitvec_get_bit_high(struct bitvec *bv);
55int bitvec_set_bits(struct bitvec *bv, const enum bit_value *bits, unsigned int count);
56int bitvec_set_u64(struct bitvec *bv, uint64_t v, uint8_t num_bits, bool use_lh);
57int bitvec_set_uint(struct bitvec *bv, unsigned int in, unsigned int count);
58int bitvec_get_uint(struct bitvec *bv, unsigned int num_bits);
59int bitvec_find_bit_pos(const struct bitvec *bv, unsigned int n, enum bit_value val);
60int bitvec_spare_padding(struct bitvec *bv, unsigned int up_to_bit);
61int bitvec_get_bytes(struct bitvec *bv, uint8_t *bytes, unsigned int count);
62int bitvec_set_bytes(struct bitvec *bv, const uint8_t *bytes, unsigned int count);
63struct bitvec *bitvec_alloc(unsigned int size, void *bvctx);
64void bitvec_free(struct bitvec *bv);
65int bitvec_unhex(struct bitvec *bv, const char *src);
66unsigned int bitvec_pack(const struct bitvec *bv, uint8_t *buffer);
67unsigned int bitvec_unpack(struct bitvec *bv, const uint8_t *buffer);
68uint64_t bitvec_read_field(struct bitvec *bv, unsigned int *read_index, unsigned int len);
69int bitvec_write_field(struct bitvec *bv, unsigned int *write_index, uint64_t val, unsigned int len);
70int bitvec_fill(struct bitvec *bv, unsigned int num_bits, enum bit_value fill);
71char bit_value_to_char(enum bit_value v);
72void bitvec_to_string_r(const struct bitvec *bv, char *str);
73void bitvec_zero(struct bitvec *bv);
74unsigned bitvec_rl(const struct bitvec *bv, bool b);
75unsigned bitvec_rl_curbit(struct bitvec *bv, bool b, unsigned int max_bits);
76void bitvec_shiftl(struct bitvec *bv, unsigned int n);
77int16_t bitvec_get_int16_msb(const struct bitvec *bv, unsigned int num_bits);
78unsigned int bitvec_add_array(struct bitvec *bv, const uint32_t *array,
79 unsigned int array_len, bool dry_run,
80 unsigned int num_bits);
81
83static inline unsigned int bitvec_used_bytes(const struct bitvec *bv)
84{
85 unsigned int bytes = bv->cur_bit/8;
86 if (bv->cur_bit%8)
87 bytes++;
88 return bytes;
89}
90
92static inline unsigned int bitvec_tailroom_bits(const struct bitvec *bv)
93{
94 return bv->data_len*8 - bv->cur_bit;
95}
96
General definitions that are meant to be included from header files.
int16_t bitvec_get_int16_msb(const struct bitvec *bv, unsigned int num_bits)
get multiple bits (num_bits) from beginning of vector (MSB side)
Definition: bitvec.c:249
unsigned int bitvec_pack(const struct bitvec *bv, uint8_t *buffer)
Export a bit vector to a buffer.
Definition: bitvec.c:429
int bitvec_set_u64(struct bitvec *bv, uint64_t v, uint8_t num_bits, bool use_lh)
set multiple bits (based on numeric value) at current pos.
Definition: bitvec.c:218
unsigned bitvec_rl_curbit(struct bitvec *bv, bool b, unsigned int max_bits)
Return number (bits) of uninterrupted bit run in vector starting from the current bit.
Definition: bitvec.c:605
char bit_value_to_char(enum bit_value v)
convert enum to corresponding character
Definition: bitvec.c:526
uint64_t bitvec_read_field(struct bitvec *bv, unsigned int *read_index, unsigned int len)
read part of the vector
Definition: bitvec.c:476
struct bitvec * bitvec_alloc(unsigned int size, void *bvctx)
Allocate a bit vector.
Definition: bitvec.c:398
int bitvec_get_bytes(struct bitvec *bv, uint8_t *bytes, unsigned int count)
get multiple bytes from current pos Assumes MSB first encoding.
Definition: bitvec.c:325
unsigned int bitvec_get_nth_set_bit(const struct bitvec *bv, unsigned int n)
get the Nth set bit inside the bit vector
Definition: bitvec.c:122
int bitvec_set_bit_pos(struct bitvec *bv, unsigned int bitnum, enum bit_value bit)
set a bit at given position in a bit vector
Definition: bitvec.c:143
int bitvec_fill(struct bitvec *bv, unsigned int num_bits, enum bit_value fill)
fill num_bits with \fill starting from the current position
Definition: bitvec.c:282
void bitvec_to_string_r(const struct bitvec *bv, char *str)
prints bit vector to provided string It's caller's responsibility to ensure that we won't shoot him i...
Definition: bitvec.c:541
void bitvec_shiftl(struct bitvec *bv, unsigned int n)
static unsigned int bitvec_used_bytes(const struct bitvec *bv)
Return the number of bytes used within the bit vector.
Definition: bitvec.h:83
int bitvec_spare_padding(struct bitvec *bv, unsigned int up_to_bit)
pad all remaining bits up to a given bit number
Definition: bitvec.c:294
int bitvec_find_bit_pos(const struct bitvec *bv, unsigned int n, enum bit_value val)
find first bit set in bit vector
Definition: bitvec.c:305
static unsigned int bitvec_tailroom_bits(const struct bitvec *bv)
Return the tailroom in number of unused bits remaining in the bit-vector.
Definition: bitvec.h:92
int bitvec_set_bits(struct bitvec *bv, const enum bit_value *bits, unsigned int count)
set multiple bits (based on array of bitvals) at current pos
Definition: bitvec.c:198
enum bit_value bitvec_get_bit_pos_high(const struct bitvec *bv, unsigned int bitnr)
check if the bit is L or H for a given position inside a bitvec
Definition: bitvec.c:99
int bitvec_get_bit_high(struct bitvec *bv)
get the next bit (low/high) inside a bitvec
Definition: bitvec.c:182
bit_value
A single GSM bit.
Definition: bitvec.h:33
int bitvec_set_bit(struct bitvec *bv, enum bit_value bit)
set the next bit inside a bitvec
Definition: bitvec.c:169
unsigned bitvec_rl(const struct bitvec *bv, bool b)
Return number (bits) of uninterrupted bit run in vector starting from the MSB.
Definition: bitvec.c:586
enum bit_value bitvec_get_bit_pos(const struct bitvec *bv, unsigned int bitnr)
check if the bit is 0 or 1 for a given position inside a bitvec
Definition: bitvec.c:77
void bitvec_zero(struct bitvec *bv)
force bit vector to all 0 and current bit to the beginnig of the vector
Definition: bitvec.c:575
int bitvec_write_field(struct bitvec *bv, unsigned int *write_index, uint64_t val, unsigned int len)
write into the vector
Definition: bitvec.c:508
int bitvec_get_uint(struct bitvec *bv, unsigned int num_bits)
get multiple bits (based on numeric value) from current pos
Definition: bitvec.c:262
unsigned int bitvec_unpack(struct bitvec *bv, const uint8_t *buffer)
Copy buffer of unpacked bits into bit vector.
Definition: bitvec.c:442
int bitvec_set_uint(struct bitvec *bv, unsigned int in, unsigned int count)
set multiple bits (based on numeric value) at current pos.
Definition: bitvec.c:242
int bitvec_set_bytes(struct bitvec *bv, const uint8_t *bytes, unsigned int count)
set multiple bytes at current pos Assumes MSB first encoding.
Definition: bitvec.c:361
int bitvec_unhex(struct bitvec *bv, const char *src)
read hexadecimap string into a bit vector
Definition: bitvec.c:456
unsigned int bitvec_add_array(struct bitvec *bv, const uint32_t *array, unsigned int array_len, bool dry_run, unsigned int num_bits)
Add given array to bitvec.
Definition: bitvec.c:685
void bitvec_free(struct bitvec *bv)
Free a bit vector (release its memory)
Definition: bitvec.c:417
@ H
A CSN.1 "H" bit.
Definition: bitvec.h:37
@ ONE
A one (1) bit.
Definition: bitvec.h:35
@ ZERO
A zero (0) bit.
Definition: bitvec.h:34
@ L
A CSN.1 "L" bit.
Definition: bitvec.h:36
static size_t len(const char *str)
write Write running configuration to or terminal n Write configuration to the copy running config startup Copy configuration n Copy running config to n Copy running config to startup write Write running configuration to or terminal n Write to terminal n
structure describing a bit vector
Definition: bitvec.h:41
uint8_t * data
pointer to data array
Definition: bitvec.h:44
unsigned int cur_bit
cursor to the next unused bit
Definition: bitvec.h:42
unsigned int data_len
length of data array in bytes
Definition: bitvec.h:43