S32K3系列单片学习LPSPI是什么

news2025/1/10 1:35:35

前言

通过前面的学习,已经可以实现最基础的引脚配置功能了,并实现了点亮LED的程序。下面将记录一下,S32K3的SPI模块的配置方法,以及注意事项。

一、LPSPI介绍

**LPSPI:LOW POWER Serial Peripheral Interface**

1.概述

所有LPSPI支持最大数据速率15 MHz的附加板和7.5MHz的标准版。
LPSPI0实例在loopback模式下支持20MHz,在normal模式下支持15MHZ;
所有6个LPSPI模块Tx和Rx支持DMA访问。
可配置时钟极性和时钟相位。
每个SPI 具有 2 个 4 字深度的 FIFO 分别缓冲 TX 与 RX 信息。
每个LPSPI实例支持多个芯片选择。
在主模式下灵活定时,包括SCK频率,占空比和PCS与SCK边缘之间的延迟。
TXMASK和RXMSK为半双工或匹配功能。
支持半双工传输,支持在每个时钟边缘上发送或接收1/2/4/8位。
在这里插入图片描述

每个SPI均具有多个片选信号线,其中SPI0具有8个外部片选信号线。

2.时钟配置

在这里插入图片描述

高性能的SPI0以外设桥平台时钟AIPS_PLAT_CLK为总线时钟源,其他SPI以外设桥时钟作为总线时钟源。总线时钟源输入SPI 后,根据 SPI 预分频值得到用于度量时序参数的功能时钟,最后由功能时钟分频得到输出的 SPI 同步时钟信号 SCK根据时钟源的配置SPI0 回环模式下支持 20M 波特率,普通引脚下 15M ;其他 SPI 模块回环模式下 15M ,普通模式下 7.5M。

3.功能框图

在这里插入图片描述

1.控制逻辑:负责管理模块工作参数与通信参数,通过配置寄存器与 TXFIFO写入参数;
2.移位寄存器:将传输数据移出到总线与将数据移入 RXFIFO
3.FIFO:分为两类,发送 FIFO 与接收 FIFO ,总共 4 字深度。其中传输命令字也通过TXFIFO 写入控制逻辑;
4.SPI外部接口:连接引脚与 IO 信号;

二、使用步骤
1.引脚配置
在这里插入图片描述

例程使用的是LPSPI0,参数选择默认即可。

2.外设配置

SPI配置界面将 SPI 模块抽象化为三个功能部分,分别为 Name SpiDriver
SpiGeneral 。其中 Name 模块用于更上层的抽象定义 如 MCAL)MCAL),保持默认即可;我们主要讨论 SpiDriver SpiGeneral 两个模块的配置;
SpiGeneral界面主要负责配置 SPI 物理模块参数的配置(即硬件参数),如全局 DMA支持,同步传输定时器的选择, SPI 模块号与主从模式的配置, DMA 通道的选择等。有多少个 SPI 模块就需要在 SpiPhyUnit 中加入对应项数。
在这里插入图片描述

SPI Driver 配置界面主要负责配置 SPI 通信参数与传输命令字,由于通信参数与连接
的外设芯片相关,所以也被称为 externalDevice 配置。该界面主要可配置波特率,
PCS 片选信号线的选择,时钟极性与时钟相位,帧数据长度与格式、时钟延迟参数以及是否使能连续传输功能等。当配置完成后,通过SpiHwUnit 参数将此 externalDevice 配置映射到前面提到物理模块项。这种将物理模块与外设通信参数分离的设计思路可以很方便地应对 1 个 SPI 连接多个外设的情况。
在这里插入图片描述

值得注意的是SpiHwUnit中的选项就对应着SpiGeneral栏中的SpiphyUnit。这样我们就可以配置多个SPI芯片,对应一个SPI模块。

3.时钟配置

在这里插入图片描述

4.常用API

