Coverage Report

Created: 2024-09-21 06:25

/src/mpg123/src/libmpg123/getbits.h
Line
Count
Source (jump to first uncovered line)
1
/*
2
  getbits
3
4
  copyright ?-2009 by the mpg123 project - free software under the terms of the LGPL 2.1
5
  see COPYING and AUTHORS files in distribution or http://mpg123.org
6
  initially written by Michael Hipp
7
8
  All code is in the header to suggest/force inlining of these small often-used functions.
9
  This indeed has some impact on performance.
10
*/
11
12
#ifndef _MPG123_GETBITS_H_
13
#define _MPG123_GETBITS_H_
14
15
#include "mpg123lib_intern.h"
16
#include "../common/debug.h"
17
18
0
#define backbits(fr,nob) ((void)( \
19
0
  fr->bits_avail  += nob, \
20
0
  fr->bitindex    -= nob, \
21
0
  fr->wordpointer += (fr->bitindex>>3), \
22
0
  fr->bitindex    &= 0x7 ))
23
24
0
#define getbitoffset(fr) ((-fr->bitindex)&0x7)
25
/* Precomputing the bytes to be read is error-prone, and some over-read
26
   is even expected for Huffman. Just play safe and return zeros in case
27
   of overflow. This assumes you made bitindex zero already! */
28
0
#define getbyte(fr) ( (fr)->bits_avail-=8, (fr)->bits_avail >= 0 \
29
0
  ? *((fr)->wordpointer++) \
30
0
  : 0 )
31
32
static unsigned int getbits(mpg123_handle *fr, int number_of_bits)
33
0
{
34
0
  unsigned long rval;
35
36
#ifdef DEBUG_GETBITS
37
fprintf(stderr,"g%d",number_of_bits);
38
#endif
39
0
  fr->bits_avail -= number_of_bits;
40
  /* Safety catch until we got the nasty code fully figured out. */
41
  /* No, that catch stays here, even if we think we got it figured out! */
42
0
  if(fr->bits_avail < 0)
43
0
  {
44
0
    if(NOQUIET)
45
0
      error2( "Tried to read %i bits with %li available."
46
0
      ,  number_of_bits, fr->bits_avail );
47
0
    return 0;
48
0
  }
49
/*  This is actually slow: if(!number_of_bits)
50
    return 0; */
51
52
#if 0
53
   check_buffer_range(number_of_bits+fr->bitindex);
54
#endif
55
56
0
  {
57
0
    rval = fr->wordpointer[0];
58
0
    rval <<= 8;
59
0
    rval |= fr->wordpointer[1];
60
0
    rval <<= 8;
61
0
    rval |= fr->wordpointer[2];
62
63
0
    rval <<= fr->bitindex;
64
0
    rval &= 0xffffff;
65
66
0
    fr->bitindex += number_of_bits;
67
68
0
    rval >>= (24-number_of_bits);
69
70
0
    fr->wordpointer += (fr->bitindex>>3);
71
0
    fr->bitindex &= 7;
72
0
  }
73
74
#ifdef DEBUG_GETBITS
75
fprintf(stderr,":%lx\n",rval);
76
#endif
77
78
0
  return rval;
79
0
}
Unexecuted instantiation: parse.c:getbits
Unexecuted instantiation: layer1.c:getbits
Unexecuted instantiation: layer2.c:getbits
Unexecuted instantiation: layer3.c:getbits
80
81
82
0
#define skipbits(fr, nob) fr->ultmp = ( \
83
0
  fr->ultmp = fr->wordpointer[0], fr->ultmp <<= 8, fr->ultmp |= fr->wordpointer[1], \
84
0
  fr->ultmp <<= 8, fr->ultmp |= fr->wordpointer[2], fr->ultmp <<= fr->bitindex, \
85
0
  fr->ultmp &= 0xffffff, fr->bitindex += nob, fr->bits_avail -= nob, \
86
0
  fr->ultmp >>= (24-nob), fr->wordpointer += (fr->bitindex>>3), \
87
0
  fr->bitindex &= 7 )
88
89
0
#define getbits_fast(fr, nob) ( \
90
0
  fr->ultmp = (unsigned char) (fr->wordpointer[0] << fr->bitindex), \
91
0
  fr->ultmp |= ((unsigned long) fr->wordpointer[1]<<fr->bitindex)>>8, \
92
0
  fr->ultmp <<= nob, fr->ultmp >>= 8, \
93
0
  fr->bitindex += nob, fr->bits_avail -= nob, \
94
0
  fr->wordpointer += (fr->bitindex>>3), \
95
0
  fr->bitindex &= 7, fr->ultmp )
96
97
0
#define get1bit(fr) ( \
98
0
  fr->uctmp = *fr->wordpointer << fr->bitindex, \
99
0
  ++fr->bitindex, --fr->bits_avail, \
100
0
  fr->wordpointer += (fr->bitindex>>3), fr->bitindex &= 7, fr->uctmp>>7 )
101
102
103
#endif