[FFmpeg-cvslog] r17412 - in trunk/libavcodec: h264.c h264.h
cehoyos
subversion
Wed Feb 18 01:36:07 CET 2009
Author: cehoyos
Date: Wed Feb 18 01:36:07 2009
New Revision: 17412
Log:
Parse dpb_output_delay in SEI picture structure.
Patch by Ivan Schreter, schreter gmx net
Modified:
trunk/libavcodec/h264.c
trunk/libavcodec/h264.h
Modified: trunk/libavcodec/h264.c
==============================================================================
--- trunk/libavcodec/h264.c Wed Feb 18 01:33:33 2009 (r17411)
+++ trunk/libavcodec/h264.c Wed Feb 18 01:36:07 2009 (r17412)
@@ -2209,6 +2209,7 @@ static av_cold int decode_init(AVCodecCo
h->outputed_poc = INT_MIN;
h->prev_poc_msb= 1<<16;
h->sei_recovery_frame_cnt = -1;
+ h->sei_dpb_output_delay = 0;
return 0;
}
@@ -3144,6 +3145,7 @@ static void flush_dpb(AVCodecContext *av
h->s.current_picture_ptr->reference= 0;
h->s.first_field= 0;
h->sei_recovery_frame_cnt = -1;
+ h->sei_dpb_output_delay = 0;
ff_mpeg_flush(avctx);
}
@@ -6782,7 +6784,7 @@ static int decode_picture_timing(H264Con
MpegEncContext * const s = &h->s;
if(h->sps.nal_hrd_parameters_present_flag || h->sps.vcl_hrd_parameters_present_flag){
skip_bits(&s->gb, h->sps.cpb_removal_delay_length); /* cpb_removal_delay */
- skip_bits(&s->gb, h->sps.dpb_output_delay_length); /* dpb_output_delay */
+ h->sei_dpb_output_delay = get_bits(&s->gb, h->sps.dpb_output_delay_length);
}
if(h->sps.pic_struct_present_flag){
unsigned int i, num_clock_ts;
@@ -7691,6 +7693,7 @@ static int decode_frame(AVCodecContext *
MPV_frame_end(s);
h->sei_recovery_frame_cnt = -1;
+ h->sei_dpb_output_delay = 0;
if (cur->field_poc[0]==INT_MAX || cur->field_poc[1]==INT_MAX) {
/* Wait for second field. */
Modified: trunk/libavcodec/h264.h
==============================================================================
--- trunk/libavcodec/h264.h Wed Feb 18 01:33:33 2009 (r17411)
+++ trunk/libavcodec/h264.h Wed Feb 18 01:36:07 2009 (r17412)
@@ -502,6 +502,11 @@ typedef struct H264Context{
SEI_PicStructType sei_pic_struct;
/**
+ * dpb_output_delay in picture timing SEI message, see H.264 C.2.2
+ */
+ int sei_dpb_output_delay;
+
+ /**
* recovery_frame_cnt from SEI message
*
* Set to -1 if no recovery point SEI message found or to number of frames
More information about the ffmpeg-cvslog
mailing list