Coverage Report

Created: 2026-05-30 06:53

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libtheora/lib/dequant.c
Line
Count
Source
1
/********************************************************************
2
 *                                                                  *
3
 * THIS FILE IS PART OF THE OggTheora SOFTWARE CODEC SOURCE CODE.   *
4
 * USE, DISTRIBUTION AND REPRODUCTION OF THIS LIBRARY SOURCE IS     *
5
 * GOVERNED BY A BSD-STYLE SOURCE LICENSE INCLUDED WITH THIS SOURCE *
6
 * IN 'COPYING'. PLEASE READ THESE TERMS BEFORE DISTRIBUTING.       *
7
 *                                                                  *
8
 * THE Theora SOURCE CODE IS COPYRIGHT (C) 2002-2009                *
9
 * by the Xiph.Org Foundation and contributors                      *
10
 * https://www.xiph.org/                                            *
11
 *                                                                  *
12
 ********************************************************************
13
14
  function:
15
16
 ********************************************************************/
17
18
#include <stdlib.h>
19
#include <string.h>
20
#include <ogg/ogg.h>
21
#include "dequant.h"
22
#include "decint.h"
23
24
1.35k
int oc_quant_params_unpack(oc_pack_buf *_opb,th_quant_info *_qinfo){
25
1.35k
  th_quant_base *base_mats;
26
1.35k
  long           val;
27
1.35k
  int            nbase_mats;
28
1.35k
  int            sizes[64];
29
1.35k
  int            indices[64];
30
1.35k
  int            nbits;
31
1.35k
  int            bmi;
32
1.35k
  int            ci;
33
1.35k
  int            qti;
34
1.35k
  int            pli;
35
1.35k
  int            qri;
36
1.35k
  int            qi;
37
1.35k
  int            i;
38
1.35k
  val=oc_pack_read(_opb,3);
39
1.35k
  nbits=(int)val;
40
88.0k
  for(qi=0;qi<64;qi++){
41
86.7k
    val=oc_pack_read(_opb,nbits);
42
86.7k
    _qinfo->loop_filter_limits[qi]=(unsigned char)val;
43
86.7k
  }
44
1.35k
  val=oc_pack_read(_opb,4);
45
1.35k
  nbits=(int)val+1;
46
88.0k
  for(qi=0;qi<64;qi++){
47
86.7k
    val=oc_pack_read(_opb,nbits);
48
86.7k
    _qinfo->ac_scale[qi]=(ogg_uint16_t)val;
49
86.7k
  }
50
1.35k
  val=oc_pack_read(_opb,4);
51
1.35k
  nbits=(int)val+1;
52
88.0k
  for(qi=0;qi<64;qi++){
53
86.7k
    val=oc_pack_read(_opb,nbits);
54
86.7k
    _qinfo->dc_scale[qi]=(ogg_uint16_t)val;
55
86.7k
  }
56
1.35k
  val=oc_pack_read(_opb,9);
57
1.35k
  nbase_mats=(int)val+1;
58
1.35k
  base_mats=_ogg_malloc(nbase_mats*sizeof(base_mats[0]));
59
1.35k
  if(base_mats==NULL)return TH_EFAULT;
60
9.97k
  for(bmi=0;bmi<nbase_mats;bmi++){
61
560k
    for(ci=0;ci<64;ci++){
62
551k
      val=oc_pack_read(_opb,8);
63
551k
      base_mats[bmi][ci]=(unsigned char)val;
64
551k
    }
65
8.61k
  }
66
1.35k
  nbits=oc_ilog(nbase_mats-1);
67
9.35k
  for(i=0;i<6;i++){
68
8.02k
    th_quant_ranges *qranges;
69
8.02k
    th_quant_base   *qrbms;
70
8.02k
    int             *qrsizes;
71
8.02k
    qti=i/3;
72
8.02k
    pli=i%3;
73
8.02k
    qranges=_qinfo->qi_ranges[qti]+pli;
74
8.02k
    if(i>0){
75
6.67k
      val=oc_pack_read1(_opb);
76
6.67k
      if(!val){
77
6.47k
        int qtj;
78
6.47k
        int plj;
79
6.47k
        if(qti>0){
80
3.91k
          val=oc_pack_read1(_opb);
81
3.91k
          if(val){
82
1.60k
            qtj=qti-1;
83
1.60k
            plj=pli;
84
1.60k
          }
85
2.30k
          else{
86
2.30k
            qtj=(i-1)/3;
87
2.30k
            plj=(i-1)%3;
88
2.30k
          }
89
3.91k
        }
90
2.55k
        else{
91
2.55k
          qtj=(i-1)/3;
92
2.55k
          plj=(i-1)%3;
93
2.55k
        }
94
6.47k
        *qranges=*(_qinfo->qi_ranges[qtj]+plj);
95
6.47k
        continue;
96
6.47k
      }
97
6.67k
    }
98
1.55k
    val=oc_pack_read(_opb,nbits);
99
1.55k
    indices[0]=(int)val;
100
9.93k
    for(qi=qri=0;qi<63;){
101
8.38k
      val=oc_pack_read(_opb,oc_ilog(62-qi));
102
8.38k
      sizes[qri]=(int)val+1;
103
8.38k
      qi+=(int)val+1;
104
8.38k
      val=oc_pack_read(_opb,nbits);
105
8.38k
      indices[++qri]=(int)val;
106
8.38k
    }
107
    /*Note: The caller is responsible for cleaning up any partially
108
       constructed qinfo.*/
109
1.55k
    if(qi>63){
110
15
      _ogg_free(base_mats);
111
15
      return TH_EBADHEADER;
112
15
    }
113
1.54k
    qranges->nranges=qri;
114
1.54k
    qranges->sizes=qrsizes=(int *)_ogg_malloc(qri*sizeof(qrsizes[0]));
115
1.54k
    if(qranges->sizes==NULL){
116
      /*Note: The caller is responsible for cleaning up any partially
117
         constructed qinfo.*/
118
0
      _ogg_free(base_mats);
119
0
      return TH_EFAULT;
120
0
    }
121
1.54k
    memcpy(qrsizes,sizes,qri*sizeof(qrsizes[0]));
122
1.54k
    qrbms=(th_quant_base *)_ogg_malloc((qri+1)*sizeof(qrbms[0]));
123
1.54k
    if(qrbms==NULL){
124
      /*Note: The caller is responsible for cleaning up any partially
125
         constructed qinfo.*/
126
0
      _ogg_free(base_mats);
127
0
      return TH_EFAULT;
128
0
    }
129
1.54k
    qranges->base_matrices=(const th_quant_base *)qrbms;
130
9.86k
    do{
131
9.86k
      bmi=indices[qri];
132
      /*Note: The caller is responsible for cleaning up any partially
133
         constructed qinfo.*/
134
9.86k
      if(bmi>=nbase_mats){
135
8
        _ogg_free(base_mats);
136
8
        return TH_EBADHEADER;
137
8
      }
138
9.85k
      memcpy(qrbms[qri],base_mats[bmi],sizeof(qrbms[qri]));
139
9.85k
    }
140
9.85k
    while(qri-->0);
141
1.54k
  }
142
1.33k
  _ogg_free(base_mats);
143
1.33k
  return 0;
144
1.35k
}
145
146
1.35k
void oc_quant_params_clear(th_quant_info *_qinfo){
147
1.35k
  int i;
148
9.48k
  for(i=6;i-->0;){
149
8.13k
    int qti;
150
8.13k
    int pli;
151
8.13k
    qti=i/3;
152
8.13k
    pli=i%3;
153
    /*Clear any duplicate pointer references.*/
154
8.13k
    if(i>0){
155
6.77k
      int qtj;
156
6.77k
      int plj;
157
6.77k
      qtj=(i-1)/3;
158
6.77k
      plj=(i-1)%3;
159
6.77k
      if(_qinfo->qi_ranges[qti][pli].sizes==
160
6.77k
       _qinfo->qi_ranges[qtj][plj].sizes){
161
6.45k
        _qinfo->qi_ranges[qti][pli].sizes=NULL;
162
6.45k
      }
163
6.77k
      if(_qinfo->qi_ranges[qti][pli].base_matrices==
164
6.77k
       _qinfo->qi_ranges[qtj][plj].base_matrices){
165
6.45k
        _qinfo->qi_ranges[qti][pli].base_matrices=NULL;
166
6.45k
      }
167
6.77k
    }
168
8.13k
    if(qti>0){
169
4.06k
      if(_qinfo->qi_ranges[1][pli].sizes==
170
4.06k
       _qinfo->qi_ranges[0][pli].sizes){
171
163
        _qinfo->qi_ranges[1][pli].sizes=NULL;
172
163
      }
173
4.06k
      if(_qinfo->qi_ranges[1][pli].base_matrices==
174
4.06k
       _qinfo->qi_ranges[0][pli].base_matrices){
175
163
        _qinfo->qi_ranges[1][pli].base_matrices=NULL;
176
163
      }
177
4.06k
    }
178
    /*Now free all the non-duplicate storage.*/
179
8.13k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].sizes);
180
8.13k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].base_matrices);
181
8.13k
  }
182
1.35k
}