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.

150 lines
3.0KB

  1. #include "avformat.h"
  2. #include "libavcodec/get_bits.h"
  3. #include "libavcodec/put_bits.h"
  4. #define MAX_FRAME_SIZE 10
  5. #define SYNC_WORD 0x6b21
  6. #define BIT_0 0x7f
  7. #define BIT_1 0x81
  8. static int probe(AVProbeData *p)
  9. {
  10. int i;
  11. i=AV_RL16(&p->buf[0]);
  12. if(i != SYNC_WORD)
  13. return 0;
  14. switch(AV_RL16(&p->buf[2]))
  15. {
  16. case 0x40:
  17. case 0x50:
  18. return AVPROBE_SCORE_MAX/2;
  19. default:
  20. return 0;
  21. }
  22. }
  23. static int read_header(AVFormatContext *s, AVFormatParameters *ap)
  24. {
  25. AVStream* st;
  26. ByteIOContext *pb = s->pb;
  27. st=av_new_stream(s, 0);
  28. if (!st)
  29. return AVERROR(ENOMEM);
  30. url_fskip(pb, 2);
  31. switch(get_le16(pb))
  32. {
  33. case 0x40:
  34. st->codec->bit_rate = 6400;
  35. break;
  36. case 0x50:
  37. st->codec->bit_rate = 8000;
  38. break;
  39. }
  40. st->codec->codec_type = AVMEDIA_TYPE_AUDIO;
  41. st->codec->codec_id=CODEC_ID_G729;
  42. st->codec->sample_rate=8000;
  43. st->codec->block_align = 16;
  44. st->codec->channels=1;
  45. av_set_pts_info(st, 64, 1, 100);
  46. url_fseek(pb, 0, SEEK_SET);
  47. return 0;
  48. }
  49. static int read_packet(AVFormatContext *s,
  50. AVPacket *pkt)
  51. {
  52. ByteIOContext *pb = s->pb;
  53. PutBitContext pbo;
  54. uint16_t buf[8 * MAX_FRAME_SIZE + 2];
  55. int packet_size;
  56. int sync;
  57. uint16_t* src=buf;
  58. int i, j, ret;
  59. if(url_feof(pb))
  60. return AVERROR_EOF;
  61. sync = get_le16(pb); // sync word
  62. packet_size = get_le16(pb) / 8;
  63. assert(packet_size < 8 * MAX_FRAME_SIZE);
  64. ret = get_buffer(pb, (uint8_t*)buf, (8 * packet_size) * sizeof(uint16_t));
  65. if(ret<0)
  66. return ret;
  67. if(ret != 8 * packet_size * sizeof(uint16_t))
  68. return AVERROR(EIO);
  69. av_new_packet(pkt, packet_size);
  70. init_put_bits(&pbo, pkt->data, packet_size);
  71. for(j=0; j < packet_size; j++)
  72. for(i=0; i<8;i++)
  73. put_bits(&pbo,1, AV_RL16(src++) == BIT_1 ? 1 : 0);
  74. flush_put_bits(&pbo);
  75. pkt->duration=1;
  76. return 0;
  77. }
  78. AVInputFormat ff_bit_demuxer = {
  79. "bit",
  80. "G.729 BIT file format",
  81. 0,
  82. probe,
  83. read_header,
  84. read_packet,
  85. .extensions = "bit"
  86. };
  87. #ifdef CONFIG_MUXERS
  88. static int write_header(AVFormatContext *s)
  89. {
  90. AVCodecContext *enc = s->streams[0]->codec;
  91. enc->codec_id = CODEC_ID_G729;
  92. enc->channels = 1;
  93. enc->bits_per_coded_sample = 16;
  94. enc->block_align = (enc->bits_per_coded_sample * enc->channels) >> 3;
  95. return 0;
  96. }
  97. static int write_packet(AVFormatContext *s, AVPacket *pkt)
  98. {
  99. ByteIOContext *pb = s->pb;
  100. GetBitContext gb;
  101. int i;
  102. uint16_t b;
  103. put_le16(pb, SYNC_WORD);
  104. put_le16(pb, 8 * 10);
  105. init_get_bits(&gb, pkt->data, 8*10);
  106. for(i=0; i< 8 * 10; i++)
  107. put_le16(pb, get_bits1(&gb) ? BIT_1 : BIT_0);
  108. put_flush_packet(pb);
  109. return 0;
  110. }
  111. AVOutputFormat ff_bit_muxer = {
  112. "bit",
  113. "G.729 BIT file format",
  114. "audio/bit",
  115. "bit",
  116. 0,
  117. CODEC_ID_G729,
  118. CODEC_ID_NONE,
  119. write_header,
  120. write_packet,
  121. .extensions = "bit"
  122. };
  123. #endif