Virtex7Microblaze下DDR3测试

FPGA技术江湖 2022-08-15 12:53

  这篇文章我们讲一下Virtex7上DDR3的测试例程,Vivado也提供了一个DDR的example,但却是纯Verilog代码,比较复杂,这里我们把DDR3的MIG的IP Core挂在Microblaze下,用很简单的程序就可以进行DDR3的测试。

  1. 新建工程,FPGA选型为xc7v690tffg-1761。创建Block Design,命名为Microblaze_DDR3。

ddr1
  1. 在bd文件中加入Mircoblaze。

ddr2
  1. 点击Run Block Automation

ddr3
  1. 按照默认配置,确定即可。

ddr4
  1. 出现下面的界面。

ddr5
  1. 添加MIG的IP Core

ddr6
  1. 开始配置DDR,选择Create Design.

ddr7
  1. 这一步是选择Pin脚兼容的FPGA,我们不做选择,直接Next。

ddr8
  1. 选择DDR3.

ddr9
  1. ①选择DDR的工作频率,我们这里让DDR3的频率为1600MHz,所以时钟频率是800MHz;
      ②选择器件,根据实际情况来选择即可;
      ③数据位宽,也是根据板卡上的实际位宽进行选择;
      ④默认即可。

ddr10
  1. 选择AXI总线的位宽,这里我们选择512.

ddr11
  1. ①选择输入时钟频率,虽然DDR的工作时钟是800MHz(在第10步中选择),但我们可以输入一个低频时钟,然后MIG的IP Core中会倍频到所需频率。
     ②MIG的IP Core默认会输出一个200MHz的时钟,如果还需要其他的时钟输出,可以在这里选择。其他选择默认即可。

ddr12
  1. ①选择输入时钟的方式,这里的输入时钟就是我们上一个页面中的设置的200MHz的输入时钟,如果选择差分或单端,则输入通过FPGA的管脚输入200MHz时钟到MIG的IP Core;如果选择No Buffer,则可以通过FPGA内部的MMCM输出一个200MHz时钟到MIG;这里我选择了No Buffer;
     ②选择参考时钟的方式,参考时钟频率固定是200MHz,如果选择如果选择差分或单端,则输入通过FPGA的管脚输入200MHz时钟到MIG的IP Core;如果选择No Buffer,则可以通过FPGA内部的MMCM输出一个200MHz时钟到MIG;如果在前一个页面中选择了输入时钟频率是200MHz,则这边会出现一个Use System Clock的选项,因为此时两个时钟频率是相同的嘛。这里我选择了Use System Clock;
     ③设置输入复位信号的极性,这个要特别注意,尽量选择高有效,因为无论我们选择高复位还是低复位,它的端口名都叫sys_rst,会让人直观就觉得是高复位。我第一次使用时,就没注意到这个选项,默认为低,但在MIG的端口上看到sys_rst这个名字我以为是高有效,结果DDR一直不通。
    (备注:对于绝大多数的Xilinx的IP,如果是低有效的复位,端口名字中肯定是有N这个标志的)

ddr13
  1. 这个页面不需要操作。

ddr14
  1. 下面开始分配管脚,我比较习惯于选第二个,无论是第一次分配还是后面再重新分配。

  2. 在这一页,可以根据原理图一一分配管脚;如果有现成的xdc/ucf文件,可以直接通过Read XDC/UCF读入,然后再选择Validate验证管脚分配是否正确。

ddr16

如果Validate成功,则会提示下面的界面。

ddr17
  1. 如果在第13步中,选择了差分或单端输入,则这里会出现下面第一个图;如果选择了No buffer,则这里会出现第二个图。很容易理解,如果选择了通过外部管脚输入时钟,那这里就是让选择具体的管脚。并不是所有的MRCC或者SRCC管脚都可以选的,只能选择跟DDR管脚同一片区域的(比如DDR放在了Bank31 32 33,那么这里的时钟输入管脚就不能选择Bank15)。

ddr18

如果不选择复位信号管脚,就可以通过FPGA内部逻辑来输入复位。

ddr19

