On 01/08/2015 09:34 AM, Xiang, Haihao wrote:
On Thu, 2015-01-08 at 09:24 +0800, Zhao, Yakui wrote:
On Wed, 2015-01-07 at 18:24 -0700, Xiang, Haihao wrote:
On Thu, 2015-01-08 at 09:01 +0800, Zhao, Yakui wrote:
On Wed, 2015-01-07 at 01:44 -0700, Qu,Pengfei wrote:
Signed-off-by: Qu,Pengfei <pengfei...@intel.com>
---
  src/i965_drv_video.h     |  17 +-
  src/i965_encoder_utils.c | 457 +++++++++++++++++++++++++++++++++++++++++++++++
  src/i965_encoder_utils.h |  29 +++
  3 files changed, 500 insertions(+), 3 deletions(-)

diff --git a/src/i965_drv_video.h b/src/i965_drv_video.h
index cb4e8e8..24f2b14 100644
--- a/src/i965_drv_video.h
+++ b/src/i965_drv_video.h
@@ -1,5 +1,5 @@
  /*
- * Copyright © 2009 Intel Corporation
+ * Copyright ?2009 Intel Corporation
   *
   * Permission is hereby granted, free of charge, to any person obtaining a
   * copy of this software and associated documentation files (the
@@ -33,6 +33,7 @@
  #include <va/va.h>
  #include <va/va_enc_h264.h>
  #include <va/va_enc_mpeg2.h>
+#include <va/va_enc_hevc.h>
  #include <va/va_enc_jpeg.h>
  #include <va/va_vpp.h>
  #include <va/va_backend.h>
@@ -150,8 +151,8 @@ struct encode_state
      /* for ext */
      struct buffer_store *seq_param_ext;
      struct buffer_store *pic_param_ext;
-    struct buffer_store *packed_header_param[4];
-    struct buffer_store *packed_header_data[4];
+    struct buffer_store *packed_header_param[5];
+    struct buffer_store *packed_header_data[5];
      struct buffer_store **slice_params_ext;
      int max_slice_params_ext;
      int num_slice_params_ext;
@@ -171,6 +172,8 @@ struct encode_state
      int max_packed_header_data_ext;
      int num_packed_header_data_ext;
+ /* the index of current vps and sps ,special for HEVC*/
+    int vps_sps_seq_index;
      /* the index of current slice */
      int slice_index;
      /* the array is determined by max_slice_params_ext */
@@ -370,6 +373,7 @@ struct hw_codec_info
      unsigned int has_vp8_encoding:1;
      unsigned int has_h264_mvc_encoding:1;
      unsigned int has_hevc_decoding:1;
+    unsigned int has_hevc_encoding:1;
unsigned int num_filters;
      struct i965_filter filters[VAProcFilterCount];
@@ -454,6 +458,7 @@ va_enc_packed_type_to_idx(int packed_type);
  #define CODEC_MPEG2     1
  #define CODEC_H264_MVC  2
  #define CODEC_JPEG      3
+#define CODEC_HEVC      5
#define H264_DELIMITER0 0x00
  #define H264_DELIMITER1 0x00
@@ -467,6 +472,12 @@ va_enc_packed_type_to_idx(int packed_type);
  #define MPEG2_DELIMITER3        0x00
  #define MPEG2_DELIMITER4        0xb0
