You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

659 lines
17KB

  1. /*
  2. * RTP input/output format
  3. * Copyright (c) 2002 Fabrice Bellard.
  4. *
  5. * This library is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU Lesser General Public
  7. * License as published by the Free Software Foundation; either
  8. * version 2 of the License, or (at your option) any later version.
  9. *
  10. * This library is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  13. * Lesser General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU Lesser General Public
  16. * License along with this library; if not, write to the Free Software
  17. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  18. */
  19. #include <sys/socket.h>
  20. #include "avformat.h"
  21. #include <unistd.h>
  22. #include <sys/types.h>
  23. #include <netinet/in.h>
  24. #ifndef __BEOS__
  25. # include <arpa/inet.h>
  26. #else
  27. # include "barpainet.h"
  28. #endif
  29. #include <netdb.h>
  30. //#define DEBUG
  31. /* TODO: - add RTCP statistics reporting (should be optional).
  32. - add support for h263/mpeg4 packetized output : IDEA: send a
  33. buffer to 'rtp_write_packet' contains all the packets for ONE
  34. frame. Each packet should have a four byte header containing
  35. the length in big endian format (same trick as
  36. 'url_open_dyn_packet_buf')
  37. */
  38. #define RTP_VERSION 2
  39. #define RTP_MAX_SDES 256 /* maximum text length for SDES */
  40. /* RTCP paquets use 0.5 % of the bandwidth */
  41. #define RTCP_TX_RATIO_NUM 5
  42. #define RTCP_TX_RATIO_DEN 1000
  43. typedef enum {
  44. RTCP_SR = 200,
  45. RTCP_RR = 201,
  46. RTCP_SDES = 202,
  47. RTCP_BYE = 203,
  48. RTCP_APP = 204
  49. } rtcp_type_t;
  50. typedef enum {
  51. RTCP_SDES_END = 0,
  52. RTCP_SDES_CNAME = 1,
  53. RTCP_SDES_NAME = 2,
  54. RTCP_SDES_EMAIL = 3,
  55. RTCP_SDES_PHONE = 4,
  56. RTCP_SDES_LOC = 5,
  57. RTCP_SDES_TOOL = 6,
  58. RTCP_SDES_NOTE = 7,
  59. RTCP_SDES_PRIV = 8,
  60. RTCP_SDES_IMG = 9,
  61. RTCP_SDES_DOOR = 10,
  62. RTCP_SDES_SOURCE = 11
  63. } rtcp_sdes_type_t;
  64. enum RTPPayloadType {
  65. RTP_PT_ULAW = 0,
  66. RTP_PT_GSM = 3,
  67. RTP_PT_G723 = 4,
  68. RTP_PT_ALAW = 8,
  69. RTP_PT_S16BE_STEREO = 10,
  70. RTP_PT_S16BE_MONO = 11,
  71. RTP_PT_MPEGAUDIO = 14,
  72. RTP_PT_JPEG = 26,
  73. RTP_PT_H261 = 31,
  74. RTP_PT_MPEGVIDEO = 32,
  75. RTP_PT_MPEG2TS = 33,
  76. RTP_PT_H263 = 34, /* old H263 encapsulation */
  77. };
  78. typedef struct RTPContext {
  79. int payload_type;
  80. UINT32 ssrc;
  81. UINT16 seq;
  82. UINT32 timestamp;
  83. UINT32 base_timestamp;
  84. UINT32 cur_timestamp;
  85. int max_payload_size;
  86. /* rtcp sender statistics receive */
  87. INT64 last_rtcp_ntp_time;
  88. UINT32 last_rtcp_timestamp;
  89. /* rtcp sender statistics */
  90. unsigned int packet_count;
  91. unsigned int octet_count;
  92. unsigned int last_octet_count;
  93. int first_packet;
  94. /* buffer for output */
  95. UINT8 buf[RTP_MAX_PACKET_LENGTH];
  96. UINT8 *buf_ptr;
  97. } RTPContext;
  98. int rtp_get_codec_info(AVCodecContext *codec, int payload_type)
  99. {
  100. switch(payload_type) {
  101. case RTP_PT_ULAW:
  102. codec->codec_id = CODEC_ID_PCM_MULAW;
  103. codec->channels = 1;
  104. codec->sample_rate = 8000;
  105. break;
  106. case RTP_PT_ALAW:
  107. codec->codec_id = CODEC_ID_PCM_ALAW;
  108. codec->channels = 1;
  109. codec->sample_rate = 8000;
  110. break;
  111. case RTP_PT_S16BE_STEREO:
  112. codec->codec_id = CODEC_ID_PCM_S16BE;
  113. codec->channels = 2;
  114. codec->sample_rate = 44100;
  115. break;
  116. case RTP_PT_S16BE_MONO:
  117. codec->codec_id = CODEC_ID_PCM_S16BE;
  118. codec->channels = 1;
  119. codec->sample_rate = 44100;
  120. break;
  121. case RTP_PT_MPEGAUDIO:
  122. codec->codec_id = CODEC_ID_MP2;
  123. break;
  124. case RTP_PT_JPEG:
  125. codec->codec_id = CODEC_ID_MJPEG;
  126. break;
  127. case RTP_PT_MPEGVIDEO:
  128. codec->codec_id = CODEC_ID_MPEG1VIDEO;
  129. break;
  130. default:
  131. return -1;
  132. }
  133. return 0;
  134. }
  135. /* return < 0 if unknown payload type */
  136. int rtp_get_payload_type(AVCodecContext *codec)
  137. {
  138. int payload_type;
  139. /* compute the payload type */
  140. payload_type = -1;
  141. switch(codec->codec_id) {
  142. case CODEC_ID_PCM_MULAW:
  143. payload_type = RTP_PT_ULAW;
  144. break;
  145. case CODEC_ID_PCM_ALAW:
  146. payload_type = RTP_PT_ALAW;
  147. break;
  148. case CODEC_ID_PCM_S16BE:
  149. if (codec->channels == 1) {
  150. payload_type = RTP_PT_S16BE_MONO;
  151. } else if (codec->channels == 2) {
  152. payload_type = RTP_PT_S16BE_STEREO;
  153. }
  154. break;
  155. case CODEC_ID_MP2:
  156. case CODEC_ID_MP3LAME:
  157. payload_type = RTP_PT_MPEGAUDIO;
  158. break;
  159. case CODEC_ID_MJPEG:
  160. payload_type = RTP_PT_JPEG;
  161. break;
  162. case CODEC_ID_MPEG1VIDEO:
  163. payload_type = RTP_PT_MPEGVIDEO;
  164. break;
  165. default:
  166. break;
  167. }
  168. return payload_type;
  169. }
  170. static inline UINT32 decode_be32(const UINT8 *p)
  171. {
  172. return (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3];
  173. }
  174. static inline UINT32 decode_be64(const UINT8 *p)
  175. {
  176. return ((UINT64)decode_be32(p) << 32) | decode_be32(p + 4);
  177. }
  178. static int rtcp_parse_packet(AVFormatContext *s1, const unsigned char *buf, int len)
  179. {
  180. RTPContext *s = s1->priv_data;
  181. if (buf[1] != 200)
  182. return -1;
  183. s->last_rtcp_ntp_time = decode_be64(buf + 8);
  184. s->last_rtcp_timestamp = decode_be32(buf + 16);
  185. return 0;
  186. }
  187. /**
  188. * Parse an RTP packet directly sent as raw data. Can only be used if
  189. * 'raw' is given as input file
  190. * @param s1 media file context
  191. * @param pkt returned packet
  192. * @param buf input buffer
  193. * @param len buffer len
  194. * @return zero if no error.
  195. */
  196. int rtp_parse_packet(AVFormatContext *s1, AVPacket *pkt,
  197. const unsigned char *buf, int len)
  198. {
  199. RTPContext *s = s1->priv_data;
  200. unsigned int ssrc, h;
  201. int payload_type, seq, delta_timestamp;
  202. AVStream *st;
  203. UINT32 timestamp;
  204. if (len < 12)
  205. return -1;
  206. if ((buf[0] & 0xc0) != (RTP_VERSION << 6))
  207. return -1;
  208. if (buf[1] >= 200 && buf[1] <= 204) {
  209. rtcp_parse_packet(s1, buf, len);
  210. return -1;
  211. }
  212. payload_type = buf[1] & 0x7f;
  213. seq = (buf[2] << 8) | buf[3];
  214. timestamp = decode_be32(buf + 4);
  215. ssrc = decode_be32(buf + 8);
  216. if (s->payload_type < 0) {
  217. s->payload_type = payload_type;
  218. if (payload_type == RTP_PT_MPEG2TS) {
  219. /* XXX: special case : not a single codec but a whole stream */
  220. return -1;
  221. } else {
  222. st = av_new_stream(s1, 0);
  223. if (!st)
  224. return -1;
  225. rtp_get_codec_info(&st->codec, payload_type);
  226. }
  227. }
  228. /* NOTE: we can handle only one payload type */
  229. if (s->payload_type != payload_type)
  230. return -1;
  231. #if defined(DEBUG) || 1
  232. if (seq != ((s->seq + 1) & 0xffff)) {
  233. printf("RTP: PT=%02x: bad cseq %04x expected=%04x\n",
  234. payload_type, seq, ((s->seq + 1) & 0xffff));
  235. }
  236. s->seq = seq;
  237. #endif
  238. len -= 12;
  239. buf += 12;
  240. st = s1->streams[0];
  241. switch(st->codec.codec_id) {
  242. case CODEC_ID_MP2:
  243. /* better than nothing: skip mpeg audio RTP header */
  244. if (len <= 4)
  245. return -1;
  246. h = decode_be32(buf);
  247. len -= 4;
  248. buf += 4;
  249. av_new_packet(pkt, len);
  250. memcpy(pkt->data, buf, len);
  251. break;
  252. case CODEC_ID_MPEG1VIDEO:
  253. /* better than nothing: skip mpeg audio RTP header */
  254. if (len <= 4)
  255. return -1;
  256. h = decode_be32(buf);
  257. buf += 4;
  258. len -= 4;
  259. if (h & (1 << 26)) {
  260. /* mpeg2 */
  261. if (len <= 4)
  262. return -1;
  263. buf += 4;
  264. len -= 4;
  265. }
  266. av_new_packet(pkt, len);
  267. memcpy(pkt->data, buf, len);
  268. break;
  269. default:
  270. av_new_packet(pkt, len);
  271. memcpy(pkt->data, buf, len);
  272. break;
  273. }
  274. if (s->last_rtcp_ntp_time != AV_NOPTS_VALUE) {
  275. /* compute pts from timestamp with received ntp_time */
  276. delta_timestamp = timestamp - s->last_rtcp_timestamp;
  277. /* XXX: do conversion, but not needed for mpeg at 90 KhZ */
  278. pkt->pts = s->last_rtcp_ntp_time + delta_timestamp;
  279. }
  280. return 0;
  281. }
  282. static int rtp_read_header(AVFormatContext *s1,
  283. AVFormatParameters *ap)
  284. {
  285. RTPContext *s = s1->priv_data;
  286. s->payload_type = -1;
  287. s->last_rtcp_ntp_time = AV_NOPTS_VALUE;
  288. return 0;
  289. }
  290. static int rtp_read_packet(AVFormatContext *s1, AVPacket *pkt)
  291. {
  292. char buf[RTP_MAX_PACKET_LENGTH];
  293. int ret;
  294. /* XXX: needs a better API for packet handling ? */
  295. for(;;) {
  296. ret = url_read(url_fileno(&s1->pb), buf, sizeof(buf));
  297. if (ret < 0)
  298. return AVERROR_IO;
  299. if (rtp_parse_packet(s1, pkt, buf, ret) == 0)
  300. break;
  301. }
  302. return 0;
  303. }
  304. static int rtp_read_close(AVFormatContext *s1)
  305. {
  306. // RTPContext *s = s1->priv_data;
  307. return 0;
  308. }
  309. static int rtp_probe(AVProbeData *p)
  310. {
  311. if (strstart(p->filename, "rtp://", NULL))
  312. return AVPROBE_SCORE_MAX;
  313. return 0;
  314. }
  315. /* rtp output */
  316. static int rtp_write_header(AVFormatContext *s1)
  317. {
  318. RTPContext *s = s1->priv_data;
  319. int payload_type, max_packet_size;
  320. AVStream *st;
  321. if (s1->nb_streams != 1)
  322. return -1;
  323. st = s1->streams[0];
  324. payload_type = rtp_get_payload_type(&st->codec);
  325. if (payload_type < 0)
  326. return -1;
  327. s->payload_type = payload_type;
  328. s->base_timestamp = random();
  329. s->timestamp = s->base_timestamp;
  330. s->ssrc = random();
  331. s->first_packet = 1;
  332. max_packet_size = url_fget_max_packet_size(&s1->pb);
  333. if (max_packet_size <= 12)
  334. return AVERROR_IO;
  335. s->max_payload_size = max_packet_size - 12;
  336. switch(st->codec.codec_id) {
  337. case CODEC_ID_MP2:
  338. case CODEC_ID_MP3LAME:
  339. s->buf_ptr = s->buf + 4;
  340. s->cur_timestamp = 0;
  341. break;
  342. case CODEC_ID_MPEG1VIDEO:
  343. s->cur_timestamp = 0;
  344. break;
  345. default:
  346. s->buf_ptr = s->buf;
  347. break;
  348. }
  349. return 0;
  350. }
  351. /* send an rtcp sender report packet */
  352. static void rtcp_send_sr(AVFormatContext *s1, INT64 ntp_time)
  353. {
  354. RTPContext *s = s1->priv_data;
  355. #if defined(DEBUG)
  356. printf("RTCP: %02x %Lx %x\n", s->payload_type, ntp_time, s->timestamp);
  357. #endif
  358. put_byte(&s1->pb, (RTP_VERSION << 6));
  359. put_byte(&s1->pb, 200);
  360. put_be16(&s1->pb, 6); /* length in words - 1 */
  361. put_be32(&s1->pb, s->ssrc);
  362. put_be64(&s1->pb, ntp_time);
  363. put_be32(&s1->pb, s->timestamp);
  364. put_be32(&s1->pb, s->packet_count);
  365. put_be32(&s1->pb, s->octet_count);
  366. put_flush_packet(&s1->pb);
  367. }
  368. /* send an rtp packet. sequence number is incremented, but the caller
  369. must update the timestamp itself */
  370. static void rtp_send_data(AVFormatContext *s1, UINT8 *buf1, int len)
  371. {
  372. RTPContext *s = s1->priv_data;
  373. #ifdef DEBUG
  374. printf("rtp_send_data size=%d\n", len);
  375. #endif
  376. /* build the RTP header */
  377. put_byte(&s1->pb, (RTP_VERSION << 6));
  378. put_byte(&s1->pb, s->payload_type & 0x7f);
  379. put_be16(&s1->pb, s->seq);
  380. put_be32(&s1->pb, s->timestamp);
  381. put_be32(&s1->pb, s->ssrc);
  382. put_buffer(&s1->pb, buf1, len);
  383. put_flush_packet(&s1->pb);
  384. s->seq++;
  385. s->octet_count += len;
  386. s->packet_count++;
  387. }
  388. /* send an integer number of samples and compute time stamp and fill
  389. the rtp send buffer before sending. */
  390. static void rtp_send_samples(AVFormatContext *s1,
  391. UINT8 *buf1, int size, int sample_size)
  392. {
  393. RTPContext *s = s1->priv_data;
  394. int len, max_packet_size, n;
  395. max_packet_size = (s->max_payload_size / sample_size) * sample_size;
  396. /* not needed, but who nows */
  397. if ((size % sample_size) != 0)
  398. av_abort();
  399. while (size > 0) {
  400. len = (max_packet_size - (s->buf_ptr - s->buf));
  401. if (len > size)
  402. len = size;
  403. /* copy data */
  404. memcpy(s->buf_ptr, buf1, len);
  405. s->buf_ptr += len;
  406. buf1 += len;
  407. size -= len;
  408. n = (s->buf_ptr - s->buf);
  409. /* if buffer full, then send it */
  410. if (n >= max_packet_size) {
  411. rtp_send_data(s1, s->buf, n);
  412. s->buf_ptr = s->buf;
  413. /* update timestamp */
  414. s->timestamp += n / sample_size;
  415. }
  416. }
  417. }
  418. /* NOTE: we suppose that exactly one frame is given as argument here */
  419. /* XXX: test it */
  420. static void rtp_send_mpegaudio(AVFormatContext *s1,
  421. UINT8 *buf1, int size)
  422. {
  423. RTPContext *s = s1->priv_data;
  424. AVStream *st = s1->streams[0];
  425. int len, count, max_packet_size;
  426. max_packet_size = s->max_payload_size;
  427. /* test if we must flush because not enough space */
  428. len = (s->buf_ptr - s->buf);
  429. if ((len + size) > max_packet_size) {
  430. if (len > 4) {
  431. rtp_send_data(s1, s->buf, s->buf_ptr - s->buf);
  432. s->buf_ptr = s->buf + 4;
  433. /* 90 KHz time stamp */
  434. s->timestamp = s->base_timestamp +
  435. (s->cur_timestamp * 90000LL) / st->codec.sample_rate;
  436. }
  437. }
  438. /* add the packet */
  439. if (size > max_packet_size) {
  440. /* big packet: fragment */
  441. count = 0;
  442. while (size > 0) {
  443. len = max_packet_size - 4;
  444. if (len > size)
  445. len = size;
  446. /* build fragmented packet */
  447. s->buf[0] = 0;
  448. s->buf[1] = 0;
  449. s->buf[2] = count >> 8;
  450. s->buf[3] = count;
  451. memcpy(s->buf + 4, buf1, len);
  452. rtp_send_data(s1, s->buf, len + 4);
  453. size -= len;
  454. buf1 += len;
  455. count += len;
  456. }
  457. } else {
  458. if (s->buf_ptr == s->buf + 4) {
  459. /* no fragmentation possible */
  460. s->buf[0] = 0;
  461. s->buf[1] = 0;
  462. s->buf[2] = 0;
  463. s->buf[3] = 0;
  464. }
  465. memcpy(s->buf_ptr, buf1, size);
  466. s->buf_ptr += size;
  467. }
  468. s->cur_timestamp += st->codec.frame_size;
  469. }
  470. /* NOTE: a single frame must be passed with sequence header if
  471. needed. XXX: use slices. */
  472. static void rtp_send_mpegvideo(AVFormatContext *s1,
  473. UINT8 *buf1, int size)
  474. {
  475. RTPContext *s = s1->priv_data;
  476. AVStream *st = s1->streams[0];
  477. int len, h, max_packet_size;
  478. UINT8 *q;
  479. max_packet_size = s->max_payload_size;
  480. while (size > 0) {
  481. /* XXX: more correct headers */
  482. h = 0;
  483. if (st->codec.sub_id == 2)
  484. h |= 1 << 26; /* mpeg 2 indicator */
  485. q = s->buf;
  486. *q++ = h >> 24;
  487. *q++ = h >> 16;
  488. *q++ = h >> 8;
  489. *q++ = h;
  490. if (st->codec.sub_id == 2) {
  491. h = 0;
  492. *q++ = h >> 24;
  493. *q++ = h >> 16;
  494. *q++ = h >> 8;
  495. *q++ = h;
  496. }
  497. len = max_packet_size - (q - s->buf);
  498. if (len > size)
  499. len = size;
  500. memcpy(q, buf1, len);
  501. q += len;
  502. /* 90 KHz time stamp */
  503. /* XXX: overflow */
  504. s->timestamp = s->base_timestamp +
  505. (s->cur_timestamp * 90000LL * FRAME_RATE_BASE) / st->codec.frame_rate;
  506. rtp_send_data(s1, s->buf, q - s->buf);
  507. buf1 += len;
  508. size -= len;
  509. }
  510. s->cur_timestamp++;
  511. }
  512. /* write an RTP packet. 'buf1' must contain a single specific frame. */
  513. static int rtp_write_packet(AVFormatContext *s1, int stream_index,
  514. UINT8 *buf1, int size, int force_pts)
  515. {
  516. RTPContext *s = s1->priv_data;
  517. AVStream *st = s1->streams[0];
  518. int rtcp_bytes;
  519. INT64 ntp_time;
  520. #ifdef DEBUG
  521. printf("%d: write len=%d\n", stream_index, size);
  522. #endif
  523. /* XXX: mpeg pts hardcoded. RTCP send every 0.5 seconds */
  524. rtcp_bytes = ((s->octet_count - s->last_octet_count) * RTCP_TX_RATIO_NUM) /
  525. RTCP_TX_RATIO_DEN;
  526. if (s->first_packet || rtcp_bytes >= 28) {
  527. /* compute NTP time */
  528. ntp_time = force_pts; // ((INT64)force_pts << 28) / 5625
  529. rtcp_send_sr(s1, ntp_time);
  530. s->last_octet_count = s->octet_count;
  531. s->first_packet = 0;
  532. }
  533. switch(st->codec.codec_id) {
  534. case CODEC_ID_PCM_MULAW:
  535. case CODEC_ID_PCM_ALAW:
  536. case CODEC_ID_PCM_U8:
  537. case CODEC_ID_PCM_S8:
  538. rtp_send_samples(s1, buf1, size, 1 * st->codec.channels);
  539. break;
  540. case CODEC_ID_PCM_U16BE:
  541. case CODEC_ID_PCM_U16LE:
  542. case CODEC_ID_PCM_S16BE:
  543. case CODEC_ID_PCM_S16LE:
  544. rtp_send_samples(s1, buf1, size, 2 * st->codec.channels);
  545. break;
  546. case CODEC_ID_MP2:
  547. case CODEC_ID_MP3LAME:
  548. rtp_send_mpegaudio(s1, buf1, size);
  549. break;
  550. case CODEC_ID_MPEG1VIDEO:
  551. rtp_send_mpegvideo(s1, buf1, size);
  552. break;
  553. default:
  554. return AVERROR_IO;
  555. }
  556. return 0;
  557. }
  558. static int rtp_write_trailer(AVFormatContext *s1)
  559. {
  560. // RTPContext *s = s1->priv_data;
  561. return 0;
  562. }
  563. AVInputFormat rtp_demux = {
  564. "rtp",
  565. "RTP input format",
  566. sizeof(RTPContext),
  567. rtp_probe,
  568. rtp_read_header,
  569. rtp_read_packet,
  570. rtp_read_close,
  571. .flags = AVFMT_NOHEADER,
  572. };
  573. AVOutputFormat rtp_mux = {
  574. "rtp",
  575. "RTP output format",
  576. NULL,
  577. NULL,
  578. sizeof(RTPContext),
  579. CODEC_ID_PCM_MULAW,
  580. CODEC_ID_NONE,
  581. rtp_write_header,
  582. rtp_write_packet,
  583. rtp_write_trailer,
  584. };
  585. int rtp_init(void)
  586. {
  587. av_register_output_format(&rtp_mux);
  588. av_register_input_format(&rtp_demux);
  589. return 0;
  590. }