由以上资料可知,MSM8976平台支持2组PCM接口,PCM0和PCM1,分别与QUAT I2S和QUIN I2S共用GPIO接口。
那么接下来我们将使用MSM8976 的QUIN I2S 接口外接一个通讯模块,调试其回环功能是否可以打通。其中外接模块作master模式,MSM作slave模式。模块支持 8khz 16bit语音,其中CLK为256Khz。
由于PCM同步信号分为两种,short frame 和long frame,时序如下:
所以作为short模式的模块端pcm clk与sync信号如下:
CLK:256KHZ SYNC:8KHZ 采样率:8KHZ 采样深度:16BIT
那么MSM端主要需要配置的部分有三处,第一:CLK 由外部提供。第二:sync由外部提供。第三:通讯数据的clk设为256k,frame设为32BPF(256k/8k)。第四:配置dsp寄存器,关闭LPASS对PCM1 的CLK供给。
1:CLK 由外部提供
kernel\sound\soc\msm\qdsp6v2\msm-dai-q6-v2.c API:msm_dai_q6_auxpcm_prepare
调用afe_set_lpass_clock函数设置pcm配置。我们修改其默认配置为外部clk。
static const struct afe_clk_cfg lpass_clk_cfg_default = {
AFE_API_VERSION_I2S_CONFIG,
Q6AFE_LPASS_OSR_CLK_2_P048_MHZ,
0,
Q6AFE_LPASS_CLK_SRC_EXTERNAL,//Q6AFE_LPASS_CLK_SRC_INTERNAL,
Q6AFE_LPASS_CLK_ROOT_DEFAULT,
Q6AFE_LPASS_MODE_CLK1_VALID,
0,
};
将默认的内部CLK资源配置成外部CLK即可。
2:sync由外部提供 以及 通讯数据的配置
kernel\arch\arm\boot\dts\qcom\msm8976-qrd-skun.dtsi
dai_sec_auxpcm: qcom,msm-sec-auxpcm {
compatible = "qcom,msm-auxpcm-dev";
qcom,msm-cpudai-auxpcm-mode = <0>, <0>;
qcom,msm-cpudai-auxpcm-sync = <0>, <0>;//EXTERNAL 0x0 INTERNAL 0x1
qcom,msm-cpudai-auxpcm-frame = <2>, <2>;
qcom,msm-cpudai-auxpcm-quant = <2>, <2>;
qcom,msm-cpudai-auxpcm-num-slots = <1>, <1>;
qcom,msm-cpudai-auxpcm-slot-mapping = <1>, <1>;
qcom,msm-cpudai-auxpcm-data = <0>, <0>;
qcom,msm-cpudai-auxpcm-pcm-clk-rate = <256000>, <256000>;
qcom,msm-auxpcm-interface = "secondary";
};
以上两组参数分别对应8KHZ和16KHZ的配置,我们目前配置8KHZ,可以只修改第一组参数即可。
配置外部sync信号可修改qcom,msm-cpudai-auxpcm-sync为0。
由于外部CLK提供256K,SYNC为8K。
所以 qcom,msm-cpudai-auxpcm-pcm-clk-rate配置为256000,
qcom,msm-cpudai-auxpcm-frame取值分别对应如下参数:
0:AFE_PORT_PCM_BITS_PER_FRAME_8
1:AFE_PORT_PCM_BITS_PER_FRAME_16
2:AFE_PORT_PCM_BITS_PER_FRAME_32
3:AFE_PORT_PCM_BITS_PER_FRAME_64
4:AFE_PORT_PCM_BITS_PER_FRAME_128
5:AFE_PORT_PCM_BITS_PER_FRAME_256
由于CLK/SYNC=(256K/8k)=32BPF.
所以将qcom,msm-cpudai-auxpcm-frame配置为2。
3:配置dsp寄存器
由于PCM1与QUIN I2S共用gpio,根据以上寄存器说明,配置PCM1为slave模式如下:
kernel\sound\soc\msm\msm8952-slimbus.c API:msm_sec_auxpcm_startup
当启用PCM1 DAILINK时,调用 pcm1的上电函数,直接配置对应寄存器切换到PCM1 SLAVE模式。
我使用主板有通过slimbus外挂wcd9335 codec,wcd9335 再直连MIC和HANDSET。
通过tinymix 和tinyhostless命令做如下回环测试: