作者:liuyayong
1、实验方案
data:image/s3,"s3://crabby-images/02b4e/02b4e8e91bb74bc1537a602df86248fe5a85cfac" alt=""
图1 实验方案系统框图
2、具体步骤
2.1、vivado工程建立
①打开vivado集成开发环境,点击“Create Project”,如下图所示。
data:image/s3,"s3://crabby-images/4f451/4f451d62fb1231e2314e2b6098e8de0e4a6a420e" alt=""
②点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/782b5/782b5f065e731f9d9ea4d8305018dc51da9a6bec" alt=""
③在“Project name”中输入工程名;在“Project location”中选择保存路径;勾选“Create project subdirectory”,最后点击“Next”,如下图所示,注意均不要出现中文。
data:image/s3,"s3://crabby-images/fec3d/fec3ddc7392344b61ea199f795444207b6e8619f" alt=""
④选择“RTL Project”,点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/b04b0/b04b065ab6f15d35446295f2a529adc5af030558" alt=""
⑤点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/401c7/401c785f576edc6356b9ea07791aba5247f15c52" alt=""
⑥点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/45f48/45f48b47ffdb2f4446730d450d4e4ca203ffcf85" alt=""
⑦输入芯片型号,然后点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/6a6dd/6a6dd33aa27c496dd1114df284bac41a95754d0d" alt=""
⑧点击“Finish”,完成vivado的工程创建,如下图所示。
data:image/s3,"s3://crabby-images/302e3/302e3cf3a393bbdd539767cebaa14df679381814" alt=""
2.2、创建一个Block设计
⑨IP INTEGRATOR→Create Block Design,在弹出的对话框中输入设计名,最后点击“OK”,如下图所示。
data:image/s3,"s3://crabby-images/7ed8b/7ed8bda7b1cfa1b5332b4b53a0ed31b693772a30" alt=""
⑩点击“+”,在搜索框中输入“zynq”找到“ZYNQ7 Processing System”,双击就可以将ZYNQ处理器添加到设计中了,如下图所示。
data:image/s3,"s3://crabby-images/43c66/43c6697a345725449058fa7c164bce3dbbded801" alt=""
⑪双击ZYNQ→DDR Configuration→DDR Controller Configuration→DDR3,在Memory Part下拉菜单中根据自己板子上的DDR来选择相应的DDR3,本实验所用到型号:MT41K256M16 RE-15E,最后点击“OK”,如下图所示。
注意这里的DDR3并不是和板子上的DDR3严格对应,而是参数最接近的型号,有时候实验不通的话,问题往往出现在这里,可以多试几个。
data:image/s3,"s3://crabby-images/346bb/346bbc6f5d2669c95eeb962fb0466e75bd418736" alt=""
⑫点击“Run Block Automation”如下图所示。
data:image/s3,"s3://crabby-images/899b9/899b915bba639bb035a29fbfc0df4ed8bf7101b3" alt=""
⑬在弹出的选项中保持默认,点击“OK”,即可完成对ZYNQ7 Processing System的配置。
data:image/s3,"s3://crabby-images/56046/560466a56cb8f51d2dba5ae2441c90c1ec43d328" alt=""
⑭按照添加ZYNQ7 Processing System的方法,继续添加AXI GPIO,然后双击AXI GPIO,打开AXI GPIO配置对话框,由于只有输出4个led灯,故而按照下图对其进行设置,最后点击“OK”确认。
data:image/s3,"s3://crabby-images/ba240/ba240a367ecdadb77398718a48010463acaa7f2e" alt=""
⑮点击“Run Block Automation”即可完成对AXI GPIO的设置,如下图所示
data:image/s3,"s3://crabby-images/4a861/4a8617438d5875c60522f88919f9e3940468110f" alt=""
⑯点击“Run Connection Automation”。
data:image/s3,"s3://crabby-images/51b3b/51b3b15e066d577de1d44df3a95795927b5871a4" alt=""
⑰在弹出的对话框中按照下图所示配置,然后“OK”确认。
data:image/s3,"s3://crabby-images/53449/534490e7b7187988a5ad87e71edac71347201c40" alt=""
⑱最后生成如下的框图。
data:image/s3,"s3://crabby-images/0a395/0a3951aa6101b1bef58453bacb662b9bc8d87389" alt=""
⑲在框图中点击gpio引脚,在左边的“External Interface Properties”给gpio起名leds,如下图所示。
data:image/s3,"s3://crabby-images/aafef/aafefe675d14e4f610fe7b5de2b49deb1d7feb44" alt=""
⑳source→design_1→create HDL wrapper…,如下图所示。
data:image/s3,"s3://crabby-images/628dd/628dd59b0e63344ab9b835f7010b020acb65060c" alt=""
21在弹出的对话框中,保持默认,点击“OK”确认,如下图所示。
data:image/s3,"s3://crabby-images/8dc2e/8dc2ee46e64d90d050966e68cc4f460ead755afe" alt=""
22至此,可生成HDL文件,如下图所示。
data:image/s3,"s3://crabby-images/ca6ab/ca6aba222c57a58d70c5318fb5e2b80ff32b9b74" alt=""
2.3、.XDC文件约束PL管脚
23在source目录下,点击“+”,在弹出的对话框中选定“Add or create constraints”最后点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/27950/27950be2bde35b477e39f4ff89a2ef88176b6ac8" alt=""
24点击“Create File”,在弹出的对话框中给约束文件命名,点击“OK”确认,如下图所示。
data:image/s3,"s3://crabby-images/ad54b/ad54b97bfd5071d97cd53762156e0f95b0731cbe" alt=""
25点击“Finish”,完成约束文件的创建。
data:image/s3,"s3://crabby-images/7b4b7/7b4b779ab2873b2b645c183d1a855ea64a7b2358" alt=""
26打开新建的约束文件,进行如下的管脚分配。
data:image/s3,"s3://crabby-images/c28c9/c28c91c2fecb7ef5bee6ceacdc4277a0988291f8" alt=""
27产生bit文件。
data:image/s3,"s3://crabby-images/d857f/d857f15b901784865d298dd564f9f0009da45a19" alt=""
2.4、SDK程序编写
28File→Export→Export hardware…,在弹出的对话框中勾选“include bitstream”,点击“OK”确认,如下图所示。
data:image/s3,"s3://crabby-images/96f21/96f21838579ce2b5696932fa4c6ef117c6c85c1d" alt=""
29File→Lauch SDK,在弹出的对话框中,保存默认,点击“OK”,如下图所示。
data:image/s3,"s3://crabby-images/ce614/ce614598559714be81fd20e48bd0d6cd506d65f3" alt=""
30至此,打开SDK开发环境,如下图所示。
data:image/s3,"s3://crabby-images/02353/023533e6ecff93623a747115958eb8263d9ff802" alt=""
31file→new→Application Project,来新建一个“Application Project”,如下图所示。
data:image/s3,"s3://crabby-images/568e9/568e99fb6ad90c1b10b7fc934276c40454f5aa7a" alt=""
32 给Application Project命名,最后点击“Next”,如下图所示。
data:image/s3,"s3://crabby-images/72505/72505641e7a95e377475ce22502d4bb2b3b22879" alt=""
33选择“Empty Application”,然后点击“Finish”,如下图所示。
data:image/s3,"s3://crabby-images/cdd23/cdd2357b5a2030f9d411b90f40f94d653393323d" alt=""
34axi_led_bsp→system.mss→import examples,在弹出的对话框中选择“xgpio_example”,最后点击“OK”确认,如下图所示。
data:image/s3,"s3://crabby-images/9b053/9b05377f3002002bff84335d98a60fdc1eb81970" alt=""
35这样新建一个“xgpio_example”,如下图所示。
data:image/s3,"s3://crabby-images/449bf/449bf26370ffd4f9de0385b2c00cdb26d02cc0c7" alt=""
2.5、下载调试
36design_1_wrapper_hw_platform0→Program FPGA,在弹出的对话框中选择默认,点击“program”,如下图所示;第一次下载可能会失败,第二次下载就成功了,这样就完成了bit文件的下载。
data:image/s3,"s3://crabby-images/1f95f/1f95fd64d85310060e05699a2f26b1c398f0a620" alt=""
37axi_led_bsp_xgpio_example_1→Run As→1 Launch on Hardware(System Debugger),
data:image/s3,"s3://crabby-images/d309e/d309e0cc621142be7135029f97fe54a667b4a7cd" alt=""
2.5、实验总结
38下面是实验测试结果的视频,可以看到4个led在闪烁。(由于视频上传不了,只有个图片)
data:image/s3,"s3://crabby-images/4e728/4e7285ebedfc569902c7d34e11c14bb4d3a81af0" alt=""
2.6、备注及疑问
40注意这里的DDR3并不是和板子上的DDR3严格对应,而是参数最接近的型号,有时候实验不通的话,问题往往出现在这里,可以多试几个。
41第一次下载可能会失败,第二次下载就成功了,这样就完成了bit文件的下载。
2.7、参考资料
1. cource_s1_ALINX_ZYNQ(AX7010_AX7020)开发平台基础教程V1.09
2. https://blog.csdn.net/q416524389/article/details/83865266
3. https://blog.csdn.net/weixin_39813867/article/details/83512913
文章转载自: https://www.cnblogs.com/ahead-liuyayong/p/10689021.html