[SCM] libav/experimental: Fix computation of the "NTP time" field in RTCP SR packets, and do not export times with microsecond precision
siretart at users.alioth.debian.org
siretart at users.alioth.debian.org
Sun Jun 30 16:15:17 UTC 2013
The following commit has been merged in the experimental branch:
commit d597e1b76cbde5d8ae04dfa4207f5813b3dbf8af
Author: Luca Abeni <lucabe72 at email.it>
Date: Wed Feb 20 10:19:35 2008 +0000
Fix computation of the "NTP time" field in RTCP SR packets, and do not
export times with microsecond precision
Originally committed as revision 12158 to svn://svn.ffmpeg.org/ffmpeg/trunk
diff --git a/libavformat/rtpenc.c b/libavformat/rtpenc.c
index 9e62c65..19e4f19 100644
--- a/libavformat/rtpenc.c
+++ b/libavformat/rtpenc.c
@@ -33,6 +33,13 @@
//#define DEBUG
#define RTCP_SR_SIZE 28
+#define NTP_OFFSET 2208988800ULL
+#define NTP_OFFSET_US (NTP_OFFSET * 1000000ULL)
+
+static uint64_t ntp_time(void)
+{
+ return (av_gettime() / 1000) * 1000 + NTP_OFFSET_US;
+}
static int rtp_write_header(AVFormatContext *s1)
{
@@ -301,8 +308,8 @@ static int rtp_write_packet(AVFormatContext *s1, AVPacket *pkt)
rtcp_bytes = ((s->octet_count - s->last_octet_count) * RTCP_TX_RATIO_NUM) /
RTCP_TX_RATIO_DEN;
if (s->first_packet || ((rtcp_bytes >= RTCP_SR_SIZE) &&
- (av_gettime() - s->last_rtcp_ntp_time > 5000000))) {
- rtcp_send_sr(s1, av_gettime());
+ (ntp_time() - s->last_rtcp_ntp_time > 5000000))) {
+ rtcp_send_sr(s1, ntp_time());
s->last_octet_count = s->octet_count;
s->first_packet = 0;
}
--
Libav/FFmpeg packaging
More information about the pkg-multimedia-commits
mailing list