详细讲解Xilinx DDR3 的MIG IP生成步骤及参数含义

  前几篇文章讲解了SDRAM到DDR3各自的变化,本文讲解如何使用DDR3,在Altera的Cyclone IV开发板上一般会使用SDRAM作为存储数据的芯片,而Xilinx的S6和7000系列一般使用DDR3作为存储数据的芯片。

  从SDRAM芯片内部结构分析其原理,从内部结构讲解SDRAM与DDR的变化,从内部结构讲解DDR到DDR2的变化,从内部结构分析DDR2到DDR3的变化及DDR3原理图分析。

  SDRAM的控制器还算比较简单,一般可以通过Verilog HDL去实现,也推荐初学者写一下SDRAM的驱动,相比UART、IIC这些驱动难度还是会大一点,能够强化状态机的代码能力,另外也能充分理解SDRAM的控制流程。

  对于DDR3控制器来说,一般都是调用Altera或者Xilinx官方的MIG IP来完成设计,DDR3控制器的难度偏大,即使通过Verilog HDL写出来,性能和稳定性也未必能得到保障。

  Vivado通过调用MIG实现对DDR3的控制,用户在使用时需要了解该IP的各个参数。Xilinx提供了ug586对该IP的功能和参数进行说明,由于该IP的功能比较多,导致手册有六百八十页。涉及到DDR3相关内容也只有一百多页内容,本文结合手册对IP配置的各个参数进行讲解。

1、生成MIG IP

  首先在vivado中创建一个工程,然后添加MIG IP,如下图所示。

在这里插入图片描述

图1 添加MIG IP

  双击进入MIG配置界面后,首先如下图所示,该界面显示MIG的功能以及本工程选定的fpga器件型号,我使用的是zynq7030器件,直接进入下一步即可。

在这里插入图片描述

图2 向导界面

  进入MIG Output Option页面,该页有几个选项,意思分别如下:

  1. Create Design:创建DDR3 IP工程设计,此处勾选。

  2. 表示对已有工程引脚约束进行验证。

  3. 这个IP生成后的模块名。

  4. 由于这个IP支持多个控制器,所以这里需要选择主控的数量,FPGA使用的话一般只会存在一个。

  5. 这个IP有两种接口,默认使用的接口比较简单,适合FPGA内部使用,勾选5处会使用AXI4接口,这个接口一般给ARM端控制DDR3会比较方便,FPGA内部使用AXI4接口就是把简单的问题复杂化且浪费资源。

在这里插入图片描述

图3 MIG Output Option配置页面

  点击Next到Pin Compatible FPGAs 配置页面,如下图所示该界面可用于配置选择和当前所设定的唯一器件型号做引脚兼容的其它FPGA型号。对于可能升级器件型号的应用而言,这个功能是很实用的。本设计保持默认不做配置。

在这里插入图片描述

图4 Pin Compatible FPGAs配置页面

  点击Next进入到如下图所示的Memory Selection配置页面,该IP可以控制DDR3、DDR、LPDDR2等多种器件,所以这里需要选择这个IP具体控制哪种芯片,开发板上板载的是DDR3,这里选择“DDR3 SDRAM”即可。

在这里插入图片描述

图5 Memory Selection配置页面

  点击Next进入到如下图所示的Controller Options配置页面该配置,该界面是主要参数的配置界面之一,涉及的内容比较多。

  1、Clock Period:设置DDR3的IO时钟频率,根据开发板上实际DDR3支持的最大时钟频率进行设置,MT41K256M16RE-125最大支持800MHz的接口时钟,在加上ZYNQ 7030是K7架构,DDR3运行在800MHz时钟频率下是没有问题的。但是本文只是对IP进行测试,所以选用400MHz即可。

  2、PHY to Controller Clock Ratlo:FPGA给DDR3芯片提供的时钟频率为Clock Period,但是FPGA内部其余模块的时钟一般是运行不到Clock Period这么高的时钟频率的,所以需要给FPGA内部提供一个较低的时钟,这个参数就是用来设置DDR3接口时钟与MIG IP提供给FPGA内部其他模块的时钟(ui_clk)频率比值。

