TI中文支持网
TI专业的中文技术问题搜集分享网站

c6455_vcp2译码器的译码长度应该怎么配置?

为什么译不同长度的一帧,除了帧长配置外,对edma的几个参数应该怎么配置?
比如acnt,bcnt等。。。

Jane Lu:

Huiyan,

             您好!

             EDMA的相关参数配置在VCP2 user guider 的4.2章节。

             相关代码可以参考下面这个网页中的VCP2的例子:

             http://www.ti.com/dsp/docs/litabsmultiplefilelist.tsp?sectionId=3&tabId=409&literatureNumber=spraag4&docCategoryId=1&familyId=1648

 

huiyan zeng:

回复 Jane Lu:

Jane LU  谢谢你

这个例子信息量很大,值得学习研究。。。

希望能搞定我的两个问题:大于1000多的帧长设置和怎么控制译码结束后的中断。。。。。

Jane Lu:

回复 huiyan zeng:

Huiyan,

              如果是大于1000多的帧,请对照VCP2的手册看一下是否在最大帧长范围内(不同K值最大限制也不同)。 如果超过最大长度限制,就需要您用软件参与做分段译码,具体原理类同sliding window方式。

              这个例子用的是查询方式判断译码是否结束, 如果用中断方式,是由EDMA传输完成事件来触发的,您可以借鉴其他EDMA中断的例子来做。

Jane Lu:

回复 Jane Lu:

附件是另一个例子,有中断方式。

huiyan zeng:

回复 Jane Lu:

Jane 谢谢 提前祝新年快乐

附件 我昨天看了,也看到了相关的配置,待年后我试试。。再次谢谢

huiyan zeng:

回复 Jane Lu:

Jane 您提供的例子 我看了

可是有几个地方不理解。

1、VcpConfigParms是怎么赋值的?在例程中没有找到赋值的地方,不知道poly,traceBack,numBmFrames等等这些值怎么来的?

2、还有branch_metrics这个的格式怎么也VCP2的用户手册提到的格式不一样呢?

3、您提供的例程是不是没有驱动VCP2硬核?而是用的软核(只调用某些函数来译码?)?

4、VCP2用户手册提到的Tailed TraceBack Mode是指咬尾模式吗?启用这个模式,是不是VCP2核会自动为译码信息的头部添加信息再译码?

谢谢

huiyan zeng:

回复 Jane Lu:

Jane,

由于我最开始从贵网站下载的VCP和TCP例程是“dsk6455_v2\boards\dsk6455_v2\csl_c6455\example”内的“vcp2_soft_decisions”和“tcp2_standalone_mode”,除了上述几个问题之外。在使用过程中,我还遇到一个很奇怪的问题,有时候程序会死在VCP_statRun和TCP2_statTcpState中,这个时候需要对C6455进行复位才能让VCP和TCP正常工作?请问这是为什么?应该怎么避免?谢谢!!

Jane Lu:

回复 huiyan zeng:

Huiyan,

               您好,下面是我的回复:

1  VcpConfigParms是通过CSL函数VCP2_genParams()来赋值的。 该函数的源码见附件,里面有poly,traceBack,numBmFrames相关参数赋值。   其中,poly采用了默认值,如果你的多项式与默认值不同,需要在这个函数之后另行修改。

2    branch_metrics的格式应该是按照VCP2的手册要求排列的。

3    VCP2_BER这个工程可以用C 仿真模型(通过#ifdef VCP2_C_MODEL 控制),默认是用硬核译码。

4     Tailed TraceBack Mode是指一帧数据都在同一个回溯判决内,不是咬尾模式。 如果您需要做咬尾,需要手动在头尾添加信息。

5     如果程序死在VCP_statRun中,应该是VCP处于running状态没有结束。 有可能是与VCP2配合的EDMA传输存在问题。 建议每次load程序之前,都用仿真器把DSP 复位一下。

huiyan zeng:

回复 Jane Lu:

1、例子VCP2BER.zip中ConvolutionalEncode函数的编码方式是什么?这个编码和FEC编码有什么本质上的区别?

目前的情况是,我的编码信息通过VCP2BER.zip这个例程来译码,结果不正确,后来才发现我的编码和VCP2BER.zip中ConvolutionalEncode中的编码不同。。

2、同时我的编码后的信息通过“从贵网站下载的例程dsk6455_v2\boards\dsk6455_v2\csl_c6455\example\vcp2”是可以正确译码的,只是在使用这个例程时,我遇到一个棘手的问题:怎么能知道译码结束了?感觉这个例程的配置可能不全面,可是我又不知道怎么去配置?“http://www.deyisupport.com/question_answer/dsp_arm/c6000_multicore/f/53/p/52474/119725.aspx#119725”这是我发在贵网站的针对这个问题的一个帖子。

huiyan zeng:

回复 huiyan zeng:

已通过EDMA的IPR来确认译码的结束。。。谢谢

赞(0)
未经允许不得转载:TI中文支持网 » c6455_vcp2译码器的译码长度应该怎么配置?
分享到: 更多 (0)