Coverage Report

Created: 2026-05-30 06:10

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/work/libde265/libde265/vui.cc
Line
Count
Source
1
/*
2
 * H.265 video codec.
3
 * Copyright (c) 2013-2014 struktur AG, Dirk Farin <farin@struktur.de>
4
 *
5
 * This file is part of libde265.
6
 *
7
 * libde265 is free software: you can redistribute it and/or modify
8
 * it under the terms of the GNU Lesser General Public License as
9
 * published by the Free Software Foundation, either version 3 of
10
 * the License, or (at your option) any later version.
11
 *
12
 * libde265 is distributed in the hope that it will be useful,
13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
 * GNU Lesser General Public License for more details.
16
 *
17
 * You should have received a copy of the GNU Lesser General Public License
18
 * along with libde265.  If not, see <http://www.gnu.org/licenses/>.
19
 */
20
21
#include "vui.h"
22
#include "decctx.h"
23
24
#include <assert.h>
25
#include <stdlib.h>
26
#include <string.h>
27
28
#define READ_VLC(variable, vlctype)   \
29
1.41k
  if ((vlc = br->get_ ## vlctype()) == UVLC_ERROR) {   \
30
22
    errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);  \
31
22
    return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE; \
32
22
  } \
33
1.41k
  (variable) = vlc;
