Coverage Report

Created: 2025-12-29 06:15

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/libavc/decoder/ih264d_sei.c
Line
Count
Source
1
/******************************************************************************
2
 *
3
 * Copyright (C) 2015 The Android Open Source Project
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at:
8
 *
9
 * http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 *
17
 *****************************************************************************
18
 * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19
*/
20
21
/*****************************************************************************/
22
/*                                                                           */
23
/*  File Name         : ih264d_sei.c                                         */
24
/*                                                                           */
25
/*  Description       : This file contains routines to parse SEI NAL's       */
26
/*                                                                           */
27
/*  List of Functions : <List the functions defined in this file>            */
28
/*                                                                           */
29
/*  Issues / Problems : None                                                 */
30
/*                                                                           */
31
/*  Revision History  :                                                      */
32
/*                                                                           */
33
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
34
/*         25 05 2005   NS              Draft                                */
35
/*                                                                           */
36
/*****************************************************************************/
37
38
#include <string.h>
39
40
#include "ih264_typedefs.h"
41
#include "ih264_macros.h"
42
#include "ih264_platform_macros.h"
43
#include "ih264d_bitstrm.h"
44
#include "ih264d_structs.h"
45
#include "ih264d_error_handler.h"
46
#include "ih264d_vui.h"
47
#include "ih264d_parse_cavlc.h"
48
#include "ih264d_defs.h"
49
50
/*****************************************************************************/
51
/*                                                                           */
52
/*  Function Name : ih264d_parse_buffering_period                            */
53
/*                                                                           */
54
/*  Description   : This function parses SEI message buffering_period        */
55
/*  Inputs        : ps_buf_prd pointer to struct buf_period_t                */
56
/*                  ps_bitstrm    Bitstream                                  */
57
/*  Globals       : None                                                     */
58
/*  Processing    : Parses SEI payload buffering period.                     */
59
/*  Outputs       : None                                                     */
60
/*  Return        : 0 for successfull parsing, else error message            */
61
/*                                                                           */
62
/*  Issues        : Not implemented fully                                    */
63
/*                                                                           */
64
/*  Revision History:                                                        */
65
/*                                                                           */
66
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
67
/*         06 05 2002   NS              Draft                                */
68
/*                                                                           */
69
/*****************************************************************************/
70
71
WORD32 ih264d_parse_buffering_period(buf_period_t *ps_buf_prd,
72
                                     dec_bit_stream_t *ps_bitstrm,
73
                                     dec_struct_t *ps_dec)
74
2.25k
{
75
2.25k
    UWORD8 u1_seq_parameter_set_id;
76
2.25k
    dec_seq_params_t *ps_seq;
77
2.25k
    UWORD8 u1_nal_hrd_present, u1_vcl_hrd_present;
78
2.25k
    UWORD32 i;
79
2.25k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
80
2.25k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
81
2.25k
    UNUSED(ps_buf_prd);
82
2.25k
    u1_seq_parameter_set_id = ih264d_uev(pu4_bitstrm_ofst,
83
2.25k
                                         pu4_bitstrm_buf);
84
2.25k
    if(u1_seq_parameter_set_id >= MAX_NUM_SEQ_PARAMS)
85
2
        return ERROR_INVALID_SEQ_PARAM;
86
2.25k
    ps_seq = &ps_dec->ps_sps[u1_seq_parameter_set_id];
87
2.25k
    if(TRUE != ps_seq->u1_is_valid)
88
1
        return ERROR_INVALID_SEQ_PARAM;
89
90
2.25k
    ps_dec->ps_sei->u1_seq_param_set_id = u1_seq_parameter_set_id;
91
2.25k
    ps_dec->ps_cur_sps = ps_seq;
92
2.25k
    if(FALSE == ps_seq->u1_is_valid)
93
0
        return ERROR_INVALID_SEQ_PARAM;
94
2.25k
    if(1 == ps_seq->u1_vui_parameters_present_flag)
95
551
    {
96
551
        u1_nal_hrd_present = ps_seq->s_vui.u1_nal_hrd_params_present;
97
551
        if(u1_nal_hrd_present)
98
304
        {
99
4.88k
            for(i = 0; i < ps_seq->s_vui.s_nal_hrd.u4_cpb_cnt; i++)
100
4.57k
            {
101
4.57k
                ih264d_get_bits_h264(
102
4.57k
                                ps_bitstrm,
103
4.57k
                                ps_seq->s_vui.s_nal_hrd.u1_initial_cpb_removal_delay);
104
4.57k
                ih264d_get_bits_h264(
105
4.57k
                                ps_bitstrm,
106
4.57k
                                ps_seq->s_vui.s_nal_hrd.u1_initial_cpb_removal_delay);
107
4.57k
            }
108
304
        }
109
110
551
        u1_vcl_hrd_present = ps_seq->s_vui.u1_vcl_hrd_params_present;
111
551
        if(u1_vcl_hrd_present)
112
320
        {
113
2.93k
            for(i = 0; i < ps_seq->s_vui.s_vcl_hrd.u4_cpb_cnt; i++)
114
2.61k
            {
115
2.61k
                ih264d_get_bits_h264(
116
2.61k
                                ps_bitstrm,
117
2.61k
                                ps_seq->s_vui.s_vcl_hrd.u1_initial_cpb_removal_delay);
118
2.61k
                ih264d_get_bits_h264(
119
2.61k
                                ps_bitstrm,
120
2.61k
                                ps_seq->s_vui.s_vcl_hrd.u1_initial_cpb_removal_delay);
121
2.61k
            }
122
320
        }
123
551
    }
124
2.25k
    return (OK);
125
2.25k
}
126
127
/*****************************************************************************/
128
/*                                                                           */
129
/*  Function Name : ih264d_parse_pic_timing                                  */
130
/*                                                                           */
131
/*  Description   : This function parses SEI message pic_timing              */
132
/*  Inputs        : ps_bitstrm    Bitstream                                  */
133
/*                  ps_dec          Poniter decoder context                  */
134
/*                  ui4_payload_size pay load i4_size                        */
135
/*  Globals       : None                                                     */
136
/*  Processing    : Parses SEI payload picture timing                        */
137
/*  Outputs       : None                                                     */
138
/*  Return        : 0                                                        */
139
/*                                                                           */
140
/*  Issues        : Not implemented fully                                    */
141
/*                                                                           */
142
/*  Revision History:                                                        */
143
/*                                                                           */
144
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
145
/*         06 05 2002   NS              Draft                                */
146
/*                                                                           */
147
/*****************************************************************************/
148
WORD32 ih264d_parse_pic_timing(dec_bit_stream_t *ps_bitstrm,
149
                               dec_struct_t *ps_dec,
150
                               UWORD32 ui4_payload_size)
