正点原子[第二期]Linux之ARM(MX6U)裸机篇学习笔记-24.3,4 SPI驱动实验-I.MX6U SPI 寄存器

前言:

本文是根据哔哩哔哩网站上“正点原子[第二期]Linux之ARM(MX6U)裸机篇”视频的学习笔记,在这里会记录下正点原子 I.MX6ULL 开发板的配套视频教程所作的实验和学习笔记内容。本文大量引用了正点原子教学视频和链接中的内容。

引用:

正点原子IMX6U仓库 (GuangzhouXingyi) - Gitee.com

《【正点原子】I.MX6U嵌入式Linux驱动开发指南V1.5.2.pdf》

正点原子资料下载中心 — 正点原子资料下载中心 1.0.0 文档

SPI学习参考资料:

简述SPI通信协议-01_cpha选择为第一个边沿-CSDN博客

SPI中的CPHA,CPOL详解-CSDN博客

一文搞懂SPI通信协议_spi协议-CSDN博客

摩托罗拉 《SPI Block Guide V03.06》 手册

链接:https://pan.baidu.com/s/1_mvR5AD0-OBI2bYyx2i4Sw?pwd=f4bo 
提取码:f4bo

正文:

本文是 “正点原子[第二期]Linux之ARM(MX6U)裸机篇--第24讲 SPI驱动。本节将参考正点原子的视频教程第24讲和配套的正点原子开发指南文档进行学习。

0. 概述

通I2C一样,SPI是很常用的通信接口,也可以通过SPI来连接众多的传感器。相比I2C接口,SPI接口的通信速度很快,I2C最多400KHz,但是SPI可以到达即使MHz。I.MX6U 也有4个SPI接口,可以通过这4个SPI接口来连接一些SPI外设。I.MX6U-ALHPA使用SPI3接口连接了一个6周传感器 ICM-20608,本章我们就来学习如何使用I.MX6U的SPI接口来驱动ICM-20608,读取ICM-20608的六轴数据。

1. I.MX6U 的SPI接口

I.MX6U 处理器的SPI接口在《I.MX6ULL参考手册》的第20章 "Chapter 20Enhanced Configurable SPI (ECSPI)"章节,

I.MX6U ECSPI 接口的硬件框图如下:

  • ECSPI有64个32位的TXFIFO 缓冲区
  • ECSPI有64个32位的RXFIFO 缓冲区
  • 通过ECSPI 硬件接口的 FIFOx 缓冲区可以减少数据传输时的中断数量从而提高传输速率

I.MX6U ECSPI 硬件接口的特向如下:

  • 全双工,同步,串行接口
  • 主机/从机模式
  • 4个CS(Chip Seclect)片选信号线来支持多个外部设备
  • 持续传输模式允许任意长度的数据传输
  • Tx和Rx方向分别有32位的 64 条目的FOFO缓冲器
  • 时钟极性(Polarity),时钟相位(Phase)和时钟频率可以配置
  • DMA支持
  • 最大运行频率可以达到参考时钟频率

2. I.MX6U ECSPI 时钟

从I.MX6U的时钟树(Clock Tree)可以找到 ECSPI 接口的时钟来源于 PLL3_480MHz,并且经过一个固定值为8的分频,所以从时钟树CCM进入到到 ESPAI 接口的时钟频率为

ESAPI = PLL3_480Mhz/8 = 60MHz

在ECSAPI时钟树可以看到,ECSAPI的时钟源选择还需要配置一个多路选择器 CCM_CSCDR2 [ECSPI_CLK_SEL] 和一个分频器 CCM_CSCDR2[ECSPI_CLK_PODF] 

这个CCM_CSCDR2 寄存器的结构如下图所示:

这里配置为1分频,时钟源选择为PLL3_60M

CCM_CSCDR2寄存器的 bit[24:19] 设置为0表示1分频,bit[18]=0 表示时钟源选择 PLL3_60M

3. I.MX6U ECSPI 寄存器

I.MX6U ECSPI 寄存器主要有如下这些寄存器。

本节实验中正点原子的示例教程里不使用SPI的DMA和中断,所以我们需要的寄存器有:

  • ECSPIx_RXDATA:Tx要发送数据
  • ECSPIx_TXDATA:Rx接收到的数据
  • ECSPIx_CONREG:控制寄存器
  • ECSPIx_CONFIGREG:控制寄存器
  • ECSSPIx_STATREG:状态寄存器

