专栏中心

EEPW首页 > 专栏 > imx6q-------SPI调试记录

imx6q-------SPI调试记录

发布人:电子禅石 时间:2020-05-15 来源:工程师 发布文章
采用飞凌imx6q的核心板,默认配置了espi2,由于项目中使用了espi1,因此需要配置espi1,对调试过程进行记录。

1、参考espi2的设备树文件,增加了espi1的配置,如下:

1.png

上面第一个是默认的,第二个是我新增的,对这个不是很熟,初步按照这个方式配置。

2、配置espi1的gpio管脚,默认和uart4复用,注释掉uart4的引脚配置:

2.png

然后重新编译设备树,完了用新的设备树启动,启动完了,可以看到已经加载了两个设备spi0和spi1:

3.png

/dev目录下由两个spi节点

4.png

然后根据默认的测试程序测试了下spidev0.0发现时钟和数据都出来了,表明espi1已经可以使用,但是此时使用spidev1.0的时候发现并无任何时钟和数据输出,感觉是配置espi1的时候影响了espi2,尝试修改设备树的fsl,spi-num-chipselects = <1>;字段,但并不起作用。单独配置espi2是没问题的,spidev1.0可以使用,但同时配置espi1和espi2就会出现espi2不能使用,暂时不知道怎么回事。
3、测试
3.1 接线
与spi通信的设备是三线的一个DAC的spi芯片,且只支持写,接线方式需要注意,除了片选和时钟对接,从设备的数据线接到imx6q的MOSI管脚即可。
3.2 软件测试
a. 基本上是采用了linux提供了spi_test.c进行测试,修改了部分参数,第一次测试发现芯片没有任何输出,但是量了下数据线、时钟线和片选都有信号;
b. 后来又查看这个DAC的芯片手册,查到说需要配置spi主设备为下降沿发送数据(POL=0,PHA=1),因此重新配置后进行第二次测试发现仍然没有输出;
c.又把spi代码的配置参数详细看了下,有个一次发送的数据位数,默认是8位的,由于我需要写一个16位的数据,因此就尝试改为了16位数据的模式,发现这次有效了,芯片有输出信号;
d.为什么8位数据和16位数据会产生不同的影响呢,于是又用示波器分别抓取了一下8位模式和16位模式下的区别,发现16位模式是连续发送的16bit数据,而8位数据模式每次发送8位,分了两次发送,默认是先发送低字节数据。比如我需要发送0x04e0,采用16位数据模式就直接一次性发送完毕,而采用8位数据模式就先发送的0xe0,然后发送了0x04,导致芯片接收的数据为0xe004,这个数据会造成芯片休眠模式,因此没有输出,于是把数据字节调换后发送发现8位数据即可生效。
但是现在就一个问题,espi1不能使用,对设备树的配置还不熟,改起来费劲。
————————————————

原文链接:https://blog.csdn.net/aa304037208/article/details/82769719


专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们

关键词: 驱动

相关推荐

马达驱动电路

TFT LCD液晶显示器的驱动原理

IGBT的驱动与保护技术

资源下载 2007-02-16

大功率开关电源中功率MOSFET的驱动技术

纳芯微携汽车照明全场景LED驱动解决方案亮相2026ALE

如何驱动一个直流电机?直流电机驱动电路大全

MPS做一体化电机驱动方案有三绝招

工控自动化 2019-04-16

聚积科技赋能幻映纪元推动影视产业「文艺复兴」

光电显示 2022-05-26

超结高压MOSFET驱动电路及EMI设计

消息称英伟达在最新的驱动中取消了 RTX 30 显卡挖矿限制

试验六:Flash驱动

干货码住丨深度剖析IGBT栅极驱动注意事项

2023-07-27

电机控制应用不断迭代,ST平台化方案满足碎片化需求

工控自动化 2020-06-22

53年后,惠普于1972年推出的总线标准获得了稳定的Linux驱动——通用接口总线拥有惊人的8 MB/s带宽

MOS管驱动电路设计

2023-09-30
更多 培训课堂
更多 焦点
更多 视频

技术专区