3822|1

234

帖子

0

TA的资源

一粒金砂(高级)

楼主
 

使用spi协议,接收来自slave的数据之前写0xff的原因 [复制链接]

    今天一个1君问我为什么使用spi IP接收数据的时候要先写一个0xff到发送移位寄存器中。我一听傻愣了一下,然后就呆了。 其实我也不知道为什么,只知道要是接收时不写0xff的话接收到的数据就会出错。之前才使用spi IP核写一个flash芯片的时候就遇到这个问题,我那时看spi IP和的代码的时候并不觉得在读的时候要先写一个0xff进移位寄存器。可是我老是接收不到正确的数据,这时另一个2君和我说再读之前先写0xff进入移位寄存器。我按照此2君的说法做,结果就是读写都正确了,于是我也没有深究之前的问题。今天1君问我,我就不知道怎么回答。他这一问我就必须要弄清楚这个到底是怎么回事。经过查看spi IP核,我还是觉得写这个0xff对接收数据没有什么作用,于是我把问题定位在spi应用层面上,并不是spi IP核发送和接受逻辑上。那应用层面上是怎么回事呢?原来是spi IP核在接收的时候也把移位寄存器中的数据通过mosi发送出去了,从slave看,它通过miso发送数据给master的同时也接收来自master mosi上的数据。因为spi协议是没有反馈信号的,所以slave在发送数据的同时接收到的数据如果是slave能够识别的一个命令值的话那么这时就会对slave产生影响了。这时slave就会按照新的命令运行,然而这个命令是master在接收slave数据时不经意发送出去的,它本身是不打算发送出去的。为了解决master在接收数据的同时误发命令,所以在接收数据之前先写0xff进入移位寄存器。这样master在接收来自slave的数据的同时发送0xffslaveslave不识别0xff这个命令自然就不会影响它本身的运行了。

上面说了一大堆东西,现在你就会发送其实也不一定要写0xff是不是啊?是的,只要接收数据之前往移位寄存器写一个slave无法识别的数据就行了。

此帖出自FPGA/CPLD论坛

最新回复

这个经验好,找到了SPI核的工作过程。  详情 回复 发表于 2012-11-28 12:33
点赞 关注
 

回复
举报

1万

帖子

25

TA的资源

裸片初长成(高级)

沙发
 
这个经验好,找到了SPI核的工作过程。
此帖出自FPGA/CPLD论坛
 
 

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

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/10 下一条
Microchip 直播|利用motorBench开发套件高效开发电机磁场定向控制方案 报名中!
直播主题:利用motorBench开发套件高效开发电机磁场定向控制方案
直播时间:2025年3月25日(星期二)上午10:30-11:30
快来报名!

查看 »

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表