34
35
36
35
#define NUM_SAR_PRESETS 17
37
38
static uint16_t sar_presets[NUM_SAR_PRESETS+1][2] = {
39
  { 0,0 },
40
  { 1,1 },
41
  { 12,11 },
42
  { 10,11 },
43
  { 16,11 },
44
  { 40,33 },
45
  { 24,11 },
46
  { 20,11 },
47
  { 32,11 },
48
  { 80,33 },
49
  { 18,11 },
50
  { 15,11 },
51
  { 64,33 },
52
  { 160,99 },
53
  { 4,3 },
54
  { 3,2 },
55
  { 2,1 }
56
};
57
58
34
#define EXTENDED_SAR 255
59
60
61
const char* get_video_format_name(enum VideoFormat format)
62
0
{
63
0
  switch (format) {
64
0
  case VideoFormat_Component: return "component";
65
0
  case VideoFormat_PAL:       return "PAL";
66
0
  case VideoFormat_NTSC:      return "NTSC";
67
0
  case VideoFormat_SECAM:     return "SECAM";
68
0
  case VideoFormat_MAC:       return "MAC";
69
0
  default:                    return "unspecified";
70
0
  }
71
0
}
72
73
74
543
video_usability_information::video_usability_information() = default;
75
76
77
de265_error video_usability_information::hrd_parameters(error_queue* errqueue, bitreader* br, const seq_parameter_set* sps)
78
35
{
79
35
  uint32_t vlc;
80
81
35
  nal_hrd_parameters_present_flag = br->get_bits(1);
82
35
  vcl_hrd_parameters_present_flag = br->get_bits(1);
83
84
35
  if (nal_hrd_parameters_present_flag || vcl_hrd_parameters_present_flag)
85
31
  {
86
31
    sub_pic_hrd_params_present_flag = br->get_bits(1);
87
31
    if (sub_pic_hrd_params_present_flag)
88
27
    {
89
27
      tick_divisor_minus2 = br->get_bits(8);
90
27
      du_cpb_removal_delay_increment_length_minus1 = br->get_bits(5);
91
27
      sub_pic_cpb_params_in_pic_timing_sei_flag = br->get_bits(1);
92
27
      dpb_output_delay_du_length_minus1 = br->get_bits(5);
93
27
    }
94
31
    bit_rate_scale = br->get_bits(4);
95
31
    cpb_size_scale = br->get_bits(4);
96
97
98
31
    if (sub_pic_hrd_params_present_flag)
99
27
    {
100
27
      cpb_size_du_scale = br->get_bits(4);
101
27
    }
102
31
    initial_cpb_removal_delay_length_minus1 = br->get_bits(5);
103
31
    au_cpb_removal_delay_length_minus1 = br->get_bits(5);
104
31
    dpb_output_delay_length_minus1 = br->get_bits(5);
105
31
  }
106
35
  int  i, nalOrVcl;
107
108
57
  for (i = 0; i < sps->sps_max_sub_layers; i++)
109
35
  {
110
35
    fixed_pic_rate_general_flag[i] = br->get_bits(1);
111
35
    if (!fixed_pic_rate_general_flag[i])
112
10
    {
113
10
      fixed_pic_rate_within_cvs_flag[i] = br->get_bits(1);
114
10
    }
115
25
    else
116
25
    {
117
25
      fixed_pic_rate_within_cvs_flag[i] = true;
118
25
    }
119
120
35
    low_delay_hrd_flag[i] = 0;// Inferred to be 0 when not present
121
35
    cpb_cnt_minus1[i] = 0;    // Inferred to be 0 when not present
122
123
35
    if (fixed_pic_rate_within_cvs_flag[i])
124
27
    {
125
27
      READ_VLC(elemental_duration_in_tc_minus1[i], uvlc);
126
26
    }
127
8
    else
128
8
    {
129
8
      low_delay_hrd_flag[i] = br->get_bits(1);
130
8
    }
131
34
    if (!low_delay_hrd_flag[i])
132
32
    {
133
32
      READ_VLC(cpb_cnt_minus1[i], uvlc);
134
32
      if (cpb_cnt_minus1[i] > 31) {
135
0
  return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
136
0
      }
137
32
    }
138
139
86
    for (nalOrVcl = 0; nalOrVcl < 2; nalOrVcl++)
140
64
    {
141
64
      if (((nalOrVcl == 0) && nal_hrd_parameters_present_flag) ||
142
35
        ((nalOrVcl == 1) && vcl_hrd_parameters_present_flag))
143
53
      {
144
340
        for (uint32_t j = 0; j <= cpb_cnt_minus1[i]; j++)
145
299
        {
146
299
          READ_VLC(bit_rate_value_minus1[i][j][nalOrVcl], uvlc);
147
295
          READ_VLC(cpb_size_value_minus1[i][j][nalOrVcl], uvlc);
148
149
295
          if (sub_pic_hrd_params_present_flag)
150
289
          {
151
289
            READ_VLC(cpb_size_du_value_minus1[i][j][nalOrVcl], uvlc);
152
288
            READ_VLC(bit_rate_du_value_minus1[i][j][nalOrVcl], uvlc);
153
281
          }
154
287
          cbr_flag[i][j][nalOrVcl] = br->get_bits(1);
155
287
        }
156
53
      }
157
64
    }
158
34
  }
159
22
  return DE265_OK;
160
35
}
161
162
de265_error video_usability_information::read(error_queue* errqueue, bitreader* br,
163
                                              const seq_parameter_set* sps)
