mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
Fix decoding of mpegts streams with h264 video that does *NOT* have b frames
One of the causes of this bug is that the h264 parser defaults low_delay to 1, but the h264 codec defaults low_delay to 0. Really Ugly. After many hours of looking at this, I'm still not sure how has_b_frames is *intended* to behave, but to me the implementation appears way more complicated than it ought to be. My patch relies on the encoder to set an optional field in the SPS. This works for libx264 streams, but I'm not sure that all h264 encoders will set it. Signed-off-by: Anton Khirnov <anton@khirnov.net>
This commit is contained in:
parent
7c44d716e7
commit
aa15e68721
@ -3768,7 +3768,8 @@ static int decode_nal_units(H264Context *h, const uint8_t *buf, int buf_size){
|
|||||||
init_get_bits(&s->gb, ptr, bit_length);
|
init_get_bits(&s->gb, ptr, bit_length);
|
||||||
ff_h264_decode_seq_parameter_set(h);
|
ff_h264_decode_seq_parameter_set(h);
|
||||||
|
|
||||||
if(s->flags& CODEC_FLAG_LOW_DELAY)
|
if (s->flags& CODEC_FLAG_LOW_DELAY ||
|
||||||
|
(h->sps.bitstream_restriction_flag && !h->sps.num_reorder_frames))
|
||||||
s->low_delay=1;
|
s->low_delay=1;
|
||||||
|
|
||||||
if(avctx->has_b_frames < 2)
|
if(avctx->has_b_frames < 2)
|
||||||
|
Loading…
Reference in New Issue
Block a user