OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 2458|回复: 3

mp3解码出来的数据都是00,移植的是原子哥的例程

[复制链接]

1

主题

4

帖子

0

精华

新手上路

积分
45
金钱
45
注册时间
2019-5-15
在线时间
13 小时
发表于 2020-2-10 15:50:22 | 显示全部楼层 |阅读模式
1金钱
                                        while(1)
                                        {
                                                if(bINC_flag == 1)
                                                {
                                                        bINC_flag = 0;
                                                        break;
                                                }//change file       
                               
            /* find start of next MP3 frame - assume EOF if no sync found */
            offset = MP3FindSyncWord(readPtr, bytesLeft);
            if (offset < 0)
                                                {
              outOfData = 1;
              break;
            }
            else
                                                {
              readPtr += offset;       //data start point
              bytesLeft -= offset;      //in buffer
              errs = MP3Decode(hMP3Decoder, &readPtr, (int *)&bytesLeft, (BuffP->BufData), 0);

              if (bytesLeft < READBUF_SIZE)
                                                        {
                memmove(readBuf,readPtr,bytesLeft);
                res = f_read(&fsrc, readBuf + bytesLeft, READBUF_SIZE - bytesLeft, &br);

                                                                if( (res) ||(br == 0))
                                                                        break;
                                                               
                if (br < READBUF_SIZE - bytesLeft)
                  memset(readBuf + bytesLeft + br, 0, READBUF_SIZE - bytesLeft - br);
                bytesLeft = READBUF_SIZE;
                readPtr = readBuf;               
              }
              MP3GetLastFrameInfo(hMP3Decoder, &mp3FrameInfo);
                                                       
              //sample_rate(mp3FrameInfo.samprate);
              if(1 == mp3FrameInfo.nChans)
                Convert_Mono((BuffP->BufData));
              else
                Convert_Stereo((BuffP->BufData));

              OSSemPend(SemBufWr, 0, &err);
                          
              DMA_Transmit((u32)(BuffP->BufData), 2304);

              BuffP = BuffP->Next;
            }
          }
红色这行,解码函数返回值是0,是正确的,但是解码出来的BuffP->BufData缓冲区都是00,哪里出了问题呢

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2020-2-10 21:48:17 | 显示全部楼层
跟踪进去,看具体问题出在哪里(注意各个函数的返回值,一般返回值0为正常,其他值为异常)
回复

使用道具 举报

1

主题

4

帖子

0

精华

新手上路

积分
45
金钱
45
注册时间
2019-5-15
在线时间
13 小时
 楼主| 发表于 2020-2-11 19:58:54 | 显示全部楼层
正点原子 发表于 2020-2-10 21:48
跟踪进去,看具体问题出在哪里(注意各个函数的返回值,一般返回值0为正常,其他值为异常)


感谢原指导,能再帮我看看吗,我跟踪进去之后到了下面的代码

int Subband(MP3DecInfo *mp3DecInfo, short *pcmBuf)
{
        int b;
        //HuffmanInfo *hi;
        IMDCTInfo *mi;
        SubbandInfo *sbi;

        /* validate pointers */
        if (!mp3DecInfo || !mp3DecInfo->HuffmanInfoPS || !mp3DecInfo->IMDCTInfoPS || !mp3DecInfo->SubbandInfoPS)
                return -1;

        //hi = (HuffmanInfo *)mp3DecInfo->HuffmanInfoPS;
        mi = (IMDCTInfo *)(mp3DecInfo->IMDCTInfoPS);
        sbi = (SubbandInfo*)(mp3DecInfo->SubbandInfoPS);

        if (mp3DecInfo->nChans == 2) {
                /* stereo */
                for (b = 0; b < BLOCK_SIZE; b++) {
                        FDCT32(mi->outBuf[0], sbi->vbuf + 0*32, sbi->vindex, (b & 0x01), mi->gb[0]);
                        FDCT32(mi->outBuf[1], sbi->vbuf + 1*32, sbi->vindex, (b & 0x01), mi->gb[1]);
                        PolyphaseStereo(pcmBuf, sbi->vbuf + sbi->vindex + VBUF_LENGTH * (b & 0x01), polyCoef);
                        sbi->vindex = (sbi->vindex - (b & 0x01)) & 7;
                        pcmBuf += (2 * NBANDS);
                }
        } else {
                /* mono */
                for (b = 0; b < BLOCK_SIZE; b++) {
                        FDCT32(mi->outBuf[0], sbi->vbuf + 0*32, sbi->vindex, (b & 0x01), mi->gb[0]);
                        PolyphaseMono(pcmBuf, sbi->vbuf + sbi->vindex + VBUF_LENGTH * (b & 0x01), polyCoef);
                        sbi->vindex = (sbi->vindex - (b & 0x01)) & 7;
                        pcmBuf += NBANDS;
                }
        }

        return 0;
}


程序到PolyphaseStereo这个函数,里面是汇编的,看不明白了。但是Subband这个函数返回的值是0,说明是成功的
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165516
金钱
165516
注册时间
2010-12-1
在线时间
2116 小时
发表于 2020-2-12 22:21:02 | 显示全部楼层
t8811519 发表于 2020-2-11 19:58
感谢原指导,能再帮我看看吗,我跟踪进去之后到了下面的代码

int Subband(MP3DecInfo *mp3DecInfo,  ...

没问题的函数就跳过,继续下一步代码
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-5-20 13:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表