diff options
-rw-r--r-- | include/osmocom/core/bitvec.h | 6 | ||||
-rw-r--r-- | tests/bitvec/bitvec_test.c | 19 |
2 files changed, 25 insertions, 0 deletions
diff --git a/include/osmocom/core/bitvec.h b/include/osmocom/core/bitvec.h index da2d4e45..bd107093 100644 --- a/include/osmocom/core/bitvec.h +++ b/include/osmocom/core/bitvec.h @@ -93,4 +93,10 @@ static inline unsigned int bitvec_used_bytes(const struct bitvec *bv) return bytes; } +/*! Return the tailroom in number of unused bits remaining in the bit-vector */ +static inline unsigned int bitvec_tailroom_bits(const struct bitvec *bv) +{ + return bv->data_len*8 - bv->cur_bit; +} + /*! @} */ diff --git a/tests/bitvec/bitvec_test.c b/tests/bitvec/bitvec_test.c index c8795dbd..fbf5c5dd 100644 --- a/tests/bitvec/bitvec_test.c +++ b/tests/bitvec/bitvec_test.c @@ -204,6 +204,24 @@ static void test_used_bytes() } } +static void test_tailroom() +{ + struct bitvec b; + uint8_t d[32]; + unsigned int i; + + b.data = d; + b.data_len = sizeof(d); + bitvec_zero(&b); + + OSMO_ASSERT(bitvec_tailroom_bits(&b) == sizeof(d)*8); + + for (i = 0; i < 8*sizeof(d); i++) { + bitvec_set_bit(&b, 1); + OSMO_ASSERT(bitvec_tailroom_bits(&b) == sizeof(d)*8-(i+1)); + } +} + int main(int argc, char **argv) { struct bitvec bv; @@ -311,6 +329,7 @@ int main(int argc, char **argv) printf("\nbitvec bytes used.\n"); test_used_bytes(); + test_tailroom(); printf("\nbitvec ok.\n"); return 0; |