3.1 ECSPIx_RXDATA寄存器

ECSPIx_RXDATA 是32位的 Rx 接收数据寄存器,在读取Rx数据之前需要先检查 RR (Read Ready)标志位是否为1.

3.2 ECSPIx_TXDATA寄存器

ECSPIx_TXDATA 是32位的 Tx 发送数据寄存器,写到TxDATA寄存器的数据被存放到ECSPI的TX FIFO中,如果TXFIFO不满软件就可以向这个寄存器写值。

3.3 ECSPIx_CONREG 寄存器

ECSPI_CONREG 寄存器允许软件来使能/复位 ECSPI接口,设置时钟分频值,设置传输长度(Bust-Length)。我们需要使用的位如下:

  • EN bit[0]:为1使能ECSPI接口,为0去使能接口并对ECSPI进行复位。
  • HT bit[1]: 硬件翻转,手册说I.MX6ULL不支持该功能
  • XCH bit[2]:指示空闲或者Busy,本实验设置该位值为0。
  • SMC bit[3]:传输开始模式,值为1的时候需要SPI_RDY信号来控制传输开始,值为0时TXFIFO中写数据立即传输开始,本实验设置该位为0。
  • CHANNEL_MODE bit[7:4]:一个ECSPI接口支持4个通道(Channel),这里是选择4个通道的工作模式为主机模式(Master)还是从机模式(Slave),本实验使用 Channel 0,所以该位设置为0x1.
  • POST_DIVDER bit[11:8]:后级分频,值范围为0~15对应2的(0~15)次方分频。
  • PRE_DIVIDER bit[15:12]:前级分频,值范围为0~15对应1~16分频。
  • DRCTL bit[17:16]:本实验不使用
  • BUSRT_LENGTH bit[31:20]:每次突发传输长度,值范围为0~0XFFF,对应1到0x1000 bit 位,本实验设置每次突发传输长度为8位,所以设置值为7。

3.4 ECSPI_CONFIGREG寄存器

ECSPIx_CONFIGREG 寄存器允许软件来配置SPI通道的运行模式,串行时钟的极性(CPOL: Clock Polarity),串行时钟的相位(Clock Phase),数据发送波形模式(SPI Wave From)。本实验中用到的寄存器如下:

  • SCLK_PHA bit[3:0]:ECSPI接口支持4个通道(channel) ,通道0~3,配置通道0~3的 CPHA 时钟相位。
  • SCLK_POL bit[3:0]:ECSPI接口支持4个通道(channel) ,通道0~3,配置通道0~3的 CPOL时钟极性。
  • SS_CTL bit[11:8]:SPI Wave From 波形模式,配置SPI发送数据时 single bust 单突发模式,还是Multi bust 多突发模式,单突发模式每次发送数据之后等待用户再次写入数据,多突发模式会发送一个burst之后自动拉高拉低SS线并再次发送TXFIFO中的下一个数据知道TXFIFO为空。本实验选择多突发模式。
  • DATA_CTL(bit19:16):设置 DATA 信号线空闲状态电平, DATA_CTL[3:0]分别对应通道3~0,为 0 的话 DATA 空闲状态为高电平,为 1 的话 DATA 空闲状态为低电平。
  • SCLK_CTL bit[23:20]:设置 SCLK 信号线空闲状态电平, SCLK_CTL[3:0]分别对应通道3~0,为 0 的话 SCLK 空闲状态为低电平,为 1 的话 SCLK 空闲状态为高电平

3.5 ECSPIx_STATREG

ECSPIx_STATREG 状态寄存器指示ECSPI接口的 TxFIFO和 RXFIFO的状态,本实验我们需要使用的是:

  • TC(bit7):传输完成标志位,为 0 表示正在传输,为 1 表示传输完成。
  • RO(bit6): RXFIFO 溢出标志位,为 0 表示 RXFIFO 无溢出,为 1 表示 RXFIFO 溢出。
  • RF(bit5): RXFIFO 空标志位,为 0 表示 RXFIFO 不为空,为 1 表示 RXFIFO 为空。
  • RDR(bit4): RXFIFO 数据请求标志位,此位为 0 表示 RXFIFO 里面的数据不大于
  • RX_THRESHOLD,此位为 1 的话表示 RXFIFO 里面的数据大于 RX_THRESHOLD。
  • RR(bit3): RXFIFO 就绪标志位,为 0 的话 RXFIFO 没有数据,为 1 的话表示 RXFIFO 中至少有一个字的数据。
  • TF(bit2): TXFIFO 满标志位,为 0 的话表示 TXFIFO 不为满,为 1 的话表示 TXFIFO 为满。
  • TDR(bit1): TXFIFO 数据请求标志位,为 0 表示 TXFIFO 中的数据大于 TX_THRESHOLD,为 1 表示 TXFIFO 中的数据不大于 TX_THRESHOLD
  • TE(bit0): TXFIFO 空标志位,为 0 表示 TXFIFO 中至少有一个字的数据,为 1 表示 TXFIFO为空。