如果fpga是A7系列的芯片,那么在设置Clock Period为400MHz之后,该选项应该会被锁定为4:1,也就是说内部逻辑时钟只支持100MHz。

  由于ui_clk与DDR3接口时钟频率比值为4:1,且DDR3的数据在双沿传输,导致用户每次读写MIG IP的数据位宽是DDR3芯片数据位宽的8倍,DDR3如果数据位宽为16位,那么用户每次读写IP的数据为128位,这是不是与DDR3芯片内部的预取思路差不多?通过位宽换取时钟频率。

  3、Vccaux_io:设置bank的供电电压,一般都是锁死的,会根据DDR3时钟频率变化而变化。

  4、Memory Type:一般选择Components即可,其余几种与内存条有关吧。

  5、Memory Part:选择DDR3的型号,芯片类型不同会涉及具体的DDR3时序参数不同以及地址线和数据线的位数不同。

  6、Memory Voltage:选择芯片引脚的电平标准,DDR3一般只有1.5V和1.35V两种,根据原理图选择支持的电平的类型即可。

  7、Data Width:DDR3读写数据位宽,根据原理图选择DDR3位宽。前文介绍过核心板上有两颗DDR3芯片,采用数据线扩展方式连接,支持32位读写数据。但是本文只使用其中一块DDR3作为存储体,所有读写数据位宽为16。

在这里插入图片描述

图6 Controller Options配置页面

  8、ECC:数据线多余72为才能使用的功能。

  9、Data Mask:启用之后,可以通过一个掩膜信号去控制DDR3写入数据,本质就是去控制DDR3的DM引脚,勾不勾选无所谓,一般也不会使用此功能。

  10、Number of Bank Machies:选择bank数量,DDR3虽然有8个bank,但是如果不需要全部使用时,可以只选择部分bank,降低功耗,节约资源,默认使用4个bank。

  11、ORDERING:DDR控制器调度命令的顺序的配置,当选择strict时,严格按照命令先后顺序执行;选择normal时,为了得到更高的效率,可能对命令重排序。

  点击Next进入到如下图所示的Memory Options配置页面下。

在这里插入图片描述

图7 Memory Options配置完成后页面

  1. Input Clock Period:这个时钟是提供给MIG IP的时钟sys_clk,如下图所示为MIG IP内部时钟的结构图,sys_clk进入IP之后会先经过一个锁相环PLL,锁相环会根据这里的输入时钟产生MIG IP内部各种所需的时钟,所以sys_clk的频率选择并没有限制,下拉框中的各种频率值都可以选择。

  但是下图中还需要给MIG IP提供一个200MHz的IDELAY参考时钟,至于IDELAY的功能相比不用多说了吧,前文讲解原语时详细讲过。那么是不是可以把这两个时钟进行合并,那么FPGA就只需要给MIG IP提供一个200MHz的时钟就行了,这个200MHz时钟既是IDELAY的参考时钟又作为该IP锁相环输入时钟。

在这里插入图片描述

图8 MIG时钟结构图

  2.Read Burst Type and Length:设置为顺序读写Sequential,从SDRAM到DDR3都支持该功能,该参数在模式寄存器中进行设置,两种读写方式的区别在SDRAM的文章中详细分析过,需要了解的可以查看。

  3. Output Drive Impedance Control:输出驱动阻抗控制选择RZQ/7。

  4. On Die Termination:片上终端电阻设置为R ZQ/4。

  5. Controller Chip Select Pin:片选信号设置为Enable,如果开发板上DDR3的CS管脚未连接到FPGA,设置为Disable。

  6. Memory Address Mapping Selection:DDR和AXI总线之间的地址映射存储器地址映射选择。默认选择后者,在调用IP时,其实不会关心bank地址和行、列地址。

  点击Next进入到如下图所示的FPGA Options配置页面中,如下图所示。

在这里插入图片描述

