mirror of
https://gitee.com/openharmony/third_party_ffmpeg
synced 2024-11-27 21:20:41 +00:00
ffmpeg: fix wrap correction code.
The code failed with negative timestamps due to using unsigned numbers Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
parent
168ddcd331
commit
91c18beb9d
13
ffmpeg.c
13
ffmpeg.c
@ -2739,15 +2739,16 @@ static int process_input(int file_index)
|
|||||||
goto discard_packet;
|
goto discard_packet;
|
||||||
|
|
||||||
if(!ist->wrap_correction_done && input_files[file_index]->ctx->start_time != AV_NOPTS_VALUE && ist->st->pts_wrap_bits < 64){
|
if(!ist->wrap_correction_done && input_files[file_index]->ctx->start_time != AV_NOPTS_VALUE && ist->st->pts_wrap_bits < 64){
|
||||||
uint64_t stime = av_rescale_q(input_files[file_index]->ctx->start_time, AV_TIME_BASE_Q, ist->st->time_base);
|
int64_t stime = av_rescale_q(input_files[file_index]->ctx->start_time, AV_TIME_BASE_Q, ist->st->time_base);
|
||||||
uint64_t stime2= stime + (1LL<<ist->st->pts_wrap_bits);
|
int64_t stime2= stime + (1ULL<<ist->st->pts_wrap_bits);
|
||||||
ist->wrap_correction_done = 1;
|
ist->wrap_correction_done = 1;
|
||||||
if(pkt.dts != AV_NOPTS_VALUE && pkt.dts > stime && pkt.dts - stime > stime2 - pkt.dts) {
|
|
||||||
pkt.dts -= 1LL<<ist->st->pts_wrap_bits;
|
if(stime2 > stime && pkt.dts != AV_NOPTS_VALUE && pkt.dts > stime + (1LL<<(ist->st->pts_wrap_bits-1))) {
|
||||||
|
pkt.dts -= 1ULL<<ist->st->pts_wrap_bits;
|
||||||
ist->wrap_correction_done = 0;
|
ist->wrap_correction_done = 0;
|
||||||
}
|
}
|
||||||
if(pkt.pts != AV_NOPTS_VALUE && pkt.pts > stime && pkt.pts - stime > stime2 - pkt.pts) {
|
if(stime2 > stime && pkt.pts != AV_NOPTS_VALUE && pkt.pts > stime + (1LL<<(ist->st->pts_wrap_bits-1))) {
|
||||||
pkt.pts -= 1LL<<ist->st->pts_wrap_bits;
|
pkt.pts -= 1ULL<<ist->st->pts_wrap_bits;
|
||||||
ist->wrap_correction_done = 0;
|
ist->wrap_correction_done = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user