孩子都能学会的FPGA:第三十二课——用FPGA实现一个通用的SPI主机发送模块

(原创声明:该文是作者的原创,面向对象是FPGA入门者,后续会有进阶的高级教程。宗旨是让每个想做FPGA的人轻松入门作者不光让大家知其然,还要让大家知其所以然!每个工程作者都搭建了全自动化的仿真环境,只需要双击top_tb.bat文件就可以完成整个的仿真(前提是安装了modelsim),降低了初学者的门槛。如需整个工程请留言(WX:Blue23Light),不收任何费用,但是仅供参考,不建议大家获得资料后从事一些商业活动!

上节课我们实现了CPOL=0CPHA=0SPI主机的发送,现在我们要做一个通用的SPI主机的发送,就是支持POL=0/1CPHA=0/1的4种组合情况,通过参数进行传递的方式选择4种不同的模式。仔细看一下下图,MOSI的第1个数据是发送数据的第1位,由第1个数据到第2个数据的变化都是在半个SCK的时钟后,也就是说设计FPGA的时候,刚开始的前半个周期的SCK的变化不会引起MOSI的变化,最后半个周期的SCK的变化也不会引起MOSI的变化,对于N位数据的传输,FPGA开始的时候发送最高位,后续只需要把数据左移N-1次,就可以完成N位数据的串行发送,所以移位操作是N-1次。

以上节课的为例,CPOL=0CPHA=0,仿真波形如下所示,shift用来标识何时MOSI的信号进行变化。SPIsalve端会在SCK的上升沿采集数据,能够采集正确。

如果上节课的代码直接改成CPOL=0CPHA=1,仿真波形如下,shift会在开始的位置多了一次使能,造成数据多移位一次,SPIsalve端会在SCK的下升沿采集数据,很明显采集不到正常的数据,从而数据传输错误。

下面我们开始SPI通用主机发送模块的设计,主要改动是增加了三个参数CPOL,CPHACS_POL,CPOL定义了SCLK时钟线空闲状态时的电平,CPHA定义了数据位相对于时钟线的时序,CS_POL定义了使能信号的电平,就是spi_cs信号是高电平有效还是低电压有效。

定义了一个delta的参数,是一次SPI通信后过多常长时间将spi_over信号使能,上节课是直接使能的,本节课可以通过参数进行控制。和上节课最大的区别是定义了shift_domain,在该信号使能的情况下数据才可以发送,主要用来控制shift信号在开始或者结束的位置多一次触发。shift是在上升沿触发还是在下降沿触发通过产生CPHA控制,spi_cs信号通过参数CS_POL来控制是高电平有效还是低电平有效。

和上节课不同的是spi_cs信号和spi_over信号,如下所示。

通过参数CPOL来控制时钟在空闲状态下的电平,同时设置了数据移位的shift_domain,在SPI开始的前半个spi_sck和最后的半个spi_sck周期内不允许数据移位。

最后通过参数CPHA来控制spi_mosi上的信号是在spi_sck时钟的上升沿变化还是时钟的下降沿变化。

最后新建仿真的tb文件,用随机数进行仿真,其中CPOL=0,CPHA=0时的仿真波形如下,符合设计要求。

CPOL=1,CPHA=0的仿真波形如下,符合设计要求。

CPOL=0,CPHA=1的仿真波形如下,符合设计要求。

CPOL=1,CPHA=1的仿真波形如下,符合设计要求。

查看modelsimTranscript窗口,spi_master发送的数据和spi_slave接收的数据一致,设计功能正常。

上述的SPI通用主机发送模块仅仅需要根据实际情况修改参数就可以适用于绝大多数SPI接口的主机通信,通用性非常好。

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

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

相关文章

二百一十五、Flume——Flume拓扑结构之复制和多路复用的开发案例(亲测,附截图)

一、目的 对于Flume的复制和多路复用拓扑结构,进行一个小的开发测试 二、复制和多路复用拓扑结构 (一)结构含义 Flume 支持将事件流向一个或者多个目的地。 (二)结构特征 这种模式可以将相同数据复制到多个channe…

使用python向neo4j中批量导入txt和csv三元组数据

1.导入txt文件 数据示例: (头实体,关系,尾实体) (头实体,关系,尾实体) 。。。。。。在执行python代码之前在neo4j中执行这个命令,清空所有节点 match (n) d…

微信生态下的私域流量载体有哪些?

私域流量的本质就是:降低我的获客成本,提高我产品服务的复购率,增加我和用户之间的粘性,挖掘用户的终身价值。 私域流量一般我们特指微信体系的个人号、公众号、社群和小程序,现在朋友圈和视频号也成为了打造微信私域…

HubSpot和AI的完美结合:解锁业务增长密码

随着数字化时代的发展,智能营销已经成为企业走向成功的关键之一。在这个领域的领先者之一,HubSpot积极整合人工智能(AI)技术,为数字营销、销售和服务带来了新的可能性。今天运营坛将带领大家深入探讨HubSpot和人工智能…

活动预告 | 微盟技术沙龙 - Elasticsearch 在微盟的实践 12/21/2023

微盟技术沙龙 「微盟技术沙龙」是由微盟研发中心发起并联合各方小伙伴为开发者举办的系列技术沙龙,从用户,产品,技术等方面与开发者进行交流。 微盟技术沙龙关注开发者在实际应用中遇到的问题。提供最真实的干货,以技术会友&…

GPU 性能测试软件:GPU-Z,2023 年 9 月 12 日更新

GPU-Z是一款用于Windows操作系统的免费工具,它用于查看和监控计算机的图形处理单元(GPU)信息。这个工具是专为计算机硬件爱好者、游戏玩家、系统管理员和技术支持人员设计的 GPU-Z 的特点 GPU信息:GPU-Z能够显示关于您计算机中G…

命令执行 [BUUCTF 2018]Online Tool1

打开题目 我们代码审计一下 if (isset($_SERVER[HTTP_X_FORWARDED_FOR])) { $_SERVER[REMOTE_ADDR] $_SERVER[HTTP_X_FORWARDED_FOR]; } 如果存在xxf头且不为空,则将xxf头内容(真实的客户端ip)赋给ROMOTE_ADDR(代理服务器传过…

如何使用蜘蛛池蚂蚁SEO

​蜘蛛池是一种利用搜索引擎爬虫进行推广营销的方式。它的核心是建立一个能够吸引搜索引擎爬虫的网站群,这些网站能够产生大量的优质内容,并形成一个巨大的网站群,从而吸引更多的搜索引擎爬虫。 如何联系蚂蚁seo? baidu搜索&…

【C语言(十二)】

数据在内存中的存储 一、整数在内存中的存储 整数的2进制表示方法有三种,即 原码、反码和补码 有符号的整数,三种表示方法均有符号位和数值位两部分,符号位都是用0表示“正”,用1表示“负”,最高位的⼀位是被当做符号…

赠与婚外情人1百余万,主张全额返还获支持

丈夫婚内出轨,并瞒着妻子给情人转账177万余元,最终被妻子发现诉至法院。近日,湖南省湘阴县人民法院审理了一起不当得利案件,认定丈夫的赠与行为无效,支持了妻子全额返还的诉讼请求。   男子钱某与女子赵某于2020年6月…

无参数RCE知识点

什么是无参数RCE? 无参rce,就是说在无法传入参数的情况下,仅仅依靠传入没有参数的函数套娃就可以达到命令执行的效果 核心代码 if(; preg_replace(/[^\W]\((?R)?\)/, , $_GET[code])) { eval($_GET[code]); } 这段代码的核心就是只…

西工大计院计算机系统基础实验二(配置gdb插件)

第二次实验是二进制炸弹实验,为了简化操作,并且让大家接下来能够按照作者之前已经为网安院写好的博客西工大网络空间安全学院计算机系统基础实验二(清楚实验框架及phase_1)-CSDN博客来走,大家需要下载一款好用的gdb插件…

java基础进阶之List和Set和Map

1、list List本身是一个接口,该接口继承自Collection接口,它有两个常用的实现子类ArrayList和LinkedList。从功能特性上来看,List是有序、可重复的单列集合,集合中的每个元素都有对应的顺序索引,我们可以通过该索引来访…

canvas基本绘制对象

目录 绘制画布 设置画布 绘制圆形 绘制矩形填充渐变色 绘制文字及文字样式 绘制画布 <canvas id"canvas" width"800" height"600"></canvas> 设置画布 //获得画布元素var canvasdocument.getElementById(canvas);var ctxca…

基于Java (spring-boot)的二手物品交易平台

​ 一、项目介绍 1、管理员功能 &#xff08;1&#xff09;登录&#xff1a;管理员能够根据账号访问系统。 &#xff08;2&#xff09;用户管理&#xff1a;管理员可以添加、删除、修改用户信息&#xff0c;查看用户列表&#xff0c;对用户进行管理和控制。例如&#xff0c…

Python将Labelme文件的标注信息绘制到图片上

Python将Labelme文件的标注信息绘制到图片上 前言前提条件相关介绍实验环境Python将Labelme文件的标注信息绘制到图片上代码实现输出结果 前言 由于本人水平有限&#xff0c;难免出现错漏&#xff0c;敬请批评改正。更多精彩内容&#xff0c;可点击进入Python日常小操作专栏、O…

利用docker部署Node-RED

利用Docker部署Node-RED可以通过以下步骤进行&#xff1a; 1. 安装Docker&#xff1a;首先&#xff0c;确保你的计算机上已经安装了Docker。你可以从Docker官网下载并安装适合你操作系统的版本。 2. 创建Docker镜像&#xff1a;在Dockerfile中&#xff0c;编写一个包含Node-RED…

Java面试整理-多线程

Java多线程(Java Multithreading)是Java编程语言中的一个核心概念,它允许程序同时执行多个任务。在多线程环境下,CPU可以在不同的线程之间迅速切换,使得似乎多个任务在同时进行,这对于提高应用程序的性能和响应速度非常重要。 在深入讨论多线程之前,我们可以先对比一下线…

react dom的diff理解及性能优化

diff的三大过程 当某个值变化时&#xff0c;他从根组件寻找 (key,state,props,context) 当父组件稳定时&#xff0c;react会跳过子组件的props的对比 只有当当前组件值改变时&#xff0c;从他开始&#xff0c;所有的子孙节点都会对比props props是全等比较&#xff0c;所以&am…