Coverage Report

Created: 2025-08-03 06:44

/src/libtheora/lib/dequant.c
Line
Count
Source (jump to first uncovered line)
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.31k
int oc_quant_params_unpack(oc_pack_buf *_opb,th_quant_info *_qinfo){
25
1.31k
  th_quant_base *base_mats;
26
1.31k
  long           val;
27
1.31k
  int            nbase_mats;
28
1.31k
  int            sizes[64];
29
1.31k
  int            indices[64];
30
1.31k
  int            nbits;
31
1.31k
  int            bmi;
32
1.31k
  int            ci;
33
1.31k
  int            qti;
34
1.31k
  int            pli;
35
1.31k
  int            qri;
36
1.31k
  int            qi;
37
1.31k
  int            i;
38
1.31k
  val=oc_pack_read(_opb,3);
39
1.31k
  nbits=(int)val;
40
85.2k
  for(qi=0;qi<64;qi++){
41
83.9k
    val=oc_pack_read(_opb,nbits);
42
83.9k
    _qinfo->loop_filter_limits[qi]=(unsigned char)val;
43
83.9k
  }
44
1.31k
  val=oc_pack_read(_opb,4);
45
1.31k
  nbits=(int)val+1;
46
85.2k
  for(qi=0;qi<64;qi++){
47
83.9k
    val=oc_pack_read(_opb,nbits);
48
83.9k
    _qinfo->ac_scale[qi]=(ogg_uint16_t)val;
49
83.9k
  }
50
1.31k
  val=oc_pack_read(_opb,4);
51
1.31k
  nbits=(int)val+1;
52
85.2k
  for(qi=0;qi<64;qi++){
53
83.9k
    val=oc_pack_read(_opb,nbits);
54
83.9k
    _qinfo->dc_scale[qi]=(ogg_uint16_t)val;
55
83.9k
  }
56
1.31k
  val=oc_pack_read(_opb,9);
57
1.31k
  nbase_mats=(int)val+1;
58
1.31k
  base_mats=_ogg_malloc(nbase_mats*sizeof(base_mats[0]));
59
1.31k
  if(base_mats==NULL)return TH_EFAULT;
60
9.40k
  for(bmi=0;bmi<nbase_mats;bmi++){
61
525k
    for(ci=0;ci<64;ci++){
62
517k
      val=oc_pack_read(_opb,8);
63
517k
      base_mats[bmi][ci]=(unsigned char)val;
64
517k
    }
65
8.08k
  }
66
1.31k
  nbits=oc_ilog(nbase_mats-1);
67
9.08k
  for(i=0;i<6;i++){
68
7.79k
    th_quant_ranges *qranges;
69
7.79k
    th_quant_base   *qrbms;
70
7.79k
    int             *qrsizes;
71
7.79k
    qti=i/3;
72
7.79k
    pli=i%3;
73
7.79k
    qranges=_qinfo->qi_ranges[qti]+pli;
74
7.79k
    if(i>0){
75
6.47k
      val=oc_pack_read1(_opb);
76
6.47k
      if(!val){
77
6.31k
        int qtj;
78
6.31k
        int plj;
79
6.31k
        if(qti>0){
80
3.80k
          val=oc_pack_read1(_opb);
81
3.80k
          if(val){
82
1.57k
            qtj=qti-1;
83
1.57k
            plj=pli;
84
1.57k
          }
85
2.22k
          else{
86
2.22k
            qtj=(i-1)/3;
87
2.22k
            plj=(i-1)%3;
88
2.22k
          }
89
3.80k
        }
90
2.50k
        else{
91
2.50k
          qtj=(i-1)/3;
92
2.50k
          plj=(i-1)%3;
93
2.50k
        }
94
6.31k
        *qranges=*(_qinfo->qi_ranges[qtj]+plj);
95
6.31k
        continue;
96
6.31k
      }
97
6.47k
    }
98
1.47k
    val=oc_pack_read(_opb,nbits);
99
1.47k
    indices[0]=(int)val;
100
9.25k
    for(qi=qri=0;qi<63;){
101
7.77k
      val=oc_pack_read(_opb,oc_ilog(62-qi));
102
7.77k
      sizes[qri]=(int)val+1;
103
7.77k
      qi+=(int)val+1;
104
7.77k
      val=oc_pack_read(_opb,nbits);
105
7.77k
      indices[++qri]=(int)val;
106
7.77k
    }
107
    /*Note: The caller is responsible for cleaning up any partially
108
       constructed qinfo.*/
109
1.47k
    if(qi>63){
110
10
      _ogg_free(base_mats);
111
10
      return TH_EBADHEADER;
112
10
    }
113
1.46k
    qranges->nranges=qri;
114
1.46k
    qranges->sizes=qrsizes=(int *)_ogg_malloc(qri*sizeof(qrsizes[0]));
115
1.46k
    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.46k
    memcpy(qrsizes,sizes,qri*sizeof(qrsizes[0]));
122
1.46k
    qrbms=(th_quant_base *)_ogg_malloc((qri+1)*sizeof(qrbms[0]));
123
1.46k
    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.46k
    qranges->base_matrices=(const th_quant_base *)qrbms;
130
9.16k
    do{
131
9.16k
      bmi=indices[qri];
132
      /*Note: The caller is responsible for cleaning up any partially
133
         constructed qinfo.*/
134
9.16k
      if(bmi>=nbase_mats){
135
8
        _ogg_free(base_mats);
136
8
        return TH_EBADHEADER;
137
8
      }
138
9.15k
      memcpy(qrbms[qri],base_mats[bmi],sizeof(qrbms[qri]));
139
9.15k
    }
140
9.15k
    while(qri-->0);
141
1.46k
  }
142
1.29k
  _ogg_free(base_mats);
143
1.29k
  return 0;
144
1.31k
}
145
146
1.31k
void oc_quant_params_clear(th_quant_info *_qinfo){
147
1.31k
  int i;
148
9.18k
  for(i=6;i-->0;){
149
7.87k
    int qti;
150
7.87k
    int pli;
151
7.87k
    qti=i/3;
152
7.87k
    pli=i%3;
153
    /*Clear any duplicate pointer references.*/
154
7.87k
    if(i>0){
155
6.56k
      int qtj;
156
6.56k
      int plj;
157
6.56k
      qtj=(i-1)/3;
158
6.56k
      plj=(i-1)%3;
159
6.56k
      if(_qinfo->qi_ranges[qti][pli].sizes==
160
6.56k
       _qinfo->qi_ranges[qtj][plj].sizes){
161
6.28k
        _qinfo->qi_ranges[qti][pli].sizes=NULL;
162
6.28k
      }
163
6.56k
      if(_qinfo->qi_ranges[qti][pli].base_matrices==
164
6.56k
       _qinfo->qi_ranges[qtj][plj].base_matrices){
165
6.28k
        _qinfo->qi_ranges[qti][pli].base_matrices=NULL;
166
6.28k
      }
167
6.56k
    }
168
7.87k
    if(qti>0){
169
3.93k
      if(_qinfo->qi_ranges[1][pli].sizes==
170
3.93k
       _qinfo->qi_ranges[0][pli].sizes){
171
141
        _qinfo->qi_ranges[1][pli].sizes=NULL;
172
141
      }
173
3.93k
      if(_qinfo->qi_ranges[1][pli].base_matrices==
174
3.93k
       _qinfo->qi_ranges[0][pli].base_matrices){
175
141
        _qinfo->qi_ranges[1][pli].base_matrices=NULL;
176
141
      }
177
3.93k
    }
178
    /*Now free all the non-duplicate storage.*/
179
7.87k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].sizes);
180
7.87k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].base_matrices);
181
7.87k
  }
182
1.31k
}