1*495ae853SAndroid Build Coastguard Worker /****************************************************************************** 2*495ae853SAndroid Build Coastguard Worker * 3*495ae853SAndroid Build Coastguard Worker * Copyright (C) 2022 The Android Open Source Project 4*495ae853SAndroid Build Coastguard Worker * 5*495ae853SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 6*495ae853SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 7*495ae853SAndroid Build Coastguard Worker * You may obtain a copy of the License at: 8*495ae853SAndroid Build Coastguard Worker * 9*495ae853SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 10*495ae853SAndroid Build Coastguard Worker * 11*495ae853SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 12*495ae853SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 13*495ae853SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 14*495ae853SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 15*495ae853SAndroid Build Coastguard Worker * limitations under the License. 16*495ae853SAndroid Build Coastguard Worker * 17*495ae853SAndroid Build Coastguard Worker ***************************************************************************** 18*495ae853SAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore 19*495ae853SAndroid Build Coastguard Worker */ 20*495ae853SAndroid Build Coastguard Worker 21*495ae853SAndroid Build Coastguard Worker /** 22*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 23*495ae853SAndroid Build Coastguard Worker * @file 24*495ae853SAndroid Build Coastguard Worker * isvce_encode_header.h 25*495ae853SAndroid Build Coastguard Worker * 26*495ae853SAndroid Build Coastguard Worker * @brief 27*495ae853SAndroid Build Coastguard Worker * This file contains structures and interface prototypes for h264 bitstream 28*495ae853SAndroid Build Coastguard Worker * header encoding 29*495ae853SAndroid Build Coastguard Worker * 30*495ae853SAndroid Build Coastguard Worker * @author 31*495ae853SAndroid Build Coastguard Worker * ittiam 32*495ae853SAndroid Build Coastguard Worker * 33*495ae853SAndroid Build Coastguard Worker * @remarks 34*495ae853SAndroid Build Coastguard Worker * None 35*495ae853SAndroid Build Coastguard Worker * 36*495ae853SAndroid Build Coastguard Worker ******************************************************************************* 37*495ae853SAndroid Build Coastguard Worker */ 38*495ae853SAndroid Build Coastguard Worker 39*495ae853SAndroid Build Coastguard Worker #ifndef _ISVCE_ENCODE_HEADER_H_ 40*495ae853SAndroid Build Coastguard Worker #define _ISVCE_ENCODE_HEADER_H_ 41*495ae853SAndroid Build Coastguard Worker 42*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h" 43*495ae853SAndroid Build Coastguard Worker 44*495ae853SAndroid Build Coastguard Worker /* Dependencies of ih264e_bitstream.h */ 45*495ae853SAndroid Build Coastguard Worker #include "ih264e_error.h" 46*495ae853SAndroid Build Coastguard Worker 47*495ae853SAndroid Build Coastguard Worker #include "ih264e_bitstream.h" 48*495ae853SAndroid Build Coastguard Worker #include "ih264e_trace.h" 49*495ae853SAndroid Build Coastguard Worker #include "isvce_structs.h" 50*495ae853SAndroid Build Coastguard Worker 51*495ae853SAndroid Build Coastguard Worker /** 52*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 53*495ae853SAndroid Build Coastguard Worker * @brief Macro to put a code with specified number of bits into the 54*495ae853SAndroid Build Coastguard Worker * bitstream 55*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 56*495ae853SAndroid Build Coastguard Worker */ 57*495ae853SAndroid Build Coastguard Worker #define PUT_BITS(ps_bitstrm, code_val, code_len, ret_val, syntax_string) \ 58*495ae853SAndroid Build Coastguard Worker { \ 59*495ae853SAndroid Build Coastguard Worker ENTROPY_TRACE(syntax_string, code_val); \ 60*495ae853SAndroid Build Coastguard Worker ret_val = ih264e_put_bits((ps_bitstrm), (code_val), (code_len)); \ 61*495ae853SAndroid Build Coastguard Worker if(ret_val != IH264E_SUCCESS) \ 62*495ae853SAndroid Build Coastguard Worker { \ 63*495ae853SAndroid Build Coastguard Worker return ret_val; \ 64*495ae853SAndroid Build Coastguard Worker } \ 65*495ae853SAndroid Build Coastguard Worker } 66*495ae853SAndroid Build Coastguard Worker 67*495ae853SAndroid Build Coastguard Worker /** 68*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 69*495ae853SAndroid Build Coastguard Worker * @brief Macro to put a code with specified number of bits into the 70*495ae853SAndroid Build Coastguard Worker * bitstream using 0th order exponential Golomb encoding for 71*495ae853SAndroid Build Coastguard Worker * signed numbers 72*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 73*495ae853SAndroid Build Coastguard Worker */ 74*495ae853SAndroid Build Coastguard Worker #define PUT_BITS_UEV(ps_bitstrm, code_val, ret_val, syntax_string) \ 75*495ae853SAndroid Build Coastguard Worker { \ 76*495ae853SAndroid Build Coastguard Worker ENTROPY_TRACE(syntax_string, code_val); \ 77*495ae853SAndroid Build Coastguard Worker ret_val = ih264e_put_uev((ps_bitstrm), (code_val)); \ 78*495ae853SAndroid Build Coastguard Worker if(ret_val != IH264E_SUCCESS) \ 79*495ae853SAndroid Build Coastguard Worker { \ 80*495ae853SAndroid Build Coastguard Worker return ret_val; \ 81*495ae853SAndroid Build Coastguard Worker } \ 82*495ae853SAndroid Build Coastguard Worker } 83*495ae853SAndroid Build Coastguard Worker /** 84*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 85*495ae853SAndroid Build Coastguard Worker * @brief Macro to put a code with specified number of bits into the 86*495ae853SAndroid Build Coastguard Worker * bitstream using 0th order exponential Golomb encoding for 87*495ae853SAndroid Build Coastguard Worker * signed numbers 88*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 89*495ae853SAndroid Build Coastguard Worker */ 90*495ae853SAndroid Build Coastguard Worker #define PUT_BITS_SEV(ps_bitstrm, code_val, ret_val, syntax_string) \ 91*495ae853SAndroid Build Coastguard Worker { \ 92*495ae853SAndroid Build Coastguard Worker ENTROPY_TRACE(syntax_string, code_val); \ 93*495ae853SAndroid Build Coastguard Worker ret_val = ih264e_put_sev((ps_bitstrm), (code_val)); \ 94*495ae853SAndroid Build Coastguard Worker if(ret_val != IH264E_SUCCESS) \ 95*495ae853SAndroid Build Coastguard Worker { \ 96*495ae853SAndroid Build Coastguard Worker return ret_val; \ 97*495ae853SAndroid Build Coastguard Worker } \ 98*495ae853SAndroid Build Coastguard Worker } 99*495ae853SAndroid Build Coastguard Worker 100*495ae853SAndroid Build Coastguard Worker /** 101*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 102*495ae853SAndroid Build Coastguard Worker * @brief Macro to set active entropy threads to zero and return 103*495ae853SAndroid Build Coastguard Worker * in case of errors 104*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 105*495ae853SAndroid Build Coastguard Worker */ 106*495ae853SAndroid Build Coastguard Worker #define RETURN_ENTROPY_IF_ERROR(ps_codec, ps_entropy, ctxt_sel) \ 107*495ae853SAndroid Build Coastguard Worker if(ps_entropy->i4_error_code != IH264E_SUCCESS) \ 108*495ae853SAndroid Build Coastguard Worker { \ 109*495ae853SAndroid Build Coastguard Worker DATA_SYNC(); \ 110*495ae853SAndroid Build Coastguard Worker ps_codec->ae_entropy_thread_exit_state[ctxt_sel] = ERRONEOUS_EXIT; \ 111*495ae853SAndroid Build Coastguard Worker return ps_entropy->i4_error_code; \ 112*495ae853SAndroid Build Coastguard Worker } 113*495ae853SAndroid Build Coastguard Worker 114*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/ 115*495ae853SAndroid Build Coastguard Worker /* Extern Function Declarations */ 116*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/ 117*495ae853SAndroid Build Coastguard Worker extern WORD32 ih264e_generate_nal_unit_header(bitstrm_t *ps_bitstrm, WORD32 nal_unit_type, 118*495ae853SAndroid Build Coastguard Worker WORD32 nal_ref_idc); 119*495ae853SAndroid Build Coastguard Worker 120*495ae853SAndroid Build Coastguard Worker extern WORD32 ih264e_generate_vui(bitstrm_t *ps_bitstrm, vui_t *ps_vui); 121*495ae853SAndroid Build Coastguard Worker 122*495ae853SAndroid Build Coastguard Worker extern IH264E_ERROR_T ih264e_generate_sei(bitstrm_t *ps_bitstrm, sei_params_t *ps_sei, 123*495ae853SAndroid Build Coastguard Worker UWORD32 u4_insert_per_idr); 124*495ae853SAndroid Build Coastguard Worker 125*495ae853SAndroid Build Coastguard Worker extern IH264E_ERROR_T ih264e_add_filler_nal_unit(bitstrm_t *ps_bitstrm, WORD32 insert_fill_bytes); 126*495ae853SAndroid Build Coastguard Worker 127*495ae853SAndroid Build Coastguard Worker /** 128*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 129*495ae853SAndroid Build Coastguard Worker * 130*495ae853SAndroid Build Coastguard Worker * @brief Generates SPS (Sequence Parameter Set) 131*495ae853SAndroid Build Coastguard Worker * 132*495ae853SAndroid Build Coastguard Worker * @par Description 133*495ae853SAndroid Build Coastguard Worker * This function generates Sequence Parameter Set header as per the spec 134*495ae853SAndroid Build Coastguard Worker * 135*495ae853SAndroid Build Coastguard Worker * @param[in] ps_bitstrm 136*495ae853SAndroid Build Coastguard Worker * pointer to bitstream context (handle) 137*495ae853SAndroid Build Coastguard Worker * 138*495ae853SAndroid Build Coastguard Worker * @param[in] ps_sps 139*495ae853SAndroid Build Coastguard Worker * pointer to structure containing SPS data 140*495ae853SAndroid Build Coastguard Worker * 141*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 142*495ae853SAndroid Build Coastguard Worker * 143*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 144*495ae853SAndroid Build Coastguard Worker */ 145*495ae853SAndroid Build Coastguard Worker WORD32 isvce_generate_sps(bitstrm_t *ps_bitstrm, sps_t *ps_sps, NAL_UNIT_TYPE_T nal_type); 146*495ae853SAndroid Build Coastguard Worker 147*495ae853SAndroid Build Coastguard Worker /** 148*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 149*495ae853SAndroid Build Coastguard Worker * 150*495ae853SAndroid Build Coastguard Worker * @brief Generates PPS (Picture Parameter Set) 151*495ae853SAndroid Build Coastguard Worker * 152*495ae853SAndroid Build Coastguard Worker * @par Description 153*495ae853SAndroid Build Coastguard Worker * Generate Picture Parameter Set as per Section 7.3.2.2 154*495ae853SAndroid Build Coastguard Worker * 155*495ae853SAndroid Build Coastguard Worker * @param[in] ps_bitstrm 156*495ae853SAndroid Build Coastguard Worker * pointer to bitstream context (handle) 157*495ae853SAndroid Build Coastguard Worker * 158*495ae853SAndroid Build Coastguard Worker * @param[in] ps_pps 159*495ae853SAndroid Build Coastguard Worker * pointer to structure containing PPS data 160*495ae853SAndroid Build Coastguard Worker * 161*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 162*495ae853SAndroid Build Coastguard Worker * 163*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 164*495ae853SAndroid Build Coastguard Worker */ 165*495ae853SAndroid Build Coastguard Worker WORD32 isvce_generate_pps(bitstrm_t *ps_bitstrm, pps_t *ps_pps, sps_t *ps_sps); 166*495ae853SAndroid Build Coastguard Worker 167*495ae853SAndroid Build Coastguard Worker /** 168*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 169*495ae853SAndroid Build Coastguard Worker * 170*495ae853SAndroid Build Coastguard Worker * @brief Generates Slice Header 171*495ae853SAndroid Build Coastguard Worker * 172*495ae853SAndroid Build Coastguard Worker * @par Description 173*495ae853SAndroid Build Coastguard Worker * Generate Slice Header as per Section 7.3.5.1 174*495ae853SAndroid Build Coastguard Worker * 175*495ae853SAndroid Build Coastguard Worker * @param[inout] ps_bitstrm 176*495ae853SAndroid Build Coastguard Worker * pointer to bitstream context for generating slice header 177*495ae853SAndroid Build Coastguard Worker * 178*495ae853SAndroid Build Coastguard Worker * @param[in] ps_slice_hdr 179*495ae853SAndroid Build Coastguard Worker * pointer to slice header params 180*495ae853SAndroid Build Coastguard Worker * 181*495ae853SAndroid Build Coastguard Worker * @param[in] ps_pps 182*495ae853SAndroid Build Coastguard Worker * pointer to pps params referred by slice 183*495ae853SAndroid Build Coastguard Worker * 184*495ae853SAndroid Build Coastguard Worker * @param[in] ps_sps 185*495ae853SAndroid Build Coastguard Worker * pointer to sps params referred by slice 186*495ae853SAndroid Build Coastguard Worker * 187*495ae853SAndroid Build Coastguard Worker * @param[out] ps_dup_bit_strm_ent_offset 188*495ae853SAndroid Build Coastguard Worker * Bitstream struct to store bitstream state 189*495ae853SAndroid Build Coastguard Worker * 190*495ae853SAndroid Build Coastguard Worker * @param[out] pu4_first_slice_start_offset 191*495ae853SAndroid Build Coastguard Worker * first slice offset is returned 192*495ae853SAndroid Build Coastguard Worker * 193*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 194*495ae853SAndroid Build Coastguard Worker * 195*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 196*495ae853SAndroid Build Coastguard Worker */ 197*495ae853SAndroid Build Coastguard Worker WORD32 isvce_generate_slice_header(bitstrm_t *ps_bitstrm, slice_header_t *ps_slice_hdr, 198*495ae853SAndroid Build Coastguard Worker pps_t *ps_pps, sps_t *ps_sps, UWORD8 u1_idr_flag); 199*495ae853SAndroid Build Coastguard Worker /** 200*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 201*495ae853SAndroid Build Coastguard Worker * 202*495ae853SAndroid Build Coastguard Worker * @brief Populates sps structure 203*495ae853SAndroid Build Coastguard Worker * 204*495ae853SAndroid Build Coastguard Worker * @par Description 205*495ae853SAndroid Build Coastguard Worker * Populates sps structure for its use in header generation 206*495ae853SAndroid Build Coastguard Worker * 207*495ae853SAndroid Build Coastguard Worker * @param[in] ps_codec 208*495ae853SAndroid Build Coastguard Worker * pointer to encoder context 209*495ae853SAndroid Build Coastguard Worker * 210*495ae853SAndroid Build Coastguard Worker * @param[out] ps_sps 211*495ae853SAndroid Build Coastguard Worker * pointer to sps params that needs to be populated 212*495ae853SAndroid Build Coastguard Worker * 213*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 214*495ae853SAndroid Build Coastguard Worker * 215*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 216*495ae853SAndroid Build Coastguard Worker */ 217*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T isvce_populate_sps(isvce_codec_t *ps_codec, sps_t *ps_sps, UWORD8 u1_sps_id, 218*495ae853SAndroid Build Coastguard Worker UWORD8 u1_profile_idc, isvce_inp_buf_t *ps_inp_buf, 219*495ae853SAndroid Build Coastguard Worker UWORD8 u1_spatial_layer_id); 220*495ae853SAndroid Build Coastguard Worker 221*495ae853SAndroid Build Coastguard Worker /** 222*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 223*495ae853SAndroid Build Coastguard Worker * 224*495ae853SAndroid Build Coastguard Worker * @brief Populates pps structure 225*495ae853SAndroid Build Coastguard Worker * 226*495ae853SAndroid Build Coastguard Worker * @par Description 227*495ae853SAndroid Build Coastguard Worker * Populates pps structure for its use in header generation 228*495ae853SAndroid Build Coastguard Worker * 229*495ae853SAndroid Build Coastguard Worker * @param[in] ps_codec 230*495ae853SAndroid Build Coastguard Worker * pointer to encoder context 231*495ae853SAndroid Build Coastguard Worker * 232*495ae853SAndroid Build Coastguard Worker * @param[out] ps_pps 233*495ae853SAndroid Build Coastguard Worker * pointer to pps params that needs to be populated 234*495ae853SAndroid Build Coastguard Worker * 235*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 236*495ae853SAndroid Build Coastguard Worker * 237*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 238*495ae853SAndroid Build Coastguard Worker */ 239*495ae853SAndroid Build Coastguard Worker IH264E_ERROR_T isvce_populate_pps(isvce_codec_t *ps_codec, pps_t *ps_pps, UWORD8 u1_sps_id, 240*495ae853SAndroid Build Coastguard Worker UWORD8 u1_pps_id, UWORD8 u1_spatial_layer_id); 241*495ae853SAndroid Build Coastguard Worker 242*495ae853SAndroid Build Coastguard Worker /** 243*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 244*495ae853SAndroid Build Coastguard Worker * 245*495ae853SAndroid Build Coastguard Worker * @brief Populates slice header structure 246*495ae853SAndroid Build Coastguard Worker * 247*495ae853SAndroid Build Coastguard Worker * @par Description 248*495ae853SAndroid Build Coastguard Worker * Populates slice header structure for its use in header generation 249*495ae853SAndroid Build Coastguard Worker * 250*495ae853SAndroid Build Coastguard Worker * @param[in] ps_proc 251*495ae853SAndroid Build Coastguard Worker * pointer to proc context 252*495ae853SAndroid Build Coastguard Worker * 253*495ae853SAndroid Build Coastguard Worker * @param[out] ps_slice_hdr 254*495ae853SAndroid Build Coastguard Worker * pointer to slice header structure that needs to be populated 255*495ae853SAndroid Build Coastguard Worker * 256*495ae853SAndroid Build Coastguard Worker * @param[in] ps_pps 257*495ae853SAndroid Build Coastguard Worker * pointer to pps params structure referred by the slice 258*495ae853SAndroid Build Coastguard Worker * 259*495ae853SAndroid Build Coastguard Worker * @param[in] ps_sps 260*495ae853SAndroid Build Coastguard Worker * pointer to sps params referred by the pps 261*495ae853SAndroid Build Coastguard Worker * 262*495ae853SAndroid Build Coastguard Worker * @return success or failure error code 263*495ae853SAndroid Build Coastguard Worker * 264*495ae853SAndroid Build Coastguard Worker ****************************************************************************** 265*495ae853SAndroid Build Coastguard Worker */ 266*495ae853SAndroid Build Coastguard Worker WORD32 isvce_populate_slice_header(isvce_process_ctxt_t *ps_proc, slice_header_t *ps_slice_hdr, 267*495ae853SAndroid Build Coastguard Worker pps_t *ps_pps, sps_t *ps_sps, UWORD8 u1_is_idr); 268*495ae853SAndroid Build Coastguard Worker 269*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_populate_svc_nalu_extension(isvce_process_ctxt_t *ps_proc, 270*495ae853SAndroid Build Coastguard Worker svc_nalu_ext_t *ps_svc_nalu_ext, 271*495ae853SAndroid Build Coastguard Worker NAL_UNIT_TYPE_T nalu_type, UWORD8 u1_idr_flag); 272*495ae853SAndroid Build Coastguard Worker 273*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_generate_svc_nalu_extension(bitstrm_t *ps_bitstrm, 274*495ae853SAndroid Build Coastguard Worker svc_nalu_ext_t *ps_svc_nalu_ext, UWORD8 u1_nalu_id); 275*495ae853SAndroid Build Coastguard Worker 276*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_populate_svc_slice(isvce_process_ctxt_t *ps_proc, 277*495ae853SAndroid Build Coastguard Worker svc_slice_header_t *ps_svc_slice_hdr, pps_t *ps_pps, 278*495ae853SAndroid Build Coastguard Worker subset_sps_t *ps_subset_sps, 279*495ae853SAndroid Build Coastguard Worker svc_nalu_ext_t *ps_svc_nalu_ext); 280*495ae853SAndroid Build Coastguard Worker 281*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_populate_subset_sps(isvce_codec_t *ps_codec, subset_sps_t *ps_subset_sps, 282*495ae853SAndroid Build Coastguard Worker UWORD8 u1_sps_id, isvce_inp_buf_t *ps_inp_buf, 283*495ae853SAndroid Build Coastguard Worker UWORD8 u1_spatial_layer_id); 284*495ae853SAndroid Build Coastguard Worker 285*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_generate_prefix_nal(bitstrm_t *ps_bitstrm, svc_nalu_ext_t *ps_svc_nalu_ext, 286*495ae853SAndroid Build Coastguard Worker slice_header_t *ps_slice_header, 287*495ae853SAndroid Build Coastguard Worker UWORD8 u1_max_num_ref_frames, UWORD8 u1_num_spatial_layers); 288*495ae853SAndroid Build Coastguard Worker 289*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_generate_slice_header_svc(bitstrm_t *ps_bitstrm, pps_t *ps_pps, 290*495ae853SAndroid Build Coastguard Worker svc_nalu_ext_t *ps_svc_nalu_ext, 291*495ae853SAndroid Build Coastguard Worker svc_slice_header_t *ps_svc_slice_hdr, 292*495ae853SAndroid Build Coastguard Worker subset_sps_t *ps_subset_sps); 293*495ae853SAndroid Build Coastguard Worker 294*495ae853SAndroid Build Coastguard Worker extern WORD32 isvce_generate_subset_sps(bitstrm_t *ps_bitstrm, subset_sps_t *ps_subset_sps); 295*495ae853SAndroid Build Coastguard Worker 296*495ae853SAndroid Build Coastguard Worker #endif 297