164
95
{
165
95
  uint32_t vlc;
166
167
168
  // --- sample aspect ratio (SAR) ---
169
170
95
  aspect_ratio_info_present_flag = br->get_bits(1);
171
95
  if (aspect_ratio_info_present_flag) {
172
35
    int aspect_ratio_idc = br->get_bits(8);
173
35
    if (aspect_ratio_idc <= NUM_SAR_PRESETS) {
174
1
      sar_width = sar_presets[aspect_ratio_idc][0];
175
1
      sar_height = sar_presets[aspect_ratio_idc][1];
176
1
    }
177
34
    else if (aspect_ratio_idc == EXTENDED_SAR) {
178
13
      sar_width = br->get_bits(16);
179
13
      sar_height = br->get_bits(16);
180
13
    }
181
21
    else {
182
21
      sar_width = 0;
183
21
      sar_height = 0;
184
21
    }
185
35
  }
186
60
  else {
187
60
    sar_width = 0;
188
60
    sar_height = 0;
189
60
  }
190
191
192
  // --- overscan ---
193
194
95
  overscan_info_present_flag = br->get_bits(1);
195
95
  if (overscan_info_present_flag) {
196
57
    overscan_appropriate_flag = br->get_bits(1);
197
57
  }
198
199
200
  // --- video signal type ---
201
202
95
  { // defaults
203
95
    video_format = VideoFormat_Unspecified;
204
95
    video_full_range_flag = false;
205
95
    colour_primaries = 2;
206
95
    transfer_characteristics = 2;
207
95
    matrix_coeffs = 2;
208
95
  }
209
210
95
  video_signal_type_present_flag = br->get_bits(1);
211
95
  if (video_signal_type_present_flag) {
212
68
    int video_format_idc = br->get_bits(3);
213
68
    if (video_format_idc > 5) {
214
32
      video_format_idc = VideoFormat_Unspecified;
215
32
    }
216
68
    video_format = (VideoFormat)video_format_idc;
217
218
68
    video_full_range_flag = br->get_bits(1);
219
220
68
    colour_description_present_flag = br->get_bits(1);
221
68
    if (colour_description_present_flag) {
222
42
      colour_primaries = br->get_bits(8);
223
42
      if (colour_primaries == 0 ||
224
42
        colour_primaries == 3 ||
225
42
        colour_primaries >= 11) {
226
38
        colour_primaries = 2;
227
38
      }
228
229
42
      transfer_characteristics = br->get_bits(8);
230
42
      if (transfer_characteristics == 0 ||
231
42
        transfer_characteristics == 3 ||
232
42
        transfer_characteristics >= 18) {
233
28
        transfer_characteristics = 2;
234
28
      }
235
236
42
      matrix_coeffs = br->get_bits(8);
237
      
238
42
      if (matrix_coeffs >= 11) {
239
38
        matrix_coeffs = 2;
240
38
      }
241
42
    }
242
68
  }
243
244
245
  // --- chroma / interlaced ---
246
247
95
  chroma_loc_info_present_flag = br->get_bits(1);
248
95
  if (chroma_loc_info_present_flag) {
249
61
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 5) {
250
8
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
251
8
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
252
8
    }
253
53
    chroma_sample_loc_type_top_field = vlc;
254
255
53
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 5) {
256
2
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
257
2
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
258
2
    }
259
51
    chroma_sample_loc_type_bottom_field = vlc;
260
51
  }
261
34
  else {
262
34
    chroma_sample_loc_type_top_field = 0;
263
34
    chroma_sample_loc_type_bottom_field = 0;
264
34
  }
265
266
85
  neutral_chroma_indication_flag = br->get_bits(1);
267
85
  field_seq_flag = br->get_bits(1);
268
85
  frame_field_info_present_flag = br->get_bits(1);
269
270
271
  // --- default display window ---
272
273
85
  default_display_window_flag = br->get_bits(1);
274
85
  if (default_display_window_flag) {
275
45
    READ_VLC(def_disp_win_left_offset, uvlc);
276
45
    READ_VLC(def_disp_win_right_offset, uvlc);
277
45
    READ_VLC(def_disp_win_top_offset, uvlc);
278
45
    READ_VLC(def_disp_win_bottom_offset, uvlc);
279
36
  }
280
40
  else {
281
40
    def_disp_win_left_offset = 0;
282
40
    def_disp_win_right_offset = 0;
283
40
    def_disp_win_top_offset = 0;
284
40
    def_disp_win_bottom_offset = 0;
285
40
  }
286
287
288
  // --- timing ---
289
290
76
  vui_timing_info_present_flag = br->get_bits(1);
291
76
  if (vui_timing_info_present_flag) {
292
63
    vui_num_units_in_tick = br->get_bits(32);
293
63
    vui_time_scale = br->get_bits(32);
294
295
63
    vui_poc_proportional_to_timing_flag = br->get_bits(1);
296
63
    if (vui_poc_proportional_to_timing_flag) {
297
29
      if ((vlc = br->get_uvlc()) == UVLC_ERROR) {
298
0
        errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
299
0
        return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
300
0
      }
301
302
29
      vui_num_ticks_poc_diff_one = vlc + 1;
303
29
    }
304
305
    // --- hrd parameters ---
306
307
63
    vui_hrd_parameters_present_flag = br->get_bits(1);
308
63
    if (vui_hrd_parameters_present_flag) {
309
35
      de265_error err;
310
35
      err = hrd_parameters(errqueue, br, sps);
311
35
      if (err) {
312
13
  return err;
313
13
      }
314
35
    }
315
63
  }
