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

2024-01-09 21:30
文章标签 调试 记录 spi imx6q

本文主要是介绍imx6q-------SPI调试记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

采用飞凌imx6q的核心板,默认配置了espi2,由于项目中使用了espi1,因此需要配置espi1,对调试过程进行记录。

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

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

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

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

/dev目录下由两个spi节点

然后根据默认的测试程序测试了下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不能使用,对设备树的配置还不熟,改起来费劲。

这篇关于imx6q-------SPI调试记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/588491

相关文章

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

vscode中文乱码问题,注释,终端,调试乱码一劳永逸版

忘记咋回事突然出现了乱码问题,很多方法都试了,注释乱码解决了,终端又乱码,调试窗口也乱码,最后经过本人不懈努力,终于全部解决了,现在分享给大家我的方法。 乱码的原因是各个地方用的编码格式不统一,所以把他们设成统一的utf8. 1.电脑的编码格式 开始-设置-时间和语言-语言和区域 管理语言设置-更改系统区域设置-勾选Bata版:使用utf8-确定-然后按指示重启 2.vscode

记录每次更新到仓库 —— Git 学习笔记 10

记录每次更新到仓库 文章目录 文件的状态三个区域检查当前文件状态跟踪新文件取消跟踪(un-tracking)文件重新跟踪(re-tracking)文件暂存已修改文件忽略某些文件查看已暂存和未暂存的修改提交更新跳过暂存区删除文件移动文件参考资料 咱们接着很多天以前的 取得Git仓库 这篇文章继续说。 文件的状态 不管是通过哪种方法,现在我们已经有了一个仓库,并从这个仓

学习记录:js算法(二十八):删除排序链表中的重复元素、删除排序链表中的重复元素II

文章目录 删除排序链表中的重复元素我的思路解法一:循环解法二:递归 网上思路 删除排序链表中的重复元素 II我的思路网上思路 总结 删除排序链表中的重复元素 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。 图一 图二 示例 1:(图一)输入:head = [1,1,2]输出:[1,2]示例 2:(图

perl的学习记录——仿真regression

1 记录的背景 之前只知道有这个强大语言的存在,但一直侥幸自己应该不会用到它,所以一直没有开始学习。然而人生这么长,怎就确定自己不会用到呢? 这次要搭建一个可以自动跑完所有case并且打印每个case的pass信息到指定的文件中。从而减轻手动跑仿真,手动查看log信息的重复无效低质量的操作。下面简单记录下自己的思路并贴出自己的代码,方便自己以后使用和修正。 2 思路整理 作为一个IC d