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命令做如下回环测试:

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,992评论 19 139
  • Android Things Preview 6中已移除本文中提及的重要API,并变更了I2S音频的实现方式,新的...
    Cocoonshu阅读 6,522评论 2 5
  • 超高速音视频编码器用法: ffmpeg [options] [[infile options] -i infile...
    吉凶以情迁阅读 4,663评论 0 4
  • 本文为官方文档翻译版本 rabbitmq3.7.5版本,原地址:https://github.com/rabbit...
    yanshaowen阅读 28,639评论 0 3
  • 刚吃完晚饭,就收到死党的微信,叫去菜市场看表演!抱上小宝就出门了!原来是安微一家三口来卖艺的!出来跑江湖也是...
    天空飘来五个字蓉杰阅读 251评论 0 1