316
317
  // --- bitstream restriction ---
318
319
63
  bitstream_restriction_flag = br->get_bits(1);
320
63
  if (bitstream_restriction_flag) {
321
40
    tiles_fixed_structure_flag = br->get_bits(1);
322
40
    motion_vectors_over_pic_boundaries_flag = br->get_bits(1);
323
40
    restricted_ref_pic_lists_flag = br->get_bits(1);
324
325
40
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 4095) {
326
0
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
327
0
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
328
0
    }
329
40
    min_spatial_segmentation_idc = vlc;
330
331
40
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 16) {
332
18
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
333
18
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
334
18
    }
335
22
    max_bytes_per_pic_denom = vlc;
336
337
22
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 16) {
338
2
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
339
2
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
340
2
    }
341
20
    max_bits_per_min_cu_denom = vlc;
342
343
20
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 15) {
344
0
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
345
0
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
346
0
    }
347
20
    log2_max_mv_length_horizontal = vlc;
348
349
20
    if ((vlc = br->get_uvlc()) == UVLC_ERROR || vlc > 15) {
350
4
      errqueue->add_warning(DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE, false);
351
4
      return DE265_ERROR_CODED_PARAMETER_OUT_OF_RANGE;
352
4
    }
353
16
    log2_max_mv_length_vertical = vlc;
354
16
  }
355
23
  else {
356
23
    tiles_fixed_structure_flag = false;
357
23
    motion_vectors_over_pic_boundaries_flag = true;
358
23
    restricted_ref_pic_lists_flag = false; // NOTE: default not specified in standard 2014/10
359
360
23
    min_spatial_segmentation_idc = 0;
361
23
    max_bytes_per_pic_denom   = 2;
362
23
    max_bits_per_min_cu_denom = 1;
363
23
    log2_max_mv_length_horizontal = 15;
364
23
    log2_max_mv_length_vertical   = 15;
365
23
  }
366
367
  //vui_read = true;
368
369
39
  return DE265_OK;
