你好,
我正在经历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 = -24 dB
ALC_THRESHOLD_MAX = -9 dB
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:~ i2cump -f -y 2 0x1a
没有指定大小(使用字节数据访问)
0123456789abcdef 0123456789abcdef
00: 00 00 00 05 00 00 07 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 00 00 00 00 ................
20: 00 10 0a 08 07 ea 1e 88 80 08 32 8b 00 00 00 00 00 00 .?????????2?....
30: 35 35 35 02 02 0f 0f 6f 6f 88 07 07 00 00 00 00 00 00 55????oo?? .....
40: 00 88 88 08 80 6f 6f 61 39 39 30 000 000 000 000 000 000 .????ooa990.....
50: 00 00 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(“终极战士? ?
70: 00 00 00 00 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 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 000 .!??............
3f 10 06 aa ....?2?.....????
A0: 71 00 00 d0 0f 00 00 00 85 0f 00 00 00 00 00 00 00 q. ??
b0: 00 00 00 00 00 00 00 55 15 00 40 02 01 00 00 00 .......U? @??
C0: 00 00 00 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 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 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 01 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_ANTICLIP_LEVEL = 0xA2到0x64。这应该可以解决观察到的问题。
亲切的问候,
艾略特德克斯特
嗨,艾略特,
回答你的问题:
1.在我的测试中,信号的振幅是正常的语言。然后,我轻敲麦克风,以激发对ALC的高输入。增益当然像预期的那样降低了,但当我停止轻敲麦克风时,增益有时仍然很低。
2.见附件
3.我还没试过。
我所尝试的是使用无自动校准的ALC,这似乎解决了问题。我设置ALC_SYNC_MODE = 1和ALC_OFFSET_EN = 0。这会产生什么影响呢?
在我看来,似乎ALC偏移校准不正确,这导致ALC有时失败。我已经附加了我的linux da7213驱动程序。有什么可疑的地方吗?
最好的问候,
乌尔里希
你好,
附件示意图。
最好的问候,
乌尔里希