aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-12-17 13:46:46 +0100
committerMichael Niedermayer <michaelni@gmx.at>2012-12-17 13:46:54 +0100
commit021b3497e1bccd4d6b2e54ecf89cfd43793a2489 (patch)
tree037a86c27ad153bf52887f48e80d5c83038f9117 /libavformat
parent0f450ac575b1c1b9d92f139d67f7c83552b392d0 (diff)
parent65e053271a98f7acf3ef6b412998cfcb44a8eef8 (diff)
downloadffmpeg-021b3497e1bccd4d6b2e54ecf89cfd43793a2489.tar.gz
Merge commit '65e053271a98f7acf3ef6b412998cfcb44a8eef8'
* commit '65e053271a98f7acf3ef6b412998cfcb44a8eef8': rtpenc_vp8: Include the picture number in VP8 packets Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat')
-rw-r--r--libavformat/rtpenc.h2
-rw-r--r--libavformat/rtpenc_vp8.c20
2 files changed, 15 insertions, 7 deletions
diff --git a/libavformat/rtpenc.h b/libavformat/rtpenc.h
index c3607c15a4..04b8fc7305 100644
--- a/libavformat/rtpenc.h
+++ b/libavformat/rtpenc.h
@@ -59,6 +59,8 @@ struct RTPMuxContext {
int nal_length_size;
int flags;
+
+ unsigned int frame_count;
};
typedef struct RTPMuxContext RTPMuxContext;
diff --git a/libavformat/rtpenc_vp8.c b/libavformat/rtpenc_vp8.c
index d16e6764c9..671d245758 100644
--- a/libavformat/rtpenc_vp8.c
+++ b/libavformat/rtpenc_vp8.c
@@ -26,24 +26,30 @@
void ff_rtp_send_vp8(AVFormatContext *s1, const uint8_t *buf, int size)
{
RTPMuxContext *s = s1->priv_data;
- int len, max_packet_size;
+ int len, max_packet_size, header_size;
s->buf_ptr = s->buf;
s->timestamp = s->cur_timestamp;
- max_packet_size = s->max_payload_size - 1; // minus one for header byte
- // no extended control bits, reference frame, start of partition,
+ // extended control bit set, reference frame, start of partition,
// partition id 0
- *s->buf_ptr++ = 0x10;
+ *s->buf_ptr++ = 0x90;
+ *s->buf_ptr++ = 0x80; // Picture id present
+ *s->buf_ptr++ = s->frame_count++ & 0x7f;
+ // Calculate the number of remaining bytes
+ header_size = s->buf_ptr - s->buf;
+ max_packet_size = s->max_payload_size - header_size;
+
while (size > 0) {
len = FFMIN(size, max_packet_size);
memcpy(s->buf_ptr, buf, len);
- ff_rtp_send_data(s1, s->buf, len+1, size == len); // marker bit is last packet in frame
+ // marker bit is last packet in frame
+ ff_rtp_send_data(s1, s->buf, len + header_size, size == len);
size -= len;
buf += len;
- s->buf_ptr = s->buf;
- *s->buf_ptr++ = 0; // payload descriptor
+ // Clear the partition start bit, keep the rest of the header untouched
+ s->buf[0] &= ~0x10;
}
}