图9 FPGA Options配置页面

  1、System Clock:设置系统时钟sys_clk的来源,图7设置为200MHz。由FPGA内部提供,不由管脚输入,选择No Buffer。如果实际硬件管脚有提供200MHz时钟,也可以选择Differential(差分输入)或Signal-Ended(单端输入)。

  2、Reference Clock:设置图8中IDELAY参考时钟200MHz的来源,由于在图7中将系统时钟设置为200MHz,可以选择Use System Clock,将两个输入时钟合并一个共用的200MH输入。如果图7中系统时钟设置不是200MHz,这里配置选项就没有“Use System Clock”,只能由管脚端口输入时钟或者FPGA内部产生这个200MHz时钟。

  3、System Reset Polarity:系统复位极性设置为ACTIVE LOW(低电平)。

  4、Debug Signal for Memory Controller:关闭存储器控制器的调试信号,如果选择ON,就会在IP中添加ILA作为调试,本文并不需要,关闭即可。

  5、Sample Data Depth:只有4设为ON,此处才能设置,就是设置ILA采集数据的深度。

  6、勾选internal Verf,允许把参考引脚作为正常的IO引脚使用。

  7、IO Power Reduction:相当于不操作时进入休眠状态降低功耗,这个一般关闭。

  8、XADC Instantiation:使能MIG IP通过XADC来获取温度,实现温度补偿,没有单独使用XADC时启用该功能。

  点击Next进入到如下图所示的Extended FPGA Option 配置页面中,其中1和2只有在HP Bank的FPGA中才会出现,HR bank没有这两个设置内容,一般默认即可。设定内部终端阻抗(Internal Termination Impedance)为50 Ohm。

在这里插入图片描述

图10 Extended FPGA Option配置页面

  点击Next进入到如下图所示的IO Planning Option配置页面中,如果当前IP仅用于仿真,可以选择New Design。本次实例最终是要进行上板测试的,则选择“Fixed Pin Out: Pre-existing pin out is known and fixed”。

在这里插入图片描述

图11 IO Planning Option配置页面

  点击Next进入到如下图所示的Pin Selection配置页面中,所有DDR3存储器相关的引脚定义引脚号以及IO电平标准的配置,需要和原理图连接相一致。有2种配置方式,其中一种配置方式是采用手动输入的方式,另一种采用导入.ucf约束文件方式,更加方便,添加约束的步骤如下图所示。

在这里插入图片描述

图12 Pin Selection配置页面

  点击OK后,如下图所示,Pin Selection页面中所有DDR3存储器相关的引脚都已经配置完成。点击按钮“Validate”做语法检查,弹出如下图所示的DRC Validation Log message窗口,表示引脚分配通过DRC检查,点击OK。

在这里插入图片描述

图13 Pin Selection配置页面管脚分配验证

  到此MIG IP的配置就基本完成了,之后的界面均点击“Next”,直到生成IP为止。

在这里插入图片描述

图14 生成MIG IP

2、总结

  生成MIG IP需要特别关注的就是时钟的设置,主要包括4个时钟信号。

  图6中1处决定DDR3芯片工作时端口时钟频率,也就是DDR3芯片的差分输入时钟频率。

  图6的2处决定MIG IP输出给用户端口的相关信号的时钟频率与DDR3芯片差分输入时钟频率的比值。根据FPGA的架构不同,该处能够设置的比值不同,对于A7架构,用户逻辑很难运行在200MHz时钟频率下,所以当1处设置为400MHz时,2处不支持设置成2:1,只能设置为4:1。但是如果FPGA架构为K7,当1处设置为400MHz,那么2处可以设置为2:1,即用户时钟接口信号的频率支持200MHz。

  图6中两处设置分别决定DDR3芯片差分时钟频率,MIG IP的用户接口信号ui_clk的频率。

  然后MIG IP还需要输入两路时钟信号,一路作为内部IDELAY延时的参考信号,固定为200MHz。

  另一路为MIG IP系统时钟,通过内部锁相环生成需要的各种频率信号,由于这一路时钟信号作为锁相环的输入,所以对频率的具体数值没有要求。因此图7的1处可以设置为任意频率的时钟信号。

  既然系统时钟信号频率可以是任意值,那么就可以将频率与参考时钟的频率设为一致,之后就可以只给MIG IP提供一路200MHz的时钟信号,这一路时钟既作为IDELAY的参考时钟信号,又作为MIG IP的系统时钟输入。这就是图7的1处和图9中部分设置。

  其余很多设置都是默认的,熟悉原理即可,MIG用户读写数据位宽与图6中2的设置和数据位宽的设置有关,最终要达到数据传输速率一致,具体问题具体分析。

  本文完成了对MIG IP的参数分析和设置,生成了IP,下文将讲解生成IP的各个信号的含义,以及对该IP的仿真及上板验证。


  如果对文章内容理解有疑惑或者对代码不理解,可以在评论区或者后台留言,看到后均会回复!

  如果本文对您有帮助,还请多多点赞👍、评论💬和收藏⭐!您的支持是我更新的最大动力!将持续更新工程!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