Lpspi_Ip_StatusType Lpspi_Ip_Init(const Lpspi_Ip_ConfigType *PhyUnitConfigPtr)
初始化指定的SPI HW实例。应该在调用所有其他API函数之前调用它。
Lpspi_Ip_StatusType Lpspi_Ip_UpdateTransferMode(uint8 Instance, Lpspi_Ip_ModeType Mode)
此函数更新指定SPI硬件微控制器外设的异步机制模式。
Lpspi_Ip_HwStatusType Lpspi_Ip_GetStatus(uint8 Instance)
这个函数返回指定SPI硬件微控制器外设的状态。
Lpspi_Ip_StatusType Lpspi_Ip_SyncTransmit(
                                            const Lpspi_Ip_ExternalDeviceType *ExternalDevice,
                                            uint8 *TxBuffer,
                                            uint8 *RxBuffer,
                                            uint16 Length,
                                            uint32 TimeOut
                                         )
调用SyncTransmit 函数执行一次同步传输,在函数内部获取计数器值进行计时,并
将数据依次推入 TDR 寄存器中发送。

5.Demo

应用程序使用SPI驱动程序以半双工模式传输数据
-通过LPSPI0(MASTER)传输10帧8位,通过LPSPI2(SLAVE)传输10帧8位
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Unity3d数字化看板-多关节机器人运动控制

特殊:机器人多关节跟随运动 机械手运动控制主要是关节的旋转,通过控制多个关节的角度,实现对机械手的同步控制 机械手运动控制,可以分解为多个关节的运动,下一关节是跟随在上一关节运动,在处理模型的时候…

小案例CSS

代码&#xff1a; <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <meta http-equiv"X-UA-Compatible" content"IEedge"> <meta name"viewport" content"widthde…

一个基于 go 实现的轻量级任务调度框架

github 地址&#xff1a;GitHub - memory-overflow/light-task-scheduler: 一个go语言的轻量级的快速实现任务调度的框架&#xff0c;并且支持有状态任务的持久化&#xff0c;并发控制和超时控制。 框架的设计思想和背景 业务后台开发&#xff0c;经常会遇到很多并发低&#…

QT笔记——属性栏之QtPropertyBrowser下载配置

我们常常看到Qt Designer如下图&#xff0c;属性栏 环境&#xff1a;vs2019 qt 5.12.2 QtPropertyBrowser 下面我将介绍如何去下载和安装配置 QtPropertyBrowser&#xff0c;使用的是.dll和.lib 第一种方式&#xff1a;编译qt4 源码的方式 然后修改为qt5 的形式 第一步&am…

Ext JS 4实现合并行单元格

目录 文件 最后由 oscar999 在 几秒前 编辑 有一位朋友咨询了一个问题: 在Ext JS 4中, 如何合并行的单元格, 已经选取的时候只能选择某一列, 期望的效果如下: 在Ext JS 中, 合并表头的列有现成方案, 但是合并行单元格不是extjs的现有功能,这个需要底层扩展, 也就是使…

云原生(docker+k8s+阿里云)-Docker

Gitee-Kubernetes学习 kubectl备忘清单 k8s官方文档-task [云原生-kubectl命令详解] ingress详解 ingress官方文档 云原生-语雀-架构师第一课 从Docker到Kubernetes进阶-社区 云计算学习路线-阿里云大学 如上图&#xff0c;服务器有公网ip和私网ip&#xff0c;公网ip是外部访问…

AWT-对话框——Dialog以及其子类FileDialog

Dialog: Dialog时Window类的子类&#xff0c;时一个容器类&#xff0c;属于特殊组件。对话框是可以独立存在的顶级窗口&#xff0c;因此用法与普通窗口的用法几乎完全一样&#xff0c;但是使用对话框需要注意以下几点&#xff1a; 对话框通常依赖于其它窗口&#xff0c;就是通…

分布式系统通信中使用安全套接字(SSL/TSL)

协商加密和认证算法 SSL的设计&#xff0c;可以在链接的两端初始化握手通信时&#xff0c;在进程间协商加密和认证的算法。 因此可能出现在通信双方没有足够的公共算法导致链接尝试失败的情况。 自举安全通信 通过混合协议建立安全通道。 使未加密的通信进行初始化交换&#xf…

【论文笔记】SwinIR: Image Restoration Using Swin Transformer

声明 不定期更新自己精度论文&#xff0c;通俗易懂&#xff0c;初级小白也可以理解 涉及范围&#xff1a;深度学习方向&#xff0c;包括 CV、NLP、Data Fusion、Digital Twin 论文标题&#xff1a;SwinIR: Image Restoration Using Swin Transformer 论文链接&#xff1a;http…

