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.

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