370
63
}
371
372
373
void video_usability_information::dump(int fd) const
374
0
{
375
  //#if (_MSC_VER >= 1500)
376
  //#define LOG0(t) loginfo(LogHeaders, t)
377
  //#define LOG1(t,d) loginfo(LogHeaders, t,d)
378
  //#define LOG2(t,d1,d2) loginfo(LogHeaders, t,d1,d2)
379
  //#define LOG3(t,d1,d2,d3) loginfo(LogHeaders, t,d1,d2,d3)
380
381
0
  FILE* fh;
382
0
  if (fd==1) fh=stdout;
383
0
  else if (fd==2) fh=stderr;
384
0
  else { return; }
385
386
0
#define LOG0(t) log2fh(fh, t)
387
0
#define LOG1(t,d) log2fh(fh, t,d)
388
0
#define LOG2(t,d1,d2) log2fh(fh, t,d1,d2)
389
0
#define LOG3(t,d1,d2,d3) log2fh(fh, t,d1,d2,d3)
390
391
0
  LOG0("----------------- VUI -----------------\n");
392
0
  LOG2("sample aspect ratio        : %d:%d\n", sar_width,sar_height);
393
0
  LOG1("overscan_info_present_flag : %d\n", overscan_info_present_flag);
394
0
  LOG1("overscan_appropriate_flag  : %d\n", overscan_appropriate_flag);
395
396
0
  LOG1("video_signal_type_present_flag: %d\n", video_signal_type_present_flag);
397
0
  if (video_signal_type_present_flag) {
398
0
    LOG1("  video_format                : %s\n", get_video_format_name(video_format));
399
0
    LOG1("  video_full_range_flag       : %d\n", video_full_range_flag);
400
0
    LOG1("  colour_description_present_flag : %d\n", colour_description_present_flag);
401
0
    LOG1("  colour_primaries            : %d\n", colour_primaries);
402
0
    LOG1("  transfer_characteristics    : %d\n", transfer_characteristics);
403
0
    LOG1("  matrix_coeffs               : %d\n", matrix_coeffs);
404
0
  }
405
406
0
  LOG1("chroma_loc_info_present_flag: %d\n", chroma_loc_info_present_flag);
407
0
  if (chroma_loc_info_present_flag) {
408
0
    LOG1("  chroma_sample_loc_type_top_field   : %d\n", chroma_sample_loc_type_top_field);
409
0
    LOG1("  chroma_sample_loc_type_bottom_field: %d\n", chroma_sample_loc_type_bottom_field);
410
0
  }
411
412
0
  LOG1("neutral_chroma_indication_flag: %d\n", neutral_chroma_indication_flag);
413
0
  LOG1("field_seq_flag                : %d\n", field_seq_flag);
414
0
  LOG1("frame_field_info_present_flag : %d\n", frame_field_info_present_flag);
415
416
0
  LOG1("default_display_window_flag   : %d\n", default_display_window_flag);
417
0
  LOG1("  def_disp_win_left_offset    : %d\n", def_disp_win_left_offset);
418
0
  LOG1("  def_disp_win_right_offset   : %d\n", def_disp_win_right_offset);
419
0
  LOG1("  def_disp_win_top_offset     : %d\n", def_disp_win_top_offset);
420
0
  LOG1("  def_disp_win_bottom_offset  : %d\n", def_disp_win_bottom_offset);
421
422
0
  LOG1("vui_timing_info_present_flag  : %d\n", vui_timing_info_present_flag);
423
0
  if (vui_timing_info_present_flag) {
424
0
    LOG1("  vui_num_units_in_tick       : %d\n", vui_num_units_in_tick);
425
0
    LOG1("  vui_time_scale              : %d\n", vui_time_scale);
426
0
  }
427
428
0
  LOG1("vui_poc_proportional_to_timing_flag : %d\n", vui_poc_proportional_to_timing_flag);
429
0
  LOG1("vui_num_ticks_poc_diff_one          : %d\n", vui_num_ticks_poc_diff_one);
430
431
0
  LOG1("vui_hrd_parameters_present_flag : %d\n", vui_hrd_parameters_present_flag);
432
0
  if (vui_hrd_parameters_present_flag) {
433
    //hrd_parameters vui_hrd_parameters;
434
0
  }
435
436
437
  // --- bitstream restriction ---
438
439
0
  LOG1("bitstream_restriction_flag         : %d\n", bitstream_restriction_flag);
440
0
  if (bitstream_restriction_flag) {
441
0
    LOG1("  tiles_fixed_structure_flag       : %d\n", tiles_fixed_structure_flag);
442
0
    LOG1("  motion_vectors_over_pic_boundaries_flag : %d\n", motion_vectors_over_pic_boundaries_flag);
443
0
    LOG1("  restricted_ref_pic_lists_flag    : %d\n", restricted_ref_pic_lists_flag);
444
0
    LOG1("  min_spatial_segmentation_idc     : %d\n", min_spatial_segmentation_idc);
445
0
    LOG1("  max_bytes_per_pic_denom          : %d\n", max_bytes_per_pic_denom);
446
0
    LOG1("  max_bits_per_min_cu_denom        : %d\n", max_bits_per_min_cu_denom);
447
0
    LOG1("  log2_max_mv_length_horizontal    : %d\n", log2_max_mv_length_horizontal);
448
0
    LOG1("  log2_max_mv_length_vertical      : %d\n", log2_max_mv_length_vertical);
449
0
  }
450
451
0
#undef LOG0
452
0
#undef LOG1
453
0
#undef LOG2
454
0
#undef LOG3
455
  //#endif
456
0
}