aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2013-10-27 01:03:19 +0200
committerCarl Eugen Hoyos <cehoyos@ag.or.at>2013-10-27 19:43:26 +0100
commit93d720b040bf62afac6e63277eedb58b949d1209 (patch)
treebc0b9682c5c64b2f9bd3e89a841f9cde36be1f3a
parent720e2d4143b52aed731b8d8cd1350bf57d9bfcf3 (diff)
downloadffmpeg-93d720b040bf62afac6e63277eedb58b949d1209.tar.gz
avformat/utils: do not override pts in h264 when they are provided from the demuxer
Fixes Ticket2143 Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit 1e5271a9fd6ddcceb083f2185a4bbd8d44c9a813)
-rw-r--r--libavformat/utils.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/libavformat/utils.c b/libavformat/utils.c
index 4e6e21586d..a0bb89d8d6 100644
--- a/libavformat/utils.c
+++ b/libavformat/utils.c
@@ -1165,12 +1165,14 @@ static void compute_pkt_fields(AVFormatContext *s, AVStream *st,
if (pkt->dts != AV_NOPTS_VALUE) {
// got DTS from the stream, update reference timestamp
st->reference_dts = pkt->dts - pc->dts_ref_dts_delta * num / den;
- pkt->pts = pkt->dts + pc->pts_dts_delta * num / den;
} else if (st->reference_dts != AV_NOPTS_VALUE) {
// compute DTS based on reference timestamp
pkt->dts = st->reference_dts + pc->dts_ref_dts_delta * num / den;
- pkt->pts = pkt->dts + pc->pts_dts_delta * num / den;
}
+
+ if (st->reference_dts != AV_NOPTS_VALUE && pkt->pts == AV_NOPTS_VALUE)
+ pkt->pts = pkt->dts + pc->pts_dts_delta * num / den;
+
if (pc->dts_sync_point > 0)
st->reference_dts = pkt->dts; // new reference
}