-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathbitstream.c
More file actions
55 lines (51 loc) · 1.13 KB
/
bitstream.c
File metadata and controls
55 lines (51 loc) · 1.13 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#include "bitstream.h"
uint8_t feed_byte(bitstream *bs, uint8_t byte)
{
if (32-bs->available < 8)
return 0;
#ifdef LITTLE_ENDIAN
uint8_t bytenb = 3-(bs->available/8);
#else
uint8_t bytenb = bs->available/8;
#endif
uint8_t bytemod = bs->available%8;
if (bytemod == 0) {
bs->bytes[bytenb] = byte;
} else {
bs->bytes[bytenb] |= byte>>bytemod;
#ifdef LITTLE_ENDIAN
bs->bytes[bytenb-1] |= byte<<(8-bytemod);
#else
bs->bytes[bytenb+1] |= byte<<(8-bytemod);
#endif
}
bs->available += 8;
return 1;
}
// Always able to read at most 24bits
uint32_t read_bits(bitstream *bs, uint8_t nb)
{
uint32_t out = bs->data>>(32-nb);
bs->data<<=nb;
bs->available -= nb;
while (32-bs->available >= 8)
feed_byte(bs,next_byte(bs->stream));
return out;
}
void init_bitstream(bitstream *bs, void *st)
{
bs->data = 0;
bs->available = 0;
bs->stream = st;
for (int i=0;i<4;i++)
feed_byte(bs,next_byte(st));
}
float read_float(bitstream *bs)
{
//#ifdef LITTLE_ENDIAN
uint32_t f = read_bits(bs,8)|read_bits(bs,8)<<8|read_bits(bs,8)<<16|read_bits(bs,8)<<24;
/*#else
uint32_t f = read_bits(bs,24)<<8|read_bits(bs,8);
#endif*/
return *((float*)&f);
}