151
1.49k
{
152
1.49k
    sei *ps_sei;
153
1.49k
    vui_t *ps_vu4;
154
1.49k
    UWORD8 u1_cpb_dpb_present;
155
1.49k
    UWORD8 u1_pic_struct_present_flag;
156
1.49k
    UWORD32 u4_start_offset, u4_bits_consumed;
157
1.49k
    UWORD8 u1_cpb_removal_delay_length, u1_dpb_output_delay_length;
158
159
1.49k
    ps_sei = (sei *)ps_dec->ps_sei;
160
1.49k
    ps_vu4 = &ps_dec->ps_cur_sps->s_vui;
161
162
1.49k
    u1_cpb_dpb_present = ps_vu4->u1_vcl_hrd_params_present
163
1.49k
                    + ps_vu4->u1_nal_hrd_params_present;
164
165
1.49k
    if(ps_vu4->u1_vcl_hrd_params_present)
166
163
    {
167
163
        u1_cpb_removal_delay_length =
168
163
                        ps_vu4->s_vcl_hrd.u1_cpb_removal_delay_length;
169
163
        u1_dpb_output_delay_length =
170
163
                        ps_vu4->s_vcl_hrd.u1_dpb_output_delay_length;
171
163
    }
172
1.33k
    else if(ps_vu4->u1_nal_hrd_params_present)
173
351
    {
174
351
        u1_cpb_removal_delay_length =
175
351
                        ps_vu4->s_nal_hrd.u1_cpb_removal_delay_length;
176
351
        u1_dpb_output_delay_length =
177
351
                        ps_vu4->s_nal_hrd.u1_dpb_output_delay_length;
178
351
    }
179
979
    else
180
979
    {
181
979
        u1_cpb_removal_delay_length = 24;
182
979
        u1_dpb_output_delay_length = 24;
183
184
979
    }
185
186
1.49k
    u4_start_offset = ps_bitstrm->u4_ofst;
187
1.49k
    if(u1_cpb_dpb_present)
188
514
    {
189
514
        ih264d_get_bits_h264(ps_bitstrm, u1_cpb_removal_delay_length);
190
514
        ih264d_get_bits_h264(ps_bitstrm, u1_dpb_output_delay_length);
191
514
    }
192
193
1.49k
    u1_pic_struct_present_flag = ps_vu4->u1_pic_struct_present_flag;
194
1.49k
    if(u1_pic_struct_present_flag)
195
389
    {
196
389
        ps_sei->u1_pic_struct = ih264d_get_bits_h264(ps_bitstrm, 4);
197
389
        ps_dec->u1_pic_struct_copy = ps_sei->u1_pic_struct;
198
389
        ps_sei->u1_is_valid = 1;
199
389
    }
200
1.49k
    u4_bits_consumed = ps_bitstrm->u4_ofst - u4_start_offset;
201
202
1.49k
    if((ui4_payload_size << 3) < u4_bits_consumed)
203
1
        return ERROR_CORRUPTED_SLICE;
204
205
1.49k
    ih264d_flush_bits_h264(ps_bitstrm,
206
1.49k
                           (ui4_payload_size << 3) - u4_bits_consumed);
207
208
1.49k
    return (OK);
209
1.49k
}
210
211
/*****************************************************************************/
212
/*                                                                           */
213
/*  Function Name : ih264d_parse_recovery_point                              */
214
/*                                                                           */
215
/*  Description   : This function parses SEI message recovery point          */
216
/*  Inputs        : ps_bitstrm    Bitstream                                  */
217
/*                  ps_dec          Poniter decoder context                  */
218
/*                  ui4_payload_size pay load i4_size                        */
219
/*  Globals       : None                                                     */
220
/*  Processing    : Parses SEI payload picture timing                        */
221
/*  Outputs       : None                                                     */
222
/*  Return        : 0                                                        */
223
/*                                                                           */
224
/*  Issues        : Not implemented fully                                    */
225
/*                                                                           */
226
/*  Revision History:                                                        */
227
/*                                                                           */
228
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
229
/*         06 05 2002   NS              Draft                                */
230
/*                                                                           */
231
/*****************************************************************************/
232
WORD32 ih264d_parse_recovery_point(dec_bit_stream_t *ps_bitstrm,
233
                                   dec_struct_t *ps_dec,
234
                                   UWORD32 ui4_payload_size)
235
10.2k
{
236
10.2k
    sei *ps_sei = ps_dec->ps_sei;
237
10.2k
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
238
10.2k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
239
10.2k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
240
10.2k
    UNUSED(ui4_payload_size);
241
10.2k
    ps_sei->u2_recovery_frame_cnt = ih264d_uev(pu4_bitstrm_ofst,
242
10.2k
                                               pu4_bitstrm_buf);
243
10.2k
    ps_err->u4_frm_sei_sync = ps_err->u4_cur_frm
244
10.2k
                    + ps_sei->u2_recovery_frame_cnt;
245
10.2k
    ps_sei->u1_exact_match_flag = ih264d_get_bit_h264(ps_bitstrm);
246
10.2k
    ps_sei->u1_broken_link_flag = ih264d_get_bit_h264(ps_bitstrm);
247
10.2k
    ps_sei->u1_changing_slice_grp_idc = ih264d_get_bits_h264(ps_bitstrm, 2);
248
249
10.2k
    return (OK);
250
10.2k
}
251
252
/*****************************************************************************/
253
/*                                                                           */
254
/*  Function Name : ih264d_parse_mdcv                                        */
255
/*                                                                           */
256
/*  Description   : This function parses SEI message mdcv                    */
257
/*  Inputs        : ps_bitstrm    Bitstream                                  */
258
/*                  ps_dec          Poniter decoder context                  */
259
/*                  ui4_payload_size pay load i4_size                        */
260
/*  Globals       : None                                                     */
261
/*  Processing    :                                                          */
262
/*  Outputs       : None                                                     */
263
/*  Return        : 0 for successfull parsing, else -1                       */
264
/*                                                                           */
265
/*  Issues        :                                                          */
266
/*                                                                           */
267
/*  Revision History:                                                        */
268
/*                                                                           */
269
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
270
/*                                         Draft                             */
271
/*                                                                           */
272
/*****************************************************************************/
273
WORD32 ih264d_parse_mdcv(dec_bit_stream_t *ps_bitstrm,
274
                         dec_struct_t *ps_dec,
275
                         UWORD32 ui4_payload_size)