+#define HEVC_DELIMITER0 0x00
+#define HEVC_DELIMITER1 0x00
+#define HEVC_DELIMITER2 0x00
+#define HEVC_DELIMITER3 0x00
+#define HEVC_DELIMITER4 0x00
+
I am curious how the above delemiter can work for HEVC?
In fact if one buffer is initialized, maybe all the content is zero.
As we enable drm cache (intel_bufmgr_gem_enable_reuse()), an object
allocated from drm cache still keep the content unchanged.
But this is not safe. We can't presume the status of the previous
content. Maybe it is zero or other unknown state.
we don't presume the status of the previous content, '0000000000' is
inserted by driver with INSERT_OBJECT command.
I also think it's unsafe. Maybe the last byte of bitstream is 0x00, then five delimiters is inserted. Using these delimiters to calculate bitstream size will drop the last byte, right?
Does HEVC have end_code or  reserved bits?


  struct i965_coded_buffer_segment
  {
      VACodedBufferSegment base;
diff --git a/src/i965_encoder_utils.c b/src/i965_encoder_utils.c
index e59e7fb..ac6813a 100644
--- a/src/i965_encoder_utils.c
+++ b/src/i965_encoder_utils.c
@@ -29,6 +29,7 @@
  #include <va/va.h>
  #include <va/va_enc_h264.h>
  #include <va/va_enc_mpeg2.h>
+#include <va/va_enc_hevc.h>
#include "i965_encoder_utils.h" @@ -62,6 +63,17 @@
  #define PROFILE_IDC_MAIN        77
  #define PROFILE_IDC_HIGH        100
+/*HEVC*/
+#define VPS_NUT                32
+#define SPS_NUT                33
+#define PPS_NUT                34
+#define IDR_WRADL_NUT  19
+#define IDR_NLP_NUT    20
+#define SLICE_TRAIL_N_NUT      0
+#define SLICE_TRAIL_R_NUT      1
+#define PREFIX_SEI_NUT 39
+#define SUFFIX_SEI_NUT 40
+
  struct __avc_bitstream {
      unsigned int *buffer;
      int bit_offset;
@@ -562,3 +574,448 @@ 
build_avc_mvc_slice_header(VAEncSequenceParameterBufferH264_MVC *mvc_sps_param,
return bs.bit_offset;
  }
+
+/* HEVC to do for internal header generated*/
+
+void nal_header_hevc(avc_bitstream *bs, int nal_unit_type, int temporalid)
+{
+    /* forbidden_zero_bit: 0 */
+    avc_bitstream_put_ui(bs, 0, 1);
+    /* nal unit_type */
+    avc_bitstream_put_ui(bs, nal_unit_type, 6);
+    /* layer_id. currently it is zero */
+    avc_bitstream_put_ui(bs, 0, 6);
+    /* teporalid + 1 .*/
+    avc_bitstream_put_ui(bs, temporalid + 1, 3);
+}
+
+int build_hevc_sei_buffering_period(int init_cpb_removal_delay_length,
+                                unsigned int init_cpb_removal_delay,
+                                unsigned int init_cpb_removal_delay_offset,
+                                unsigned char **sei_buffer)
+{
+    unsigned char *byte_buf;
+    int bp_byte_size, i;
+    //unsigned int cpb_removal_delay;
+
+    avc_bitstream nal_bs;
+    avc_bitstream sei_bp_bs;
+
+    avc_bitstream_start(&sei_bp_bs);
+    avc_bitstream_put_ue(&sei_bp_bs, 0);       /*seq_parameter_set_id*/
+    /* SEI buffer period info */
+    /* NALHrdBpPresentFlag == 1 */
+    avc_bitstream_put_ui(&sei_bp_bs, 
init_cpb_removal_delay,init_cpb_removal_delay_length);
+    avc_bitstream_put_ui(&sei_bp_bs, 
init_cpb_removal_delay_offset,init_cpb_removal_delay_length);
+    if ( sei_bp_bs.bit_offset & 0x7) {
+        avc_bitstream_put_ui(&sei_bp_bs, 1, 1);
+    }
+    avc_bitstream_end(&sei_bp_bs);
+    bp_byte_size = (sei_bp_bs.bit_offset + 7) / 8;
+
+    avc_bitstream_start(&nal_bs);
+    nal_start_code_prefix(&nal_bs);
+    nal_header_hevc(&nal_bs, PREFIX_SEI_NUT ,0);
+
+    /* Write the SEI buffer period data */
+    avc_bitstream_put_ui(&nal_bs, 0, 8);
+    avc_bitstream_put_ui(&nal_bs, bp_byte_size, 8);
+
+    byte_buf = (unsigned char *)sei_bp_bs.buffer;
+    for(i = 0; i < bp_byte_size; i++) {
+        avc_bitstream_put_ui(&nal_bs, byte_buf[i], 8);
+    }
+    free(byte_buf);
+
+    avc_rbsp_trailing_bits(&nal_bs);
+    avc_bitstream_end(&nal_bs);
+
+    *sei_buffer = (unsigned char *)nal_bs.buffer;
+
+    return nal_bs.bit_offset;
+}
+
+int build_hevc_idr_sei_buffer_timing(unsigned int 
init_cpb_removal_delay_length,
+                                 unsigned int init_cpb_removal_delay,
+                                 unsigned int init_cpb_removal_delay_offset,
+                                 unsigned int cpb_removal_length,
+                                 unsigned int cpb_removal_delay,
+                                 unsigned int dpb_output_length,
+                                 unsigned int dpb_output_delay,
+                                 unsigned char **sei_buffer)
+{
+    unsigned char *byte_buf;
+    int bp_byte_size, i, pic_byte_size;
+    //unsigned int cpb_removal_delay;
+
+    avc_bitstream nal_bs;
+    avc_bitstream sei_bp_bs, sei_pic_bs;
+
+    avc_bitstream_start(&sei_bp_bs);
+    avc_bitstream_put_ue(&sei_bp_bs, 0);       /*seq_parameter_set_id*/
+    /* SEI buffer period info */
+    /* NALHrdBpPresentFlag == 1 */
+    avc_bitstream_put_ui(&sei_bp_bs, 
init_cpb_removal_delay,init_cpb_removal_delay_length);
+    avc_bitstream_put_ui(&sei_bp_bs, 
init_cpb_removal_delay_offset,init_cpb_removal_delay_length);
+    if ( sei_bp_bs.bit_offset & 0x7) {
+        avc_bitstream_put_ui(&sei_bp_bs, 1, 1);
+    }
+    avc_bitstream_end(&sei_bp_bs);
+    bp_byte_size = (sei_bp_bs.bit_offset + 7) / 8;
+
+    /* SEI pic timing info */
+    avc_bitstream_start(&sei_pic_bs);
+    /* The info of CPB and DPB delay is controlled by CpbDpbDelaysPresentFlag,
+    * which is derived as 1 if one of the following conditions is true:
+    * nal_hrd_parameters_present_flag is present in the avc_bitstream and is 
equal to 1,
+    * vcl_hrd_parameters_present_flag is present in the avc_bitstream and is 
equal to 1,
+    */
+    //cpb_removal_delay = (hevc_context.current_cpb_removal - 
hevc_context.prev_idr_cpb_removal);
+    avc_bitstream_put_ui(&sei_pic_bs, cpb_removal_delay, cpb_removal_length);
+    avc_bitstream_put_ui(&sei_pic_bs, dpb_output_delay,dpb_output_length);
+    if ( sei_pic_bs.bit_offset & 0x7) {
+        avc_bitstream_put_ui(&sei_pic_bs, 1, 1);
+    }
+    /* The pic_structure_present_flag determines whether the pic_structure
+    * info is written into the SEI pic timing info.
+    * Currently it is set to zero.
+    */
+    avc_bitstream_end(&sei_pic_bs);
+    pic_byte_size = (sei_pic_bs.bit_offset + 7) / 8;
+
+    avc_bitstream_start(&nal_bs);
+    nal_start_code_prefix(&nal_bs);
+    nal_header_hevc(&nal_bs, PREFIX_SEI_NUT ,0);
+
+    /* Write the SEI buffer period data */
+    avc_bitstream_put_ui(&nal_bs, 0, 8);
+    avc_bitstream_put_ui(&nal_bs, bp_byte_size, 8);
+
+    byte_buf = (unsigned char *)sei_bp_bs.buffer;
+    for(i = 0; i < bp_byte_size; i++) {
+        avc_bitstream_put_ui(&nal_bs, byte_buf[i], 8);
+    }
+    free(byte_buf);
+    /* write the SEI pic timing data */
+    avc_bitstream_put_ui(&nal_bs, 0x01, 8);
+    avc_bitstream_put_ui(&nal_bs, pic_byte_size, 8);
+
+    byte_buf = (unsigned char *)sei_pic_bs.buffer;
+    for(i = 0; i < pic_byte_size; i++) {
+        avc_bitstream_put_ui(&nal_bs, byte_buf[i], 8);
+    }
+    free(byte_buf);
+
+    avc_rbsp_trailing_bits(&nal_bs);
+    avc_bitstream_end(&nal_bs);
+
+    *sei_buffer = (unsigned char *)nal_bs.buffer;
+
+    return nal_bs.bit_offset;
+}
+
+int build_hevc_sei_pic_timing(unsigned int cpb_removal_length, unsigned int 
cpb_removal_delay,
+                         unsigned int dpb_output_length, unsigned int 
dpb_output_delay,
+                         unsigned char **sei_buffer)
+{
+    unsigned char *byte_buf;
+    int i, pic_byte_size;
+    //unsigned int cpb_removal_delay;
+
+    avc_bitstream nal_bs;
+    avc_bitstream sei_pic_bs;
+
+    avc_bitstream_start(&sei_pic_bs);
+    /* The info of CPB and DPB delay is controlled by CpbDpbDelaysPresentFlag,
+    * which is derived as 1 if one of the following conditions is true:
+    * nal_hrd_parameters_present_flag is present in the avc_bitstream and is 
equal to 1,
+    * vcl_hrd_parameters_present_flag is present in the avc_bitstream and is 
equal to 1,
+    */
+    //cpb_removal_delay = (hevc_context.current_cpb_removal - 
hevc_context.current_idr_cpb_removal);
+    avc_bitstream_put_ui(&sei_pic_bs, cpb_removal_delay, cpb_removal_length);
+    avc_bitstream_put_ui(&sei_pic_bs, dpb_output_delay,     dpb_output_length);
+    if ( sei_pic_bs.bit_offset & 0x7) {
+        avc_bitstream_put_ui(&sei_pic_bs, 1, 1);
+    }
+
+    /* The pic_structure_present_flag determines whether the pic_structure
+    * info is written into the SEI pic timing info.
+    * Currently it is set to zero.
+    */
+    avc_bitstream_end(&sei_pic_bs);
+    pic_byte_size = (sei_pic_bs.bit_offset + 7) / 8;
+
+    avc_bitstream_start(&nal_bs);
+    nal_start_code_prefix(&nal_bs);
+    nal_header_hevc(&nal_bs, PREFIX_SEI_NUT ,0);
+
+    /* write the SEI Pic timing data */
+    avc_bitstream_put_ui(&nal_bs, 0x01, 8);
+    avc_bitstream_put_ui(&nal_bs, pic_byte_size, 8);
+
+    byte_buf = (unsigned char *)sei_pic_bs.buffer;
+    for(i = 0; i < pic_byte_size; i++) {
+        avc_bitstream_put_ui(&nal_bs, byte_buf[i], 8);
+    }
+    free(byte_buf);
+
+    avc_rbsp_trailing_bits(&nal_bs);
+    avc_bitstream_end(&nal_bs);
+
+    *sei_buffer = (unsigned char *)nal_bs.buffer;
+
+    return nal_bs.bit_offset;
+}
+
+typedef struct _RefPicSet
+{
+    unsigned char    num_negative_pics;
+    unsigned char    num_positive_pics;
+    unsigned char    delta_poc_s0_minus1[8];
+    unsigned char    used_by_curr_pic_s0_flag[8];
+    unsigned char    delta_poc_s1_minus1[8];
+    unsigned char    used_by_curr_pic_s1_flag[8];
+    unsigned int     inter_ref_pic_set_prediction_flag;
+}hevcRefPicSet;
+
+void hevc_short_term_ref_pic_set(avc_bitstream 
*bs,VAEncSliceParameterBufferHEVC *slice_param,int curPicOrderCnt)
+{
+    hevcRefPicSet hevc_rps;
+    int rps_idx = 1, ref_idx = 0;
+    int i = 0;
+
+    hevc_rps.inter_ref_pic_set_prediction_flag = 0;
+    /* s0: between I and P/B; s1 : between P and B */
+    hevc_rps.num_negative_pics               = 
(slice_param->slice_type!=SLICE_TYPE_I) ? 1 : 0;
+    hevc_rps.num_positive_pics               = 
(slice_param->slice_type==SLICE_TYPE_B) ? 1 : 0;
+    hevc_rps.delta_poc_s0_minus1[0]          = 0;
+    hevc_rps.used_by_curr_pic_s0_flag[0]     = 0;
+    hevc_rps.delta_poc_s1_minus1[0]          = 0;
+    hevc_rps.used_by_curr_pic_s1_flag[0]     = 0;
+    if(slice_param->num_ref_idx_l0_active_minus1==0 )
+    {
+        hevc_rps.delta_poc_s0_minus1[0]          = 
(slice_param->slice_type==SLICE_TYPE_I) ? 0 : ( curPicOrderCnt - 
slice_param->ref_pic_list0[0].pic_order_cnt-1); //0;
+        hevc_rps.used_by_curr_pic_s0_flag[0]     = 1;
+    }
+    if(slice_param->num_ref_idx_l1_active_minus1==0 )
+    {
+        hevc_rps.delta_poc_s1_minus1[0]          = 
(slice_param->slice_type==SLICE_TYPE_I) ? 0 : ( 
slice_param->ref_pic_list1[0].pic_order_cnt -curPicOrderCnt -1);
+        hevc_rps.used_by_curr_pic_s1_flag[0]     = 1;
+    }
+
+    if (rps_idx)
+        avc_bitstream_put_ui(bs, hevc_rps.inter_ref_pic_set_prediction_flag, 
1);
+
+    if (hevc_rps.inter_ref_pic_set_prediction_flag)
+    {
+        /* not support */
+        /* to do */
+    } else {
+        avc_bitstream_put_ue(bs, hevc_rps.num_negative_pics);
+        avc_bitstream_put_ue(bs, hevc_rps.num_positive_pics);
+
+        for (i = 0; i < hevc_rps.num_negative_pics; i++)
+        {
+            avc_bitstream_put_ue(bs, hevc_rps.delta_poc_s0_minus1[ref_idx]);
+            avc_bitstream_put_ui(bs, 
hevc_rps.used_by_curr_pic_s0_flag[ref_idx], 1);
+        }
+        for (i = 0; i < hevc_rps.num_positive_pics; i++)
+        {
+            avc_bitstream_put_ue(bs, hevc_rps.delta_poc_s1_minus1[ref_idx]);
+            avc_bitstream_put_ui(bs, 
hevc_rps.used_by_curr_pic_s1_flag[ref_idx], 1);
+        }
+    }
+
+    return;
+}
+
+static void slice_rbsp(avc_bitstream *bs,
+                       int slice_index,
+                       VAEncSequenceParameterBufferHEVC *seq_param,
+                       VAEncPictureParameterBufferHEVC *pic_param,
+                       VAEncSliceParameterBufferHEVC *slice_param)
+{
+    int log2_cu_size = seq_param->log2_min_luma_coding_block_size_minus3 + 3;
+    int log2_ctb_size = seq_param->log2_diff_max_min_luma_coding_block_size + 
log2_cu_size;
+    int ctb_size = 1 << log2_ctb_size;
+
+    int picture_width_in_ctb = (seq_param->pic_width_in_luma_samples + 
ctb_size - 1) / ctb_size;
+    int picture_height_in_ctb = (seq_param->pic_height_in_luma_samples + 
ctb_size - 1) / ctb_size;
+
+    /* first_slice_segment_in_pic_flag */
+    if (slice_index == 0)
+    {
+        avc_bitstream_put_ui(bs, 1, 1);
+    }
+    else
+    {
+        avc_bitstream_put_ui(bs, 0, 1);
+    }
+
+    /* no_output_of_prior_pics_flag. This doesn't exist on TRAIL_N */
+
+    /* slice_pic_parameter_set_id */
+    avc_bitstream_put_ue(bs, 0);
+
+    /* not the first slice */
+    if (slice_index)
+    {
+        /* TBD */
+        int bit_size;
+
+        float num_ctus;
+
+        num_ctus = picture_width_in_ctb * picture_height_in_ctb;
+        bit_size = ceilf(log2f(num_ctus));
+
+        if (pic_param->pic_fields.bits.dependent_slice_segments_enabled_flag)
+        {
+            avc_bitstream_put_ui(bs,
+                slice_param->slice_fields.bits.dependent_slice_segment_flag, 
1);
+        }
+        /* slice_segment_address is based on Ceil(log2(PictureSizeinCtbs)) */
+        avc_bitstream_put_ui(bs, slice_param->slice_segment_address, bit_size);
+    }
+    if (!slice_param->slice_fields.bits.dependent_slice_segment_flag)
+    {
+        /* slice_reserved_flag */
+
+        /* slice_type */
+        avc_bitstream_put_ue(bs, slice_param->slice_type);
+        /* use the inferred the value of pic_output_flag */
+
+        /* colour_plane_id */
+        if (seq_param->seq_fields.bits.separate_colour_plane_flag)
+        {
+            avc_bitstream_put_ui(bs, 
slice_param->slice_fields.bits.colour_plane_id, 1);
+        }
+
+        if (!pic_param->pic_fields.bits.idr_pic_flag)
+        {
+            int Log2MaxPicOrderCntLsb = 8;
+            avc_bitstream_put_ui(bs, 
pic_param->decoded_curr_pic.pic_order_cnt, Log2MaxPicOrderCntLsb);
+
+            //if (!slice_param->short_term_ref_pic_set_sps_flag)
+            {
+                /* short_term_ref_pic_set_sps_flag.
+                * Use zero and then pass the RPS from slice_header
+                */
+                avc_bitstream_put_ui(bs, 0, 1);
+                /* TBD
+                * Add the short_term reference picture set
+                */
+                
hevc_short_term_ref_pic_set(bs,slice_param,pic_param->decoded_curr_pic.pic_order_cnt);
+            }
+            /* long term reference present flag. unpresent */
+            /* TBD */
+
+            /* sps temporal MVP*/
+            if (seq_param->seq_fields.bits.sps_temporal_mvp_enabled_flag)
+            {
+                avc_bitstream_put_ui(bs,
+                    
slice_param->slice_fields.bits.slice_temporal_mvp_enabled_flag, 1);
+            }
+        }
+
+        /* long term reference present flag. unpresent */
+        if (seq_param->seq_fields.bits.sps_temporal_mvp_enabled_flag)
+        {
+            avc_bitstream_put_ui(bs, 
slice_param->slice_fields.bits.slice_temporal_mvp_enabled_flag, 1);
+        }
+        /* sample adaptive offset enabled flag */
+        if (seq_param->seq_fields.bits.sample_adaptive_offset_enabled_flag)
+        {
+            avc_bitstream_put_ui(bs, 
slice_param->slice_fields.bits.slice_sao_luma_flag, 1);
+            avc_bitstream_put_ui(bs, 
slice_param->slice_fields.bits.slice_sao_chroma_flag, 1);
+        }
+
+        if (slice_param->slice_type != SLICE_TYPE_I)
+        {
+            /* num_ref_idx_active_override_flag. 0 */
+            avc_bitstream_put_ui(bs, 0, 1);
+            /* lists_modification_flag is unpresent NumPocTotalCurr > 1 ,here 
it is 1*/
+
+            /* No reference picture set modification */
+
+            /* MVD_l1_zero_flag */
+            if (slice_param->slice_type == SLICE_TYPE_B)
+                avc_bitstream_put_ui(bs, 
slice_param->slice_fields.bits.mvd_l1_zero_flag, 1);
+
+            /* cabac_init_present_flag. 0 */
+
+            /* slice_temporal_mvp_enabled_flag. */
+            if (slice_param->slice_fields.bits.slice_temporal_mvp_enabled_flag)
+            {
+                /*
+                * TBD: Add the collocated_l0_ref_flag and
+                * collocated_ref_idx.
+                */
+            }
+            if (((pic_param->pic_fields.bits.weighted_pred_flag) &&
+                (slice_param->slice_type == SLICE_TYPE_P)) ||
+                ((pic_param->pic_fields.bits.weighted_bipred_flag) &&
+                (slice_param->slice_type == SLICE_TYPE_B)))
+            {
+                /* TBD:
+                * add the weighted table
+                */
+            }
+            avc_bitstream_put_ue(bs, slice_param->max_num_merge_cand);
+        }
+        /* slice_qp_delta */
+        avc_bitstream_put_ue(bs, slice_param->slice_qp_delta);
+
+        /* slice_cb/cr_qp_offset is controlled by 
pps_slice_chroma_qp_offsets_present_flag
+        * The present flag is set to 1.
+        */
+        avc_bitstream_put_ue(bs, slice_param->slice_cb_qp_offset);
+        avc_bitstream_put_ue(bs, slice_param->slice_cr_qp_offset);
+
+        /*
+        * deblocking_filter_override_flag is controlled by
+        * deblocking_filter_override_enabled_flag.
+        * The override_enabled_flag is zero.
+        * deblocking_filter_override_flag is zero. then
+        * slice_deblocking_filter_disabled_flag is also zero
+        * (It is inferred to be equal to pps_deblocking_filter_disabled_flag.
+        */
+
+        /* slice_loop_filter_across_slices_enabled_flag is controlled
+        * by pps_loop_filter_across_slices_enabled_flag &&
+        * (slice_sao_luma_flag | | slice_sao_chroma_flag | |
+        *  !slice_deblocking_filter_disabled_flag ))
+        *
+        */
+    }
+
+    if (pic_param->pic_fields.bits.tiles_enabled_flag ||
+        pic_param->pic_fields.bits.entropy_coding_sync_enabled_flag)
+    {
+        /* TBD.
+        * Add the Entry-points && tile definition.
+        */
+    }
+
+    /* slice_segment_header_extension_present_flag. Not present */
+
+    /* byte_alignment */
+    avc_rbsp_trailing_bits(bs);
+}
+
+int build_hevc_slice_header(VAEncSequenceParameterBufferHEVC *seq_param,
+                       VAEncPictureParameterBufferHEVC *pic_param,
+                       VAEncSliceParameterBufferHEVC *slice_param,
+                       unsigned char **header_buffer,
+                       int slice_index)
+{
+    avc_bitstream bs;
+
+    avc_bitstream_start(&bs);
+    nal_start_code_prefix(&bs);
+    nal_header_hevc(&bs, SLICE_TRAIL_N_NUT, 0);
+    slice_rbsp(&bs, slice_index, seq_param,pic_param,slice_param);
+    avc_bitstream_end(&bs);
+
+    *header_buffer = (unsigned char *)bs.buffer;
+    return bs.bit_offset;
+}
diff --git a/src/i965_encoder_utils.h b/src/i965_encoder_utils.h
index 4885376..cfc8a0b 100644
--- a/src/i965_encoder_utils.h
+++ b/src/i965_encoder_utils.h
@@ -44,4 +44,33 @@ 
build_avc_mvc_slice_header(VAEncSequenceParameterBufferH264_MVC *mvc_sps_param,
                             VAEncSliceParameterBufferH264   *slice_param,
                             unsigned char **slice_header_buffer);
