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/85836/85836b3e6ef763f3a3b0186955b3f059057998a2" alt="mpsoc开发"
开发环境:vivado 2017.4,开发板型号:米尔myd-czu3eg, 主芯片xczu3eg-1sfvc784。这个系列板子还有4ev,5ev等版本,手里的3eg版本不支持sfp,因此板上相应接口(白色部分)是空贴的。
生成的vivado工程(如果不知道如何生成可以参考前面的工程)data:image/s3,"s3://crabby-images/84400/844003992d99cf533946e4f72bc310ec58d89e04" alt="mpsoc开发"
step1新建block design
data:image/s3,"s3://crabby-images/6f923/6f9235187fa5ee923f18d4bcf1b9a9edbabba1bb" alt="mpsoc开发"
点击ok
data:image/s3,"s3://crabby-images/94cfc/94cfcd5b28b3900c26d55593ca35a71911e61da1" alt="mpsoc开发"
step2添加ps的ip核并配置
点击这个add ip添加ip核
data:image/s3,"s3://crabby-images/4d257/4d2571329fea5689d0ad42650f1b22a28b249a8d" alt="mpsoc开发"
输入mpsoc,然后双击zynq ultrascale mpsoc添加mpsoc核
data:image/s3,"s3://crabby-images/7f722/7f722d50a3943941dc3e64a25733a26842dc6174" alt="mpsoc开发"
zynq mpsoc核如下图所示
data:image/s3,"s3://crabby-images/2aedb/2aedb867d67ff87fe2815957aa21570cbee70195" alt="mpsoc开发"
双击zynq mpsoc核导入配置文件
presets-->apply configuration
data:image/s3,"s3://crabby-images/a93f5/a93f5a8e99ef0f7a376d99add2b6ad53a526bec8" alt="mpsoc开发"
这里导入的是gpio_emio.tcl配置文件
data:image/s3,"s3://crabby-images/167c0/167c0b1aca5fa125ea4870e149002b90049a7d62" alt="mpsoc开发"
配置完成后,如下图所示
data:image/s3,"s3://crabby-images/d8ac2/d8ac29f5b2af8babb77f3aabe97a0edf1c68ab99" alt="mpsoc开发"
在gpio管脚上右击选择make external
data:image/s3,"s3://crabby-images/677f0/677f0ec60851f06138643969ccebbb1a1a46be6d" alt="mpsoc开发"
引出的gpio管脚如下图所示
data:image/s3,"s3://crabby-images/8971c/8971cc587af69e942bb0746b652b0be19341d1e3" alt="mpsoc开发"
step3 生成综合文件
data:image/s3,"s3://crabby-images/905c6/905c68677b7f3e95f01b144674123a07fcea1c2d" alt="mpsoc开发"
step4 生成fpga顶层文件
data:image/s3,"s3://crabby-images/d00fe/d00feb10e846ada3d4b220748ab7887c73f346e7" alt="mpsoc开发"
step5 添加xdc管脚约束
data:image/s3,"s3://crabby-images/c02e7/c02e7d797a047cf1714ab0e0ab96f0d7bdad26bd" alt="mpsoc开发"
选择add create constraints
data:image/s3,"s3://crabby-images/bc909/bc9094bb00ca1078b110d4beb15226a1d736d9a9" alt="mpsoc开发"
选择create file
data:image/s3,"s3://crabby-images/9cb7a/9cb7ae95a41eb607b64886b2d9e2ed448c3ece0a" alt="mpsoc开发"
添加一个gpio_emio.xdc文件
data:image/s3,"s3://crabby-images/af709/af709d30707c79db3d06b8c4dc1de8c5d2cb2ae6" alt="mpsoc开发"
点击finish
data:image/s3,"s3://crabby-images/b837a/b837a82efce2d777041d8b4a4649cab90c76937b" alt="mpsoc开发"
将我们提供的工程里面的xdc文件复制到这个gpio_emio.xdc文件里
data:image/s3,"s3://crabby-images/82a13/82a135bef38beb7677c82b6041da989ba8af4738" alt="mpsoc开发"
step6 生成bit文件
data:image/s3,"s3://crabby-images/76ae3/76ae39c31cc5cfa4f93d70d9596f3ab3b110e5ae" alt="mpsoc开发"
step7导出硬件配置文件
点击菜单栏上的 file->export->export hardware->ok 导出硬件配置文件
data:image/s3,"s3://crabby-images/5a1e2/5a1e2b66a76579e717cc952e739af02719f80454" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/61105/61105f3689f4d4b880595950999934f6a84fa7e6" alt="mpsoc开发"
step8 启动sdk,新建fsbl
点击菜单栏上的 file->launch sdk->ok 启动 sdk
data:image/s3,"s3://crabby-images/d0f36/d0f3645340d97bb6ef50beeca3096115311b231c" alt="mpsoc开发"
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/44e10/44e10d6ebcd28e4559887172b803a391ce8e176d" alt="mpsoc开发"
输入工程名为fsbl
data:image/s3,"s3://crabby-images/54c5c/54c5c9d39b0959e234b980f3d32e498c6d5ae670" alt="mpsoc开发"
选择zynq mp fsbl
data:image/s3,"s3://crabby-images/e3e89/e3e89dd49f77ac15f83cdda42a28b77f457fbabc" alt="mpsoc开发"
生成的fsbl如下图所示
data:image/s3,"s3://crabby-images/88542/88542d6a894ea7e6a025960bdb0de6f01ba13153" alt="mpsoc开发"
step9 新建一个gpio_emio工程
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/49dd0/49dd0824f8209b4d1627323e994294d26ae8e24f" alt="mpsoc开发"
输入工程名gpio_emio
data:image/s3,"s3://crabby-images/58da6/58da644fe8c64f25983191fff70a4bf448c2acdd" alt="mpsoc开发"
选择hello_world工程模板
data:image/s3,"s3://crabby-images/a42bb/a42bb8d14c3ef6383722da720bff12c2799a1e54" alt="mpsoc开发"
新建gpio_emio工程完成后,如下图所示
data:image/s3,"s3://crabby-images/0c50c/0c50ce727c75682782e897d89d5ae79bb0e98fc1" alt="mpsoc开发"
将我们提供的gpio_emio工程的程序复制到这个hello_world工程模板里
data:image/s3,"s3://crabby-images/98916/98916506e8f2ee8f03b8d30e5d3e1e881ef098e4" alt="mpsoc开发"
step10 生成boot.bin文件
右击 gpio_emio ->create boot image
data:image/s3,"s3://crabby-images/de365/de365fe9be3f5506481f6b00ed88fa226084f868" alt="mpsoc开发"
点击create image,生成boot.bin启动文件
data:image/s3,"s3://crabby-images/4f87c/4f87c672a910852c54449419e71dd1a46c897f0a" alt="mpsoc开发"
将这个boot.bin文件拷贝到sd卡
data:image/s3,"s3://crabby-images/0e2dd/0e2dd3e8a2ceffd2eb1a2c8e20454d2e5b325ff1" alt="mpsoc开发"
开发板模式设置,这里我们设置为sd卡启动模式
data:image/s3,"s3://crabby-images/0a271/0a271ed4330c56ec275ae7141bcc5c6bd0c040dc" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/34135/341359a110b8b9db3de210ade902bdb97168136b" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/77a51/77a51b9ab7d63c0e49a8c3a47cb8e18234901ebb" alt="mpsoc开发"
开发板连接12v电源、连接uart串口、插入sd卡
data:image/s3,"s3://crabby-images/00d81/00d812813418f2bb4c2d1424112e239478772acd" alt="mpsoc开发"
开发板上电运行,两个led会同时闪烁
data:image/s3,"s3://crabby-images/047e3/047e3ec4f4c163bc409186c964766cdc33c0ffaf" alt="mpsoc开发"