diff options
author | Luca Abeni <lucabe72@email.it> | 2007-09-03 07:14:10 +0000 |
---|---|---|
committer | Luca Abeni <lucabe72@email.it> | 2007-09-03 07:14:10 +0000 |
commit | 73130dfee29f7ea3d202d074b747eed1b688eb9b (patch) | |
tree | 549845262a17f2027f678914b9d429f36692728f /libavformat/rtp_mpv.c | |
parent | 9be51815877cd48479c110a214f283dc4eff71e8 (diff) | |
download | ffmpeg-73130dfee29f7ea3d202d074b747eed1b688eb9b.tar.gz |
Correctly set the "P" field in the payload header
Originally committed as revision 10282 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/rtp_mpv.c')
-rw-r--r-- | libavformat/rtp_mpv.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/libavformat/rtp_mpv.c b/libavformat/rtp_mpv.c index dc18d90d39..bcd239d2c4 100644 --- a/libavformat/rtp_mpv.c +++ b/libavformat/rtp_mpv.c @@ -31,11 +31,12 @@ void ff_rtp_send_mpegvideo(AVFormatContext *s1, const uint8_t *buf1, int size) AVStream *st = s1->streams[0]; int len, h, max_packet_size; uint8_t *q; - int begin_of_slice, end_of_slice; + int begin_of_slice, end_of_slice, frame_type; max_packet_size = s->max_payload_size; begin_of_slice = 1; end_of_slice = 0; + frame_type = 0; while (size > 0) { len = max_packet_size - 4; @@ -53,6 +54,10 @@ void ff_rtp_send_mpegvideo(AVFormatContext *s1, const uint8_t *buf1, int size) r = ff_find_start_code(r1, buf1 + size, &start_code); if((start_code & 0xFFFFFF00) == 0x100) { /* New start code found */ + if (start_code == 0x100) { + frame_type = (r[1] & 0x38) >> 3; + } + if (r - buf1 < len) { /* The current slice fits in the packet */ if (begin_of_slice == 0) { @@ -78,6 +83,7 @@ void ff_rtp_send_mpegvideo(AVFormatContext *s1, const uint8_t *buf1, int size) h = 0; h |= begin_of_slice << 12; h |= end_of_slice << 11; + h |= frame_type << 8; q = s->buf; *q++ = h >> 24; |