Browse Source

h264: move the parameter set definitions to a new header file

The PS parsing code is independent from the decoder, so it makes more
sense for it to have its own separate header.
tags/n3.2
Anton Khirnov 9 years ago
parent
commit
f638b67e57
15 changed files with 176 additions and 131 deletions
  1. +1
    -0
      libavcodec/dxva2_h264.c
  2. +2
    -0
      libavcodec/h264.h
  3. +1
    -0
      libavcodec/h264_direct.c
  4. +1
    -0
      libavcodec/h264_loopfilter.c
  5. +1
    -0
      libavcodec/h264_mb.c
  6. +1
    -0
      libavcodec/h264_parse.c
  7. +6
    -9
      libavcodec/h264_parse.h
  8. +1
    -0
      libavcodec/h264_parser.c
  9. +3
    -1
      libavcodec/h264_ps.c
  10. +154
    -0
      libavcodec/h264_ps.h
  11. +1
    -0
      libavcodec/h264_slice.c
  12. +1
    -0
      libavcodec/h264dec.c
  13. +1
    -121
      libavcodec/h264dec.h
  14. +1
    -0
      libavcodec/vaapi_h264.c
  15. +1
    -0
      libavcodec/vdpau_h264.c

+ 1
- 0
libavcodec/dxva2_h264.c View File

@@ -22,6 +22,7 @@


#include "h264dec.h" #include "h264dec.h"
#include "h264data.h" #include "h264data.h"
#include "h264_ps.h"
#include "mpegutils.h" #include "mpegutils.h"


// The headers above may include w32threads.h, which uses the original // The headers above may include w32threads.h, which uses the original


+ 2
- 0
libavcodec/h264.h View File

@@ -24,6 +24,8 @@
#ifndef AVCODEC_H264_H #ifndef AVCODEC_H264_H
#define AVCODEC_H264_H #define AVCODEC_H264_H


#define QP_MAX_NUM (51 + 2 * 6) // The maximum supported qp