3.6 ECSPI_PERIODREG

寄存器 ECSPIx_PERIODREG,这个是 ECSPI 的采样周期寄存器。寄存器 ECSPIx_PERIODREG 用到的重要位如下:

  • CSD_CTL(bit21:16): 片选信号延时控制位,用于设置片选信号和第一个 SPI 时钟信号之间的时间间隔,范围为 0~63。
  • CSRC(bit15): SPI 时钟源选择,为 0 的话选择 SPI CLK 为 SPI 的时钟源,为 1 的话选择32.768KHz 的晶振为 SPI 时钟源

关于 ECSPI 的寄存器就介绍到这里,关于这些寄存器详细的描述,请参考《I.MX6ULL 参
考手册》第 805 页的 20.7 小节。

4. 6轴传感器

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/657519.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Vue2基本创建项目

简单版项目初始化 新建一个vue2 官网文档:介绍 — Vue.js 先确保下载了vue的脚手架 npm install -g vue-cli npm install -g vue/cli --force vue -V 创建项目 vue create 自己起个名字 选择自己选择特性 选择: Babel:他可以将我们写…

基于模糊PID控制器的汽车电磁悬架控制系统simulink建模与仿真

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 5.完整工程文件 1.课题概述 基于模糊PID控制器的汽车电磁悬架控制系统simulink建模与仿真。 2.系统仿真结果 上面的仿真结果是无控制器和LQG的对比,以及有控制器和LQG的对比仿真。 3.核心程…

UE5 UE4 快速定位节点位置

在材质面板中,找到之前写的一个节点,想要修改,但是当时写的比较多,想要快速定位到节点位置. 在面板下方的 Find Results面板中,输入所需节点,找结果后双击,就定位到该节点处。 同理,…

从0开始学会做标书:新手学习做标书制作必修(95节课)

入门框架 电子标书 商务标书 文档排版 技术标书 实操演示 你是否也有同样的问题 1、做标书公司没人教、没人带? 2、如何看懂招标文件? 3、小白零基础能不能学习做标书? 4、商务标、技术标如何得高分? 5、做标书需要什么软件? 6、如何制作电子标书? 7、如何避…

AI菜鸟向前飞 — LangChain系列之十五 - Agent系列:从现象看机制(中篇)一个Agent的“旅行”

Agent基本架构 先谈谈Agent基本架构概念,如果看得云里雾里,等看完本篇之后,再回头看就会豁然开朗的,而我尽量写得更易懂: ) 这里面会穿插着上一篇的内容,请大家记得往回翻翻,传送门&…

软件性能测试有哪些测试类型和方法?

软件性能测试是一种通过模拟真实用户使用情况,评估软件系统在各种压力和负载下的表现的测试方法。在今天这个讲究效率的时代,软件性能测试是不可或缺的一环。它能帮助开发人员和企业发现潜在的性能问题,提前优化改进,保证软件系统…

一些关于深度聚类以及部分对比学习的论文阅读笔记