腾讯云8核16g服务器性能好不好?亲测并发数支持人数

腾讯云8核16G轻量服务器CPU性能如何?18M带宽支持多少人在线?轻量应用服务器具有100%CPU性能,18M带宽下载速度2304KB/秒,折合2.25M/s,系统盘为270GB SSD盘,月流量3500GB,折合每天116.6GB流量&…

AHU 人工智能实验-CCA

神经网络覆盖算法——CCA(基于Ling Zhang 和Bo Zhang论文) Abstract 在这篇文章中我将介绍基于张铃和张钹学者提出的CCA算法,并实现代码复现,给出使用的数据集,以及实验结果对比。 1. Introduction 1.1 Background 我们知道自…

外包干了6天后悔了,技术明显进步。。。。。

先说一下自己的情况,本科生,19年通过校招进入广州某软件公司,干了接近3年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…

[虚拟机保护逆向] [HGAME 2023 week4]vm

[虚拟机保护逆向] [HGAME 2023 week4]vm 虚拟机逆向的注意点:具体每个函数的功能,和其对应的硬件编码的*长度* 和 *含义*,都分析出来后就可以编写脚本将题目的opcode转化位vm实际执行的指令 :分析完成函数功能后就可以编写脚本输出…

跑马灯样式

这里的公告是要做成&#xff0c;跑马灯的样式&#xff0c;文字是会移动并且隐藏掉的。 HTML&#xff1a; <div class"notice"><div class"yrr"><img src"./img/ia_100000018.png" alt"" /></div><div …

循序渐进丨MogDB 数据库特性之动态数据脱敏机制

数据脱敏是行之有效的数据库隐私保护方案之一&#xff0c;可以在一定程度上限制非授权用户对隐私数据的窥探。动态数据脱敏机制是一种通过定制化脱敏策略来实现对隐私数据保护的技术&#xff0c;可以在保留原始数据的前提下有效地解决非授权用户对敏感信息访问的问题。当管理员…

Fastjson 1.2.24 反序列化导致任意命令执行漏洞复现(CVE-2017-18349)

写在前面 CVE-2017-18349 指的是 fastjson 1.2.24 及之前版本存在的反序列化漏洞&#xff0c;fastjson 于 1.2.24 版本后增加了反序列化白名单&#xff1b; 而在 2019 年&#xff0c;fastjson 又被爆出在 fastjson< 1.2.47 的版本中&#xff0c;攻击者可以利用特殊构造的 …

js【详解】async await

为什么要使用 async await async await 实现了使用同步的语法实现异步&#xff0c;不再需要借助回调函数&#xff0c;让代码更加易于理解和维护。 (async function () {// await 必须放在 async 函数中try {// 加载第一张图片const img1 await loadImg1()// 加载第二张图片co…

xss.haozi.me靶机 通关

0x00 没有任何过滤可以直接注入<img srcx οnerrοralert(1)> 0x01 使用了testarea标签将我们的输入内容以普通的字符串进行展示 但是我们可以将标签进行闭合 </textarea><img srcx οnerrοralert(1)> 0x02 我们依然可以先闭合之后添加属性a" οncl…

Arcgis小技巧【20】——属性表有东西,缩放至图层却看不到?

一、问题分析 这是一个看似正常的要素类数据&#xff0c;打开它的属性表&#xff0c;里面有一行要素&#xff1a; 说明这不是空数据。 回到地图界面&#xff0c;在图层列表中&#xff0c;右键单击&#xff0c;点击【缩放至图层】。 使用过这个功能的应该知道&#xff0c;点击…

