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
| @@ -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 | ||||
| @@ -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, | ||||
| @@ -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" | ||||
| @@ -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" | ||||
| @@ -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" | ||||
| @@ -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, | ||||
| @@ -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 */ | ||||
| @@ -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" | ||||
| @@ -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 }, | ||||
| @@ -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 */ | |||||
| @@ -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" | ||||
| @@ -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" | ||||
| @@ -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. | ||||
| */ | */ | ||||
| @@ -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" | ||||
| /** | /** | ||||
| @@ -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" | ||||