您尚未登录。

楼主 # 2021-05-23 14:11:50

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

终于搞定f1c100s的i2s输出

内核用的是linux5.4.99,是mangopi r1/2/3官网给的buildroot一键编译包
设备树里已经有了i2s0节点,但是需要自己添加pinctl节点
2021-05-23_13-59.png
这里踩过一个坑,function不是写i2s0而是i2s
然后设备树继续添加对应的codec,我这里是pcm5102a
2021-05-23_14-02.png
2021-05-23_14-04.png
直接这样还是不能用,自己测试的时候,拿示波器测量,aplay播放的时候一直是bck和lrck有时钟正常在跑,data上没有数据,aplay一会儿就出现Input/Output Error
2021-05-23_14-08.png
各种查看源码和手册,最后终于找到解决办法:
2021-05-23_14-09.png
sun4i-i2s.c sun4i_i2s_probe函数中两个maxburst = 8改为4即可
因为f1c100s的DDMA和NDMA都各只有4个channel
2021-05-23_14-11.png

离线

#1 2021-05-23 14:35:26

raspberryman
会员
注册时间: 2019-12-27
已发帖子: 501
积分: 464

Re: 终于搞定f1c100s的i2s输出

请问楼主,mclk怎么给呢?

离线

楼主 #2 2021-05-23 14:45:36

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

Re: 终于搞定f1c100s的i2s输出

raspberryman 说:

请问楼主,mclk怎么给呢?

应该是可以的,但我现在用的pcm5102a可以不给mclk
我研究一下,晚点回复你

离线

#3 2021-05-23 14:49:28

raspberryman
会员
注册时间: 2019-12-27
已发帖子: 501
积分: 464

Re: 终于搞定f1c100s的i2s输出

Molly 说:
raspberryman 说:

请问楼主,mclk怎么给呢?

应该是可以的,但我现在用的pcm5102a可以不给mclk
我研究一下,晚点回复你

嗯嗯,我觉得应该和摄像头那个PCLK输出一样。

楼主方便贴一份完整的dts和config吗,有空我也试一试。

离线

楼主 #4 2021-05-23 14:58:24

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

Re: 终于搞定f1c100s的i2s输出

raspberryman 说:
Molly 说:
raspberryman 说:

请问楼主,mclk怎么给呢?

应该是可以的,但我现在用的pcm5102a可以不给mclk
我研究一下,晚点回复你

嗯嗯,我觉得应该和摄像头那个PCLK输出一样。

楼主方便贴一份完整的dts和config吗,有空我也试一试。

测过了,mclk直接有输出,pinctl那边写的PD7就是mclk
IMG_20210523_145220.jpg
dts:
i2s-devicetree.zip

离线

楼主 #5 2021-05-23 15:07:38

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

Re: 终于搞定f1c100s的i2s输出

外接dac音质真的比自带codec好多了
不过又发现有些问题,测试的时候播放的是48kHz采样率的wav文件,正常出声
后来尝试用madplay播放mp3文件失败,发现44.1kHz的文件都无法播放
2021-05-23_15-06.png
以及alsamixer里面并没有音量控制,我再研究研究

离线

#6 2021-05-23 17:23:52

拉轰的脚踏车
会员
注册时间: 2020-03-20
已发帖子: 240
积分: 196

Re: 终于搞定f1c100s的i2s输出

好评好评! 我也以为 F1C 和 S3一样没有MCLK引脚,  结果还真有.

S3手册V0.2: Allwinner_S3_Datasheet_V0_2.pdf

F1C100s手册: F1C100s_Datasheet_V1_0.pdf

离线

楼主 #7 2021-05-23 17:43:31

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

Re: 终于搞定f1c100s的i2s输出

44.1kHz那一组采样率(11025 22050 44100 88200 176400)也搞定了
原本是切换采样率时设置mod_clk那边出错,但是代码里并没有dev_err输出错误信息,自己加了行上去后发现错误位置
2021-05-23_17-27.png
解决方法:drivers/clk/sunxi-ng/ccu-suniv-f1c100s.c 找到static SUNXI_CCU_MUX_WITH_GATE(i2s_clk, "i2s", i2s_spdif_parents, 0x0b0, 16, 2, BIT(31), 0);
修改为static SUNXI_CCU_MUX_WITH_GATE(i2s_clk, "i2s", i2s_spdif_parents, 0x0b0, 16, 2, BIT(31), CLK_SET_RATE_PARENT);
2021-05-23_17-03.png
听首歌测试测试(图中是flac转成wav的 采样率176400hz,事实上44100等也测试过了)
2021-05-23_17-25.png
顺便把之前设备树里的mclk,fs由256改为128,这样可以最高支持192khz采样率
IMG_20210523_165637.jpg

离线

#8 2021-05-23 21:39:18

xfdr0805
会员
注册时间: 2020-07-23
已发帖子: 128
积分: 111

Re: 终于搞定f1c100s的i2s输出

赞,可以做高品质的音乐播放器了

离线

#9 2021-05-24 08:27:47

illusion
会员
注册时间: 2018-05-09
已发帖子: 66
积分: 360

Re: 终于搞定f1c100s的i2s输出

是个牛人。另外这个示波器啥型号啊?

离线

楼主 #10 2021-05-24 09:41:27

Molly
会员
注册时间: 2021-05-16
已发帖子: 10
积分: 30
个人网站

Re: 终于搞定f1c100s的i2s输出

illusion 说:

是个牛人。另外这个示波器啥型号啊?

便宜买的,ads5012h,感觉不怎么专业:P

离线

#11 2021-05-24 10:51:36

IAMLIUBO
会员
注册时间: 2019-04-01
已发帖子: 58
积分: 43

Re: 终于搞定f1c100s的i2s输出

Molly 说:
illusion 说:

是个牛人。另外这个示波器啥型号啊?

便宜买的,ads5012h,感觉不怎么专业:P


感觉还可以,正点原子家的那个便携式示波器DS100,感觉也还不错。

离线

页脚

工信部备案:粤ICP备20025096号 Powered by FluxBB

感谢为中文互联网持续输出优质内容的各位老铁们。 QQ: 516333132, 微信(wechat): whycan_cn (哇酷网/挖坑网/填坑网) service@whycan.cn