mpsoc系列处理器是赛灵思推出的新一代集成soc,号称比zynq系列性能高5倍。与zynq相比,mpsoc最最突出的是集成 4core a53 / 2 core r5、gpu、h264等,在图形图像处理、智能算法等比较有竞争力有较大优势。此外,mpsoc接口也很有优势,zynq中除了acp口,并没有提供其他cache一致性接口,而mpsoc提供了cci总线,cci总线上连接的a53/r5/gpu/dma等可以高效的同步数据,而不用对cache进行特殊操作,这大大提高了数据搬运的效率。本篇文章使用米尔myd-czu3eg开发板实操,介绍怎样通过 emio引出 gpio, 并在 sdk 中控制 d37 和 d41 闪烁。
data:image/s3,"s3://crabby-images/38d5e/38d5e8540869ff792df663426d4ae49c8f969261" alt="mpsoc开发"
开发环境:vivado 2017.4,开发板型号:米尔myd-czu3eg, 主芯片xczu3eg-1sfvc784。这个系列板子还有4ev,5ev等版本,手里的3eg版本不支持sfp,因此板上相应接口(白色部分)是空贴的。
生成的vivado工程(如果不知道如何生成可以参考前面的工程)data:image/s3,"s3://crabby-images/d8182/d8182a50fbb226060c091de61925bfc2cc76c764" alt="mpsoc开发"
step1新建block design
data:image/s3,"s3://crabby-images/10a3c/10a3c8629a1767cad852391c4c816c55df77ac2f" alt="mpsoc开发"
点击ok
data:image/s3,"s3://crabby-images/103ff/103ff07f6c2e2d3cdfd6525f98483c7be28b5ab5" alt="mpsoc开发"
step2添加ps的ip核并配置
点击这个add ip添加ip核
data:image/s3,"s3://crabby-images/aa541/aa54176665dd29bfc3d306dfe70b71ba7712d544" alt="mpsoc开发"
输入mpsoc,然后双击zynq ultrascale mpsoc添加mpsoc核
data:image/s3,"s3://crabby-images/5602e/5602e837fa9ad14e9649402f08081f9859b95260" alt="mpsoc开发"
zynq mpsoc核如下图所示
data:image/s3,"s3://crabby-images/0200b/0200b60af3dada86021916d686f495c05094658e" alt="mpsoc开发"
双击zynq mpsoc核导入配置文件
presets-->apply configuration
data:image/s3,"s3://crabby-images/e21fc/e21fcc79752b303857014cdc3877feade3acb827" alt="mpsoc开发"
这里导入的是gpio_emio.tcl配置文件
data:image/s3,"s3://crabby-images/aea32/aea32c90435dddc81f4484067992b244df2447a1" alt="mpsoc开发"
配置完成后,如下图所示
data:image/s3,"s3://crabby-images/c48a5/c48a561a3eea889dea4d7f99262366c004aa20e7" alt="mpsoc开发"
在gpio管脚上右击选择make external
data:image/s3,"s3://crabby-images/f9021/f9021bdb887901644977412cb1a36cde6a4ff735" alt="mpsoc开发"
引出的gpio管脚如下图所示
data:image/s3,"s3://crabby-images/22d52/22d529fe15c3c108a213add64b4856915d28eaa7" alt="mpsoc开发"
step3 生成综合文件
data:image/s3,"s3://crabby-images/9de17/9de17510e47c1845b5550e4f60ec9964ff6f79d1" alt="mpsoc开发"
step4 生成fpga顶层文件
data:image/s3,"s3://crabby-images/ad638/ad63810082a5a210437130a912bb2692a34fee1b" alt="mpsoc开发"
step5 添加xdc管脚约束
data:image/s3,"s3://crabby-images/8cc56/8cc56009fcc1f230785fdeed1b419ced083ce233" alt="mpsoc开发"
选择add create constraints
data:image/s3,"s3://crabby-images/6bf6f/6bf6f5e7857b017dedce5ab817268dd4aa6201b4" alt="mpsoc开发"
选择create file
data:image/s3,"s3://crabby-images/b8369/b8369003f95f6b197c46c03b493e3d6eb42b3a5b" alt="mpsoc开发"
添加一个gpio_emio.xdc文件
data:image/s3,"s3://crabby-images/65f4c/65f4c8d4594fc4396397282772751b949935d693" alt="mpsoc开发"
点击finish
data:image/s3,"s3://crabby-images/d3dbd/d3dbd5656eb5aeb215c7449882b13ceca5ef79e2" alt="mpsoc开发"
将我们提供的工程里面的xdc文件复制到这个gpio_emio.xdc文件里
data:image/s3,"s3://crabby-images/1a824/1a824d3d9d983baed7f6b52b396caa474a37733c" alt="mpsoc开发"
step6 生成bit文件
data:image/s3,"s3://crabby-images/236f7/236f7f4e6456dce9cda1f4bd5406b678930d4b04" alt="mpsoc开发"
step7导出硬件配置文件
点击菜单栏上的 file->export->export hardware->ok 导出硬件配置文件
data:image/s3,"s3://crabby-images/ac35e/ac35eb054acb2ce18ce21664dad1e900e1eb3d15" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/0229a/0229a070c66af9b39fc381bb12331babc3d091a5" alt="mpsoc开发"
step8 启动sdk,新建fsbl
点击菜单栏上的 file->launch sdk->ok 启动 sdk
data:image/s3,"s3://crabby-images/ef21c/ef21c8b58a3f912f8fca1a4f455f9aa0524d2a3b" alt="mpsoc开发"
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/8ce2a/8ce2a1324b817c92d17304826900154dea19cfbe" alt="mpsoc开发"
输入工程名为fsbl
data:image/s3,"s3://crabby-images/8dd0e/8dd0e855d2606364813315a3629428c444f927e0" alt="mpsoc开发"
选择zynq mp fsbl
data:image/s3,"s3://crabby-images/e647f/e647fd1ae26d2e2be60c47d44debbe81a531ebb5" alt="mpsoc开发"
生成的fsbl如下图所示
data:image/s3,"s3://crabby-images/bab52/bab5229d9fd3f724317b5cea5785fc532f5d16c4" alt="mpsoc开发"
step9 新建一个gpio_emio工程
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/0f686/0f6868f041c3e940529c0bd41a6d3e2889b7ad72" alt="mpsoc开发"
输入工程名gpio_emio
data:image/s3,"s3://crabby-images/bfbd7/bfbd737c8f5a24a3d53a61d332ea625f668e3cf3" alt="mpsoc开发"
选择hello_world工程模板
data:image/s3,"s3://crabby-images/c8db4/c8db470e41a07f9114e11f5b8ca2d329913c5bd3" alt="mpsoc开发"
新建gpio_emio工程完成后,如下图所示
data:image/s3,"s3://crabby-images/c4ae7/c4ae7f8bc549b88d28cf6ed978d84a099998b209" alt="mpsoc开发"
将我们提供的gpio_emio工程的程序复制到这个hello_world工程模板里
data:image/s3,"s3://crabby-images/2fc58/2fc58b2fe96f7552963e290faa878b5349c09f34" alt="mpsoc开发"
step10 生成boot.bin文件
右击 gpio_emio ->create boot image
data:image/s3,"s3://crabby-images/5d896/5d896f50337006911b824ba31646614f229bc728" alt="mpsoc开发"
点击create image,生成boot.bin启动文件
data:image/s3,"s3://crabby-images/837fe/837fe8c5980fc26fe37913a2d730459ff60e7dc8" alt="mpsoc开发"
将这个boot.bin文件拷贝到sd卡
data:image/s3,"s3://crabby-images/14f07/14f07d51e36a486a05143e3951908d8f2e558b5f" alt="mpsoc开发"
开发板模式设置,这里我们设置为sd卡启动模式
data:image/s3,"s3://crabby-images/d7fb4/d7fb4cc2697b99d3af6c1905c5a2a18779d31a14" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/79c8d/79c8db2fbdd70d47807bd9550832c76e16fec51a" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/20c7a/20c7a881aa372bbe66ff1cc8e5e114cd5b57f60c" alt="mpsoc开发"
开发板连接12v电源、连接uart串口、插入sd卡
data:image/s3,"s3://crabby-images/eeffc/eeffc9fc737fea98a8e33c95862cd541565f383f" alt="mpsoc开发"
开发板上电运行,两个led会同时闪烁
data:image/s3,"s3://crabby-images/75090/75090256bf6e0d719827823b3b1e27cc535060a8" alt="mpsoc开发"