diff options
author | John Stebbins <[email protected]> | 2015-11-12 09:31:19 -0800 |
---|---|---|
committer | John Stebbins <[email protected]> | 2015-11-12 09:33:49 -0800 |
commit | 88ce808b3083415950be070fa7bdc90d49a67eea (patch) | |
tree | 77343d055f8056d9e02e094b6c840c31cbbfb0fa /libhb | |
parent | 6b713adaa58a127a65a5e69a6507d894a4760884 (diff) |
bd: fix discontinuity handling
Tag only one buffer with discontinuity flag, not multiple.
Flush pre-discontinuity buffers before signaling the discontinuity, not
after.
Make sure discontinuity flag is on the buffer with the PCR change
when possible.
Diffstat (limited to 'libhb')
-rw-r--r-- | libhb/bd.c | 3 | ||||
-rw-r--r-- | libhb/stream.c | 31 |
2 files changed, 19 insertions, 15 deletions
diff --git a/libhb/bd.c b/libhb/bd.c index 7da108c50..f34eaa1d9 100644 --- a/libhb/bd.c +++ b/libhb/bd.c @@ -702,9 +702,9 @@ hb_buffer_t * hb_bd_read( hb_bd_t * d ) uint8_t discontinuity; int new_chap = 0; - discontinuity = 0; while ( 1 ) { + discontinuity = 0; if ( d->next_chap != d->chapter ) { new_chap = d->chapter = d->next_chap; @@ -757,6 +757,7 @@ hb_buffer_t * hb_bd_read( hb_bd_t * d ) out = hb_ts_decode_pkt( d->stream, buf+4, new_chap, discontinuity ); if (out != NULL) return out; + new_chap = 0; } return NULL; } diff --git a/libhb/stream.c b/libhb/stream.c index caa998a07..57fd74f94 100644 --- a/libhb/stream.c +++ b/libhb/stream.c @@ -448,8 +448,11 @@ static void ts_err( hb_stream_t *stream, int curstream, char *log, ... ) ts_warn_helper( stream, log, args ); va_end( args ); - stream->ts.list[curstream].skipbad = 1; - stream->ts.list[curstream].continuity = -1; + if (curstream >= 0) + { + stream->ts.list[curstream].skipbad = 1; + stream->ts.list[curstream].continuity = -1; + } } static int check_ps_sync(const uint8_t *buf) @@ -4545,8 +4548,6 @@ static hb_buffer_t * generate_output_data(hb_stream_t *stream, int curstream) buf->s.id = get_id(pes_stream); buf->s.type = stream_kind_to_buf_type(pes_stream->stream_kind); - buf->s.discontinuity = stream->ts.discontinuity; - stream->ts.discontinuity = 0; buf->s.new_chap = b->s.new_chap; b->s.new_chap = 0; @@ -4554,6 +4555,8 @@ static hb_buffer_t * generate_output_data(hb_stream_t *stream, int curstream) // only put timestamps on the first output buffer for this PES packet. if (ts_stream->packet_offset > 0) { + buf->s.discontinuity = stream->ts.discontinuity; + stream->ts.discontinuity = 0; buf->s.pcr = stream->ts.pcr; stream->ts.pcr = AV_NOPTS_VALUE; buf->s.start = ts_stream->pes_info.pts; @@ -4640,6 +4643,10 @@ hb_buffer_t * hb_ts_decode_pkt( hb_stream_t *stream, const uint8_t * pkt, } if (discontinuity) { + // If there is a discontinuity, flush all data + buf = flush_ts_streams(stream); + hb_buffer_list_append(&list, buf); + stream->ts.discontinuity = 1; } @@ -4649,15 +4656,17 @@ hb_buffer_t * hb_ts_decode_pkt( hb_stream_t *stream, const uint8_t * pkt, int pid = ((pkt[1] & 0x1F) << 8) | pkt[2]; if ( ( curstream = index_of_pid( stream, pid ) ) < 0 ) { - return NULL; + // Not a stream we care about + return hb_buffer_list_clear(&list); } + // Get error int errorbit = (pkt[1] & 0x80) != 0; if (errorbit) { ts_err( stream, curstream, "packet error bit set"); - return NULL; + return hb_buffer_list_clear(&list); } // Get adaption header info @@ -4666,7 +4675,7 @@ hb_buffer_t * hb_ts_decode_pkt( hb_stream_t *stream, const uint8_t * pkt, if (adaption == 0) { ts_err( stream, curstream, "adaptation code 0"); - return NULL; + return hb_buffer_list_clear(&list); } else if (adaption == 0x2) adapt_len = 184; @@ -4676,16 +4685,10 @@ hb_buffer_t * hb_ts_decode_pkt( hb_stream_t *stream, const uint8_t * pkt, if (adapt_len > 184) { ts_err( stream, curstream, "invalid adapt len %d", adapt_len); - return NULL; + return hb_buffer_list_clear(&list); } } - if (discontinuity) - { - // If there is a discontinuity, flush all data - buf = flush_ts_streams(stream); - hb_buffer_list_append(&list, buf); - } if (adapt_len > 0) { if (pkt[5] & 0x40) |