[FFmpeg-cvslog] avformat/apngdec: set pts to AV_NOPTS_VALUE
Marton Balint
git at videolan.org
Mon Jul 2 14:43:45 EEST 2018
ffmpeg | branch: master | Marton Balint <cus at passwd.hu> | Thu Jun 28 21:07:30 2018 +0200| [06a8d7ff00f5c3d13d331a56db839fb825ea6697] | committer: Marton Balint
avformat/apngdec: set pts to AV_NOPTS_VALUE
And let the generic code figure out the proper PTS. This is needed because apng
does not provide seek functions, but after a generic seek (e.g. to file start)
timestamps are not reset which causes broken timestamps when looping apngs,
like in ticket #6121.
Signed-off-by: Marton Balint <cus at passwd.hu>
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=06a8d7ff00f5c3d13d331a56db839fb825ea6697
---
libavformat/apngdec.c | 4 +---
1 file changed, 1 insertion(+), 3 deletions(-)
diff --git a/libavformat/apngdec.c b/libavformat/apngdec.c
index ffff03710a..f9a97e5681 100644
--- a/libavformat/apngdec.c
+++ b/libavformat/apngdec.c
@@ -44,7 +44,6 @@ typedef struct APNGDemuxContext {
int max_fps;
int default_fps;
- int64_t pkt_pts;
int pkt_duration;
int is_key_frame;
@@ -390,9 +389,8 @@ static int apng_read_packet(AVFormatContext *s, AVPacket *pkt)
if (ctx->is_key_frame)
pkt->flags |= AV_PKT_FLAG_KEY;
- pkt->pts = ctx->pkt_pts;
+ pkt->pts = pkt->dts = AV_NOPTS_VALUE;
pkt->duration = ctx->pkt_duration;
- ctx->pkt_pts += ctx->pkt_duration;
return ret;
case MKTAG('I', 'E', 'N', 'D'):
ctx->cur_loop++;
More information about the ffmpeg-cvslog
mailing list