数据结构奇妙旅程之二叉平衡树

꒰˃͈꒵˂͈꒱ write in front ꒰˃͈꒵˂͈꒱ ʕ̯•͡˔•̯᷅ʔ大家好&#xff0c;我是xiaoxie.希望你看完之后,有不足之处请多多谅解&#xff0c;让我们一起共同进步૮₍❀ᴗ͈ . ᴗ͈ აxiaoxieʕ̯•͡˔•̯᷅ʔ—CSDN博客 本文由xiaoxieʕ̯•͡˔•̯᷅ʔ 原创 CSDN …

数据结构入门篇 之 【单链表】的实现讲解(附单链表的完整实现代码以及用单链表完成通讯录的实现代码)

虽然封面是顶针&#xff0c;但是我们还是要好好学习❀ 一.单链表 1.单链表的概念 2.单链表的结构 3.单链表的实现 1&#xff09;.尾插函数 SLTPushBack 2&#xff09;.打印函数 SLPrint 3&#xff09;. 头插函数 SLTPushFront 4&#xff09;.尾删函数 SLTPopBack 5&am…

docker容器的数据卷

1配置数据卷 docker run --namen01 -d --restartalways -p 80:80 -v /qy172/data/nginx/html:/usr/share/nginx/html nginx 2Docker应用部署 1搜索mysql镜像 docker search mysql 2拉取mysql镜像 docker pull mysql:5.6 3创建容器&#xff0c; 设置端口映射、目录映射 d…

Pycharm安装,环境初次配置与运行第一个简单程序

一、Pycharm安装 1.在PyCharm官网中&#xff0c;找到社区版下载链接&#xff0c;下载Pycharm社区版&#xff0c;社区版免费 2.下载成功后&#xff0c;双击下载好的安装包&#xff0c;点击下一步后&#xff0c;点击“浏览”更改安装路径到C盘以外其他硬盘&#xff0c;点击“下…

6 种 卷积神经网络压缩方法

文章目录 前言 1、低秩近似 2、剪枝与稀疏约束 3、参数量化 4、二值化网络 &#xff08;1&#xff09;二值网络的梯度下降 &#xff08;2&#xff09;两个问题 &#xff08;3&#xff09;二值连接算法改进 &#xff08;4&#xff09;二值网络设计注意事项 5、知识蒸馏 6、浅层 …

Pulsar 社区周报 | No.2024.03.08 Pulsar-Spark Connector 助力实时计算

关于 Apache Pulsar Apache Pulsar 是 Apache 软件基金会顶级项目&#xff0c;是下一代云原生分布式消息流平台&#xff0c;集消息、存储、轻量化函数式计算为一体&#xff0c;采用计算与存储分离架构设计&#xff0c;支持多租户、持久化存储、多机房跨区域数据复制&#xff0c…

SpringCloudGateway理论与实践

文章目录 网关介绍为什么需要网关Gateway 使用gateway pom依赖yml 配置重启测试总结 断言过滤器工厂路由过滤器的种类请求头过滤器默认过滤器全局过滤器总结 Gateway解决跨域 网关介绍 Spring Cloud Gateway 是一个基于Spring Framework 5&#xff0c;由Spring Cloud团队开发的…

定制repo(不再切换python和google源)

文章目录 定制repo&#xff08;不再切换python和google源&#xff09;前言各用各的repo定制repo2/repo3源码自动识别repo2/repo3项目完整解决方案&#xff1a; 定制repo&#xff08;不再切换python和google源&#xff09; 众知&#xff0c;Android/AOSP/ROM系统开发&#xff0c…

垃圾回收:JavaScript内存管理的利器

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

【SpringCloud】微服务重点解析

微服务重点解析 1. Spring Cloud 组件有哪些&#xff1f; 2. 服务注册和发现是什么意思&#xff1f;Spring Cloud 如何实现服务注册和发现的&#xff1f; 如果写过微服务项目&#xff0c;可以说做过的哪个微服务项目&#xff0c;使用了哪个注册中心&#xff0c;常见的有 eurek…