后面一路Next就完成了MIG IP Core的配置了。

  1. 在bd文件中,加入AXI Interconnect、UARTLite和Interrupt(如果不加中断模块,Microblaze的程序跑不起来),串口用来打印信息。然后再添加各输入输出端口,把内部的线连接起来,如下图所示。

ddr20

但这个图里的线太多,看着不直观,我们把Microblaze模块、mdm_1、rst_clk_wiz和local_memory模块(上图中红框中的4个模块)放到一个子模块中,取名mb_min_sys,如下图。

ddr21
  1. 创建顶层的top文件,并在top文件中例化bd文件。可以把init_calib_complete和mmcm_locked这两个信号抓出来,在下载程序后,这两个信号必须都是高,不然DDR就工作不正常,肯定是中间某个环节配置有问题。具体top.v文件内容见附录

  2. 将工程综合、实现、生成bit文件,并导出Hardware。

ddr22
  1. 打开sdk,新建Application Project,并按下面的步骤依次操作。

ddr23
ddr24

再选择模板为HelloWorld,最后Finish。

ddr25
  1. 修改helloworld.c,见附录,重新编译,如果提示overflowed则把lscript.ld文件中的size改大。

ddr26

运行程序后,可以看到串口打印信息如下:

ddr27

附录

// top.v
`timescale 1ns / 1ps

module top
   (
  input clk_n,
  input clk_p,
  input UART_rxd,
  output UART_txd,
  output [15:0]ddr3_addr,
  output [2:0]ddr3_ba,
  output ddr3_cas_n,
  output [0:0]ddr3_ck_n,
  output [0:0]ddr3_ck_p,
  output [0:0]ddr3_cke,
  output [0:0]ddr3_cs_n,
  output [7:0]ddr3_dm,
  inout [63:0]ddr3_dq,
  inout [7:0]ddr3_dqs_n,
  inout [7:0]ddr3_dqs_p,
  output [0:0]ddr3_odt,
  output ddr3_ras_n,
  output ddr3_reset_n,
  output ddr3_we_n
  );

  wire axi4_clk;
  wire axil_clk;
  reg axi4_rstn;
  wire axil_rstn;
  wire init_calib_complete;
  wire mmcm_locked;
  wire ddr_rst;

  always @ ( posedge axi4_clk )
  begin
      axi4_rstn <= axil_rstn;
  end 

  reg [8:0] cnt;
  always @ ( posedge axil_clk )
  begin
      if(~axil_rstn)
          cnt <= 'd0;
      else if(cnt=='d256)
          cnt <= cnt ;
      else 
          cnt <= cnt + 1'b1;
  end 

  assign ddr_rst = (cnt=='d256)?1'b0:1'b1;

  MicroBlaze_DDR3 MicroBlaze_DDR3_i
       (.UART_rxd                   (UART_rxd             ),
        .UART_txd                   (UART_txd             ),
        .axil_clk                   (axil_clk             ),
        .axi4_clk                   (axi4_clk             ),
        .axi4_rstn                  (axi4_rstn            ),
        .clk_in_clk_n               (clk_n                ),
        .clk_in_clk_p               (clk_p                ),
        .ddr3_addr                  (ddr3_addr            ),
        .ddr3_ba                    (ddr3_ba              ),
        .ddr3_cas_n                 (ddr3_cas_n           ),
        .ddr3_ck_n                  (ddr3_ck_n            ),
        .ddr3_ck_p                  (ddr3_ck_p            ),
        .ddr3_cke                   (ddr3_cke             ),
        .ddr3_cs_n                  (ddr3_cs_n            ),
        .ddr3_dm                    (ddr3_dm              ),
        .ddr3_dq                    (ddr3_dq              ),
        .ddr3_dqs_n                 (ddr3_dqs_n           ),
        .ddr3_dqs_p                 (ddr3_dqs_p           ),
        .ddr3_odt                   (ddr3_odt             ),
        .ddr3_ras_n                 (ddr3_ras_n           ),
        .ddr3_reset_n               (ddr3_reset_n         ),
        .ddr3_we_n                  (ddr3_we_n            ),
        .ddr_rst                    (ddr_rst              ),
        .init_calib_complete        (init_calib_complete  ),
        .mmcm_locked                (mmcm_locked          ),
        .reset                      (1'b0                 ),
        .axil_rstn                  (axil_rstn            )
      );
endmodule
// helloworld.c
#include 
#include "platform.h"
#include "xil_printf.h"


int main()
{
    init_platform();
    print("-------ddr3 test----------------------\n\r");
    unsigned int *DDR_MEM = (unsigned int*) XPAR_MIG_7SERIES_0_BASEADDR;
    // write data to ddr3
    *DDR_MEM = 0x12345678;
    // read back
    unsigned int value = *(unsigned int *) XPAR_MIG_7SERIES_0_BASEADDR;

    xil_printf("value = 0x%x\n", value);

    cleanup_platform();
    return 0;
}


- End -

往期精选 

 
 

【免费】FPGA工程师人才招聘平台

FPGA人才招聘,企业HR,看过来!

系统设计精选 | 基于FPGA的实时图像边缘检测系统设计(附代码)

基于原语的千兆以太网RGMII接口设计

时序分析理论和timequest使用_中文电子版

求职面试 | FPGA或IC面试题最新汇总篇

FPGA图像处理专题课新增Vivado部分内容,线上线下均可报名

FPGA时序分析及约束专题课新增Vivado部分内容,线上线下均可报名

资料汇总|FPGA软件安装包、书籍、源码、技术文档…(2022.05.15更新)

FPGA技术江湖广发江湖帖

无广告纯净模式,给技术交流一片净土,从初学小白到行业精英业界大佬等,从军工领域到民用企业等,从通信、图像处理到人工智能等各个方向应有尽有,QQ微信双选,FPGA技术江湖打造最纯净最专业的技术交流学习平台。


FPGA技术江湖微信交流群

加群主微信,备注职业+方向+名字进群


FPGA技术江湖QQ交流群

备注地区+职业+方向+名字进群

FPGA技术江湖 任何技术的学习就好比一个江湖,对于每一位侠客都需要不断的历练,从初入江湖的小白到归隐山林的隐世高人,需要不断的自我感悟自己修炼,让我们一起仗剑闯FPGA乃至更大的江湖。
评论
  • RK3506 是瑞芯微推出的MPU产品,芯片制程为22nm,定位于轻量级、低成本解决方案。该MPU具有低功耗、外设接口丰富、实时性高的特点,适合用多种工商业场景。本文将基于RK3506的设计特点,为大家分析其应用场景。RK3506核心板主要分为三个型号,各型号间的区别如下图:​图 1  RK3506核心板处理器型号场景1:显示HMIRK3506核心板显示接口支持RGB、MIPI、QSPI输出,且支持2D图形加速,轻松运行QT、LVGL等GUI,最快3S内开
    万象奥科 2024-12-11 15:42 83浏览
  • 首先在gitee上打个广告:ad5d2f3b647444a88b6f7f9555fd681f.mp4 · 丙丁先生/香河英茂工作室中国 - Gitee.com丙丁先生 (mr-bingding) - Gitee.com2024年对我来说是充满挑战和机遇的一年。在这一年里,我不仅进行了多个开发板的测评,还尝试了多种不同的项目和技术。今天,我想分享一下这一年的故事,希望能给大家带来一些启发和乐趣。 年初的时候,我开始对各种开发板进行测评。从STM32WBA55CG到瑞萨、平头哥和平海的开发板,我都
    丙丁先生 2024-12-11 20:14 68浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-11 17:58 83浏览
  • 铁氧体芯片是一种基于铁氧体磁性材料制成的芯片,在通信、传感器、储能等领域有着广泛的应用。铁氧体磁性材料能够通过外加磁场调控其导电性质和反射性质,因此在信号处理和传感器技术方面有着独特的优势。以下是对半导体划片机在铁氧体划切领域应用的详细阐述: 一、半导体划片机的工作原理与特点半导体划片机是一种使用刀片或通过激光等方式高精度切割被加工物的装置,是半导体后道封测中晶圆切割和WLP切割环节的关键设备。它结合了水气电、空气静压高速主轴、精密机械传动、传感器及自动化控制等先进技术,具有高精度、高
    博捷芯划片机 2024-12-12 09:16 82浏览
  • 时源芯微——RE超标整机定位与解决详细流程一、 初步测量与问题确认使用专业的电磁辐射测量设备,对整机的辐射发射进行精确测量。确认是否存在RE超标问题,并记录超标频段和幅度。二、电缆检查与处理若存在信号电缆:步骤一:拔掉所有信号电缆,仅保留电源线,再次测量整机的辐射发射。若测量合格:判定问题出在信号电缆上,可能是电缆的共模电流导致。逐一连接信号电缆,每次连接后测量,定位具体哪根电缆或接口导致超标。对问题电缆进行处理,如加共模扼流圈、滤波器,或优化电缆布局和屏蔽。重新连接所有电缆,再次测量
    时源芯微 2024-12-11 17:11 106浏览
  • 习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-12 10:13 27浏览
  • 本文介绍瑞芯微RK3588主板/开发板Android12系统下,APK签名文件生成方法。触觉智能EVB3588开发板演示,搭载了瑞芯微RK3588芯片,该开发板是核心板加底板设计,音视频接口、通信接口等各类接口一应俱全,可帮助企业提高产品开发效率,缩短上市时间,降低成本和设计风险。工具准备下载Keytool-ImportKeyPair工具在源码:build/target/product/security/系统初始签名文件目录中,将以下三个文件拷贝出来:platform.pem;platform.
    Industio_触觉智能 2024-12-12 10:27 32浏览
  • 在智能化技术快速发展当下,图像数据的采集与处理逐渐成为自动驾驶、工业等领域的一项关键技术。高质量的图像数据采集与算法集成测试都是确保系统性能和可靠性的关键。随着技术的不断进步,对于图像数据的采集、处理和分析的需求日益增长,这不仅要求我们拥有高性能的相机硬件,还要求我们能够高效地集成和测试各种算法。我们探索了一种多源相机数据采集与算法集成测试方案,能够满足不同应用场景下对图像采集和算法测试的多样化需求,确保数据的准确性和算法的有效性。一、相机组成相机一般由镜头(Lens),图像传感器(Image
    康谋 2024-12-12 09:45 74浏览
  • 一、SAE J1939协议概述SAE J1939协议是由美国汽车工程师协会(SAE,Society of Automotive Engineers)定义的一种用于重型车辆和工业设备中的通信协议,主要应用于车辆和设备之间的实时数据交换。J1939基于CAN(Controller Area Network)总线技术,使用29bit的扩展标识符和扩展数据帧,CAN通信速率为250Kbps,用于车载电子控制单元(ECU)之间的通信和控制。小北同学在之前也对J1939协议做过扫盲科普【科普系列】SAE J
    北汇信息 2024-12-11 15:45 108浏览
  • 应用环境与极具挑战性的测试需求在服务器制造领域里,系统整合测试(System Integration Test;SIT)是确保产品质量和性能的关键步骤。随着服务器系统的复杂性不断提升,包括:多种硬件组件、操作系统、虚拟化平台以及各种应用程序和服务的整合,服务器制造商面临着更有挑战性的测试需求。这些挑战主要体现在以下五个方面:1. 硬件和软件的高度整合:现代服务器通常包括多个处理器、内存模块、储存设备和网络接口。这些硬件组件必须与操作系统及应用软件无缝整合。SIT测试可以帮助制造商确保这些不同组件
    百佳泰测试实验室 2024-12-12 17:45 32浏览
  • 全球智能电视时代来临这年头若是消费者想随意地从各个通路中选购电视时,不难发现目前市场上的产品都已是具有智能联网功能的智能电视了,可以宣告智能电视的普及时代已到临!Google从2021年开始大力推广Google TV(即原Android TV的升级版),其他各大品牌商也都跟进推出搭载Google TV操作系统的机种,除了Google TV外,LG、Samsung、Panasonic等大厂牌也开发出自家的智能电视平台,可以看出各家业者都一致地看好这块大饼。智能电视的Wi-Fi连线怎么消失了?智能电
    百佳泰测试实验室 2024-12-12 17:33 41浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