你好,
我在DA7212编解码器中遇到ALC周期性问题。该系统运行于Linux系统,使用Dialog Semi提供的DA7213 SoC驱动程序。
问题是,有时ALC不恢复后,它已经降低了增益。似乎这个问题是由麦克风上突然的高输入触发的,这导致ALC降低增益,但它永远不会把增益恢复起来。
ALC_ATTACK = 44 / fs
ALC_RELEASE = 176 / fs
ALC_INTEG_RELEASE = 1/4
ALC_INTEG_ATTACK = 1/4
ALC_HOLD = 62 / fs
ALC_THRESHOLD_MIN = - 24db
ALC_THRESHOLD_MAX = - 9db
ALC_ATTEN_MAX = 60 dB
ALC_GAIN_MAX = 60 dB
ALC_ANA_GAIN_MAX = 36 dB
ALC_ANA_GAIN_MIN = 0 dB
ALC_ANTICLIP_EN是禁用的
ALC_ANTICLIP_LEVEL = 0.
ALC噪声水平设置为-94.5 dB
有什么想法能解释为什么会这样吗?DA7212中的任何寄存器,我可以监视以查看ALC的内部状态/操作。
此致,
乌尔里希
设备:
你好,乌尔里希,
让我来调查一下。
亲切的问候,
艾略特Dexterb
你好,乌尔里希,
你能给我提供一份登记册吗?
亲切的问候,
艾略特德克斯特
你好,
在流中,请参阅下面的注册转储。请注意,ALC在这种情况下正常行为。
root@x:~ i2cdump -f -y 2 0x1a . txt
未指定大小(使用字节数据访问)
0123456789abcdef
00:00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ... ......
10: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
20:00 10 0A 08 07 EA 1E 88 80 08 32 8B 00 00 00 00。?????????? 2?....
30: 35 35 02 02 0f 0f 6f 6f 88 07 07 00 00 00 00 00 55????oo?? .....
40: 00 88 88 08 80 6f 6f 61 39 39 30 00 00 00 00 00 .????ooa990.....
50:00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
60:64 64 11 08 08 28 28 20 20 60 60 68 68 68 18 18 18 18 18 DD ???((`hhh ??
70: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
80: 00 21 89 03 00 00 00 00 00 00 00 00 00 00 00 00 .!??............
90: 00 00 00 00 00 03 32 95 00 00 00 00 00 3f 10 06 aa ....?2?.....????
A0: 71 00 00 d0 00 00 00 00 85 00 f 00 00 00 00 00 00 q. ?? ?? ?......
b0: 00 00 00 00 00 00 00 55 15 00 40 02 01 00 00 00 00 .......U?.@??
C0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
D0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................
e0: 01 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ?...............
F0: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 .............?..
此致,
乌尔里希
你好,乌尔里希,
谢谢你把登记簿扔了。我们设法在实验室重现了你的问题,我们找到了一个潜在的解决方案,将ALC_Gain_Max改为72dB。自从更改值以来,我们没有观察到这个问题。我们将进一步了解为什么会发生这种情况。
亲切的问候,
艾略特德克斯特
你好,
谢谢你的反馈。我会测试你的建议并反馈给你。
此致,
乌尔里希
你好,
我已经测试了提议的更改,它并不能解决问题。在降低增益后,ALC仍然不总是恢复。同样,将ALC_Gain_Max更改为72dB会由于信号的裁剪而导致失真。
你能解释在ALC中是什么导致了这种意外行为吗?其他解决问题的建议。
此致,
乌尔里希
嗨,艾略特,
另一个关于ALC的观察是,我看到左右通道的振幅有很大的不同。这只有在使用ALC时才能看到。从数据表中我读到的,ALC对两个通道应用相同的增益,对吗?
使用固定增益时,左右通道的振幅是相等的。
此致,
乌尔里希
嗨,乌尔里希,
这是有趣的,周围的工作似乎在这里工作。我再次向球队提出了这个,我可以尽快给你答复一些答案。
亲切的问候,
艾略特德克斯特
你好,乌尔里希,
很抱歉回复晚了,我现在不在办公室。我有几个问题和一个建议:
设置ALC_SYNC_MODE为enabled,假设我们已经启用了,那么我们还需要ALC_ANTICLP_CTRL enabled = 0xA1到0x80, alc_antilip_level = 0xA2到0x64。这应该能解决正在观察的问题。
亲切的问候,
艾略特德克斯特
嗨,艾略特,
回答您的问题:
1.在我的测试中,信号的振幅是正常的语音。然后我轻按麦克风,以激发一个高输入到ALC。增益当然会像预期的那样降低,但当我停止轻拍麦克风时,增益有时仍然很低。
2.见附件
我还没有尝试过。
我尝试的是使用ALC而没有自动校准,似乎可以解决问题。我设置了ALC_SYNC_MODE = 1和ALC_OFFSET_EN = 0.可能会产生什么影响?
对我而言,看起来alc偏移校准不是正确完成的,这导致ALC有时会失败。我附上了我的Linux DA7213驱动程序。对你有什么看法吗?
此致,
乌尔里希
你好,
附件示意图。
此致,
乌尔里希