From f29f8a4cefbdc798c4a9aba495da7d2c0a81774c Mon Sep 17 00:00:00 2001 From: Christopher Peplin Date: Sun, 29 Dec 2013 12:06:11 -0500 Subject: Check if a value will fit in bitfield before setting. --- src/bitfield/8byte.c | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) (limited to 'src/bitfield/8byte.c') diff --git a/src/bitfield/8byte.c b/src/bitfield/8byte.c index 77251996..3b6b5466 100644 --- a/src/bitfield/8byte.c +++ b/src/bitfield/8byte.c @@ -40,16 +40,17 @@ uint64_t get_bit_field(uint64_t source, const uint16_t startBit, return int_result; } -/** - * TODO it would be nice to have a warning if you call with this a value that - * won't fit in the number of bits you've specified it should use. - */ -void set_bit_field(uint64_t* destination, uint64_t value, const uint16_t offset, +bool set_bit_field(uint64_t* destination, uint64_t value, const uint16_t offset, const uint16_t bit_count) { + if(value > bitmask(bit_count)) { + return false; + } + int shiftDistance = EIGHTBYTE_BIT - offset - bit_count; value <<= shiftDistance; *destination &= ~(bitmask(bit_count) << shiftDistance); *destination |= value; + return true; } uint8_t nth_byte(const uint64_t source, const uint16_t byte_index) { -- cgit 1.2.3-korg