目录 资料SwAV问题方法方法的创新点为什么有效有什么可以借鉴的地方聚类Multi-crop 代码 PCL代码 Feature Alignment and Uniformity for Test Time Adaptation代码 SimSiam 资料 深度聚类算法研究综述(很赞,从聚类方法和深度学习方法两个方面进行了总结&#xff0…

OSINT 与心理学:通过开源情报进行剖析和行为分析

在不断发展的心理学领域,人们越来越认识到通过应用开源情报 (OSINT) 方法取得进步的潜力。OSINT 主要以其在安全和情报领域的应用而闻名,并且越来越多地展示其在心理分析和行为分析方面的潜力。本文探讨了 OSINT 和心理学的迷人交叉点,研究如…

JUC笔记

1、什么是 JUC JUC就是 java.util 下的工具包、包、分类等。 普通的线程代码: ThreadRunnable 没有返回值、效率相比入 Callable 相对较低!Callable 有返回值! 2、线程和进程 线程、进程,如果不能使用一句话说出来的技术&#x…

Firefox浏览器网页上的按钮点击无效解决办法

我在github下点下载经常不好使,查了原因,原来是浏览器的问题。在Firefox浏览器的设置里面,去掉一些cookies的禁用即可。之后,就可以点击按钮成功响应了。

让大模型更聪明——复杂而艰巨的任务

一、引言 在人工智能领域,大模型因其强大的数据处理能力和复杂的结构,成为了推动技术进步的重要力量。然而,要让大模型真正展现出“聪明”的特质,即具备高度的人类智能水平,仍是一项极具挑战性的任务。本文将从数据质…

Clickhouse Bitmap 类型操作总结—— Clickhouse 基础篇(四)

文章目录 创建 Bitmap 对象Bitmap 转换为整数数组计算总数(去重)值指定start, end 索引生成子 Bitmap指定 start 索引和数量限制生成子 Bitmap指定偏移量生成子 Bitmap是否包含指定元素两个 Bitmap 是否存在相同元素一个是否为另一个 Bitmap 的子集求最小…

[机缘参悟-191] - 《道家-水木然人间清醒1》读书笔记 -14- 关系界限 - 经济和人格上的独立,走向成熟的必经之路,才能更好的谈其他情感(IT)

目录 前言: 1、“友善的孤独者” 2、“外向的孤独者” 3、道不同不相为谋 4、警惕依赖 5、完整独立的个体 6、不必纠正他人的错误,除非他影响了你 7、不再期待别人能理解自己,只有高维向下兼容你的人才能理解你 8、只有高维和同频的…

简单得阴影引导实现

效果如下: 实现方式: 1、引入三方库: implementation io.github.razerdp:BasePopup:3.2.0 2、代码实现 class NewUserGuide3Popup : BasePopupWindow {constructor(activity: Activity) : super(activity)constructor(context: Context) : super(con…

【ArcGIS For JS】前端geojson渲染行政区划图层并加标签

原理 通过DataV工具 生成行政区的geojson(得到各区的面元素数据), 随后使用手动绘制featureLayer与Label,并加载到地图。 //vue3加载geojson数据public/geojson/pt.json,在MapView渲染上加载geojson数据 type是"MultiPolygon"fetc…

K-means 聚类模型详解

K-means 聚类模型详解 K-means 是一种常用的无监督学习算法,用于将数据集分成 K 个簇。其目标是最小化各个簇内数据点到簇中心的距离平方和。K-means 广泛应用于图像压缩、市场细分、模式识别等领域。 算法步骤 初始化: 随机选择 K 个初始簇中心(质心…

APM2.8内置罗盘校准

如果你有外置罗盘,可以不用校准内置罗盘,可以忽略此文。推荐使用外置罗盘,内置罗盘容易受干扰。 使用内置罗盘需要插入飞控GPS接口旁边的跳线帽。如图: 如果要使用内置罗盘,而又加了GPS的,记得一定要把GPS…

美光拟投巨资在日本广岛建DRAM厂,目标2027年底投产

美光科技(Micron Technology)据日本媒体报道,计划在日本广岛县新建一座DRAM芯片生产工厂,目标最快于2027年底投入运营。这一举措标志着美光在增强其内存芯片生产能力方面的又一重大步伐。 报道称,新工厂的总投资规模预…

【Qt秘籍】[003]-Qt环境变量配置-磨刀不误砍柴工

一、为什么要设置环境变量 ?[原因] 配置PATH环境变量的主要用处在于让操作系统能够识别并执行不在当前工作目录下的可执行文件。具体来说,它的作用包括: 命令执行便捷性:当你在命令行输入一个命令(如java, python或np…

152.找出峰值(力扣)

代码解决 class Solution { public:// 函数用于找到山峰元素的索引vector<int> findPeaks(vector<int>& mountain) {vector<int> result; // 用于存储山峰元素的索引// 遍历数组&#xff0c;从第二个元素到倒数第二个元素for(int i 1; i 1 < mount…