- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
准备工作: (网盘链接:) 1.蜂鸟e203的RTL源码; 2.一段分频代码; 3.顶层设计文件(system.v) 4.开发板文件; 5.Nexys4DDR电路图; 6.Nexys4DDR管脚约束模板; 7.Nexys4DDR官方文档.
在Vivado中创建工程,命名随意,路径随意; 。
这里可以选择是否添加源文件等,我们先不添加; 。
这里我们选择的是 Nexys4DDR ,若Vivado库中没有此板载文件,可以添加对应板载文件到 Vivado\2018.2\data\boards\board_files 目录下,这里我们给出了Nexys4DDR的开发板文件; 。
创建工程完成后,单击" + ",添加源文件,这里我们选择添加的是 文件夹e203 (路径为 e203_hbirdv2/rtl/e203 ),Finish完成添加,那两个勾建议可以勾选,会将添加的源文件拷贝到我们的工程目录下,防止对原始文件造成改动; 。
同上操作,找到对应想要移植板子的 system.v 文件(路径为 e203_hbirdv2-master\fpga\mcu200t\system.v ),这里选择的是MCU; 。
添加完成后,右键点击 system.v 将其设置为头文件; 。
这时,我们会观察到有两个文件有问题,这是由于e203中调用了相应的IP核,我们也要在工程中对应添加; 。
在IP目录中找到对应IP核 Processor System Reset ,双击将名字改为system.v中的对应名字 reset_sys 。注意!这里一定要保持名称一致!后修改其复位的优先级为最高,即可完成IP核的调用; 。
在IP目录中找到对应IP核 Clocking Wizard ,同上操作,将名改为 mmcm ,修改生成时钟频率为 16M ,改变复位方式为低电平复位,即可完成IP核的调用;同时应注意这里IP核调用的例化名称应与system.v中保持一致.
添加源文件代码,若无可以在资料中找到对应的,调用该模块生成 CLK32768KHZ 的时钟 。
右键单击 e203_defines.v ,将其设为 global define ,并在其文件头添加语句: `define FPGA_SOURCE 。完成后查看Elaborated Design,若此时报错无法打开e203_defines.v文件,可以在SourceFileProperties中将其对应文件类型改为 Verilog Header 。
这里提供资料有Nexys4DDR的电路原理图及其约束文件模板,可据此对时钟管脚,SPI引脚,PMU引脚等必要的引脚进行一定约束来简单验证我们能否移植成功。对于管脚约束的完成,我们可以划分成两个模块: xdc约束文件的编写 、 system.v顶层文件的对应修改 .
# Clock signal
set_property -dict {PACKAGE_PIN E3 IOSTANDARD LVCMOS33} [get_ports CLK100MHZ]
# set_property -dict { PACKAGE_PIN F15 IOSTANDARD LVCMOS33 } [get_ports { CLK32768KHZ }];
create_clock -period 10.000 -name sys_clk_pin -waveform {0.000 5.000} -add [get_ports CLK100MHZ]
# set_property CLOCK_DEDICATED_ROUTE FALSE [get_nets dut_io_pads_jtag_TCK_i_ival]
# set_property CLOCK_DEDICATED_ROUTE FALSE [get_nets IOBUF_jtag_TCK/O]
# Reset
set_property -dict {PACKAGE_PIN C12 IOSTANDARD LVCMOS33} [get_ports fpga_rst]
set_property -dict {PACKAGE_PIN M18 IOSTANDARD LVCMOS33} [get_ports mcu_rst]
# QSPI interface
set_property -dict {PACKAGE_PIN K17 IOSTANDARD LVCMOS33} [get_ports {qspi0_dq[0]}]
set_property -dict {PACKAGE_PIN K18 IOSTANDARD LVCMOS33} [get_ports {qspi0_dq[1]}]
set_property -dict {PACKAGE_PIN L14 IOSTANDARD LVCMOS33} [get_ports {qspi0_dq[2]}]
set_property -dict {PACKAGE_PIN M14 IOSTANDARD LVCMOS33} [get_ports {qspi0_dq[3]}]
set_property -dict {PACKAGE_PIN L13 IOSTANDARD LVCMOS33} [get_ports qspi0_cs]
# JTAG connection
# set_property -dict { PACKAGE_PIN E13 IOSTANDARD LVCMOS33 } [get_ports { mcu_TDO }];
# set_property -dict { PACKAGE_PIN E10 IOSTANDARD LVCMOS33 } [get_ports { mcu_TCK }];
# set_property -dict { PACKAGE_PIN E11 IOSTANDARD LVCMOS33 } [get_ports { mcu_TDI }];
# set_property -dict { PACKAGE_PIN E12 IOSTANDARD LVCMOS33 } [get_ports { mcu_TMS }];
# pmu_wakeup
set_property -dict {PACKAGE_PIN H17 IOSTANDARD LVCMOS33} [get_ports pmu_paden]
set_property -dict {PACKAGE_PIN K15 IOSTANDARD LVCMOS33} [get_ports pmu_padrst]
set_property -dict {PACKAGE_PIN N17 IOSTANDARD LVCMOS33} [get_ports mcu_wakeup]
set_property BITSTREAM.CONFIG.SPI_BUSWIDTH 4 [current_design]
set_property BITSTREAM.CONFIG.SPI_FALL_EDGE YES [current_design]
system.v中对应文件的修改 :顶层模块中代码功能划分十分规整,对于不需要的模块如GPIO等直接注释掉即可.
如恰好我们移植的是同一块板子,那么恭喜你,我已经在资料包里准备好了两份文件,直接导入工程即可😊 。
点击 implementation 进行工程的综合,这个时间会比较漫长,可以先去吃个晚饭😊! 。
将开发板与PC正确连接并供电,在Vivado中打开HardwareManager,使用Auto Connect自动连接板子,如此步报错,或一直无法连接成功,可能是由于电脑未安装相关驱动造成,可以在 \Xilinx\Vivado\2018.3\data\xicom\cable_drivers\nt64 目录下找到 install_diligent.exe 双击安装,如果此时还不能自动连接,就下载一个驱动精灵什么的让他解决一下吧~(虽然那个软件看起来很“金山毒霸”\doge) 。
单击Vivado上方工具栏的Tools->Generate Memory Configuration Files,弹出的窗口如下所示,进行如图所示的配置,即可在当前工程目录下生成MCS文件.
在左侧功能栏最末尾找到Add Configuration Memory Device,填出的窗口如图所示,进行如图所示的配置,即可导入相应的开发板flash.
完成装置选择后,将会自动弹出一个询问你是否现在就要Program的一个窗口,选择是,则来到以下界面,添加入我们前面生成的MCS文件即可,等待---,即完成了我们的内核固化过程.
写在最后的话 : 花了很多精力才完成了整个的移植,在网上也找了很多教程,或是因为版本不一致,或是一些细致之处没有说明,踩了很多坑,走了很多弯路。写这篇教程时,已经是我第五次尝试移植了,可能还存在不够细致之处,或者上下文逻辑不连贯之处,如有问题指出, 欢迎大家留言,我每天都会看的!!大家一起进步!! 。
最后此篇关于手把手教你蜂鸟e203移植(以Nexys4DDR为例)的文章就讲到这里了,如果你想了解更多关于手把手教你蜂鸟e203移植(以Nexys4DDR为例)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我每个人! :D我在大学中间。项目,基本上就是用FPGA和Verilog制作音频均衡器。我们已经完成了所有寄存器,数据捕获,分频器以及PWM的工作,并且我们即将使信号通过Nexys内部的滤波器,然后到
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 12 个月
我到处都查过了,数据表、Xilinx 网站、digilent 等等,但什么也没找到!我能够使用 Adept 工具来验证我的蜂窝 RAM 是否正常运行,但我找不到任何库存 VHDL 代码作为 Contr
我是一名优秀的程序员,十分优秀!