MSM8976平台配置PCM1 接口为slave模式



由以上资料可知,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命令做如下回环测试:

你可能感兴趣的:(MSM8976平台配置PCM1 接口为slave模式)