+
+/* HEVC */
+
+int
+build_hevc_slice_header(VAEncSequenceParameterBufferHEVC *seq_param,
+                        VAEncPictureParameterBufferHEVC *pic_param,
+                        VAEncSliceParameterBufferHEVC *slice_param,
+                        unsigned char **header_buffer,
+                        int slice_index);
+int
+build_hevc_sei_buffering_period(int cpb_removal_length,
+                                unsigned int init_cpb_removal_delay,
+                                unsigned int init_cpb_removal_delay_offset,
+                                unsigned char **sei_buffer);
+
+int
+build_hevc_sei_pic_timing(unsigned int cpb_removal_length, unsigned int 
cpb_removal_delay,
+                          unsigned int dpb_output_length, unsigned int 
dpb_output_delay,
+                          unsigned char **sei_buffer);
+
+int
+build_hevc_idr_sei_buffer_timing(unsigned int init_cpb_removal_delay_length,
+                                 unsigned int init_cpb_removal_delay,
+                                 unsigned int init_cpb_removal_delay_offset,
+                                 unsigned int cpb_removal_length,
+                                 unsigned int cpb_removal_delay,
+                                 unsigned int dpb_output_length,
+                                 unsigned int dpb_output_delay,
+                                 unsigned char **sei_buffer);
  #endif /* __I965_ENCODER_UTILS_H__ */
--
1.9.1


_______________________________________________
Libva mailing list
Libva@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/libva



_______________________________________________
Libva mailing list
Libva@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/libva

_______________________________________________
Libva mailing list
Libva@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/libva

Reply via email to