276
54
{
277
54
    sei *ps_sei = ps_dec->ps_sei_parse;
278
54
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
279
54
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
280
54
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
281
54
    UWORD32 u4_count;
282
54
    UNUSED(ui4_payload_size);
283
284
54
    if((ps_dec == NULL) || (ps_sei == NULL))
285
0
    {
286
0
        return NOT_OK;
287
0
    }
288
289
54
    ps_sei->u1_sei_mdcv_params_present_flag = 1;
290
291
    /* display primaries x */
292
209
    for(u4_count = 0; u4_count < NUM_SEI_MDCV_PRIMARIES; u4_count++)
293
158
    {
294
158
        ps_sei->s_sei_mdcv_params.au2_display_primaries_x[u4_count] =
295
158
                                    (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
296
297
158
        if((ps_sei->s_sei_mdcv_params.au2_display_primaries_x[u4_count] >
298
158
                                                DISPLAY_PRIMARIES_X_UPPER_LIMIT) ||
299
157
           (ps_sei->s_sei_mdcv_params.au2_display_primaries_x[u4_count] <
300
157
                                                DISPLAY_PRIMARIES_X_LOWER_LIMIT) ||
301
157
           ((ps_sei->s_sei_mdcv_params.au2_display_primaries_x[u4_count] %
302
157
                                               DISPLAY_PRIMARIES_X_DIVISION_FACTOR) != 0))
303
2
        {
304
2
            ps_sei->u1_sei_mdcv_params_present_flag = 0;
305
2
            return ERROR_INV_SEI_MDCV_PARAMS;
306
2
        }
307
308
156
        ps_sei->s_sei_mdcv_params.au2_display_primaries_y[u4_count] =
309
156
                                    (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
310
311
156
        if((ps_sei->s_sei_mdcv_params.au2_display_primaries_y[u4_count] >
312
156
                                                DISPLAY_PRIMARIES_Y_UPPER_LIMIT) ||
313
156
           (ps_sei->s_sei_mdcv_params.au2_display_primaries_y[u4_count] <
314
156
                                               DISPLAY_PRIMARIES_Y_LOWER_LIMIT) ||
315
156
           ((ps_sei->s_sei_mdcv_params.au2_display_primaries_y[u4_count] %
316
156
                                              DISPLAY_PRIMARIES_Y_DIVISION_FACTOR) != 0))
317
1
        {
318
1
            ps_sei->u1_sei_mdcv_params_present_flag = 0;
319
1
            return ERROR_INV_SEI_MDCV_PARAMS;
320
1
        }
321
156
    }
322
323
    /* white point x */
324
51
    ps_sei->s_sei_mdcv_params.u2_white_point_x = (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
325
326
51
    if((ps_sei->s_sei_mdcv_params.u2_white_point_x > WHITE_POINT_X_UPPER_LIMIT) ||
327
51
       (ps_sei->s_sei_mdcv_params.u2_white_point_x < WHITE_POINT_X_LOWER_LIMIT) ||
328
50
       ((ps_sei->s_sei_mdcv_params.u2_white_point_x % WHITE_POINT_X_DIVISION_FACTOR) != 0))
329
1
    {
330
1
        ps_sei->u1_sei_mdcv_params_present_flag = 0;
331
1
        return ERROR_INV_SEI_MDCV_PARAMS;
332
1
    }
333
    /* white point y */
334
50
    ps_sei->s_sei_mdcv_params.u2_white_point_y = (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
335
336
50
    if((ps_sei->s_sei_mdcv_params.u2_white_point_y > WHITE_POINT_Y_UPPER_LIMIT) ||
337
50
       (ps_sei->s_sei_mdcv_params.u2_white_point_y < WHITE_POINT_Y_LOWER_LIMIT) ||
338
50
       ((ps_sei->s_sei_mdcv_params.u2_white_point_y % WHITE_POINT_Y_DIVISION_FACTOR) != 0))
339
2
    {
340
2
        ps_sei->u1_sei_mdcv_params_present_flag = 0;
341
2
        return ERROR_INV_SEI_MDCV_PARAMS;
342
2
    }
343
    /* max display mastering luminance */
344
48
    ps_sei->s_sei_mdcv_params.u4_max_display_mastering_luminance =
345
48
                                    (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
346
347
48
    if((ps_sei->s_sei_mdcv_params.u4_max_display_mastering_luminance >
348
48
                                            MAX_DISPLAY_MASTERING_LUMINANCE_UPPER_LIMIT) ||
349
47
       (ps_sei->s_sei_mdcv_params.u4_max_display_mastering_luminance <
350
47
                                            MAX_DISPLAY_MASTERING_LUMINANCE_LOWER_LIMIT) ||
351
47
       ((ps_sei->s_sei_mdcv_params.u4_max_display_mastering_luminance %
352
47
                                        MAX_DISPLAY_MASTERING_LUMINANCE_DIVISION_FACTOR) != 0))
353
2
    {
354
2
        ps_sei->u1_sei_mdcv_params_present_flag = 0;
355
2
        return ERROR_INV_SEI_MDCV_PARAMS;
356
2
    }
357
    /* min display mastering luminance */
358
46
    ps_sei->s_sei_mdcv_params.u4_min_display_mastering_luminance =
359
46
                                    (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
360
361
46
    if((ps_sei->s_sei_mdcv_params.u4_min_display_mastering_luminance >
362
46
                                            MIN_DISPLAY_MASTERING_LUMINANCE_UPPER_LIMIT) ||
363
42
        (ps_sei->s_sei_mdcv_params.u4_min_display_mastering_luminance <
364
42
                                            MIN_DISPLAY_MASTERING_LUMINANCE_LOWER_LIMIT))
365
4
    {
366
4
        ps_sei->u1_sei_mdcv_params_present_flag = 0;
367
4
        return ERROR_INV_SEI_MDCV_PARAMS;
368
4
    }
369
42
    if(ps_sei->s_sei_mdcv_params.u4_max_display_mastering_luminance <=
370
42
            ps_sei->s_sei_mdcv_params.u4_min_display_mastering_luminance)
371
0
    {
372
0
        ps_sei->u1_sei_mdcv_params_present_flag = 0;
373
0
        return ERROR_INV_SEI_MDCV_PARAMS;
374
0
    }
375
42
    return (OK);
376
42
}
377
378
/*****************************************************************************/
379
/*                                                                           */
380
/*  Function Name : ih264d_parse_cll                                         */
381
/*                                                                           */
382
/*  Description   : This function parses SEI message cll                     */
383
/*  Inputs        : ps_bitstrm    Bitstream                                  */
384
/*                  ps_dec          Poniter decoder context                  */
385
/*                  ui4_payload_size pay load i4_size                        */
386
/*  Globals       : None                                                     */
387
/*  Processing    :                                                          */
388
/*  Outputs       : None                                                     */
389
/*  Return        : 0 for successfull parsing, else -1                       */
390
/*                                                                           */
391
/*  Issues        :                                                          */
392
/*                                                                           */
393
/*  Revision History:                                                        */
394
/*                                                                           */
395
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
396
/*                                         Draft                             */
397
/*                                                                           */
398
/*****************************************************************************/
399
WORD32 ih264d_parse_cll(dec_bit_stream_t *ps_bitstrm,
400
                        dec_struct_t *ps_dec,
401
                        UWORD32 ui4_payload_size)
402
621
{
403
621
    sei *ps_sei = ps_dec->ps_sei_parse;
404
621
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
405
621
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
406
621
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
407
621
    UNUSED(ui4_payload_size);
408
409
621
    if((ps_dec == NULL) || (ps_sei == NULL))
410
0
    {
411
0
        return NOT_OK;
412
0
    }
413
414
621
    ps_sei->u1_sei_cll_params_present_flag = 1;
415
416
621
    ps_sei->s_sei_cll_params.u2_max_content_light_level =
417
621
                        (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
418
621
    ps_sei->s_sei_cll_params.u2_max_pic_average_light_level =
419
621
                        (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
420
    /*No any sanity checks done for CLL params*/
421
422
621
    return (OK);
423
621
}
424
425
/*****************************************************************************/
426
/*                                                                           */
427
/*  Function Name : ih264d_parse_ave                                         */
428
/*                                                                           */
429
/*  Description   : This function parses SEI message ave                     */
430
/*  Inputs        : ps_bitstrm    Bitstream                                  */
431
/*                  ps_dec          Poniter decoder context                  */
432
/*                  ui4_payload_size pay load i4_size                        */
433
/*  Globals       : None                                                     */
434
/*  Processing    :                                                          */
435
/*  Outputs       : None                                                     */
436
/*  Return        : 0 for successfull parsing, else -1                       */
437
/*                                                                           */
438
/*  Issues        :                                                          */
439
/*                                                                           */
440
/*  Revision History:                                                        */
441
/*                                                                           */
442
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
443
/*                                         Draft                             */
444
/*                                                                           */
445
/*****************************************************************************/
446
WORD32 ih264d_parse_ave(dec_bit_stream_t *ps_bitstrm,
447
                        dec_struct_t *ps_dec,
448
                        UWORD32 ui4_payload_size)
449
1.46k
{
450
1.46k
    sei *ps_sei = ps_dec->ps_sei_parse;
451
1.46k
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
452
1.46k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
453
1.46k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
454
1.46k
    UNUSED(ui4_payload_size);
455
456
1.46k
    if((ps_dec == NULL) || (ps_sei == NULL))
457
0
    {
458
0
        return NOT_OK;
459
0
    }
460
461
1.46k
    ps_sei->u1_sei_ave_params_present_flag = 1;
462
463
1.46k
    ps_sei->s_sei_ave_params.u4_ambient_illuminance = (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
464
1.46k
    if(0 == ps_sei->s_sei_ave_params.u4_ambient_illuminance)
465
0
    {
466
0
        ps_sei->u1_sei_ave_params_present_flag = 0;
467
0
        return ERROR_INV_SEI_AVE_PARAMS;
468
0
    }
469
470
1.46k
    ps_sei->s_sei_ave_params.u2_ambient_light_x = (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
471
1.46k
    if(ps_sei->s_sei_ave_params.u2_ambient_light_x > AMBIENT_LIGHT_X_UPPER_LIMIT)
472
1
    {
473
1
        ps_sei->u1_sei_ave_params_present_flag = 0;
474
1
        return ERROR_INV_SEI_AVE_PARAMS;
475
1
    }
476
477
1.45k
    ps_sei->s_sei_ave_params.u2_ambient_light_y = (UWORD16)ih264d_get_bits_h264(ps_bitstrm, 16);
478
1.45k
    if(ps_sei->s_sei_ave_params.u2_ambient_light_y > AMBIENT_LIGHT_Y_UPPER_LIMIT)
479
0
    {
480
0
        ps_sei->u1_sei_ave_params_present_flag = 0;
481
0
        return ERROR_INV_SEI_AVE_PARAMS;
482
0
    }
483
1.45k
    return (OK);
484
1.45k
}
485
486
/*****************************************************************************/
487
/*                                                                           */
488
/*  Function Name : ih264d_parse_ccv                                         */
489
/*                                                                           */
490
/*  Description   : This function parses SEI message ccv                     */
491
/*  Inputs        : ps_bitstrm    Bitstream                                  */
492
/*                  ps_dec          Poniter decoder context                  */
493
/*                  ui4_payload_size pay load i4_size                        */
494
/*  Globals       : None                                                     */
495
/*  Processing    :                                                          */
496
/*  Outputs       : None                                                     */
497
/*  Return        : 0 for successfull parsing, else -1                       */
498
/*                                                                           */
499
/*  Issues        :                                                          */
500
/*                                                                           */
501
/*  Revision History:                                                        */
502
/*                                                                           */
503
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
504
/*                         Draft                                             */
505
/*                                                                           */
506
/*****************************************************************************/
507
WORD32 ih264d_parse_ccv(dec_bit_stream_t *ps_bitstrm,
508
                        dec_struct_t *ps_dec,
509
                        UWORD32 ui4_payload_size)
510
648k
{
511
648k
    sei *ps_sei = ps_dec->ps_sei_parse;
512
648k
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
513
648k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
514
648k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
515
648k
    UWORD32 u4_count;
516
648k
    UNUSED(ui4_payload_size);
517
518
648k
    if((ps_dec == NULL) || (ps_sei == NULL))
519
0
    {
520
0
        return NOT_OK;
521
0
    }
522
523
648k
    ps_sei->u1_sei_ccv_params_present_flag = 0;
524
525
648k
    ps_sei->s_sei_ccv_params.u1_ccv_cancel_flag = (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
526
527
648k
    if(ps_sei->s_sei_ccv_params.u1_ccv_cancel_flag > 1)
528
0
    {
529
0
        return ERROR_INV_SEI_CCV_PARAMS;
530
0
    }
531
648k
    if(0 == ps_sei->s_sei_ccv_params.u1_ccv_cancel_flag)
532
38.5k
    {
533
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_persistence_flag =
534
38.5k
                                                (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
535
38.5k
        if(ps_sei->s_sei_ccv_params.u1_ccv_persistence_flag > 1)
536
0
        {
537
0
            return ERROR_INV_SEI_CCV_PARAMS;
538
0
        }
539
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_primaries_present_flag =
540
38.5k
                                                (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
541
38.5k
        if(ps_sei->s_sei_ccv_params.u1_ccv_primaries_present_flag > 1)
542
0
        {
543
0
            return ERROR_INV_SEI_CCV_PARAMS;
544
0
        }
545
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag =
546
38.5k
                                                (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
547
38.5k
        if(ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag > 1)
548
0
        {
549
0
            return ERROR_INV_SEI_CCV_PARAMS;
550
0
        }
551
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_max_luminance_value_present_flag =
552
38.5k
                                                (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
553
38.5k
        if(ps_sei->s_sei_ccv_params.u1_ccv_max_luminance_value_present_flag > 1)
554
0
        {
555
0
            return ERROR_INV_SEI_CCV_PARAMS;
556
0
        }
557
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_avg_luminance_value_present_flag =
558
38.5k
                                                (UWORD8)ih264d_get_bit_h264(ps_bitstrm);
559
38.5k
        if(ps_sei->s_sei_ccv_params.u1_ccv_avg_luminance_value_present_flag > 1)
560
0
        {
561
0
            return ERROR_INV_SEI_CCV_PARAMS;
562
0
        }
563
564
38.5k
        if((ps_sei->s_sei_ccv_params.u1_ccv_primaries_present_flag == 0) &&
565
38.1k
           (ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag == 0) &&
566
1.92k
           (ps_sei->s_sei_ccv_params.u1_ccv_max_luminance_value_present_flag == 0) &&
567
1.74k
           (ps_sei->s_sei_ccv_params.u1_ccv_avg_luminance_value_present_flag == 0))
568
1
        {
569
1
            return ERROR_INV_SEI_CCV_PARAMS;
570
1
   }
571
572
38.5k
        ps_sei->s_sei_ccv_params.u1_ccv_reserved_zero_2bits =
573
38.5k
                                                (UWORD8)ih264d_get_bits_h264(ps_bitstrm, 2);
574
38.5k
        if((ps_sei->s_sei_ccv_params.u1_ccv_reserved_zero_2bits != 0))
575
1
        {
576
1
            return ERROR_INV_SEI_CCV_PARAMS;
577
1
        }
578
579
        /* ccv primaries */
580
38.5k
        if(1 == ps_sei->s_sei_ccv_params.u1_ccv_primaries_present_flag)
581
382
        {
582
1.51k
            for(u4_count = 0; u4_count < NUM_SEI_CCV_PRIMARIES; u4_count++)
583
1.13k
            {
584
1.13k
                ps_sei->s_sei_ccv_params.ai4_ccv_primaries_x[u4_count] =
585
1.13k
                                                (WORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
586
1.13k
                if((ps_sei->s_sei_ccv_params.ai4_ccv_primaries_x[u4_count] >
587
1.13k
                                                        CCV_PRIMARIES_X_UPPER_LIMIT) ||
588
1.13k
                   (ps_sei->s_sei_ccv_params.ai4_ccv_primaries_x[u4_count] <
589
1.13k
                                                        CCV_PRIMARIES_X_LOWER_LIMIT))
590
3
                {
591
3
                    return ERROR_INV_SEI_CCV_PARAMS;
592
3
                }
593
594
1.13k
                ps_sei->s_sei_ccv_params.ai4_ccv_primaries_y[u4_count] =
595
1.13k
                                                (WORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
596
1.13k
                if((ps_sei->s_sei_ccv_params.ai4_ccv_primaries_y[u4_count] >
597
1.13k
                                                        CCV_PRIMARIES_Y_UPPER_LIMIT) ||
598
1.13k
                   (ps_sei->s_sei_ccv_params.ai4_ccv_primaries_y[u4_count] <
599
1.13k
                                                        CCV_PRIMARIES_Y_LOWER_LIMIT))
600
3
                {
601
3
                    return ERROR_INV_SEI_CCV_PARAMS;
602
3
                }
603
1.13k
            }
604
382
        }
605
606
38.5k
        if(1 == ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag)
607
36.4k
        {
608
36.4k
            ps_sei->s_sei_ccv_params.u4_ccv_min_luminance_value =
609
36.4k
                                                (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
610
36.4k
        }
611
612
38.5k
        if(1 == ps_sei->s_sei_ccv_params.u1_ccv_max_luminance_value_present_flag)
613
36.4k
        {
614
36.4k
            ps_sei->s_sei_ccv_params.u4_ccv_max_luminance_value =
615
36.4k
                                                (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
616
36.4k
            if((1 == ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag) &&
617
36.0k
                (ps_sei->s_sei_ccv_params.u4_ccv_max_luminance_value <
618
36.0k
                                                ps_sei->s_sei_ccv_params.u4_ccv_min_luminance_value))
619
1
            {
620
1
                return ERROR_INV_SEI_CCV_PARAMS;
621
1
            }
622
36.4k
        }
623
38.5k
        if(1 == ps_sei->s_sei_ccv_params.u1_ccv_avg_luminance_value_present_flag)
624
2.28k
        {
625
2.28k
            ps_sei->s_sei_ccv_params.u4_ccv_avg_luminance_value =
626
2.28k
                                                (UWORD32)ih264d_get_bits_h264(ps_bitstrm, 32);
627
2.28k
            if((1 == ps_sei->s_sei_ccv_params.u1_ccv_min_luminance_value_present_flag) &&
628
366
                (ps_sei->s_sei_ccv_params.u4_ccv_avg_luminance_value <
629
366
                                                ps_sei->s_sei_ccv_params.u4_ccv_min_luminance_value))
630
3
            {
631
3
                return ERROR_INV_SEI_CCV_PARAMS;
632
3
            }
633
2.28k
            if((1 == ps_sei->s_sei_ccv_params.u1_ccv_max_luminance_value_present_flag) &&
634
339
                (ps_sei->s_sei_ccv_params.u4_ccv_max_luminance_value <
635
339
                                                ps_sei->s_sei_ccv_params.u4_ccv_avg_luminance_value))
636
0
            {
637
0
                return ERROR_INV_SEI_CCV_PARAMS;
638
0
            }
639
2.28k
        }
640
38.5k
    }
641
648k
    ps_sei->u1_sei_ccv_params_present_flag = 1;
642
648k
    return (OK);
643
648k
}
644
645
/*****************************************************************************/
646
/*                                                                           */
647
/*  Function Name : ih264d_parse_sii                                         */
648
/*                                                                           */
649
/*  Description   : This function parses SEI message sii                     */
650
/*  Inputs        : ps_bitstrm    Bitstream                                  */
651
/*                  ps_dec        Poniter decoder context                    */
652
/*                  ui4_payload_size pay load i4_size                        */
653
/*  Globals       : None                                                     */
654
/*  Processing    :                                                          */
655
/*  Outputs       : None                                                     */
656
/*  Return        : 0 for successfull parsing, else -1                       */
657
/*                                                                           */
658
/*  Issues        :                                                          */
659
/*                                                                           */
660
/*  Revision History:                                                        */
661
/*                                                                           */
662
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
663
/*                                         Draft                             */
664
/*                                                                           */
665
/*****************************************************************************/
666
WORD32 ih264d_parse_sii(dec_bit_stream_t *ps_bitstrm, dec_struct_t *ps_dec,
667
                        UWORD32 ui4_payload_size)
668
18.1k
{
669
18.1k
    sei *ps_sei;
670
18.1k
    dec_err_status_t *ps_err;
671
18.1k
    int i;
672
18.1k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
673
18.1k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
674
18.1k
    UNUSED(ui4_payload_size);
675
676
18.1k
    if(ps_dec == NULL)
677
0
    {
678
0
        return NOT_OK;
679
0
    }
680
18.1k
    ps_sei = ps_dec->ps_sei_parse;
681
682
18.1k
    if(ps_sei == NULL)
683
0
    {
684
0
        return NOT_OK;
685
0
    }
686
18.1k
    ps_err = ps_dec->ps_dec_err_status;
687
688
18.1k
    ps_sei->u1_sei_sii_params_present_flag = 0;
689
18.1k
    memset(&ps_sei->s_sei_sii_params, 0, sizeof(ps_sei->s_sei_sii_params));
690
691
18.1k
    ps_sei->s_sei_sii_params.u4_sii_sub_layer_idx = ih264d_uev(pu4_bitstrm_ofst, pu4_bitstrm_buf);
692
693
18.1k
    if(0 == ps_sei->s_sei_sii_params.u4_sii_sub_layer_idx)
694
18.1k
    {
695
18.1k
        ps_sei->s_sei_sii_params.u1_shutter_interval_info_present_flag =
696
18.1k
            (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
697
698
18.1k
        if(1 == ps_sei->s_sei_sii_params.u1_shutter_interval_info_present_flag)
699
1.28k
        {
700
1.28k
            ps_sei->s_sei_sii_params.u4_sii_time_scale =
701
1.28k
                (UWORD32) ih264d_get_bits_h264(ps_bitstrm, 32);
702
703
1.28k
            ps_sei->s_sei_sii_params.u1_fixed_shutter_interval_within_cvs_flag =
704
1.28k
                (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
705
706
1.28k
            if(1 == ps_sei->s_sei_sii_params.u1_fixed_shutter_interval_within_cvs_flag)
707
219
            {
708
219
                ps_sei->s_sei_sii_params.u4_sii_num_units_in_shutter_interval =
709
219
                    (UWORD32) ih264d_get_bits_h264(ps_bitstrm, 32);
710
219
            }
711
1.06k
            else
712
1.06k
            {
713
1.06k
                ps_sei->s_sei_sii_params.u1_sii_max_sub_layers_minus1 =
714
1.06k
                    (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 3);
715
6.40k
                for(i = 0; i <= ps_sei->s_sei_sii_params.u1_sii_max_sub_layers_minus1; i++)
716
5.34k
                {
717
5.34k
                    ps_sei->s_sei_sii_params.au4_sub_layer_num_units_in_shutter_interval[i] =
718
5.34k
                        (UWORD32) ih264d_get_bits_h264(ps_bitstrm, 32);
719
5.34k
                }
720
1.06k
            }
721
1.28k
        }
722
18.1k
    }
723
724
18.1k
    if((ps_sei->s_sei_sii_params.u4_sii_sub_layer_idx >
725
18.1k
        ps_sei->s_sei_sii_params.u1_sii_max_sub_layers_minus1) &&
726
2
       (ps_sei->s_sei_sii_params.u1_fixed_shutter_interval_within_cvs_flag == 0))
727
2
    {
728
2
        return ERROR_INV_SEI_SII_PARAMS;
729
2
    }
730
731
18.1k
    ps_sei->u1_sei_sii_params_present_flag = 1;
732
18.1k
    return (OK);
733
18.1k
}
734
735
/*****************************************************************************/
736
/*                                                                           */
737
/*  Function Name : ih264d_parse_fgc                                         */
738
/*                                                                           */
739
/*  Description   : This function parses SEI message film grain charcaristics*/
740
/*  Inputs        : ps_bitstrm    Bitstream                                  */
741
/*                  ps_dec          Poniter decoder context                  */
742
/*                  ui4_payload_size pay load i4_size                        */
743
/*  Globals       : None                                                     */
744
/*  Processing    :                                                          */
745
/*  Outputs       : None                                                     */
746
/*  Return        : 0 for successfull parsing, else -1                       */
747
/*                                                                           */
748
/*  Issues        :                                                          */
749
/*                                                                           */
750
/*  Revision History:                                                        */
751
/*                                                                           */
752
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
753
/*                         Draft                                             */
754
/*                                                                           */
755
/*****************************************************************************/
756
WORD32 ih264d_parse_fgc(dec_bit_stream_t *ps_bitstrm, dec_struct_t *ps_dec,
757
                        UWORD32 ui4_payload_size)
758
3.66k
{
759
3.66k
    sei *ps_sei = ps_dec->ps_sei_parse;
760
3.66k
    dec_err_status_t *ps_err = ps_dec->ps_dec_err_status;
761
3.66k
    UWORD32 *pu4_bitstrm_ofst = &ps_bitstrm->u4_ofst;
762
3.66k
    UWORD32 *pu4_bitstrm_buf = ps_bitstrm->pu4_buffer;
763
3.66k
    UWORD32 u4_count;
764
3.66k
    WORD32 i4_luma_bitdepth, i4_chroma_bitdepth;
765
3.66k
    UWORD32 c, i, j;
766
3.66k
    UNUSED(ui4_payload_size);
767
768
3.66k
    if((ps_dec == NULL) || (ps_sei == NULL))
769
0
    {
770
0
        return NOT_OK;
771
0
    }
772
773
3.66k
    ps_sei->u1_sei_fgc_params_present_flag = 0;
774
775
3.66k
    ps_sei->s_sei_fgc_params.u1_film_grain_characteristics_cancel_flag =
776
3.66k
        (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
777
778
3.66k
    if(0 == ps_sei->s_sei_fgc_params.u1_film_grain_characteristics_cancel_flag)
779
3.41k
    {
780
3.41k
        ps_sei->s_sei_fgc_params.u1_film_grain_model_id =
781
3.41k
            (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 2);
782
3.41k
        if(ps_sei->s_sei_fgc_params.u1_film_grain_model_id > 1)
783
0
        {
784
0
            return ERROR_INV_SEI_FGC_PARAMS;
785
0
        }
786
3.41k
        ps_sei->s_sei_fgc_params.u1_separate_colour_description_present_flag =
787
3.41k
            (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
788
789
3.41k
        if(ps_sei->s_sei_fgc_params.u1_separate_colour_description_present_flag)
790
375
        {
791
375
            ps_sei->s_sei_fgc_params.u1_film_grain_bit_depth_luma_minus8 =
792
375
                (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 3);
793
794
375
            i4_luma_bitdepth = ps_sei->s_sei_fgc_params.u1_film_grain_bit_depth_luma_minus8 + 8;
795
796
375
            ps_sei->s_sei_fgc_params.u1_film_grain_bit_depth_chroma_minus8 =
797
375
                (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 3);
798
799
375
            i4_chroma_bitdepth = ps_sei->s_sei_fgc_params.u1_film_grain_bit_depth_chroma_minus8 + 8;
800
801
375
            ps_sei->s_sei_fgc_params.u1_film_grain_full_range_flag =
802
375
                (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
803
804
375
            ps_sei->s_sei_fgc_params.u1_film_grain_colour_primaries =
805
375
                (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
806
807
375
            ps_sei->s_sei_fgc_params.u1_film_grain_transfer_characteristics =
808
375
                (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
809
810
375
            ps_sei->s_sei_fgc_params.u1_film_grain_matrix_coefficients =
811
375
                (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
812
375
        }
813
3.03k
        else
814
3.03k
        {
815
3.03k
            if(ps_dec->ps_cur_sps == NULL)
816
0
            {
817
0
                return NOT_OK;
818
0
            }
819
3.03k
            i4_luma_bitdepth = ps_dec->ps_cur_sps->i4_bit_depth_luma_minus8 + 8;
820
3.03k
            i4_chroma_bitdepth = ps_dec->ps_cur_sps->i4_bit_depth_chroma_minus8 + 8;
821
3.03k
        }
822
3.41k
        ps_sei->s_sei_fgc_params.u1_blending_mode_id = (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 2);
823
824
3.41k
        if(ps_sei->s_sei_fgc_params.u1_blending_mode_id > 1)
825
0
        {
826
0
            return ERROR_INV_SEI_FGC_PARAMS;
827
0
        }
828
829
3.41k
        ps_sei->s_sei_fgc_params.u1_log2_scale_factor =
830
3.41k
            (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 4);
831
832
13.6k
        for(c = 0; c < SEI_FGC_NUM_COLOUR_COMPONENTS; c++)
833
10.2k
        {
834
10.2k
            ps_sei->s_sei_fgc_params.au1_comp_model_present_flag[c] =
835
10.2k
                (UWORD8) ih264d_get_bit_h264(ps_bitstrm);
836
10.2k
        }
837
838
13.6k
        for(c = 0; c < SEI_FGC_NUM_COLOUR_COMPONENTS; c++)
839
10.2k
        {
840
10.2k
            if(ps_sei->s_sei_fgc_params.au1_comp_model_present_flag[c])
841
2.24k
            {
842
2.24k
                ps_sei->s_sei_fgc_params.au1_num_intensity_intervals_minus1[c] =
843
2.24k
                    (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
844
845
2.24k
                ps_sei->s_sei_fgc_params.au1_num_model_values_minus1[c] =
846
2.24k
                    (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 3);
847
848
2.24k
                if(ps_sei->s_sei_fgc_params.au1_num_model_values_minus1[c] >
849
2.24k
                   (SEI_FGC_MAX_NUM_MODEL_VALUES - 1))
850
0
                {
851
0
                    return ERROR_INV_SEI_FGC_PARAMS;
852
0
                }
853
854
13.9k
                for(i = 0; i <= ps_sei->s_sei_fgc_params.au1_num_intensity_intervals_minus1[c]; i++)
855
11.7k
                {
856
                    /* Although the fag end of both the NALU and the bitstream buffer */
857
                    /* is being parsed, not all FGC SEI symbols would have been */
858
                    /* decoded semantically. The code below detects this condition */
859
11.7k
                    if((ps_bitstrm->u4_ofst + 8 + 8) >= ps_bitstrm->u4_max_ofst)
860
11
                    {
861
11
                        return ERROR_INV_SEI_FGC_PARAMS;
862
11
                    }
863
864
11.7k
                    ps_sei->s_sei_fgc_params.au1_intensity_interval_lower_bound[c][i] =
865
11.7k
                        (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
866
867
11.7k
                    ps_sei->s_sei_fgc_params.au1_intensity_interval_upper_bound[c][i] =
868
11.7k
                        (UWORD8) ih264d_get_bits_h264(ps_bitstrm, 8);
869
870
67.8k
                    for(j = 0; j <= ps_sei->s_sei_fgc_params.au1_num_model_values_minus1[c]; j++)
871
56.1k
                    {
872
56.1k
                        ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] =
873
56.1k
                            (WORD32) ih264d_sev(pu4_bitstrm_ofst, pu4_bitstrm_buf);
874
56.1k
                        if(0 == ps_sei->s_sei_fgc_params.u1_film_grain_model_id)
875
3.85k
                        {
876
3.85k
                            if((1 == j) || (2 == j))
877
1.65k
                            {
878
1.65k
                                if((ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] < 0) ||
879
1.65k
                                   (ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] > 16))
880
4
                                    return ERROR_INV_SEI_FGC_PARAMS;
881
1.65k
                            }
882
2.20k
                            else if((3 == j) || (4 == j))
883
970
                            {
884
970
                                if((ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] < 0) ||
885
969
                                   (ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] >
886
969
                                    ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j - 2]))
887
1
                                    return ERROR_INV_SEI_FGC_PARAMS;
888
970
                            }
889
1.23k
                            else
890
1.23k
                            {
891
1.23k
                                WORD32 max_lim = (c == 0) ? (1 << i4_luma_bitdepth) - 1
892
1.23k
                                                          : (1 << i4_chroma_bitdepth) - 1;
893
894
1.23k
                                if((ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] < 0) ||
895
1.23k
                                   (ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] >
896
1.23k
                                    max_lim))
897
1
                                {
898
1
                                    return ERROR_INV_SEI_FGC_PARAMS;
899
1
                                }
900
1.23k
                            }
901
3.85k
                        }
902
52.2k
                        else
903
52.2k
                        {
904
52.2k
                            WORD32 max_lim = (c == 0) ? (1 << (i4_luma_bitdepth - 1))
905
52.2k
                                                      : (1 << (i4_chroma_bitdepth - 1));
906
907
52.2k
                            if((ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] <
908
52.2k
                                -max_lim) ||
909
52.2k
                               (ps_sei->s_sei_fgc_params.ai4_comp_model_value[c][i][j] >= max_lim))
910
0
                            {
911
0
                                return ERROR_INV_SEI_FGC_PARAMS;
912
0
                            }
913
52.2k
                        }
914
56.1k
                    }
915
11.7k
                }
916
2.24k
            }
917
10.2k
        }
918
919
3.39k
        ps_sei->s_sei_fgc_params.u4_film_grain_characteristics_repetition_period =
920
3.39k
            (UWORD32) ih264d_uev(pu4_bitstrm_ofst, pu4_bitstrm_buf);
921
922
3.39k
        if(ps_sei->s_sei_fgc_params.u4_film_grain_characteristics_repetition_period < 0 ||
923
3.39k
           ps_sei->s_sei_fgc_params.u4_film_grain_characteristics_repetition_period > 16384)
924
1
        {
925
1
            return ERROR_INV_SEI_FGC_PARAMS;
926
1
        }
927
928
3.39k
        ps_sei->u1_sei_fgc_params_present_flag = 1;
929
3.39k
    }
930
931
3.64k
    return (OK);
932
3.66k
}
933
934
/*****************************************************************************/
935
/*                                                                           */
936
/*  Function Name : ih264d_parse_sei_payload                                 */
937
/*                                                                           */
938
/*  Description   : This function parses SEI pay loads. Currently it's       */
939
/*                  implemented partially.                                   */
940
/*  Inputs        : ps_bitstrm    Bitstream                                  */
941
/*                  ui4_payload_type  SEI payload type                       */
942
/*                  ui4_payload_size  SEI payload i4_size                    */
943
/*  Globals       : None                                                     */
944
/*  Processing    : Parses SEI payloads units and stores the info            */
945
/*  Outputs       : None                                                     */
946
/*  Return        : status for successful parsing, else -1                   */
947
/*                                                                           */
948
/*  Issues        : Not implemented fully                                    */
949
/*                                                                           */
950
/*  Revision History:                                                        */
951
/*                                                                           */
952
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
953
/*         06 05 2002   NS              Draft                                */
954
/*                                                                           */
955
/*****************************************************************************/
956
957
WORD32 ih264d_parse_sei_payload(dec_bit_stream_t *ps_bitstrm,
958
                                UWORD32 ui4_payload_type,
959
                                UWORD32 ui4_payload_size,
960
                                dec_struct_t *ps_dec)
961
744k
{
962
744k
    sei *ps_sei;
963
744k
    WORD32 i4_status = 0;
964
744k
    ps_sei = (sei *)ps_dec->ps_sei_parse;
965
966
744k
    if(ui4_payload_size == 0)
967
10
        return -1;
968
744k
    if(NULL == ps_bitstrm)
969
0
    {
970
0
        return NOT_OK;
971
0
    }
972
973
744k
    switch(ui4_payload_type)
974
744k
    {
975
2.25k
        case SEI_BUF_PERIOD:
976
977
2.25k
            i4_status = ih264d_parse_buffering_period(&ps_sei->s_buf_period,
978
2.25k
                                                      ps_bitstrm, ps_dec);
979
2.25k
            break;
980
1.49k
        case SEI_PIC_TIMING:
981
1.49k
            if(NULL == ps_dec->ps_cur_sps)
982
0
                i4_status = ih264d_flush_bits_h264(ps_bitstrm, (ui4_payload_size << 3));
983
1.49k
            else
984
1.49k
                i4_status = ih264d_parse_pic_timing(ps_bitstrm, ps_dec,
985
1.49k
                                        ui4_payload_size);
986
1.49k
            break;
987
10.2k
        case SEI_RECOVERY_PT:
988
10.2k
            i4_status = ih264d_parse_recovery_point(ps_bitstrm, ps_dec,
989
10.2k
                                        ui4_payload_size);
990
10.2k
            break;
991
54
        case SEI_MASTERING_DISP_COL_VOL:
992
993
54
            i4_status = ih264d_parse_mdcv(ps_bitstrm, ps_dec,
994
54
                                          ui4_payload_size);
995
54
            break;
996
621
        case SEI_CONTENT_LIGHT_LEVEL_DATA:
997
998
621
            i4_status = ih264d_parse_cll(ps_bitstrm, ps_dec,
999
621
                                         ui4_payload_size);
1000
621
            break;
1001
1.46k
        case SEI_AMBIENT_VIEWING_ENVIRONMENT:
1002
1003
1.46k
            i4_status = ih264d_parse_ave(ps_bitstrm, ps_dec,
1004
1.46k
                                         ui4_payload_size);
1005
1.46k
            break;
1006
648k
        case SEI_CONTENT_COLOR_VOLUME:
1007
1008
648k
            i4_status = ih264d_parse_ccv(ps_bitstrm, ps_dec,
1009
648k
                                         ui4_payload_size);
1010
648k
            break;
1011
18.1k
        case SEI_SHUTTER_INTERVAL_INFO:
1012
1013
18.1k
            i4_status = ih264d_parse_sii(ps_bitstrm, ps_dec, ui4_payload_size);
1014
18.1k
            break;
1015
1016
3.66k
        case SEI_FILM_GRAIN_CHARACTERISTICS:
1017
3.66k
            i4_status = ih264d_parse_fgc(ps_bitstrm, ps_dec, ui4_payload_size);
1018
1019
3.66k
            break;
1020
58.5k
        default:
1021
58.5k
            i4_status = ih264d_flush_bits_h264(ps_bitstrm, (ui4_payload_size << 3));
1022
58.5k
            break;
1023
744k
    }
1024
744k
    return (i4_status);
1025
744k
}
1026
1027
/*****************************************************************************/
1028
/*                                                                           */
1029
/*  Function Name : ih264d_parse_sei_message                                        */
1030
/*                                                                           */
1031
/*  Description   : This function is parses and decode SEI. Currently it's   */
1032
/*                  not implemented fully.                                   */
1033
/*  Inputs        : ps_dec    Decoder parameters                       */
1034
/*                  ps_bitstrm    Bitstream                                */
1035
/*  Globals       : None                                                     */
1036
/*  Processing    : Parses SEI NAL units and stores the info                 */
1037
/*  Outputs       : None                                                     */
1038
/*  Returns       : None                                                     */
1039
/*                                                                           */
1040
/*  Issues        : Not implemented fully                                    */
1041
/*                                                                           */
1042
/*  Revision History:                                                        */
1043
/*                                                                           */
1044
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1045
/*         06 05 2002   NS              Draft                                */
1046
/*                                                                           */
1047
/*****************************************************************************/
1048
1049
WORD32 ih264d_parse_sei_message(dec_struct_t *ps_dec,
1050
                                dec_bit_stream_t *ps_bitstrm)
1051
2.50k
{
1052
2.50k
    UWORD32 ui4_payload_type, ui4_payload_size;
1053
2.50k
    UWORD32 u4_bits;
1054
2.50k
    WORD32 i4_status = 0;
1055
1056
2.50k
    do
1057
744k
    {
1058
744k
        ui4_payload_type = 0;
1059
1060
744k
        if(!CHECK_BITS_SUFFICIENT(ps_bitstrm, 8))
1061
15
        {
1062
15
            return ERROR_EOB_GETBITS_T;
1063
15
        }
1064
744k
        u4_bits = ih264d_get_bits_h264(ps_bitstrm, 8);
1065
875k
        while(0xff == u4_bits && CHECK_BITS_SUFFICIENT(ps_bitstrm, 8))
1066
130k
        {
1067
130k
            u4_bits = ih264d_get_bits_h264(ps_bitstrm, 8);
1068
130k
            ui4_payload_type += 255;
1069
130k
        }
1070
744k
        ui4_payload_type += u4_bits;
1071
1072
744k
        ui4_payload_size = 0;
1073
744k
        if(!CHECK_BITS_SUFFICIENT(ps_bitstrm, 8))
1074
10
        {
1075
10
            return ERROR_EOB_GETBITS_T;
1076
10
        }
1077
744k
        u4_bits = ih264d_get_bits_h264(ps_bitstrm, 8);
1078
865k
        while(0xff == u4_bits && CHECK_BITS_SUFFICIENT(ps_bitstrm, 8))
1079
120k
        {
1080
120k
            u4_bits = ih264d_get_bits_h264(ps_bitstrm, 8);
1081
120k
            ui4_payload_size += 255;
1082
120k
        }
1083
744k
        ui4_payload_size += u4_bits;
1084
1085
744k
        if(!CHECK_BITS_SUFFICIENT(ps_bitstrm, (ui4_payload_size << 3)))
1086
84
        {
1087
84
            return ERROR_EOB_GETBITS_T;
1088
84
        }
1089
744k
        i4_status = ih264d_parse_sei_payload(ps_bitstrm, ui4_payload_type,
1090
744k
                                             ui4_payload_size, ps_dec);
1091
744k
        if(i4_status != OK)
1092
59
            return i4_status;
1093
1094
744k
        if(ih264d_check_byte_aligned(ps_bitstrm) == 0)
1095
642k
        {
1096
642k
            u4_bits = ih264d_get_bit_h264(ps_bitstrm);
1097
642k
            if(0 == u4_bits)
1098
637k
            {
1099
637k
                H264_DEC_DEBUG_PRINT("\nError in parsing SEI message");
1100
637k
            }
1101
4.41M
            while(0 == ih264d_check_byte_aligned(ps_bitstrm)
1102
3.76M
                            && CHECK_BITS_SUFFICIENT(ps_bitstrm, 1))
1103
3.76M
            {
1104
3.76M
                u4_bits = ih264d_get_bit_h264(ps_bitstrm);
1105
3.76M
                if(u4_bits)
1106
1.89M
                {
1107
1.89M
                    H264_DEC_DEBUG_PRINT("\nError in parsing SEI message");
1108
1.89M
                }
1109
3.76M
            }
1110
642k
        }
1111
744k
    }
1112
2.50k
    while(MORE_RBSP_DATA(ps_bitstrm));
1113
2.33k
    return (i4_status);
1114
2.50k
}
1115
1116
/*****************************************************************************/
1117
/*                                                                           */
1118
/*  Function Name : ih264d_export_sei_mdcv_params                            */
1119
/*                                                                           */
1120
/*  Description   : This function populates SEI mdcv message in              */
1121
/*                     output structure                                      */
1122
/*  Inputs        : ps_sei_mdcv_op pointer to sei mdcv o\p struct            */
1123
/*                : ps_sei pointer to decoded sei params                     */
1124
/*  Outputs       :                                                          */
1125
/*  Returns       : returns 0 for success; -1 for failure                    */
1126
/*                                                                           */
1127
/*  Issues        : none                                                     */
1128
/*                                                                           */
1129
/*  Revision History:                                                        */
1130
/*                                                                           */
1131
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1132
/*                                                                           */
1133
/*                                                                           */
1134
/*****************************************************************************/
1135
WORD32 ih264d_export_sei_mdcv_params(ivd_sei_decode_op_t *ps_sei_decode_op,
1136
                                     sei *ps_sei, sei *ps_sei_export)
1137
2.43k
{
1138
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1139
1.73k
    {
1140
1.73k
        return NOT_OK;
1141
1.73k
    }
1142
1143
699
    ps_sei_export->u1_sei_mdcv_params_present_flag = ps_sei->u1_sei_mdcv_params_present_flag;
1144
699
    ps_sei_decode_op->u1_sei_mdcv_params_present_flag = ps_sei->u1_sei_mdcv_params_present_flag;
1145
1146
699
    if(0 == ps_sei_export->u1_sei_mdcv_params_present_flag)
1147
699
    {
1148
699
        memset(&ps_sei_export->s_sei_mdcv_params, 0, sizeof(sei_mdcv_params_t));
1149
699
    }
1150
0
    else
1151
0
    {
1152
0
        memcpy(&ps_sei_export->s_sei_mdcv_params, &ps_sei->s_sei_mdcv_params,
1153
0
                                                    sizeof(sei_mdcv_params_t));
1154
0
    }
1155
1156
699
    return (OK);
1157
2.43k
}
1158
1159
/*****************************************************************************/
1160
/*                                                                           */
1161
/*  Function Name : ih264d_export_sei_cll_params                             */
1162
/*                                                                           */
1163
/*  Description   : This function populates SEI cll message in               */
1164
/*                     output structure                                      */
1165
/*  Inputs        : ps_sei_cll_op pointer to sei cll o\p struct              */
1166
/*                : ps_sei pointer to decoded sei params                     */
1167
/*  Outputs       :                                                          */
1168
/*  Returns       : returns 0 for success; -1 for failure                    */
1169
/*                                                                           */
1170
/*  Issues        : none                                                     */
1171
/*                                                                           */
1172
/*  Revision History:                                                        */
1173
/*                                                                           */
1174
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1175
/*                                                                           */
1176
/*                                                                           */
1177
/*****************************************************************************/
1178
WORD32 ih264d_export_sei_cll_params(ivd_sei_decode_op_t *ps_sei_decode_op,
1179
                                    sei *ps_sei, sei *ps_sei_export)
1180
2.43k
{
1181
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1182
1.73k
    {
1183
1.73k
        return NOT_OK;
1184
1.73k
    }
1185
1186
699
    ps_sei_export->u1_sei_cll_params_present_flag = ps_sei->u1_sei_cll_params_present_flag;
1187
699
    ps_sei_decode_op->u1_sei_cll_params_present_flag = ps_sei->u1_sei_cll_params_present_flag;
1188
1189
699
    if(0 == ps_sei_export->u1_sei_cll_params_present_flag)
1190
699
    {
1191
699
        memset(&ps_sei_export->s_sei_cll_params, 0, sizeof(sei_cll_params_t));
1192
699
    }
1193
0
    else
1194
0
    {
1195
0
        memcpy(&ps_sei_export->s_sei_cll_params, &ps_sei->s_sei_cll_params,
1196
0
                                                    sizeof(sei_cll_params_t));
1197
0
    }
1198
699
    return (OK);
1199
2.43k
}
1200
1201
/*****************************************************************************/
1202
/*                                                                           */
1203
/*  Function Name : ih264d_export_sei_ave_params                             */
1204
/*                                                                           */
1205
/*  Description   : This function populates SEI ave message in               */
1206
/*                     output structure                                      */
1207
/*  Inputs        : ps_sei_ave_op pointer to sei ave o\p struct              */
1208
/*                : ps_sei pointer to decoded sei params                     */
1209
/*  Outputs       :                                                          */
1210
/*  Returns       : returns 0 for success; -1 for failure                    */
1211
/*                                                                           */
1212
/*  Issues        : none                                                     */
1213
/*                                                                           */
1214
/*  Revision History:                                                        */
1215
/*                                                                           */
1216
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1217
/*                                                                           */
1218
/*                                                                           */
1219
/*****************************************************************************/
1220
WORD32 ih264d_export_sei_ave_params(ivd_sei_decode_op_t *ps_sei_decode_op,
1221
                                    sei *ps_sei, sei *ps_sei_export)
1222
2.43k
{
1223
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1224
1.73k
    {
1225
1.73k
        return NOT_OK;
1226
1.73k
    }
1227
1228
699
    ps_sei_export->u1_sei_ave_params_present_flag = ps_sei->u1_sei_ave_params_present_flag;
1229
699
    ps_sei_decode_op->u1_sei_ave_params_present_flag = ps_sei->u1_sei_ave_params_present_flag;
1230
1231
699
    if(0 == ps_sei_export->u1_sei_ave_params_present_flag)
1232
699
    {
1233
699
        memset(&ps_sei_export->s_sei_ave_params, 0, sizeof(sei_ave_params_t));
1234
699
    }
1235
0
    else
1236
0
    {
1237
0
        memcpy(&ps_sei_export->s_sei_ave_params, &ps_sei->s_sei_ave_params,
1238
0
                                                    sizeof(sei_ave_params_t));
1239
0
    }
1240
1241
699
    return (OK);
1242
2.43k
}
1243
1244
/*****************************************************************************/
1245
/*                                                                           */
1246
/*  Function Name : ih264d_export_sei_ccv_params                             */
1247
/*                                                                           */
1248
/*  Description   : This function populates SEI ccv message in               */
1249
/*                     output structure                                      */
1250
/*  Inputs        : ps_sei_ccv_op pointer to sei ccv o\p struct              */
1251
/*                : ps_sei pointer to decoded sei params                     */
1252
/*  Outputs       :                                                          */
1253
/*  Returns       : returns 0 for success; -1 for failure                    */
1254
/*                                                                           */
1255
/*  Issues        : none                                                     */
1256
/*                                                                           */
1257
/*  Revision History:                                                        */
1258
/*                                                                           */
1259
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1260
/*                                                                           */
1261
/*                                                                           */
1262
/*****************************************************************************/
1263
WORD32 ih264d_export_sei_ccv_params(ivd_sei_decode_op_t *ps_sei_decode_op,
1264
                                    sei *ps_sei, sei *ps_sei_export)
1265
2.43k
{
1266
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1267
1.73k
    {
1268
1.73k
        return NOT_OK;
1269
1.73k
    }
1270
1271
699
    ps_sei_export->u1_sei_ccv_params_present_flag = ps_sei->u1_sei_ccv_params_present_flag;
1272
699
    ps_sei_decode_op->u1_sei_ccv_params_present_flag = ps_sei->u1_sei_ccv_params_present_flag;
1273
1274
699
    if(0 == ps_sei_export->u1_sei_ccv_params_present_flag)
1275
699
    {
1276
699
        memset(&ps_sei_export->s_sei_ccv_params, 0, sizeof(sei_ccv_params_t));
1277
699
    }
1278
0
    else
1279
0
    {
1280
0
        memcpy(&ps_sei_export->s_sei_ccv_params, &ps_sei->s_sei_ccv_params,
1281
0
                                                    sizeof(sei_ccv_params_t));
1282
0
    }
1283
699
    return (OK);
1284
2.43k
}
1285
1286
/*****************************************************************************/
1287
/*                                                                           */
1288
/*  Function Name : ih264d_export_sei_sii_params                             */
1289
/*                                                                           */
1290
/*  Description   : This function populates SEI sii message in               */
1291
/*                     output structure                                      */
1292
/*  Inputs        : ps_sei_sii_op pointer to sei sii o\p struct              */
1293
/*                : ps_sei pointer to decoded sei params                     */
1294
/*  Outputs       :                                                          */
1295
/*  Returns       : returns 0 for success; -1 for failure                    */
1296
/*                                                                           */
1297
/*  Issues        : none                                                     */
1298
/*                                                                           */
1299
/*  Revision History:                                                        */
1300
/*                                                                           */
1301
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1302
/*                                                                           */
1303
/*                                                                           */
1304
/*****************************************************************************/
1305
WORD32 ih264d_export_sei_sii_params(ivd_sei_decode_op_t *ps_sei_decode_op, sei *ps_sei,
1306
                                    sei *ps_sei_export)
1307
2.43k
{
1308
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1309
1.73k
    {
1310
1.73k
        return NOT_OK;
1311
1.73k
    }
1312
1313
699
    ps_sei_export->u1_sei_sii_params_present_flag = ps_sei->u1_sei_sii_params_present_flag;
1314
699
    ps_sei_decode_op->u1_sei_sii_params_present_flag = ps_sei->u1_sei_sii_params_present_flag;
1315
1316
699
    if(0 == ps_sei_export->u1_sei_sii_params_present_flag)
1317
699
    {
1318
699
        memset(&ps_sei_export->s_sei_sii_params, 0, sizeof(sei_sii_params_t));
1319
699
    }
1320
0
    else
1321
0
    {
1322
0
        memcpy(&ps_sei_export->s_sei_sii_params, &ps_sei->s_sei_sii_params,
1323
0
               sizeof(sei_sii_params_t));
1324
0
    }
1325
699
    return (OK);
1326
2.43k
}
1327
1328
/*****************************************************************************/
1329
/*                                                                           */
1330
/*  Function Name : ih264d_export_sei_fgc_params                             */
1331
/*                                                                           */
1332
/*  Description   : This function populates SEI film grain params in         */
1333
/*                     output structure                                      */
1334
/*  Inputs        : ps_sei_fgc_op pointer to sei fgc o\p struct              */
1335
/*                : ps_sei pointer to decoded sei params                     */
1336
/*  Outputs       :                                                          */
1337
/*  Returns       : returns 0 for success; -1 for failure                    */
1338
/*                                                                           */
1339
/*  Issues        : none                                                     */
1340
/*                                                                           */
1341
/*  Revision History:                                                        */
1342
/*                                                                           */
1343
/*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
1344
/*                                                                           */
1345
/*                                                                           */
1346
/*****************************************************************************/
1347
WORD32 ih264d_export_sei_fgc_params(ivd_sei_decode_op_t *ps_sei_decode_op, sei *ps_sei,
1348
                                    sei *ps_sei_export)
1349
2.43k
{
1350
2.43k
    if((ps_sei_export == NULL) || (ps_sei == NULL))
1351
1.73k
    {
1352
1.73k
        return NOT_OK;
1353
1.73k
    }
1354
1355
699
    ps_sei_export->u1_sei_fgc_params_present_flag = ps_sei->u1_sei_fgc_params_present_flag;
1356
699
    ps_sei_decode_op->u1_sei_fgc_params_present_flag = ps_sei->u1_sei_fgc_params_present_flag;
1357
1358
699
    if(0 == ps_sei_export->u1_sei_fgc_params_present_flag)
1359
699
    {
1360
699
        memset(&ps_sei_export->s_sei_fgc_params, 0, sizeof(sei_fgc_params_t));
1361
699
    }
1362
0
    else
1363
0
    {
1364
0
        memcpy(&ps_sei_export->s_sei_fgc_params, &ps_sei->s_sei_fgc_params,
1365
0
               sizeof(sei_fgc_params_t));
1366
0
    }
1367
1368
699
    return (OK);
1369
2.43k
}