关于Atmel A5D31平台ALC5640音频芯片的问题记录

项目需要在A5D31平台使用了ALC5640双I2S带功放的语音芯片,前期调试挺顺利,到后面调试录音时卡主了,问题是无法录音,报input/output错误,也就是没有数据流的意思。
花了两天时间跟FAE搞定ALC5640录音输出的问题,也就是说通过示波器可以确定数据一定是产生了,那么下面就是排除CPU这端的问题了。
又花了不少时间研究CPU的SSC接口(即I2S),最后锁定SSC的RCMR寄存器,如下图:
在这里插入图片描述
CKS这个配置(下图所示),内核中有错误(这个是那其他人的内核),根据原理图设计来说应该配置成1(不同的原理图选择不同,下图是默认的画法),也就是使用TK(BCLK)引脚输入的时钟信号。内核中默认配置成了2,所以不对。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
改了以为就可以了,结果还是报input/output错误,郁闷死了。继续研究(对该CPU的I2S机制并不是非常了解,可能其他的CPU并无该问题),时钟部分解决了(这里通过让接收时钟输出到IO引脚确定时钟无问题),最后锁定到录音采集开始触发的位置,如下图:
在这里插入图片描述
时钟什么的没问题了,放音没问题说明DMA和中断OK,那么就剩下这个触发了。看下寄存器对这个触发的定义描述:
在这里插入图片描述
除了0,1,8这三个值外,其他都需要RF引脚的信号,再对比内核中的配置发现(函数名atmel_ssc_hw_params),不管怎样都会需要RF信号的参与。为此修改它强制为0(1和8的值就不试了),再测试录音,郭然可以了,而且录音文件大小也正常。
以为总算可以了,但是还是不行,录音的文件杂声或者底噪非常大(人声可忽略了),但是有时候录音却是正常的(几率比较小),虽然还不行但起码可以录音了,很多的努力没白费。
有时行,有时不行,而且大部分不行,这下比根本不行更难办了,是配置问题?还是硬件模拟部分问题,无法确定。最后跟FAE借来了Demo板再测试,发现效果一样,那么可以确定不是硬件部分了。用的是alsa原版录音软件和库,也不怀疑。那么问题就是出在了内核或者原理设计上了。
最后回到触发开始采集部分,由于设置的为0没有使用同步信号这部分是不是有问题(当时并没有这么思考问题,绕了很大的弯,对于人来说最恐怖的是未知,唉没办法,想到这个问题花了有一天多,其他都测试完了,真没法了),然后决定把RF和TF短接,这时候内核中配置把SSC的RCMR中start位设置为7.
再测试,录音正常,播放录音文件很清晰(调整了运放放大倍数之后,刚开始有点破音),无杂音,整个清爽多了。
到此算是搞定了,后边再继续深测。这样的配置就跟通常的设计不同了,需要把发送和接收的两个同步信号引脚短接才行,之前的音频调试并不需要这样,坑。

发布了148 篇原创文章 · 获赞 72 · 访问量 71万+

猜你喜欢

转载自blog.csdn.net/u010406724/article/details/84451367