IDAPython入门基础语法

文章目录 参考文章IDAPython简介常用函数获取界面地址的函数数值获取函数数值判断函数patch操作函数去除花指令实例 参考文章 IDAPython入门教程 基于IDA7.5_Python3 第一讲 简介与地址获取 IDAPython简介 IDAPython拥有强大的功能,在使用IDA分析程序时非常有用,可以简化许多…

队列的实现

队列 简介 队列是一种线性表的特殊形式&#xff0c;特殊之处在于它只允许在表的前端&#xff08;front&#xff09;进行删除操作&#xff0c;而在表的后端&#xff08;rear&#xff09;进行插入操作&#xff0c;和栈一样&#xff0c;队列是一种操作受限制的线性表。进行插入操…

信息安全复习五:数据加密标准(DES)

一、本章梗概 1.主要内容&#xff1a;分组密码、分组密码用到的关键技术和结构、对称密钥密码典型算法DES 2.思考问题&#xff1a; ①按照明文被处理的形式&#xff0c;DES属于标准的什么密码 ②根据密钥的使用数量&#xff0c;DES属于标准的什么密码 3.内容回顾&#xff1a; …

力扣sql中等篇练习(十二)

力扣sql中等篇练习(十二) 1 产品销售分析 ||| 1.1 题目内容 1.1.1 基本题目信息 1.1.2 示例输入输出 1.2 示例sql语句 # Write your MySQL query statement below SELECT s1.product_id,s1.first_year,s2.quantity,s2.price FROM (SELECT product_id,Min(year) first_yearF…

基于趋动云的chatGLM-6B模型的部署

首先根据官方示例教程&#xff0c;学会怎么创建项目&#xff0c;怎么使用数据&#xff0c;怎么进入开发环境&#xff0c;以及了解最重要的2个环境变量&#xff1a; 这个是进入开发环境以后的代码目录 $GEMINI_CODE 这个是引用数据集后&#xff0c;数据集存放的路径 $GEMINI_DA…

学生信息管理系统简易版(文件读写操作)

功能模块 具体功能如下&#xff1a; 添加学生信息修改学生信息&#xff08;按学号&#xff09;排序&#xff08;分别按总分升序、降序、以及按姓名升序&#xff09;查找学生&#xff08;按学号&#xff09;删除学生查看所有学生信息 数据结构体设计 本表设计一个学生信息的结…

computed和watch

computed: 写法&#xff1a; import {computed} from vue setup(){ --- //计算属性—简写 let fullName computed(()>{ return person.firstName - person. lastName}) //计算属性-完整 let fullName computed({ get(){ return person.firstName - person. lastName},…

中小企业真的需要CRM吗?

如果你的企业没有CRM客户关系管理系统&#xff0c;企业主需要问问自己&#xff0c;他们将利用什么来扩展业务。福布斯进行的研究恰当地表明&#xff0c;充分利用CRM系统的企业可以将销售额提高29%。 中小企业定期产生大量客户&#xff0c;这可能会难以管理。这正是CRM系统在有…

Esxi8.0安装Ubuntu系统教程

本篇教程主要教大家怎么在ESXi8.0虚拟机上安装Ubuntu系统&#xff0c;首先安装Ubuntu需要准备一个ISO系统镜像文件&#xff0c;我们可以去Ubuntu官网下载。 Ubuntu官网&#xff1a;https://ubuntu.com/download/desktop 点击【Download】即可下载Ubuntu的ISO系统镜像文件 ESXi…

必学宝典 黑马《最新JavaWeb开发教程》上线

对于程序员&#xff0c;所在的行业更迭实属过快&#xff0c;如果是为了找一份好工作&#xff0c;学技术前一定要先了解技术在市场中的需求情况。不然等你学完之后&#xff0c;才发现自己学了已被淘汰、过时的技术&#xff0c;白白浪费了宝贵的学习时间&#xff0c;后悔都来不及…

网络编程代码实例:传输控制协议(TCP)简单版

文章目录 前言代码仓库内容代码&#xff08;有详细注释&#xff09;server.cclient.cMakefile 结果总结参考资料作者的话 前言 网络编程代码实例&#xff1a;传输控制协议&#xff08;TCP&#xff09;简单版。 代码仓库 yezhening/Environment-and-network-programming-examp…