Lines Matching refs:bitD

105 MEM_STATIC size_t   BIT_initDStream(BIT_DStream_t* bitD, const void* srcBuffer, size_t srcSize);
106 MEM_STATIC size_t BIT_readBits(BIT_DStream_t* bitD, unsigned nbBits);
107 MEM_STATIC BIT_DStream_status BIT_reloadDStream(BIT_DStream_t* bitD);
108 MEM_STATIC unsigned BIT_endOfDStream(const BIT_DStream_t* bitD);
131 MEM_STATIC size_t BIT_readBitsFast(BIT_DStream_t* bitD, unsigned nbBits);
272 MEM_STATIC size_t BIT_initDStream(BIT_DStream_t* bitD, const void* srcBuffer, size_t srcSize) in BIT_initDStream() argument
274 if (srcSize < 1) { memset(bitD, 0, sizeof(*bitD)); return ERROR(srcSize_wrong); } in BIT_initDStream()
276 bitD->start = (const char*)srcBuffer; in BIT_initDStream()
277 bitD->limitPtr = bitD->start + sizeof(bitD->bitContainer); in BIT_initDStream()
279 if (srcSize >= sizeof(bitD->bitContainer)) { /* normal case */ in BIT_initDStream()
280 bitD->ptr = (const char*)srcBuffer + srcSize - sizeof(bitD->bitContainer); in BIT_initDStream()
281 bitD->bitContainer = MEM_readLEST(bitD->ptr); in BIT_initDStream()
283bitD->bitsConsumed = lastByte ? 8 - BIT_highbit32(lastByte) : 0; /* ensures bitsConsumed is alway… in BIT_initDStream()
286 bitD->ptr = bitD->start; in BIT_initDStream()
287 bitD->bitContainer = *(const BYTE*)(bitD->start); in BIT_initDStream()
290 …case 7: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[6]) << (sizeof(bitD->bitContaine… in BIT_initDStream()
293 …case 6: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[5]) << (sizeof(bitD->bitContaine… in BIT_initDStream()
296 …case 5: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[4]) << (sizeof(bitD->bitContaine… in BIT_initDStream()
299 case 4: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[3]) << 24; in BIT_initDStream()
302 case 3: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[2]) << 16; in BIT_initDStream()
305 case 2: bitD->bitContainer += (size_t)(((const BYTE*)(srcBuffer))[1]) << 8; in BIT_initDStream()
311 bitD->bitsConsumed = lastByte ? 8 - BIT_highbit32(lastByte) : 0; in BIT_initDStream()
314 bitD->bitsConsumed += (U32)(sizeof(bitD->bitContainer) - srcSize)*8; in BIT_initDStream()
345 MEM_STATIC size_t BIT_lookBits(const BIT_DStream_t* bitD, U32 nbBits) in BIT_lookBits() argument
351 …return BIT_getMiddleBits(bitD->bitContainer, (sizeof(bitD->bitContainer)*8) - bitD->bitsConsumed -… in BIT_lookBits()
354 U32 const regMask = sizeof(bitD->bitContainer)*8 - 1; in BIT_lookBits()
355 …return ((bitD->bitContainer << (bitD->bitsConsumed & regMask)) >> 1) >> ((regMask-nbBits) & regMas… in BIT_lookBits()
361 MEM_STATIC size_t BIT_lookBitsFast(const BIT_DStream_t* bitD, U32 nbBits) in BIT_lookBitsFast() argument
363 U32 const regMask = sizeof(bitD->bitContainer)*8 - 1; in BIT_lookBitsFast()
365 … return (bitD->bitContainer << (bitD->bitsConsumed & regMask)) >> (((regMask+1)-nbBits) & regMask); in BIT_lookBitsFast()
368 MEM_STATIC void BIT_skipBits(BIT_DStream_t* bitD, U32 nbBits) in BIT_skipBits() argument
370 bitD->bitsConsumed += nbBits; in BIT_skipBits()
377 MEM_STATIC size_t BIT_readBits(BIT_DStream_t* bitD, unsigned nbBits) in BIT_readBits() argument
379 size_t const value = BIT_lookBits(bitD, nbBits); in BIT_readBits()
380 BIT_skipBits(bitD, nbBits); in BIT_readBits()
386 MEM_STATIC size_t BIT_readBitsFast(BIT_DStream_t* bitD, unsigned nbBits) in BIT_readBitsFast() argument
388 size_t const value = BIT_lookBitsFast(bitD, nbBits); in BIT_readBitsFast()
390 BIT_skipBits(bitD, nbBits); in BIT_readBitsFast()
400 MEM_STATIC BIT_DStream_status BIT_reloadDStreamFast(BIT_DStream_t* bitD) in BIT_reloadDStreamFast() argument
402 if (UNLIKELY(bitD->ptr < bitD->limitPtr)) in BIT_reloadDStreamFast()
404 assert(bitD->bitsConsumed <= sizeof(bitD->bitContainer)*8); in BIT_reloadDStreamFast()
405 bitD->ptr -= bitD->bitsConsumed >> 3; in BIT_reloadDStreamFast()
406 bitD->bitsConsumed &= 7; in BIT_reloadDStreamFast()
407 bitD->bitContainer = MEM_readLEST(bitD->ptr); in BIT_reloadDStreamFast()
416 MEM_STATIC BIT_DStream_status BIT_reloadDStream(BIT_DStream_t* bitD) in BIT_reloadDStream() argument
418 …if (bitD->bitsConsumed > (sizeof(bitD->bitContainer)*8)) /* overflow detected, like end of stream… in BIT_reloadDStream()
421 if (bitD->ptr >= bitD->limitPtr) { in BIT_reloadDStream()
422 return BIT_reloadDStreamFast(bitD); in BIT_reloadDStream()
424 if (bitD->ptr == bitD->start) { in BIT_reloadDStream()
425 if (bitD->bitsConsumed < sizeof(bitD->bitContainer)*8) return BIT_DStream_endOfBuffer; in BIT_reloadDStream()
429 { U32 nbBytes = bitD->bitsConsumed >> 3; in BIT_reloadDStream()
431 if (bitD->ptr - nbBytes < bitD->start) { in BIT_reloadDStream()
432 nbBytes = (U32)(bitD->ptr - bitD->start); /* ptr > start */ in BIT_reloadDStream()
435 bitD->ptr -= nbBytes; in BIT_reloadDStream()
436 bitD->bitsConsumed -= nbBytes*8; in BIT_reloadDStream()
437bitD->bitContainer = MEM_readLEST(bitD->ptr); /* reminder : srcSize > sizeof(bitD->bitContainer)… in BIT_reloadDStream()