OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6198|回复: 5

请教SPI中发送缓冲区和移位寄存器的某些关系,高难度问题

[复制链接]

29

主题

59

帖子

0

精华

初级会员

Rank: 2

积分
170
金钱
170
注册时间
2018-8-3
在线时间
48 小时
发表于 2018-8-3 17:50:39 | 显示全部楼层 |阅读模式
1金钱
使用手册写着:
1、“当写入数据至发送缓冲器时,发送过程开始。在发送第一个数据位时,数据字被并行地(通过内部总线)传入移位寄存器,而后串行地移出到MOSI脚上;”
请问这里“第一个数据位”是什么?我之前理解的事数据写入缓冲区,自动!就并行给了寄存器,然后一位一位输出,是这样吗?
2、可是还有句话是“当数据从发送缓冲器传送到移位寄存器时,设置TXE标志(发送缓冲器空),它表示内部的发送缓冲器可以接收下一个数据;”
发送缓冲区并行给了寄存器,不代表寄存器的数据已经一位一位发出了吧,这时候如果给缓冲区下一个数据,不是会自动地并行给寄存器吗?那不就会影响数据吗?
第一次问问题,不知道是不是真的会有大神来助,期待。。



最佳答案

查看完整内容[请看2#楼]

SPI的数据发送过程是: 一、主模式 当写入数据至发送缓冲器时,发送过程开始。因为是自身是主,时钟是本设备提供的,但也是要有一个等待过程的(如时钟的上升沿或下降沿), 一旦时机到,就会将第一个数据位发送出去,在发送第一个数据位时,数据字被并行地(通过内部总线)传入移位寄存器,而后串行地移出到 MOSI脚上;数据从发送缓冲器传输到移位寄存器时TXE标志将被置位 数据被传入移位寄存器的那一时刻起,你就可以将新的 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

31

主题

1955

帖子

3

精华

论坛元老

Rank: 8Rank: 8

积分
4524
金钱
4524
注册时间
2018-5-11
在线时间
947 小时
发表于 2018-8-3 17:50:40 | 显示全部楼层
本帖最后由 warship 于 2018-8-3 20:57 编辑

SPI的数据发送过程是:
一、主模式
当写入数据至发送缓冲器时,发送过程开始。因为是自身是主,时钟是本设备提供的,但也是要有一个等待过程的(如时钟的上升沿或下降沿),
一旦时机到,就会将第一个数据位发送出去,在发送第一个数据位时,数据字被并行地(通过内部总线)传入移位寄存器,而后串行地移出到
MOSI脚上;数据从发送缓冲器传输到移位寄存器时TXE标志将被置位

数据被传入移位寄存器的那一时刻起,你就可以将新的数据写入了,这不会影响原有数据的传输的,移位寄存器在旧的数据没有发完之前是不会接受新的数据的。


二、从模式
在写操作中,数据字被并行地写入发送缓冲器。并不是无条件地马上自动传入移位寄存器。而是必须满足如下条件:
当从设备收到时钟信号,并且在MOSI引脚上出现第一个数据位时,发送过程开始(此时
第一个位被发送出去)。
这一步实现之后,然后才进行下列工作:
余下的位(对于8位数据帧格式,还有7位;对于16位数据帧格式,还有
15位)被装进移位寄存器。当发送缓冲器中的数据传输到移位寄存器时,SPI_SP寄存器的TXE
标志被设置,如果设置了SPI_CR2寄存器的TXEIE位,将会产生中断。
以上两步是分步骤执行且是有条件的。

我的开源链接 https://github.com/ShuifaHe/STM32.git  请关注,点赞支持哦。
回复

使用道具 举报

29

主题

59

帖子

0

精华

初级会员

Rank: 2

积分
170
金钱
170
注册时间
2018-8-3
在线时间
48 小时
 楼主| 发表于 2018-8-4 00:41:38 | 显示全部楼层
warship 发表于 2018-8-3 18:16
SPI的数据发送过程是:
一、主模式
当写入数据至发送缓冲器时,发送过程开始。因为是自身是主,时钟是本 ...

厉害,大神。基本解决了我的疑惑。请问有一些知识您是怎么学到的呢,比如说您说的发送过程开始也就是第一个位发送出去了,余下的7位被装进寄存器继续发。
就是看STM32说明理解出来的,还是在别的方面有了解过同样类似的呢?
我想像大神看齐
回复

使用道具 举报

31

主题

1955

帖子

3

精华

论坛元老

Rank: 8Rank: 8

积分
4524
金钱
4524
注册时间
2018-5-11
在线时间
947 小时
发表于 2018-8-4 08:23:19 | 显示全部楼层
三十岁大叔 发表于 2018-8-4 00:41
厉害,大神。基本解决了我的疑惑。请问有一些知识您是怎么学到的呢,比如说您说的发送过程开始也就是第一 ...

看你还是比较爱琢磨的,
和我某些方面类似(可以翻看一下我的有关瞎琢磨的帖子),
应该很容易超过我的。
慢慢来吧,
多琢磨,触类旁通,不用太着急。
我的开源链接 https://github.com/ShuifaHe/STM32.git  请关注,点赞支持哦。
回复

使用道具 举报

3

主题

32

帖子

0

精华

初级会员

Rank: 2

积分
56
金钱
56
注册时间
2018-8-4
在线时间
2 小时
发表于 2018-8-4 17:16:08 | 显示全部楼层
回复

使用道具 举报

26

主题

355

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1770
金钱
1770
注册时间
2017-4-1
在线时间
432 小时
发表于 2018-8-4 18:03:29 | 显示全部楼层
mark一下
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-13 15:30

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表