Mercurial > libavformat.hg
annotate rtpenc.c @ 6205:1327f1008940 libavformat
Allow remuxing of explicitly signalled AAC files into ADTS.
The ADTS output files are not explicitly signaled because the format
does not support explicit signalling.
author | alexc |
---|---|
date | Thu, 01 Jul 2010 14:49:32 +0000 |
parents | 397ef451b549 |
children | 956f2e2cd288 |
rev | line source |
---|---|
0 | 1 /* |
2892
0d82fdf4fa94
Split the RTP muxer out of rtp.c, to simplify the RTSP demuxer's dependencies
lucabe
parents:
2891
diff
changeset
|
2 * RTP output format |
4251
77e0c7511d41
cosmetics: Remove pointless period after copyright statement non-sentences.
diego
parents:
3579
diff
changeset
|
3 * Copyright (c) 2002 Fabrice Bellard |
0 | 4 * |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
5 * This file is part of FFmpeg. |
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
6 * |
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
7 * FFmpeg is free software; you can redistribute it and/or |
0 | 8 * modify it under the terms of the GNU Lesser General Public |
9 * License as published by the Free Software Foundation; either | |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
10 * version 2.1 of the License, or (at your option) any later version. |
0 | 11 * |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
12 * FFmpeg is distributed in the hope that it will be useful, |
0 | 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
15 * Lesser General Public License for more details. | |
16 * | |
17 * You should have received a copy of the GNU Lesser General Public | |
1358
0899bfe4105c
Change license headers to say 'FFmpeg' instead of 'this program/this library'
diego
parents:
1332
diff
changeset
|
18 * License along with FFmpeg; if not, write to the Free Software |
896
edbe5c3717f9
Update licensing information: The FSF changed postal address.
diego
parents:
885
diff
changeset
|
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
0 | 20 */ |
3286 | 21 |
0 | 22 #include "avformat.h" |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
23 #include "mpegts.h" |
5807
f4ca0041b4f4
Make the ntp_time function available to other parts of libavformat, as ff_ntp_time
mstorsjo
parents:
5646
diff
changeset
|
24 #include "internal.h" |
5901
7028f9476da4
Initialize ssrc and base_timestamp using ff_random_get_seed()
mstorsjo
parents:
5842
diff
changeset
|
25 #include "libavutil/random_seed.h" |
0 | 26 |
27 #include <unistd.h> | |
28 | |
4388 | 29 #include "rtpenc.h" |
1419 | 30 |
0 | 31 //#define DEBUG |
32 | |
2705
cc693f9e80ee
Use a symbolic name for the payload size of an RTCP Sender Report packet
lucabe
parents:
2587
diff
changeset
|
33 #define RTCP_SR_SIZE 28 |
0 | 34 |
4796
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
35 static int is_supported(enum CodecID id) |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
36 { |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
37 switch(id) { |
4814 | 38 case CODEC_ID_H263: |
39 case CODEC_ID_H263P: | |
4796
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
40 case CODEC_ID_H264: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
41 case CODEC_ID_MPEG1VIDEO: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
42 case CODEC_ID_MPEG2VIDEO: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
43 case CODEC_ID_MPEG4: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
44 case CODEC_ID_AAC: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
45 case CODEC_ID_MP2: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
46 case CODEC_ID_MP3: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
47 case CODEC_ID_PCM_ALAW: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
48 case CODEC_ID_PCM_MULAW: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
49 case CODEC_ID_PCM_S8: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
50 case CODEC_ID_PCM_S16BE: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
51 case CODEC_ID_PCM_S16LE: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
52 case CODEC_ID_PCM_U16BE: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
53 case CODEC_ID_PCM_U16LE: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
54 case CODEC_ID_PCM_U8: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
55 case CODEC_ID_MPEG2TS: |
4836 | 56 case CODEC_ID_AMR_NB: |
57 case CODEC_ID_AMR_WB: | |
4796
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
58 return 1; |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
59 default: |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
60 return 0; |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
61 } |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
62 } |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
63 |
0 | 64 static int rtp_write_header(AVFormatContext *s1) |
65 { | |
4388 | 66 RTPMuxContext *s = s1->priv_data; |
5477 | 67 int max_packet_size, n; |
0 | 68 AVStream *st; |
69 | |
70 if (s1->nb_streams != 1) | |
71 return -1; | |
72 st = s1->streams[0]; | |
4796
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
73 if (!is_supported(st->codec->codec_id)) { |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
74 av_log(s1, AV_LOG_ERROR, "Unsupported codec %x\n", st->codec->codec_id); |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
75 |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
76 return -1; |
f48c56ac46c2
Make rtp_write_header() fail in case of unsupported payload type
lucabe
parents:
4502
diff
changeset
|
77 } |
0 | 78 |
5477 | 79 s->payload_type = ff_rtp_get_payload_type(st->codec); |
80 if (s->payload_type < 0) | |
5910
536e5527c1e0
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
5901
diff
changeset
|
81 s->payload_type = RTP_PT_PRIVATE + (st->codec->codec_type == AVMEDIA_TYPE_AUDIO); |
0 | 82 |
6036
201152a121b5
Make ff_random_get_seed public, rename to av_get_random_seed, export the header
mstorsjo
parents:
5910
diff
changeset
|
83 s->base_timestamp = av_get_random_seed(); |
0 | 84 s->timestamp = s->base_timestamp; |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
85 s->cur_timestamp = 0; |
6036
201152a121b5
Make ff_random_get_seed public, rename to av_get_random_seed, export the header
mstorsjo
parents:
5910
diff
changeset
|
86 s->ssrc = av_get_random_seed(); |
0 | 87 s->first_packet = 1; |
5807
f4ca0041b4f4
Make the ntp_time function available to other parts of libavformat, as ff_ntp_time
mstorsjo
parents:
5646
diff
changeset
|
88 s->first_rtcp_ntp_time = ff_ntp_time(); |
5842
cc35562d3747
Use AVFormatContext.start_time_realtime in the RTP muxer
mstorsjo
parents:
5807
diff
changeset
|
89 if (s1->start_time_realtime) |
cc35562d3747
Use AVFormatContext.start_time_realtime in the RTP muxer
mstorsjo
parents:
5807
diff
changeset
|
90 /* Round the NTP time to whole milliseconds. */ |
cc35562d3747
Use AVFormatContext.start_time_realtime in the RTP muxer
mstorsjo
parents:
5807
diff
changeset
|
91 s->first_rtcp_ntp_time = (s1->start_time_realtime / 1000) * 1000 + |
cc35562d3747
Use AVFormatContext.start_time_realtime in the RTP muxer
mstorsjo
parents:
5807
diff
changeset
|
92 NTP_OFFSET_US; |
0 | 93 |
2771
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
94 max_packet_size = url_fget_max_packet_size(s1->pb); |
0 | 95 if (max_packet_size <= 12) |
2274
b21c2af60bc9
Replace all occurrences of AVERROR_IO with AVERROR(EIO).
takis
parents:
2222
diff
changeset
|
96 return AVERROR(EIO); |
4391 | 97 s->buf = av_malloc(max_packet_size); |
98 if (s->buf == NULL) { | |
99 return AVERROR(ENOMEM); | |
100 } | |
0 | 101 s->max_payload_size = max_packet_size - 12; |
102 | |
2587
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
103 s->max_frames_per_packet = 0; |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
104 if (s1->max_delay) { |
5910
536e5527c1e0
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
5901
diff
changeset
|
105 if (st->codec->codec_type == AVMEDIA_TYPE_AUDIO) { |
2587
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
106 if (st->codec->frame_size == 0) { |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
107 av_log(s1, AV_LOG_ERROR, "Cannot respect max delay: frame size = 0\n"); |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
108 } else { |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
109 s->max_frames_per_packet = av_rescale_rnd(s1->max_delay, st->codec->sample_rate, AV_TIME_BASE * st->codec->frame_size, AV_ROUND_DOWN); |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
110 } |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
111 } |
5910
536e5527c1e0
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
5901
diff
changeset
|
112 if (st->codec->codec_type == AVMEDIA_TYPE_VIDEO) { |
2587
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
113 /* FIXME: We should round down here... */ |
3500 | 114 s->max_frames_per_packet = av_rescale_q(s1->max_delay, (AVRational){1, 1000000}, st->codec->time_base); |
2587
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
115 } |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
116 } |
d751acab2622
Allow to set the maximum number of frames per RTP packet (and add support for
lucabe
parents:
2569
diff
changeset
|
117 |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
118 av_set_pts_info(st, 32, 1, 90000); |
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
777
diff
changeset
|
119 switch(st->codec->codec_id) { |
0 | 120 case CODEC_ID_MP2: |
232 | 121 case CODEC_ID_MP3: |
0 | 122 s->buf_ptr = s->buf + 4; |
123 break; | |
124 case CODEC_ID_MPEG1VIDEO: | |
2760 | 125 case CODEC_ID_MPEG2VIDEO: |
0 | 126 break; |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
127 case CODEC_ID_MPEG2TS: |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
128 n = s->max_payload_size / TS_PACKET_SIZE; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
129 if (n < 1) |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
130 n = 1; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
131 s->max_payload_size = n * TS_PACKET_SIZE; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
132 s->buf_ptr = s->buf; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
133 break; |
6136
6c0e0ad77315
If the video stream is H.264 with MP4 syntax, store the NAL lenght size in
lucabe
parents:
6036
diff
changeset
|
134 case CODEC_ID_H264: |
6c0e0ad77315
If the video stream is H.264 with MP4 syntax, store the NAL lenght size in
lucabe
parents:
6036
diff
changeset
|
135 /* check for H.264 MP4 syntax */ |
6139
397ef451b549
Simplify (no need to check for st->codec->extradata) and correct
lucabe
parents:
6136
diff
changeset
|
136 if (st->codec->extradata_size > 4 && st->codec->extradata[0] == 1) { |
6136
6c0e0ad77315
If the video stream is H.264 with MP4 syntax, store the NAL lenght size in
lucabe
parents:
6036
diff
changeset
|
137 s->nal_length_size = (st->codec->extradata[4] & 0x03) + 1; |
6c0e0ad77315
If the video stream is H.264 with MP4 syntax, store the NAL lenght size in
lucabe
parents:
6036
diff
changeset
|
138 } |
6c0e0ad77315
If the video stream is H.264 with MP4 syntax, store the NAL lenght size in
lucabe
parents:
6036
diff
changeset
|
139 break; |
4836 | 140 case CODEC_ID_AMR_NB: |
141 case CODEC_ID_AMR_WB: | |
142 if (!s->max_frames_per_packet) | |
143 s->max_frames_per_packet = 12; | |
144 if (st->codec->codec_id == CODEC_ID_AMR_NB) | |
145 n = 31; | |
146 else | |
147 n = 61; | |
148 /* max_header_toc_size + the largest AMR payload must fit */ | |
149 if (1 + s->max_frames_per_packet + n > s->max_payload_size) { | |
150 av_log(s1, AV_LOG_ERROR, "RTP max payload size too small for AMR\n"); | |
151 return -1; | |
152 } | |
153 if (st->codec->channels != 1) { | |
154 av_log(s1, AV_LOG_ERROR, "Only mono is supported\n"); | |
155 return -1; | |
156 } | |
2550
e9c34ec665c6
Support for AAC streaming over RTP. Fragmentation is not implemented yet
lucabe
parents:
2540
diff
changeset
|
157 case CODEC_ID_AAC: |
4380
1b695f013cd3
Introduce a new num_frames field in RTPDemuxContext so that rtp_aac.c
lucabe
parents:
4291
diff
changeset
|
158 s->num_frames = 0; |
0 | 159 default: |
5910
536e5527c1e0
Define AVMediaType enum, and use it instead of enum CodecType, which
stefano
parents:
5901
diff
changeset
|
160 if (st->codec->codec_type == AVMEDIA_TYPE_AUDIO) { |
2539
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
161 av_set_pts_info(st, 32, 1, st->codec->sample_rate); |
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
162 } |
0 | 163 s->buf_ptr = s->buf; |
164 break; | |
165 } | |
166 | |
167 return 0; | |
168 } | |
169 | |
170 /* send an rtcp sender report packet */ | |
65 | 171 static void rtcp_send_sr(AVFormatContext *s1, int64_t ntp_time) |
0 | 172 { |
4388 | 173 RTPMuxContext *s = s1->priv_data; |
2539
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
174 uint32_t rtp_ts; |
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
175 |
3579 | 176 dprintf(s1, "RTCP: %02x %"PRIx64" %x\n", s->payload_type, ntp_time, s->timestamp); |
2539
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
177 |
2706
b1723b8da595
Do not send too many RTCP packets (according to RFC 3550, the minimum
lucabe
parents:
2705
diff
changeset
|
178 s->last_rtcp_ntp_time = ntp_time; |
3500 | 179 rtp_ts = av_rescale_q(ntp_time - s->first_rtcp_ntp_time, (AVRational){1, 1000000}, |
2539
ba933dfa4833
Properly set RTP and NTP timestamps in RTCP SR packets
lucabe
parents:
2406
diff
changeset
|
180 s1->streams[0]->time_base) + s->base_timestamp; |
2771
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
181 put_byte(s1->pb, (RTP_VERSION << 6)); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
182 put_byte(s1->pb, 200); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
183 put_be16(s1->pb, 6); /* length in words - 1 */ |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
184 put_be32(s1->pb, s->ssrc); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
185 put_be32(s1->pb, ntp_time / 1000000); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
186 put_be32(s1->pb, ((ntp_time % 1000000) << 32) / 1000000); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
187 put_be32(s1->pb, rtp_ts); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
188 put_be32(s1->pb, s->packet_count); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
189 put_be32(s1->pb, s->octet_count); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
190 put_flush_packet(s1->pb); |
0 | 191 } |
192 | |
193 /* send an rtp packet. sequence number is incremented, but the caller | |
194 must update the timestamp itself */ | |
2406
18e94e5989d8
Move the RTP packetization code for MPEG12 video in its own file (rtp_mpv.c)
lucabe
parents:
2274
diff
changeset
|
195 void ff_rtp_send_data(AVFormatContext *s1, const uint8_t *buf1, int len, int m) |
0 | 196 { |
4388 | 197 RTPMuxContext *s = s1->priv_data; |
0 | 198 |
3579 | 199 dprintf(s1, "rtp_send_data size=%d\n", len); |
0 | 200 |
201 /* build the RTP header */ | |
2771
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
202 put_byte(s1->pb, (RTP_VERSION << 6)); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
203 put_byte(s1->pb, (s->payload_type & 0x7f) | ((m & 0x01) << 7)); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
204 put_be16(s1->pb, s->seq); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
205 put_be32(s1->pb, s->timestamp); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
206 put_be32(s1->pb, s->ssrc); |
885 | 207 |
2771
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
208 put_buffer(s1->pb, buf1, len); |
d52c718e83f9
Use dynamically allocated ByteIOContext in AVFormatContext
andoma
parents:
2760
diff
changeset
|
209 put_flush_packet(s1->pb); |
885 | 210 |
0 | 211 s->seq++; |
212 s->octet_count += len; | |
213 s->packet_count++; | |
214 } | |
215 | |
216 /* send an integer number of samples and compute time stamp and fill | |
217 the rtp send buffer before sending. */ | |
218 static void rtp_send_samples(AVFormatContext *s1, | |
241 | 219 const uint8_t *buf1, int size, int sample_size) |
0 | 220 { |
4388 | 221 RTPMuxContext *s = s1->priv_data; |
0 | 222 int len, max_packet_size, n; |
223 | |
224 max_packet_size = (s->max_payload_size / sample_size) * sample_size; | |
225 /* not needed, but who nows */ | |
226 if ((size % sample_size) != 0) | |
227 av_abort(); | |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
228 n = 0; |
0 | 229 while (size > 0) { |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
230 s->buf_ptr = s->buf; |
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
231 len = FFMIN(max_packet_size, size); |
0 | 232 |
233 /* copy data */ | |
234 memcpy(s->buf_ptr, buf1, len); | |
235 s->buf_ptr += len; | |
236 buf1 += len; | |
237 size -= len; | |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
238 s->timestamp = s->cur_timestamp + n / sample_size; |
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
239 ff_rtp_send_data(s1, s->buf, s->buf_ptr - s->buf, 0); |
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
240 n += (s->buf_ptr - s->buf); |
0 | 241 } |
885 | 242 } |
0 | 243 |
244 static void rtp_send_mpegaudio(AVFormatContext *s1, | |
241 | 245 const uint8_t *buf1, int size) |
0 | 246 { |
4388 | 247 RTPMuxContext *s = s1->priv_data; |
0 | 248 int len, count, max_packet_size; |
249 | |
250 max_packet_size = s->max_payload_size; | |
251 | |
252 /* test if we must flush because not enough space */ | |
253 len = (s->buf_ptr - s->buf); | |
254 if ((len + size) > max_packet_size) { | |
255 if (len > 4) { | |
2406
18e94e5989d8
Move the RTP packetization code for MPEG12 video in its own file (rtp_mpv.c)
lucabe
parents:
2274
diff
changeset
|
256 ff_rtp_send_data(s1, s->buf, s->buf_ptr - s->buf, 0); |
0 | 257 s->buf_ptr = s->buf + 4; |
258 } | |
259 } | |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
260 if (s->buf_ptr == s->buf + 4) { |
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
261 s->timestamp = s->cur_timestamp; |
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
262 } |
0 | 263 |
264 /* add the packet */ | |
265 if (size > max_packet_size) { | |
266 /* big packet: fragment */ | |
267 count = 0; | |
268 while (size > 0) { | |
269 len = max_packet_size - 4; | |
270 if (len > size) | |
271 len = size; | |
272 /* build fragmented packet */ | |
273 s->buf[0] = 0; | |
274 s->buf[1] = 0; | |
275 s->buf[2] = count >> 8; | |
276 s->buf[3] = count; | |
277 memcpy(s->buf + 4, buf1, len); | |
2406
18e94e5989d8
Move the RTP packetization code for MPEG12 video in its own file (rtp_mpv.c)
lucabe
parents:
2274
diff
changeset
|
278 ff_rtp_send_data(s1, s->buf, len + 4, 0); |
0 | 279 size -= len; |
280 buf1 += len; | |
281 count += len; | |
282 } | |
283 } else { | |
284 if (s->buf_ptr == s->buf + 4) { | |
285 /* no fragmentation possible */ | |
286 s->buf[0] = 0; | |
287 s->buf[1] = 0; | |
288 s->buf[2] = 0; | |
289 s->buf[3] = 0; | |
290 } | |
291 memcpy(s->buf_ptr, buf1, size); | |
292 s->buf_ptr += size; | |
293 } | |
294 } | |
295 | |
296 static void rtp_send_raw(AVFormatContext *s1, | |
241 | 297 const uint8_t *buf1, int size) |
0 | 298 { |
4388 | 299 RTPMuxContext *s = s1->priv_data; |
0 | 300 int len, max_packet_size; |
301 | |
302 max_packet_size = s->max_payload_size; | |
303 | |
304 while (size > 0) { | |
305 len = max_packet_size; | |
306 if (len > size) | |
307 len = size; | |
308 | |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
309 s->timestamp = s->cur_timestamp; |
2406
18e94e5989d8
Move the RTP packetization code for MPEG12 video in its own file (rtp_mpv.c)
lucabe
parents:
2274
diff
changeset
|
310 ff_rtp_send_data(s1, buf1, len, (len == size)); |
0 | 311 |
312 buf1 += len; | |
313 size -= len; | |
314 } | |
315 } | |
316 | |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
317 /* NOTE: size is assumed to be an integer multiple of TS_PACKET_SIZE */ |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
318 static void rtp_send_mpegts_raw(AVFormatContext *s1, |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
319 const uint8_t *buf1, int size) |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
320 { |
4388 | 321 RTPMuxContext *s = s1->priv_data; |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
322 int len, out_len; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
323 |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
324 while (size >= TS_PACKET_SIZE) { |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
325 len = s->max_payload_size - (s->buf_ptr - s->buf); |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
326 if (len > size) |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
327 len = size; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
328 memcpy(s->buf_ptr, buf1, len); |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
329 buf1 += len; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
330 size -= len; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
331 s->buf_ptr += len; |
885 | 332 |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
333 out_len = s->buf_ptr - s->buf; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
334 if (out_len >= s->max_payload_size) { |
2406
18e94e5989d8
Move the RTP packetization code for MPEG12 video in its own file (rtp_mpv.c)
lucabe
parents:
2274
diff
changeset
|
335 ff_rtp_send_data(s1, s->buf, out_len, 0); |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
336 s->buf_ptr = s->buf; |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
337 } |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
338 } |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
339 } |
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
340 |
468 | 341 static int rtp_write_packet(AVFormatContext *s1, AVPacket *pkt) |
0 | 342 { |
4388 | 343 RTPMuxContext *s = s1->priv_data; |
0 | 344 AVStream *st = s1->streams[0]; |
345 int rtcp_bytes; | |
468 | 346 int size= pkt->size; |
885 | 347 |
3579 | 348 dprintf(s1, "%d: write len=%d\n", pkt->stream_index, size); |
0 | 349 |
885 | 350 rtcp_bytes = ((s->octet_count - s->last_octet_count) * RTCP_TX_RATIO_NUM) / |
0 | 351 RTCP_TX_RATIO_DEN; |
2706
b1723b8da595
Do not send too many RTCP packets (according to RFC 3550, the minimum
lucabe
parents:
2705
diff
changeset
|
352 if (s->first_packet || ((rtcp_bytes >= RTCP_SR_SIZE) && |
5807
f4ca0041b4f4
Make the ntp_time function available to other parts of libavformat, as ff_ntp_time
mstorsjo
parents:
5646
diff
changeset
|
353 (ff_ntp_time() - s->last_rtcp_ntp_time > 5000000))) { |
f4ca0041b4f4
Make the ntp_time function available to other parts of libavformat, as ff_ntp_time
mstorsjo
parents:
5646
diff
changeset
|
354 rtcp_send_sr(s1, ff_ntp_time()); |
0 | 355 s->last_octet_count = s->octet_count; |
356 s->first_packet = 0; | |
357 } | |
2540
ca3cba9c641f
Fix timestamps in RTP packets (now, MPEG1 video with B frames works correctly)
lucabe
parents:
2539
diff
changeset
|
358 s->cur_timestamp = s->base_timestamp + pkt->pts; |
0 | 359 |
820
feca73904e67
changing AVCodecContext codec -> *codec in AVStream so additions to AVCodecContext dont randomize AVStream and break binary compatibility
michael
parents:
777
diff
changeset
|
360 switch(st->codec->codec_id) { |
0 | 361 case CODEC_ID_PCM_MULAW: |
362 case CODEC_ID_PCM_ALAW: | |
363 case CODEC_ID_PCM_U8: | |
364 case CODEC_ID_PCM_S8: | |
5479 | 365 rtp_send_samples(s1, pkt->data, size, 1 * st->codec->channels); |
0 | 366 break; |
367 case CODEC_ID_PCM_U16BE: | |
368 case CODEC_ID_PCM_U16LE: | |
369 case CODEC_ID_PCM_S16BE: | |
370 case CODEC_ID_PCM_S16LE: | |
5479 | 371 rtp_send_samples(s1, pkt->data, size, 2 * st->codec->channels); |
0 | 372 break; |
373 case CODEC_ID_MP2: | |
232 | 374 case CODEC_ID_MP3: |
5479 | 375 rtp_send_mpegaudio(s1, pkt->data, size); |
0 | 376 break; |
377 case CODEC_ID_MPEG1VIDEO: | |
2760 | 378 case CODEC_ID_MPEG2VIDEO: |
5479 | 379 ff_rtp_send_mpegvideo(s1, pkt->data, size); |
0 | 380 break; |
2550
e9c34ec665c6
Support for AAC streaming over RTP. Fragmentation is not implemented yet
lucabe
parents:
2540
diff
changeset
|
381 case CODEC_ID_AAC: |
5479 | 382 ff_rtp_send_aac(s1, pkt->data, size); |
2550
e9c34ec665c6
Support for AAC streaming over RTP. Fragmentation is not implemented yet
lucabe
parents:
2540
diff
changeset
|
383 break; |
4836 | 384 case CODEC_ID_AMR_NB: |
385 case CODEC_ID_AMR_WB: | |
5479 | 386 ff_rtp_send_amr(s1, pkt->data, size); |
4836 | 387 break; |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
388 case CODEC_ID_MPEG2TS: |
5479 | 389 rtp_send_mpegts_raw(s1, pkt->data, size); |
294
6091b76cfc2a
added MPEG2TS support in RTP, SDP and RTSP - replaced fake RTP demux by a specific API
bellard
parents:
241
diff
changeset
|
390 break; |
2960 | 391 case CODEC_ID_H264: |
5479 | 392 ff_rtp_send_h264(s1, pkt->data, size); |
2960 | 393 break; |
4814 | 394 case CODEC_ID_H263: |
395 case CODEC_ID_H263P: | |
5479 | 396 ff_rtp_send_h263(s1, pkt->data, size); |
4814 | 397 break; |
0 | 398 default: |
399 /* better than nothing : send the codec raw data */ | |
5479 | 400 rtp_send_raw(s1, pkt->data, size); |
0 | 401 break; |
402 } | |
403 return 0; | |
404 } | |
405 | |
4391 | 406 static int rtp_write_trailer(AVFormatContext *s1) |
407 { | |
408 RTPMuxContext *s = s1->priv_data; | |
409 | |
410 av_freep(&s->buf); | |
411 | |
412 return 0; | |
413 } | |
414 | |
1167 | 415 AVOutputFormat rtp_muxer = { |
0 | 416 "rtp", |
3424
7a0230981402
Make long_names in lavf/lavdev optional depending on CONFIG_SMALL.
diego
parents:
3286
diff
changeset
|
417 NULL_IF_CONFIG_SMALL("RTP output format"), |
0 | 418 NULL, |
419 NULL, | |
4388 | 420 sizeof(RTPMuxContext), |
0 | 421 CODEC_ID_PCM_MULAW, |
422 CODEC_ID_NONE, | |
423 rtp_write_header, | |
424 rtp_write_packet, | |
4391 | 425 rtp_write_trailer, |
0 | 426 }; |