Coverage Report

Created: 2025-07-12 06:08

/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.17k
int oc_quant_params_unpack(oc_pack_buf *_opb,th_quant_info *_qinfo){
25
1.17k
  th_quant_base *base_mats;
26
1.17k
  long           val;
27
1.17k
  int            nbase_mats;
28
1.17k
  int            sizes[64];
29
1.17k
  int            indices[64];
30
1.17k
  int            nbits;
31
1.17k
  int            bmi;
32
1.17k
  int            ci;
33
1.17k
  int            qti;
34
1.17k
  int            pli;
35
1.17k
  int            qri;
36
1.17k
  int            qi;
37
1.17k
  int            i;
38
1.17k
  val=oc_pack_read(_opb,3);
39
1.17k
  nbits=(int)val;
40
76.3k
  for(qi=0;qi<64;qi++){
41
75.1k
    val=oc_pack_read(_opb,nbits);
42
75.1k
    _qinfo->loop_filter_limits[qi]=(unsigned char)val;
43
75.1k
  }
44
1.17k
  val=oc_pack_read(_opb,4);
45
1.17k
  nbits=(int)val+1;
46
76.3k
  for(qi=0;qi<64;qi++){
47
75.1k
    val=oc_pack_read(_opb,nbits);
48
75.1k
    _qinfo->ac_scale[qi]=(ogg_uint16_t)val;
49
75.1k
  }
50
1.17k
  val=oc_pack_read(_opb,4);
51
1.17k
  nbits=(int)val+1;
52
76.3k
  for(qi=0;qi<64;qi++){
53
75.1k
    val=oc_pack_read(_opb,nbits);
54
75.1k
    _qinfo->dc_scale[qi]=(ogg_uint16_t)val;
55
75.1k
  }
56
1.17k
  val=oc_pack_read(_opb,9);
57
1.17k
  nbase_mats=(int)val+1;
58
1.17k
  base_mats=_ogg_malloc(nbase_mats*sizeof(base_mats[0]));
59
1.17k
  if(base_mats==NULL)return TH_EFAULT;
60
7.85k
  for(bmi=0;bmi<nbase_mats;bmi++){
61
434k
    for(ci=0;ci<64;ci++){
62
427k
      val=oc_pack_read(_opb,8);
63
427k
      base_mats[bmi][ci]=(unsigned char)val;
64
427k
    }
65
6.68k
  }
66
1.17k
  nbits=oc_ilog(nbase_mats-1);
67
8.10k
  for(i=0;i<6;i++){
68
6.95k
    th_quant_ranges *qranges;
69
6.95k
    th_quant_base   *qrbms;
70
6.95k
    int             *qrsizes;
71
6.95k
    qti=i/3;
72
6.95k
    pli=i%3;
73
6.95k
    qranges=_qinfo->qi_ranges[qti]+pli;
74
6.95k
    if(i>0){
75
5.77k
      val=oc_pack_read1(_opb);
76
5.77k
      if(!val){
77
5.60k
        int qtj;
78
5.60k
        int plj;
79
5.60k
        if(qti>0){
80
3.38k
          val=oc_pack_read1(_opb);
81
3.38k
          if(val){
82
1.40k
            qtj=qti-1;
83
1.40k
            plj=pli;
84
1.40k
          }
85
1.97k
          else{
86
1.97k
            qtj=(i-1)/3;
87
1.97k
            plj=(i-1)%3;
88
1.97k
          }
89
3.38k
        }
90
2.22k
        else{
91
2.22k
          qtj=(i-1)/3;
92
2.22k
          plj=(i-1)%3;
93
2.22k
        }
94
5.60k
        *qranges=*(_qinfo->qi_ranges[qtj]+plj);
95
5.60k
        continue;
96
5.60k
      }
97
5.77k
    }
98
1.34k
    val=oc_pack_read(_opb,nbits);
99
1.34k
    indices[0]=(int)val;
100
8.41k
    for(qi=qri=0;qi<63;){
101
7.07k
      val=oc_pack_read(_opb,oc_ilog(62-qi));
102
7.07k
      sizes[qri]=(int)val+1;
103
7.07k
      qi+=(int)val+1;
104
7.07k
      val=oc_pack_read(_opb,nbits);
105
7.07k
      indices[++qri]=(int)val;
106
7.07k
    }
107
    /*Note: The caller is responsible for cleaning up any partially
108
       constructed qinfo.*/
109
1.34k
    if(qi>63){
110
12
      _ogg_free(base_mats);
111
12
      return TH_EBADHEADER;
112
12
    }
113
1.33k
    qranges->nranges=qri;
114
1.33k
    qranges->sizes=qrsizes=(int *)_ogg_malloc(qri*sizeof(qrsizes[0]));
115
1.33k
    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.33k
    memcpy(qrsizes,sizes,qri*sizeof(qrsizes[0]));
122
1.33k
    qrbms=(th_quant_base *)_ogg_malloc((qri+1)*sizeof(qrbms[0]));
123
1.33k
    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.33k
    qranges->base_matrices=(const th_quant_base *)qrbms;
130
8.32k
    do{
131
8.32k
      bmi=indices[qri];
132
      /*Note: The caller is responsible for cleaning up any partially
133
         constructed qinfo.*/
134
8.32k
      if(bmi>=nbase_mats){
135
8
        _ogg_free(base_mats);
136
8
        return TH_EBADHEADER;
137
8
      }
138
8.31k
      memcpy(qrbms[qri],base_mats[bmi],sizeof(qrbms[qri]));
139
8.31k
    }
140
8.31k
    while(qri-->0);
141
1.33k
  }
142
1.15k
  _ogg_free(base_mats);
143
1.15k
  return 0;
144
1.17k
}
145
146
1.17k
void oc_quant_params_clear(th_quant_info *_qinfo){
147
1.17k
  int i;
148
8.21k
  for(i=6;i-->0;){
149
7.04k
    int qti;
150
7.04k
    int pli;
151
7.04k
    qti=i/3;
152
7.04k
    pli=i%3;
153
    /*Clear any duplicate pointer references.*/
154
7.04k
    if(i>0){
155
5.87k
      int qtj;
156
5.87k
      int plj;
157
5.87k
      qtj=(i-1)/3;
158
5.87k
      plj=(i-1)%3;
159
5.87k
      if(_qinfo->qi_ranges[qti][pli].sizes==
160
5.87k
       _qinfo->qi_ranges[qtj][plj].sizes){
161
5.59k
        _qinfo->qi_ranges[qti][pli].sizes=NULL;
162
5.59k
      }
163
5.87k
      if(_qinfo->qi_ranges[qti][pli].base_matrices==
164
5.87k
       _qinfo->qi_ranges[qtj][plj].base_matrices){
165
5.59k
        _qinfo->qi_ranges[qti][pli].base_matrices=NULL;
166
5.59k
      }
167
5.87k
    }
168
7.04k
    if(qti>0){
169
3.52k
      if(_qinfo->qi_ranges[1][pli].sizes==
170
3.52k
       _qinfo->qi_ranges[0][pli].sizes){
171
145
        _qinfo->qi_ranges[1][pli].sizes=NULL;
172
145
      }
173
3.52k
      if(_qinfo->qi_ranges[1][pli].base_matrices==
174
3.52k
       _qinfo->qi_ranges[0][pli].base_matrices){
175
145
        _qinfo->qi_ranges[1][pli].base_matrices=NULL;
176
145
      }
177
3.52k
    }
178
    /*Now free all the non-duplicate storage.*/
179
7.04k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].sizes);
180
7.04k
    _ogg_free((void *)_qinfo->qi_ranges[qti][pli].base_matrices);
181
7.04k
  }
182
1.17k
}