/* NAL unit types */ /* NAL unit types */
enum { enum {
NAL_SLICE = 1, NAL_SLICE = 1,


+ 1
- 0
libavcodec/h264_direct.c View File

@@ -28,6 +28,7 @@
#include "internal.h" #include "internal.h"
#include "avcodec.h" #include "avcodec.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_ps.h"
#include "mpegutils.h" #include "mpegutils.h"
#include "rectangle.h" #include "rectangle.h"
#include "thread.h" #include "thread.h"


+ 1
- 0
libavcodec/h264_loopfilter.c View File

@@ -30,6 +30,7 @@
#include "internal.h" #include "internal.h"
#include "avcodec.h" #include "avcodec.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_ps.h"
#include "mathops.h" #include "mathops.h"
#include "mpegutils.h" #include "mpegutils.h"
#include "rectangle.h" #include "rectangle.h"


+ 1
- 0
libavcodec/h264_mb.c View File

@@ -32,6 +32,7 @@
#include "libavutil/intreadwrite.h" #include "libavutil/intreadwrite.h"
#include "avcodec.h" #include "avcodec.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_ps.h"
#include "qpeldsp.h" #include "qpeldsp.h"
#include "thread.h" #include "thread.h"




+ 1
- 0
libavcodec/h264_parse.c View File

@@ -22,6 +22,7 @@
#include "h264.h" #include "h264.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_parse.h" #include "h264_parse.h"
#include "h264_ps.h"


int ff_h264_pred_weight_table(GetBitContext *gb, const SPS *sps, int ff_h264_pred_weight_table(GetBitContext *gb, const SPS *sps,
const int *ref_count, int slice_type_nos, const int *ref_count, int slice_type_nos,


+ 6
- 9
libavcodec/h264_parse.h View File

@@ -25,6 +25,7 @@
#define AVCODEC_H264_PARSE_H #define AVCODEC_H264_PARSE_H


#include "get_bits.h" #include "get_bits.h"
#include "h264_ps.h"


typedef struct H264PredWeightTable { typedef struct H264PredWeightTable {
int use_weight; int use_weight;
@@ -52,11 +53,7 @@ typedef struct H264POCContext {
int prev_frame_num; ///< frame_num of the last pic for POC type 1/2 int prev_frame_num; ///< frame_num of the last pic for POC type 1/2
} H264POCContext; } H264POCContext;


struct SPS;
struct PPS;
struct H264ParamSets;

int ff_h264_pred_weight_table(GetBitContext *gb, const struct SPS *sps,
int ff_h264_pred_weight_table(GetBitContext *gb, const SPS *sps,
const int *ref_count, int slice_type_nos, const int *ref_count, int slice_type_nos,
H264PredWeightTable *pwt); H264PredWeightTable *pwt);


@@ -76,20 +73,20 @@ int ff_h264_check_intra_pred_mode(void *logctx, int top_samples_available,
int mode, int is_chroma); int mode, int is_chroma);


int ff_h264_parse_ref_count(int *plist_count, int ref_count[2], int ff_h264_parse_ref_count(int *plist_count, int ref_count[2],
GetBitContext *gb, const struct PPS *pps,
GetBitContext *gb, const PPS *pps,
int slice_type_nos, int picture_structure); int slice_type_nos, int picture_structure);


int ff_h264_init_poc(int pic_field_poc[2], int *pic_poc, int ff_h264_init_poc(int pic_field_poc[2], int *pic_poc,
const struct SPS *sps, H264POCContext *poc,
const SPS *sps, H264POCContext *poc,
int picture_structure, int nal_ref_idc); int picture_structure, int nal_ref_idc);


int ff_h264_decode_extradata(const uint8_t *data, int size, struct H264ParamSets *ps,
int ff_h264_decode_extradata(const uint8_t *data, int size, H264ParamSets *ps,
int *is_avc, int *nal_length_size, int *is_avc, int *nal_length_size,
int err_recognition, void *logctx); int err_recognition, void *logctx);


/** /**
* compute profile from sps * compute profile from sps
*/ */
int ff_h264_get_profile(const struct SPS *sps);
int ff_h264_get_profile(const SPS *sps);


#endif /* AVCODEC_H264_PARSE_H */ #endif /* AVCODEC_H264_PARSE_H */

+ 1
- 0
libavcodec/h264_parser.c View File

@@ -39,6 +39,7 @@
#include "h264.h" #include "h264.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_sei.h" #include "h264_sei.h"
#include "h264_ps.h"
#include "h264data.h" #include "h264data.h"
#include "internal.h" #include "internal.h"
#include "mpegutils.h" #include "mpegutils.h"


+ 3
- 1
libavcodec/h264_ps.c View File

@@ -31,13 +31,15 @@
#include "internal.h" #include "internal.h"
#include "mathops.h" #include "mathops.h"
#include "avcodec.h" #include "avcodec.h"
#include "h264dec.h"
#include "h264data.h" #include "h264data.h"
#include "h264_ps.h"
#include "golomb.h" #include "golomb.h"


#define MAX_LOG2_MAX_FRAME_NUM (12 + 4) #define MAX_LOG2_MAX_FRAME_NUM (12 + 4)
#define MIN_LOG2_MAX_FRAME_NUM 4 #define MIN_LOG2_MAX_FRAME_NUM 4


#define EXTENDED_SAR 255

static const AVRational pixel_aspect[17] = { static const AVRational pixel_aspect[17] = {
{ 0, 1 }, { 0, 1 },
{ 1, 1 }, { 1, 1 },


+ 154
- 0
libavcodec/h264_ps.h View File

@@ -0,0 +1,154 @@
/*
* This file is part of Libav.
*
* Libav is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* Libav is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with Libav; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/

/**
* @file
* H.264 parameter set handling
*/

#ifndef AVCODEC_H264_PS_H
#define AVCODEC_H264_PS_H

#include <stdint.h>

#include "libavutil/buffer.h"
#include "libavutil/pixfmt.h"
#include "libavutil/rational.h"

#include "avcodec.h"
#include "get_bits.h"
#include "h264.h"

#define MAX_SPS_COUNT 32
#define MAX_PPS_COUNT 256

/**
* Sequence parameter set
*/
typedef struct SPS {
unsigned int sps_id;
int profile_idc;
int level_idc;
int chroma_format_idc;
int transform_bypass; ///< qpprime_y_zero_transform_bypass_flag
int log2_max_frame_num; ///< log2_max_frame_num_minus4 + 4
int poc_type; ///< pic_order_cnt_type
int log2_max_poc_lsb; ///< log2_max_pic_order_cnt_lsb_minus4
int delta_pic_order_always_zero_flag;
int offset_for_non_ref_pic;
int offset_for_top_to_bottom_field;
int poc_cycle_length; ///< num_ref_frames_in_pic_order_cnt_cycle
int ref_frame_count; ///< num_ref_frames
int gaps_in_frame_num_allowed_flag;
int mb_width; ///< pic_width_in_mbs_minus1 + 1
int mb_height; ///< pic_height_in_map_units_minus1 + 1
int frame_mbs_only_flag;
int mb_aff; ///< mb_adaptive_frame_field_flag
int direct_8x8_inference_flag;
int crop; ///< frame_cropping_flag

/* those 4 are already in luma samples */
unsigned int crop_left; ///< frame_cropping_rect_left_offset
unsigned int crop_right; ///< frame_cropping_rect_right_offset
unsigned int crop_top; ///< frame_cropping_rect_top_offset
unsigned int crop_bottom; ///< frame_cropping_rect_bottom_offset
int vui_parameters_present_flag;
AVRational sar;
int video_signal_type_present_flag;
int full_range;
int colour_description_present_flag;
enum AVColorPrimaries color_primaries;
enum AVColorTransferCharacteristic color_trc;
enum AVColorSpace colorspace;
int timing_info_present_flag;
uint32_t num_units_in_tick;
uint32_t time_scale;
int fixed_frame_rate_flag;
short offset_for_ref_frame[256]; // FIXME dyn aloc?
int bitstream_restriction_flag;
int num_reorder_frames;
int scaling_matrix_present;
uint8_t scaling_matrix4[6][16];
uint8_t scaling_matrix8[6][64];
int nal_hrd_parameters_present_flag;
int vcl_hrd_parameters_present_flag;
int pic_struct_present_flag;
int time_offset_length;
int cpb_cnt; ///< See H.264 E.1.2
int initial_cpb_removal_delay_length; ///< initial_cpb_removal_delay_length_minus1 + 1
int cpb_removal_delay_length; ///< cpb_removal_delay_length_minus1 + 1
int dpb_output_delay_length; ///< dpb_output_delay_length_minus1 + 1
int bit_depth_luma; ///< bit_depth_luma_minus8 + 8
int bit_depth_chroma; ///< bit_depth_chroma_minus8 + 8
int residual_color_transform_flag; ///< residual_colour_transform_flag
int constraint_set_flags; ///< constraint_set[0-3]_flag
} SPS;

/**
* Picture parameter set
*/
typedef struct PPS {
unsigned int sps_id;
int cabac; ///< entropy_coding_mode_flag
int pic_order_present; ///< pic_order_present_flag
int slice_group_count; ///< num_slice_groups_minus1 + 1
int mb_slice_group_map_type;
unsigned int ref_count[2]; ///< num_ref_idx_l0/1_active_minus1 + 1
int weighted_pred; ///< weighted_pred_flag
int weighted_bipred_idc;
int init_qp; ///< pic_init_qp_minus26 + 26
int init_qs; ///< pic_init_qs_minus26 + 26
int chroma_qp_index_offset[2];
int deblocking_filter_parameters_present; ///< deblocking_filter_parameters_present_flag
int constrained_intra_pred; ///< constrained_intra_pred_flag
int redundant_pic_cnt_present; ///< redundant_pic_cnt_present_flag
int transform_8x8_mode; ///< transform_8x8_mode_flag
uint8_t scaling_matrix4[6][16];
uint8_t scaling_matrix8[6][64];
uint8_t chroma_qp_table[2][64]; ///< pre-scaled (with chroma_qp_index_offset) version of qp_table
int chroma_qp_diff;

uint32_t dequant4_buffer[6][QP_MAX_NUM + 1][16];
uint32_t dequant8_buffer[6][QP_MAX_NUM + 1][64];
uint32_t(*dequant4_coeff[6])[16];
uint32_t(*dequant8_coeff[6])[64];
} PPS;

typedef struct H264ParamSets {
AVBufferRef *sps_list[MAX_SPS_COUNT];
AVBufferRef *pps_list[MAX_PPS_COUNT];

/* currently active parameters sets */
const PPS *pps;
// FIXME this should properly be const
SPS *sps;
} H264ParamSets;

/**
* Decode SPS
*/
int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
H264ParamSets *ps);

/**
* Decode PPS
*/
int ff_h264_decode_picture_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
H264ParamSets *ps, int bit_length);

#endif /* AVCODEC_H264_PS_H */

+ 1
- 0
libavcodec/h264_slice.c View File

@@ -40,6 +40,7 @@
#include "h264data.h" #include "h264data.h"
#include "h264chroma.h" #include "h264chroma.h"
#include "h264_mvpred.h" #include "h264_mvpred.h"
#include "h264_ps.h"
#include "golomb.h" #include "golomb.h"
#include "mathops.h" #include "mathops.h"
#include "mpegutils.h" #include "mpegutils.h"


+ 1
- 0
libavcodec/h264dec.c View File

@@ -42,6 +42,7 @@
#include "h264data.h" #include "h264data.h"
#include "h264chroma.h" #include "h264chroma.h"
#include "h264_mvpred.h" #include "h264_mvpred.h"
#include "h264_ps.h"
#include "golomb.h" #include "golomb.h"
#include "mathops.h" #include "mathops.h"
#include "me_cmp.h" #include "me_cmp.h"


+ 1
- 121
libavcodec/h264dec.h View File

@@ -35,6 +35,7 @@
#include "cabac.h" #include "cabac.h"
#include "error_resilience.h" #include "error_resilience.h"
#include "h264_parse.h" #include "h264_parse.h"
#include "h264_ps.h"
#include "h264_sei.h" #include "h264_sei.h"
#include "h2645_parse.h" #include "h2645_parse.h"
#include "h264chroma.h" #include "h264chroma.h"
@@ -50,9 +51,6 @@


#define H264_MAX_PICTURE_COUNT 32 #define H264_MAX_PICTURE_COUNT 32


#define MAX_SPS_COUNT 32
#define MAX_PPS_COUNT 256

#define MAX_MMCO_COUNT 66 #define MAX_MMCO_COUNT 66


#define MAX_DELAYED_PIC_COUNT 16 #define MAX_DELAYED_PIC_COUNT 16
@@ -99,117 +97,11 @@
#define CHROMA422(h) (h->ps.sps->chroma_format_idc == 2) #define CHROMA422(h) (h->ps.sps->chroma_format_idc == 2)
#define CHROMA444(h) (h->ps.sps->chroma_format_idc == 3) #define CHROMA444(h) (h->ps.sps->chroma_format_idc == 3)


#define EXTENDED_SAR 255

#define MB_TYPE_REF0 MB_TYPE_ACPRED // dirty but it fits in 16 bit #define MB_TYPE_REF0 MB_TYPE_ACPRED // dirty but it fits in 16 bit
#define MB_TYPE_8x8DCT 0x01000000 #define MB_TYPE_8x8DCT 0x01000000
#define IS_REF0(a) ((a) & MB_TYPE_REF0) #define IS_REF0(a) ((a) & MB_TYPE_REF0)
#define IS_8x8DCT(a) ((a) & MB_TYPE_8x8DCT) #define IS_8x8DCT(a) ((a) & MB_TYPE_8x8DCT)


#define QP_MAX_NUM (51 + 2 * 6) // The maximum supported qp

/**
* Sequence parameter set
*/
typedef struct SPS {
unsigned int sps_id;
int profile_idc;
int level_idc;
int chroma_format_idc;
int transform_bypass; ///< qpprime_y_zero_transform_bypass_flag
int log2_max_frame_num; ///< log2_max_frame_num_minus4 + 4
int poc_type; ///< pic_order_cnt_type
int log2_max_poc_lsb; ///< log2_max_pic_order_cnt_lsb_minus4
int delta_pic_order_always_zero_flag;
int offset_for_non_ref_pic;
int offset_for_top_to_bottom_field;
int poc_cycle_length; ///< num_ref_frames_in_pic_order_cnt_cycle
int ref_frame_count; ///< num_ref_frames
int gaps_in_frame_num_allowed_flag;
int mb_width; ///< pic_width_in_mbs_minus1 + 1
int mb_height; ///< pic_height_in_map_units_minus1 + 1
int frame_mbs_only_flag;
int mb_aff; ///< mb_adaptive_frame_field_flag
int direct_8x8_inference_flag;
int crop; ///< frame_cropping_flag

/* those 4 are already in luma samples */
unsigned int crop_left; ///< frame_cropping_rect_left_offset
unsigned int crop_right; ///< frame_cropping_rect_right_offset
unsigned int crop_top; ///< frame_cropping_rect_top_offset
unsigned int crop_bottom; ///< frame_cropping_rect_bottom_offset
int vui_parameters_present_flag;
AVRational sar;
int video_signal_type_present_flag;
int full_range;
int colour_description_present_flag;
enum AVColorPrimaries color_primaries;
enum AVColorTransferCharacteristic color_trc;
enum AVColorSpace colorspace;
int timing_info_present_flag;
uint32_t num_units_in_tick;
uint32_t time_scale;
int fixed_frame_rate_flag;
short offset_for_ref_frame[256]; // FIXME dyn aloc?
int bitstream_restriction_flag;
int num_reorder_frames;
int scaling_matrix_present;
uint8_t scaling_matrix4[6][16];
uint8_t scaling_matrix8[6][64];
int nal_hrd_parameters_present_flag;
int vcl_hrd_parameters_present_flag;
int pic_struct_present_flag;
int time_offset_length;
int cpb_cnt; ///< See H.264 E.1.2
int initial_cpb_removal_delay_length; ///< initial_cpb_removal_delay_length_minus1 + 1
int cpb_removal_delay_length; ///< cpb_removal_delay_length_minus1 + 1
int dpb_output_delay_length; ///< dpb_output_delay_length_minus1 + 1
int bit_depth_luma; ///< bit_depth_luma_minus8 + 8
int bit_depth_chroma; ///< bit_depth_chroma_minus8 + 8
int residual_color_transform_flag; ///< residual_colour_transform_flag
int constraint_set_flags; ///< constraint_set[0-3]_flag
} SPS;

/**
* Picture parameter set
*/
typedef struct PPS {
unsigned int sps_id;
int cabac; ///< entropy_coding_mode_flag
int pic_order_present; ///< pic_order_present_flag
int slice_group_count; ///< num_slice_groups_minus1 + 1
int mb_slice_group_map_type;
unsigned int ref_count[2]; ///< num_ref_idx_l0/1_active_minus1 + 1
int weighted_pred; ///< weighted_pred_flag
int weighted_bipred_idc;
int init_qp; ///< pic_init_qp_minus26 + 26
int init_qs; ///< pic_init_qs_minus26 + 26
int chroma_qp_index_offset[2];
int deblocking_filter_parameters_present; ///< deblocking_filter_parameters_present_flag
int constrained_intra_pred; ///< constrained_intra_pred_flag
int redundant_pic_cnt_present; ///< redundant_pic_cnt_present_flag
int transform_8x8_mode; ///< transform_8x8_mode_flag
uint8_t scaling_matrix4[6][16];
uint8_t scaling_matrix8[6][64];
uint8_t chroma_qp_table[2][64]; ///< pre-scaled (with chroma_qp_index_offset) version of qp_table
int chroma_qp_diff;

uint32_t dequant4_buffer[6][QP_MAX_NUM + 1][16];
uint32_t dequant8_buffer[6][QP_MAX_NUM + 1][64];
uint32_t(*dequant4_coeff[6])[16];
uint32_t(*dequant8_coeff[6])[64];
} PPS;

typedef struct H264ParamSets {
AVBufferRef *sps_list[MAX_SPS_COUNT];
AVBufferRef *pps_list[MAX_PPS_COUNT];

/* currently active parameters sets */
const PPS *pps;
// FIXME this should properly be const
SPS *sps;
} H264ParamSets;

/** /**
* Memory management control operation opcode. * Memory management control operation opcode.
*/ */
@@ -625,18 +517,6 @@ typedef struct H264Context {


extern const uint16_t ff_h264_mb_sizes[4]; extern const uint16_t ff_h264_mb_sizes[4];


/**
* Decode SPS
*/
int ff_h264_decode_seq_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
H264ParamSets *ps);

/**
* Decode PPS
*/
int ff_h264_decode_picture_parameter_set(GetBitContext *gb, AVCodecContext *avctx,
H264ParamSets *ps, int bit_length);

/** /**
* Reconstruct bitstream slice_type. * Reconstruct bitstream slice_type.
*/ */


+ 1
- 0
libavcodec/vaapi_h264.c View File

@@ -22,6 +22,7 @@


#include "vaapi_internal.h" #include "vaapi_internal.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_ps.h"
#include "mpegutils.h" #include "mpegutils.h"


/** /**


+ 1
- 0
libavcodec/vdpau_h264.c View File

@@ -26,6 +26,7 @@
#include "avcodec.h" #include "avcodec.h"
#include "internal.h" #include "internal.h"
#include "h264dec.h" #include "h264dec.h"
#include "h264_ps.h"
#include "mpegutils.h" #include "mpegutils.h"
#include "vdpau.h" #include "vdpau.h"
#include "vdpau_internal.h" #include "vdpau_internal.h"


Loading…
Cancel
Save