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.

688 lines
18KB

  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 "avformat.h"
  20. #include <unistd.h>
  21. #include <sys/types.h>
  22. #include <sys/socket.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. RTP_PT_PRIVATE = 96,
  78. };
  79. typedef struct RTPContext {
  80. int payload_type;
  81. UINT32 ssrc;
  82. UINT16 seq;
  83. UINT32 timestamp;
  84. UINT32 base_timestamp;
  85. UINT32 cur_timestamp;
  86. int max_payload_size;
  87. /* rtcp sender statistics receive */
  88. INT64 last_rtcp_ntp_time;
  89. UINT32 last_rtcp_timestamp;
  90. /* rtcp sender statistics */
  91. unsigned int packet_count;
  92. unsigned int octet_count;
  93. unsigned int last_octet_count;
  94. int first_packet;
  95. /* buffer for output */
  96. UINT8 buf[RTP_MAX_PACKET_LENGTH];
  97. UINT8 *buf_ptr;
  98. } RTPContext;
  99. int rtp_get_codec_info(AVCodecContext *codec, int payload_type)
  100. {
  101. switch(payload_type) {
  102. case RTP_PT_ULAW:
  103. codec->codec_id = CODEC_ID_PCM_MULAW;
  104. codec->channels = 1;
  105. codec->sample_rate = 8000;
  106. break;
  107. case RTP_PT_ALAW:
  108. codec->codec_id = CODEC_ID_PCM_ALAW;
  109. codec->channels = 1;
  110. codec->sample_rate = 8000;
  111. break;
  112. case RTP_PT_S16BE_STEREO:
  113. codec->codec_id = CODEC_ID_PCM_S16BE;
  114. codec->channels = 2;
  115. codec->sample_rate = 44100;
  116. break;
  117. case RTP_PT_S16BE_MONO:
  118. codec->codec_id = CODEC_ID_PCM_S16BE;
  119. codec->channels = 1;
  120. codec->sample_rate = 44100;
  121. break;
  122. case RTP_PT_MPEGAUDIO:
  123. codec->codec_id = CODEC_ID_MP2;
  124. break;
  125. case RTP_PT_JPEG:
  126. codec->codec_id = CODEC_ID_MJPEG;
  127. break;
  128. case RTP_PT_MPEGVIDEO:
  129. codec->codec_id = CODEC_ID_MPEG1VIDEO;
  130. break;
  131. default:
  132. return -1;
  133. }
  134. return 0;
  135. }
  136. /* return < 0 if unknown payload type */
  137. int rtp_get_payload_type(AVCodecContext *codec)
  138. {
  139. int payload_type;
  140. /* compute the payload type */
  141. payload_type = -1;
  142. switch(codec->codec_id) {
  143. case CODEC_ID_PCM_MULAW:
  144. payload_type = RTP_PT_ULAW;
  145. break;
  146. case CODEC_ID_PCM_ALAW:
  147. payload_type = RTP_PT_ALAW;
  148. break;
  149. case CODEC_ID_PCM_S16BE:
  150. if (codec->channels == 1) {
  151. payload_type = RTP_PT_S16BE_MONO;
  152. } else if (codec->channels == 2) {
  153. payload_type = RTP_PT_S16BE_STEREO;
  154. }
  155. break;
  156. case CODEC_ID_MP2:
  157. case CODEC_ID_MP3LAME:
  158. payload_type = RTP_PT_MPEGAUDIO;
  159. break;
  160. case CODEC_ID_MJPEG:
  161. payload_type = RTP_PT_JPEG;
  162. break;
  163. case CODEC_ID_MPEG1VIDEO:
  164. payload_type = RTP_PT_MPEGVIDEO;
  165. break;
  166. default:
  167. break;
  168. }
  169. return payload_type;
  170. }
  171. static inline UINT32 decode_be32(const UINT8 *p)
  172. {
  173. return (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3];
  174. }
  175. static inline UINT32 decode_be64(const UINT8 *p)
  176. {
  177. return ((UINT64)decode_be32(p) << 32) | decode_be32(p + 4);
  178. }
  179. static int rtcp_parse_packet(AVFormatContext *s1, const unsigned char *buf, int len)
  180. {
  181. RTPContext *s = s1->priv_data;
  182. if (buf[1] != 200)
  183. return -1;
  184. s->last_rtcp_ntp_time = decode_be64(buf + 8);
  185. s->last_rtcp_timestamp = decode_be32(buf + 16);
  186. return 0;
  187. }
  188. /**
  189. * Parse an RTP packet directly sent as raw data. Can only be used if
  190. * 'raw' is given as input file
  191. * @param s1 media file context
  192. * @param pkt returned packet
  193. * @param buf input buffer
  194. * @param len buffer len
  195. * @return zero if no error.
  196. */
  197. int rtp_parse_packet(AVFormatContext *s1, AVPacket *pkt,
  198. const unsigned char *buf, int len)
  199. {
  200. RTPContext *s = s1->priv_data;
  201. unsigned int ssrc, h;
  202. int payload_type, seq, delta_timestamp;
  203. AVStream *st;
  204. UINT32 timestamp;
  205. if (len < 12)
  206. return -1;
  207. if ((buf[0] & 0xc0) != (RTP_VERSION << 6))
  208. return -1;
  209. if (buf[1] >= 200 && buf[1] <= 204) {
  210. rtcp_parse_packet(s1, buf, len);
  211. return -1;
  212. }
  213. payload_type = buf[1] & 0x7f;
  214. seq = (buf[2] << 8) | buf[3];
  215. timestamp = decode_be32(buf + 4);
  216. ssrc = decode_be32(buf + 8);
  217. if (s->payload_type < 0) {
  218. s->payload_type = payload_type;
  219. if (payload_type == RTP_PT_MPEG2TS) {
  220. /* XXX: special case : not a single codec but a whole stream */
  221. return -1;
  222. } else {
  223. st = av_new_stream(s1, 0);
  224. if (!st)
  225. return -1;
  226. rtp_get_codec_info(&st->codec, payload_type);
  227. }
  228. }
  229. /* NOTE: we can handle only one payload type */
  230. if (s->payload_type != payload_type)
  231. return -1;
  232. #if defined(DEBUG) || 1
  233. if (seq != ((s->seq + 1) & 0xffff)) {
  234. printf("RTP: PT=%02x: bad cseq %04x expected=%04x\n",
  235. payload_type, seq, ((s->seq + 1) & 0xffff));
  236. }
  237. s->seq = seq;
  238. #endif
  239. len -= 12;
  240. buf += 12;
  241. st = s1->streams[0];
  242. switch(st->codec.codec_id) {
  243. case CODEC_ID_MP2:
  244. /* better than nothing: skip mpeg audio RTP header */
  245. if (len <= 4)
  246. return -1;
  247. h = decode_be32(buf);
  248. len -= 4;
  249. buf += 4;
  250. av_new_packet(pkt, len);
  251. memcpy(pkt->data, buf, len);
  252. break;
  253. case CODEC_ID_MPEG1VIDEO:
  254. /* better than nothing: skip mpeg audio RTP header */
  255. if (len <= 4)
  256. return -1;
  257. h = decode_be32(buf);
  258. buf += 4;
  259. len -= 4;
  260. if (h & (1 << 26)) {
  261. /* mpeg2 */
  262. if (len <= 4)
  263. return -1;
  264. buf += 4;
  265. len -= 4;
  266. }
  267. av_new_packet(pkt, len);
  268. memcpy(pkt->data, buf, len);
  269. break;
  270. default:
  271. av_new_packet(pkt, len);
  272. memcpy(pkt->data, buf, len);
  273. break;
  274. }
  275. if (s->last_rtcp_ntp_time != AV_NOPTS_VALUE) {
  276. /* compute pts from timestamp with received ntp_time */
  277. delta_timestamp = timestamp - s->last_rtcp_timestamp;
  278. /* XXX: do conversion, but not needed for mpeg at 90 KhZ */
  279. pkt->pts = s->last_rtcp_ntp_time + delta_timestamp;
  280. }
  281. return 0;
  282. }
  283. static int rtp_read_header(AVFormatContext *s1,
  284. AVFormatParameters *ap)
  285. {
  286. RTPContext *s = s1->priv_data;
  287. s->payload_type = -1;
  288. s->last_rtcp_ntp_time = AV_NOPTS_VALUE;
  289. return 0;
  290. }
  291. static int rtp_read_packet(AVFormatContext *s1, AVPacket *pkt)
  292. {
  293. char buf[RTP_MAX_PACKET_LENGTH];
  294. int ret;
  295. /* XXX: needs a better API for packet handling ? */
  296. for(;;) {
  297. ret = url_read(url_fileno(&s1->pb), buf, sizeof(buf));
  298. if (ret < 0)
  299. return AVERROR_IO;
  300. if (rtp_parse_packet(s1, pkt, buf, ret) == 0)
  301. break;
  302. }
  303. return 0;
  304. }
  305. static int rtp_read_close(AVFormatContext *s1)
  306. {
  307. // RTPContext *s = s1->priv_data;
  308. return 0;
  309. }
  310. static int rtp_probe(AVProbeData *p)
  311. {
  312. if (strstart(p->filename, "rtp://", NULL))
  313. return AVPROBE_SCORE_MAX;
  314. return 0;
  315. }
  316. /* rtp output */
  317. static int rtp_write_header(AVFormatContext *s1)
  318. {
  319. RTPContext *s = s1->priv_data;
  320. int payload_type, max_packet_size;
  321. AVStream *st;
  322. if (s1->nb_streams != 1)
  323. return -1;
  324. st = s1->streams[0];
  325. payload_type = rtp_get_payload_type(&st->codec);
  326. if (payload_type < 0)
  327. payload_type = RTP_PT_PRIVATE; /* private payload type */
  328. s->payload_type = payload_type;
  329. s->base_timestamp = random();
  330. s->timestamp = s->base_timestamp;
  331. s->ssrc = random();
  332. s->first_packet = 1;
  333. max_packet_size = url_fget_max_packet_size(&s1->pb);
  334. if (max_packet_size <= 12)
  335. return AVERROR_IO;
  336. s->max_payload_size = max_packet_size - 12;
  337. switch(st->codec.codec_id) {
  338. case CODEC_ID_MP2:
  339. case CODEC_ID_MP3LAME:
  340. s->buf_ptr = s->buf + 4;
  341. s->cur_timestamp = 0;
  342. break;
  343. case CODEC_ID_MPEG1VIDEO:
  344. s->cur_timestamp = 0;
  345. break;
  346. default:
  347. s->buf_ptr = s->buf;
  348. break;
  349. }
  350. return 0;
  351. }
  352. /* send an rtcp sender report packet */
  353. static void rtcp_send_sr(AVFormatContext *s1, INT64 ntp_time)
  354. {
  355. RTPContext *s = s1->priv_data;
  356. #if defined(DEBUG)
  357. printf("RTCP: %02x %Lx %x\n", s->payload_type, ntp_time, s->timestamp);
  358. #endif
  359. put_byte(&s1->pb, (RTP_VERSION << 6));
  360. put_byte(&s1->pb, 200);
  361. put_be16(&s1->pb, 6); /* length in words - 1 */
  362. put_be32(&s1->pb, s->ssrc);
  363. put_be64(&s1->pb, ntp_time);
  364. put_be32(&s1->pb, s->timestamp);
  365. put_be32(&s1->pb, s->packet_count);
  366. put_be32(&s1->pb, s->octet_count);
  367. put_flush_packet(&s1->pb);
  368. }
  369. /* send an rtp packet. sequence number is incremented, but the caller
  370. must update the timestamp itself */
  371. static void rtp_send_data(AVFormatContext *s1, UINT8 *buf1, int len)
  372. {
  373. RTPContext *s = s1->priv_data;
  374. #ifdef DEBUG
  375. printf("rtp_send_data size=%d\n", len);
  376. #endif
  377. /* build the RTP header */
  378. put_byte(&s1->pb, (RTP_VERSION << 6));
  379. put_byte(&s1->pb, s->payload_type & 0x7f);
  380. put_be16(&s1->pb, s->seq);
  381. put_be32(&s1->pb, s->timestamp);
  382. put_be32(&s1->pb, s->ssrc);
  383. put_buffer(&s1->pb, buf1, len);
  384. put_flush_packet(&s1->pb);
  385. s->seq++;
  386. s->octet_count += len;
  387. s->packet_count++;
  388. }
  389. /* send an integer number of samples and compute time stamp and fill
  390. the rtp send buffer before sending. */
  391. static void rtp_send_samples(AVFormatContext *s1,
  392. UINT8 *buf1, int size, int sample_size)
  393. {
  394. RTPContext *s = s1->priv_data;
  395. int len, max_packet_size, n;
  396. max_packet_size = (s->max_payload_size / sample_size) * sample_size;
  397. /* not needed, but who nows */
  398. if ((size % sample_size) != 0)
  399. av_abort();
  400. while (size > 0) {
  401. len = (max_packet_size - (s->buf_ptr - s->buf));
  402. if (len > size)
  403. len = size;
  404. /* copy data */
  405. memcpy(s->buf_ptr, buf1, len);
  406. s->buf_ptr += len;
  407. buf1 += len;
  408. size -= len;
  409. n = (s->buf_ptr - s->buf);
  410. /* if buffer full, then send it */
  411. if (n >= max_packet_size) {
  412. rtp_send_data(s1, s->buf, n);
  413. s->buf_ptr = s->buf;
  414. /* update timestamp */
  415. s->timestamp += n / sample_size;
  416. }
  417. }
  418. }
  419. /* NOTE: we suppose that exactly one frame is given as argument here */
  420. /* XXX: test it */
  421. static void rtp_send_mpegaudio(AVFormatContext *s1,
  422. UINT8 *buf1, int size)
  423. {
  424. RTPContext *s = s1->priv_data;
  425. AVStream *st = s1->streams[0];
  426. int len, count, max_packet_size;
  427. max_packet_size = s->max_payload_size;
  428. /* test if we must flush because not enough space */
  429. len = (s->buf_ptr - s->buf);
  430. if ((len + size) > max_packet_size) {
  431. if (len > 4) {
  432. rtp_send_data(s1, s->buf, s->buf_ptr - s->buf);
  433. s->buf_ptr = s->buf + 4;
  434. /* 90 KHz time stamp */
  435. s->timestamp = s->base_timestamp +
  436. (s->cur_timestamp * 90000LL) / st->codec.sample_rate;
  437. }
  438. }
  439. /* add the packet */
  440. if (size > max_packet_size) {
  441. /* big packet: fragment */
  442. count = 0;
  443. while (size > 0) {
  444. len = max_packet_size - 4;
  445. if (len > size)
  446. len = size;
  447. /* build fragmented packet */
  448. s->buf[0] = 0;
  449. s->buf[1] = 0;
  450. s->buf[2] = count >> 8;
  451. s->buf[3] = count;
  452. memcpy(s->buf + 4, buf1, len);
  453. rtp_send_data(s1, s->buf, len + 4);
  454. size -= len;
  455. buf1 += len;
  456. count += len;
  457. }
  458. } else {
  459. if (s->buf_ptr == s->buf + 4) {
  460. /* no fragmentation possible */
  461. s->buf[0] = 0;
  462. s->buf[1] = 0;
  463. s->buf[2] = 0;
  464. s->buf[3] = 0;
  465. }
  466. memcpy(s->buf_ptr, buf1, size);
  467. s->buf_ptr += size;
  468. }
  469. s->cur_timestamp += st->codec.frame_size;
  470. }
  471. /* NOTE: a single frame must be passed with sequence header if
  472. needed. XXX: use slices. */
  473. static void rtp_send_mpegvideo(AVFormatContext *s1,
  474. UINT8 *buf1, int size)
  475. {
  476. RTPContext *s = s1->priv_data;
  477. AVStream *st = s1->streams[0];
  478. int len, h, max_packet_size;
  479. UINT8 *q;
  480. max_packet_size = s->max_payload_size;
  481. while (size > 0) {
  482. /* XXX: more correct headers */
  483. h = 0;
  484. if (st->codec.sub_id == 2)
  485. h |= 1 << 26; /* mpeg 2 indicator */
  486. q = s->buf;
  487. *q++ = h >> 24;
  488. *q++ = h >> 16;
  489. *q++ = h >> 8;
  490. *q++ = h;
  491. if (st->codec.sub_id == 2) {
  492. h = 0;
  493. *q++ = h >> 24;
  494. *q++ = h >> 16;
  495. *q++ = h >> 8;
  496. *q++ = h;
  497. }
  498. len = max_packet_size - (q - s->buf);
  499. if (len > size)
  500. len = size;
  501. memcpy(q, buf1, len);
  502. q += len;
  503. /* 90 KHz time stamp */
  504. /* XXX: overflow */
  505. s->timestamp = s->base_timestamp +
  506. (s->cur_timestamp * 90000LL * FRAME_RATE_BASE) / st->codec.frame_rate;
  507. rtp_send_data(s1, s->buf, q - s->buf);
  508. buf1 += len;
  509. size -= len;
  510. }
  511. s->cur_timestamp++;
  512. }
  513. static void rtp_send_raw(AVFormatContext *s1,
  514. UINT8 *buf1, int size)
  515. {
  516. RTPContext *s = s1->priv_data;
  517. AVStream *st = s1->streams[0];
  518. int len, max_packet_size;
  519. max_packet_size = s->max_payload_size;
  520. while (size > 0) {
  521. len = max_packet_size;
  522. if (len > size)
  523. len = size;
  524. /* 90 KHz time stamp */
  525. /* XXX: overflow */
  526. s->timestamp = s->base_timestamp +
  527. (s->cur_timestamp * 90000LL * FRAME_RATE_BASE) / st->codec.frame_rate;
  528. rtp_send_data(s1, buf1, len);
  529. buf1 += len;
  530. size -= len;
  531. }
  532. s->cur_timestamp++;
  533. }
  534. /* write an RTP packet. 'buf1' must contain a single specific frame. */
  535. static int rtp_write_packet(AVFormatContext *s1, int stream_index,
  536. UINT8 *buf1, int size, int force_pts)
  537. {
  538. RTPContext *s = s1->priv_data;
  539. AVStream *st = s1->streams[0];
  540. int rtcp_bytes;
  541. INT64 ntp_time;
  542. #ifdef DEBUG
  543. printf("%d: write len=%d\n", stream_index, size);
  544. #endif
  545. /* XXX: mpeg pts hardcoded. RTCP send every 0.5 seconds */
  546. rtcp_bytes = ((s->octet_count - s->last_octet_count) * RTCP_TX_RATIO_NUM) /
  547. RTCP_TX_RATIO_DEN;
  548. if (s->first_packet || rtcp_bytes >= 28) {
  549. /* compute NTP time */
  550. ntp_time = force_pts; // ((INT64)force_pts << 28) / 5625
  551. rtcp_send_sr(s1, ntp_time);
  552. s->last_octet_count = s->octet_count;
  553. s->first_packet = 0;
  554. }
  555. switch(st->codec.codec_id) {
  556. case CODEC_ID_PCM_MULAW:
  557. case CODEC_ID_PCM_ALAW:
  558. case CODEC_ID_PCM_U8:
  559. case CODEC_ID_PCM_S8:
  560. rtp_send_samples(s1, buf1, size, 1 * st->codec.channels);
  561. break;
  562. case CODEC_ID_PCM_U16BE:
  563. case CODEC_ID_PCM_U16LE:
  564. case CODEC_ID_PCM_S16BE:
  565. case CODEC_ID_PCM_S16LE:
  566. rtp_send_samples(s1, buf1, size, 2 * st->codec.channels);
  567. break;
  568. case CODEC_ID_MP2:
  569. case CODEC_ID_MP3LAME:
  570. rtp_send_mpegaudio(s1, buf1, size);
  571. break;
  572. case CODEC_ID_MPEG1VIDEO:
  573. rtp_send_mpegvideo(s1, buf1, size);
  574. break;
  575. default:
  576. /* better than nothing : send the codec raw data */
  577. rtp_send_raw(s1, buf1, size);
  578. break;
  579. }
  580. return 0;
  581. }
  582. static int rtp_write_trailer(AVFormatContext *s1)
  583. {
  584. // RTPContext *s = s1->priv_data;
  585. return 0;
  586. }
  587. AVInputFormat rtp_demux = {
  588. "rtp",
  589. "RTP input format",
  590. sizeof(RTPContext),
  591. rtp_probe,
  592. rtp_read_header,
  593. rtp_read_packet,
  594. rtp_read_close,
  595. .flags = AVFMT_NOHEADER,
  596. };
  597. AVOutputFormat rtp_mux = {
  598. "rtp",
  599. "RTP output format",
  600. NULL,
  601. NULL,
  602. sizeof(RTPContext),
  603. CODEC_ID_PCM_MULAW,
  604. CODEC_ID_NONE,
  605. rtp_write_header,
  606. rtp_write_packet,
  607. rtp_write_trailer,
  608. };
  609. int rtp_init(void)
  610. {
  611. av_register_output_format(&rtp_mux);
  612. av_register_input_format(&rtp_demux);
  613. return 0;
  614. }