历史上的今天
今天是:2024年09月17日(星期二)
2021年09月17日 | KST-STM学习之I2C+SPI
2021-09-17 来源:eefocus
只能说跟51的差不了多少,在这里仅仅记录下主要注意事项吧。
1、I 2 C 通信分为标准模式 100kbit/s、快速模式 400kbit/s 和高速模式 3.4Mbit/s。因为所有的I 2 C 器件都支持标准模式,但却未必支持另外两种速度。
所以作为通用的 I 2 C 程序我们选择100k 这个速率来实现,也就是说实际程序产生的时序必须小于等于 100k 的时序参数,有特殊速度需求的器件再针对性写高速通信程序。
2、I 2 C 引脚属于开漏并联结构,并且 STM32 的 GPIO 端口引脚设置为开漏输出时,可以直接从输入数据寄存器获取 I/O 电平状态,因此将 I 2 C 引脚配置为开漏输出模式。
3、由于 I 2 C 总线空闲时默认为高,初始化时还需要设置引脚输出高电平,不过设置引脚输出高电平并不是在初始化之后,而应该放在初始化之前。
这是因为 STM32 在上电复位时 I/O 口为高阻状态,复位结束后,GPIO 端口引脚默认为浮空输入,由于上拉电阻的存在,I 2 C 引脚被拉高;
当程序执行到 I 2 C 初始化时又被配置为开漏输出模式,由于 GPIO 端口输出数据寄存器初始值默认全为 0,初始化后 I/O 口输出低电平,如果初始化之后再设置引脚输出高电平,势必会在I/O 口上产生一个低电平的毛刺。
如果在 I 2 C 引脚初始化之前先设置输出数据寄存器相应位为高,初始化 I 2 C 引脚后,I/O 口会直接输出高电平,避免毛刺信号。

4、实际上 I 2 C 的配置过程比较复杂,比如要充分考虑冲突和仲裁等处理方式,但是那些处理方式在绝大多数场合用不到。STM32F103 系列自带的 I 2 C 协议模块设计的过于复杂,对于实际应用来讲实用性不强,因此实际应用 I 2 C 时,还是用 IO 口直接模拟协议。
5、即在 SCK 的第一个时钟边沿还要早半个时钟周期时,SPI 主机就已经开始输出数据了,但是 SPI 从机却是在片选 SSEL 置低后开始输出数据,总之 SPI 设备输出数据要早于 SCK,这也是为什么 SPI 通信时要先使能片选。
6、SPI 和 I2C的对比

7、SPI接口

8、引脚连接

9、SPI外设

SP3需要注意的地方
NSS需要注意的地方

几个需要注意的地方(标黄的)

10、配置流程

11、SPI的发送接收与USART的对比

12、数据传送过程

发送完成的判断,需要注意

那么应该怎么判断呢?

假如在TXE = 0 的时候仍然向SPI_DR写入数据

13、霸气。。。

14、SPI查询方式接收和发送的注意点
史海拾趣
|
该系统采用的是Qt4做的应用程序,供银行排队叫号系统使用,图片上的前端应用,实际还有Qt4编写的后台设置程序(需通过“秘密通道”打开) 外接输入输出设备有: 1. 银联刷卡器 2. USB小键盘 3. 串口打印机(串口控制模块) 4. 超声波触摸屏(串口 ...… 查看全部问答> |
|
最近,想研究一下rc电路,并阅读了不知道谁写的一本书《RC电路及其应用》,有了一点体会,描述如下. RC电路一大应用时消火花电路。产生火花电路大都是应用于感性负载,如电机、继电器线圈等 如图所示,当开关k断开时候,根据楞次定律线圈两端产 ...… 查看全部问答> |
|
使用VxWorks进行串口通信时遇到的诡异问题(基于Vmware) 先说一下环境,使用Vxworks5.5+Tornado2.2,BSP是Pentium4的,因为没有奔四的机器,所以在机器上用Vmware虚拟了一个机器,编译好的自启动vxworks镜像就在虚拟机上运行。一共有3台PC作了这样的设置,现在只拿两台作测试,用串口直连线连接两台PC ...… 查看全部问答> |
|
因为客户需要,我们准备开发A4/A3的车载GPS方案。 现在寻求硬件高手合作,如能提供A4/A3开发平台及相关资源的,可以额外另付一定的现金报酬。 另外,如果有方案公司愿意合作的,可以加我QQ详谈,46317857。… 查看全部问答> |
|
Beaglebone DS18B20 1602LCD(3.3V) 小弟最近在做一个基于Beaglebone的GSM无线温度报警的设计,温度传感器用DS18B20传感器,显示用1602,现在1602能够在正常的显示,但是DS18B20不能正确检测到初始化信号。(接的上拉电阻,一直检测到1,检测不到0)...原因可能因为使用usleep不准确所 ...… 查看全部问答> |








