[FFmpeg-trac] #527(avcodec:new): NellyMoser codec reports zero frame size and bitrate

FFmpeg trac at avcodec.org
Thu Oct 20 07:18:11 CEST 2011


#527: NellyMoser codec reports zero frame size and bitrate
-------------------------------------+-------------------------------------
             Reporter:  DrLex        |                    Owner:
                 Type:  defect       |                   Status:  new
             Priority:  normal       |                Component:  avcodec
              Version:  unspecified  |               Resolution:
             Keywords:  nellymoser   |               Blocked By:
  codec                              |  Reproduced by developer:  0
             Blocking:               |
Analyzed by developer:  0            |
-------------------------------------+-------------------------------------

Comment (by jjlee3):

 I found the same problem.
 I modified the ffmpeg/doc/eamples/decoding_encoding.c function
 audio_decode_example to test it.

 {{{
 #define AUDIO_PACKET(x) { x, sizeof(x) }

 static uint8_t audioData01[] = {
 0x3A,0x0B,0x6D,0x29,0xCB,0x6B,0x5E,0x6B,0x10,0xFB,0x54,0x95,0xB5,0x65,0x94,0x66,
 0x12,0x6A,0xDE,0x30,0x60,0x6F,0xDD,0x71,0x31,0xCB,0xA5,0xBB,0x14,0x82,0xA7,0x22,
 0xE9,0x5C,0x55,0x89,0x9A,0x12,0x64,0x4D,0x3E,0x11,0xE1,0x2C,0x35,0x3A,0x8E,0xCA,
 0x4D,0x2B,0xC3,0xEE,0xC5,0x03,0x70,0xD8,0xDD,0x33,0x9B,0x8A,0x53,0x0D,0xD2,0x54,
 0xB9,0x0C,0x45,0xB6,0xD4,0xB7,0x3D,0xD0,0x88,0x1A,0x5F,0x93,0x76,0x69,0x64,0x2D,
 0x89,0x37,0xB9,0x54,0x48,0x74,0x6E,0x29,0xFE,0x50,0x64,0xD4,0x29,0x4C,0xDD,0xF2,
 0x21,0xBA,0xB9,0x59,0x59,0xEA,0xC0,0x9F,0x3B,0x11,0xDE,0x9E,0xA0,0xA5,0x3F,0x3B,
 0x33,0xE5,0x45,0xE9,0x8A,0x44,0x06,0x37,0x5A,0xED,0x36,0xA5,0x6A,0x53,0xD3,0xD4,
 0xFB,0x1A,0xC6,0xD4,0xD9,0xF1,0x5C,0x09,0x09,0xEB,0x9A,0x7C,0x58,0xE9,0x14,0x09,
 0x43,0x46,0xDE,0xC9,0xC6,0x3A,0x50,0x63,0x21,0xD3,0x51,0x6B,0x62,0x06,0xD8,0xE0,
 0x0F,0x80,0x52,0x55,0xA3,0xFC,0xDF,0xCF,0x22,0x34,0xC7,0x31,0xB2,0x46,0xCB,0xBC,
 0xCC,0x97,0xD0,0xC9,0xE5,0x32,0x94,0xB7,0xA8,0x5E,0xD2,0xCC,0x46,0x6D,0xA2,0x74,
 0x3C,0x13,0x67,0x49,0xC9,0xB5,0x44,0x2C,0x85,0xFB,0x9E,0x6C,0xB8,0xE1,0x06,0x25,
 0x31,0xD7,0x85,0xDD,0xE6,0xE4,0xF3,0x5E,0xB2,0x21,0xA7,0xAA,0x4C,0xD3,0xE4,0x02,
 0x60,0x02,0x35,0x55,0x03,0xC0,0xFF,0xD8,0x59,0x1F,0x66,0xAF,0xC7,0xB2,0x6A,0x15,
 0x3F,0xFE,0xC4,0x0D,0xCD,0xF9,0xBB,0xB6,0x76,0xA9,0x2A,0x33,0x3B,0x8B,0x9E,0x3A,
 0xB9,0x14,0xE6,0x35,0x7C,0x77,0x4D,0xAD,0x90,0xE9,0xE0,0x8B,0x76,0xE9,0x56,0x6C,
 0x7C,0xAA,0x68,0x56,0x23,0xCB,0x22,0xC4,0xBB,0xFE,0xD9,0xA2,0xBD,0x3B,0x48,0xFB,
 0x30,0x8F,0xA6,0x41,0x1A,0x7C,0x87,0xE1,0x26,0x5E,0xB1,0xD0,0x02,0x6D,0x9A,0x56,
 0xAC,0x33,0x5B,0x07,0x31,0x46,0x36,0x9E,0xC6,0xDE,0xA5,0x9A,0x65,0x26,0x53,0xE4,
 0xFB,0x22,0x06,0xBD,0x8D,0x35,0x4D,0xCD,0x14,0xF7,0xD4,0xA4,0xB5,0x65,0xC5,0xEC,
 0xBB,0x85,0x0A,0x4A,0xA3,0x8C,0x6E,0x17,0x46,0xED,0x5D,0xC2,0x0D,0xA8,0x97,0x63,
 0xD8,0x9C,0x69,0xBE,0x4A,0xDF,0x73,0xB9,0x22,0xD3,0xA5,0x77,0xA2,0xA0,0xBA,0x66,
 0xAE,0xB3,0xA5,0x49,0x75,0x81,0x6E,0x21,0x99,0xE4,0xAA,0xA6,0xAD,0xA6,0xAE,0xB2,
 0xFC,0x13,0x8C,0xCC,0xCB,0x69,0x4D,0xCE,0x88,0xFA,0xDA,0x8C,0x55,0xED,0x34,0xED,
 0x88,0x35,0xE7,0x27,0xB7,0x44,0xAF,0x3C,0xB2,0xC0,0xF0,0x2A,0x2F,0xF3,0x1A,0xD2,
 0xD8,0xB2,0x55,0xC5,0xB3,0x4E,0x36,0x91,0x0D,0xD2,0x8D,0x64,0xA1,0x2D,0xA7,0x25,
 0x55,0xE8,0x46,0x3A,0x47,0xFC,0x74,0x5B,0xB7,0xF7,0xC1,0x2A,0xED,0x4C,0x81,0xD1,
 0xFC,0x13,0x08,0xC5,0xD9,0x6B,0x35,0x91,0x8C,0xCB,0x9E,0x84,0x57,0x69,0xF6,0xCD,
 0xC4,0x89,0x27,0x68,0x2A,0x5A,0x25,0xB8,0xF5,0x6F,0xCB,0xAF,0x9B,0x7B,0x29,0xB5,
 0x3C,0x31,0x53,0xC3,0x64,0x28,0xED,0x5F,0xC3,0x73,0x25,0xDD,0x01,0x95,0x81,0x4F,
 0x88,0x69,0xA0,0x51,0xAF,0x5E,0x5B,0xCF,0xAD,0x07,0x40,0x35,0x3B,0xDD,0x3F,0xE0,
 };
 // you can defined audioData02, audioData03, ...

 struct AudioPacket {
     uint8_t* data;
     int      size;
 };

 AudioPacket audioPacket[] = {
     AUDIO_PACKET(audioData01),
 };

 static void audio_decode_example()
 {
     AVCodec*        codec;
     AVCodecContext* c;
     uint8_t         inbuf[AUDIO_INBUF_SIZE +
 FF_INPUT_BUFFER_PADDING_SIZE];
     AVPacket        avpkt;
     int             outbuf_size, out_size, len;
     uint8_t*        outbuf;

     codec = avcodec_find_decoder(CODEC_ID_NELLYMOSER);
     assert(codec);
     c = avcodec_alloc_context3(codec);
     assert(c);
     if (avcodec_open2(c, codec, NULL) < 0) { assert(false); }

     outbuf_size = AVCODEC_MAX_AUDIO_FRAME_SIZE;
     outbuf = (uint8_t*)av_malloc(outbuf_size);

     for (int i = 0; i < _countof(audioPacket); ++i) {
         av_init_packet(&avpkt);
         memcpy(inbuf, audioPacket[i].data, audioPacket[i].size);
         memset(&inbuf[audioPacket[i].size], 0,
 FF_INPUT_BUFFER_PADDING_SIZE);
         avpkt.data = inbuf;
         avpkt.size = audioPacket[i].size;

         out_size = AVCODEC_MAX_AUDIO_FRAME_SIZE;
         len = avcodec_decode_audio3(c, reinterpret_cast<int16_t*>(outbuf),
             &out_size, &avpkt);
         assert (len >= 0);
         assert(len == avpkt.size); // only for nellymoser
         assert(c->frame_size);
     }

     av_free(outbuf);
     avcodec_close(c);
     av_free(c);
 }
 }}}

 I always got an assert for "assert(c->frame_size);".

-- 
Ticket URL: <http://ffmpeg.org/trac/ffmpeg/ticket/527#comment:4>
FFmpeg <http://ffmpeg.org>
FFmpeg issue tracker


More information about the FFmpeg-trac mailing list