OpenEdv-开源电子网

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

SPI数据长度设置为8位,但接收数据缓存却是16位

[复制链接]

1

主题

1

帖子

0

精华

新手入门

积分
12
金钱
12
注册时间
2019-1-22
在线时间
3 小时
发表于 2021-4-23 08:59:10 | 显示全部楼层 |阅读模式
1金钱
在STM32WLE5JC单片机中SPI数据长度设置了8位,并且相应的接收FIFO阈值也设成了8位,但最后收发数据是却是16位
1.传输过程中的SPI-CR2寄存器如下:

从图中可以看出CR2为0x1708,FIFO的阈值设置的是8位,但是DR的数据长度却是16位:0x0130
2.STM32WL中的CR2寄存器描述如下:


最佳答案

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

SPI数据寄存器是16位的,参考datasheet,设置8位的时候只有低8位有效,高8位会被随机填充
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

11

主题

2131

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4734
金钱
4734
注册时间
2015-1-10
在线时间
591 小时
发表于 2021-4-23 08:59:11 | 显示全部楼层
SPI数据寄存器是16位的,参考datasheet,设置8位的时候只有低8位有效,高8位会被随机填充
回复

使用道具 举报

6

主题

890

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1477
金钱
1477
注册时间
2020-8-19
在线时间
335 小时
发表于 2021-4-23 12:09:37 | 显示全部楼层
你怎么确定是16位的?
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-2-28 00:06

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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