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/e147a/e147ac5f8086f6bbbc76c147db5592f6f62623d5" alt="mpsoc开发"
开发环境:vivado 2017.4,开发板型号:米尔myd-czu3eg, 主芯片xczu3eg-1sfvc784。这个系列板子还有4ev,5ev等版本,手里的3eg版本不支持sfp,因此板上相应接口(白色部分)是空贴的。
生成的vivado工程(如果不知道如何生成可以参考前面的工程)data:image/s3,"s3://crabby-images/8e8fa/8e8fac59a64324e1c04d7b24f5031d351cb374aa" alt="mpsoc开发"
step1新建block design
data:image/s3,"s3://crabby-images/dcd01/dcd01952216d9e635d6df344f603f66d04cb153d" alt="mpsoc开发"
点击ok
data:image/s3,"s3://crabby-images/2a169/2a169cf9b2b5b45a1995218e1e49c0600355b80f" alt="mpsoc开发"
step2添加ps的ip核并配置
点击这个add ip添加ip核
data:image/s3,"s3://crabby-images/c6e2d/c6e2de3291974ee62d85fed69bb55d686e6899e1" alt="mpsoc开发"
输入mpsoc,然后双击zynq ultrascale mpsoc添加mpsoc核
data:image/s3,"s3://crabby-images/91972/9197280182844a4e46da0cd5bee624b532da8007" alt="mpsoc开发"
zynq mpsoc核如下图所示
data:image/s3,"s3://crabby-images/288e8/288e8ea6d4100f0661fb8f04195f5b41df03e059" alt="mpsoc开发"
双击zynq mpsoc核导入配置文件
presets-->apply configuration
data:image/s3,"s3://crabby-images/34140/3414029bf5c5f679e0645b1da626e70c54ca9ac0" alt="mpsoc开发"
这里导入的是gpio_emio.tcl配置文件
data:image/s3,"s3://crabby-images/9e321/9e321ce92d9cd3d512d4a75016b91d9423fc1bec" alt="mpsoc开发"
配置完成后,如下图所示
data:image/s3,"s3://crabby-images/52fba/52fbaca0512094046269e8aad45717d514830de0" alt="mpsoc开发"
在gpio管脚上右击选择make external
data:image/s3,"s3://crabby-images/1b908/1b9081f196d28355f73f3a878055d047610464d2" alt="mpsoc开发"
引出的gpio管脚如下图所示
data:image/s3,"s3://crabby-images/721a9/721a96e516a2eff6a574271931c61e98136eded5" alt="mpsoc开发"
step3 生成综合文件
data:image/s3,"s3://crabby-images/e50c1/e50c199c2fdf387973159cdbfe7c7f4fb307c593" alt="mpsoc开发"
step4 生成fpga顶层文件
data:image/s3,"s3://crabby-images/a7f14/a7f146a982d4a2d526c0c676801c1750cd98125d" alt="mpsoc开发"
step5 添加xdc管脚约束
data:image/s3,"s3://crabby-images/8807b/8807b373e84034bd89836f5d37a77e43c74910c2" alt="mpsoc开发"
选择add create constraints
data:image/s3,"s3://crabby-images/b47ca/b47cab52d8893e8025ab18c930d53f3c16b43630" alt="mpsoc开发"
选择create file
data:image/s3,"s3://crabby-images/b4698/b4698ce6217c23c143bf9ad61a62bd8b9fd00758" alt="mpsoc开发"
添加一个gpio_emio.xdc文件
data:image/s3,"s3://crabby-images/9cb94/9cb9484ebacd987c602e463931622960aefccdee" alt="mpsoc开发"
点击finish
data:image/s3,"s3://crabby-images/82645/82645e4e991adf02ad77a0d8638461ed3a52fbf9" alt="mpsoc开发"
将我们提供的工程里面的xdc文件复制到这个gpio_emio.xdc文件里
data:image/s3,"s3://crabby-images/e1fd8/e1fd83f7945f46ed918db7ba326a161e189507b6" alt="mpsoc开发"
step6 生成bit文件
data:image/s3,"s3://crabby-images/cc351/cc351a7496783f92880b7435d711529c947cf468" alt="mpsoc开发"
step7导出硬件配置文件
点击菜单栏上的 file->export->export hardware->ok 导出硬件配置文件
data:image/s3,"s3://crabby-images/75c5d/75c5deae3d281f4c675db7138133cd72638e2890" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/3d17a/3d17a8bbf11dbb028482b31e6308d28f7d4a28d7" alt="mpsoc开发"
step8 启动sdk,新建fsbl
点击菜单栏上的 file->launch sdk->ok 启动 sdk
data:image/s3,"s3://crabby-images/73f1c/73f1c296e87f64346bc6d57ce4779cab426bfc76" alt="mpsoc开发"
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/ea7e6/ea7e64bf9ea0765b2c99a303deb63f3312456fc2" alt="mpsoc开发"
输入工程名为fsbl
data:image/s3,"s3://crabby-images/1e74f/1e74f3379b1fb16b5b05a906da564345689a138b" alt="mpsoc开发"
选择zynq mp fsbl
data:image/s3,"s3://crabby-images/c4104/c41048e1d6ef191616b7947fe314a828633569c2" alt="mpsoc开发"
生成的fsbl如下图所示
data:image/s3,"s3://crabby-images/8f2bc/8f2bc527457ad3fa96ae16b770a7ff1e0d43c305" alt="mpsoc开发"
step9 新建一个gpio_emio工程
点击fileapplication project新建工程
data:image/s3,"s3://crabby-images/ed094/ed0942ad7a0580d48225ea4632a3532684d411ae" alt="mpsoc开发"
输入工程名gpio_emio
data:image/s3,"s3://crabby-images/b61c9/b61c9b3f3e86d147eb4994aa869352a549ac35b8" alt="mpsoc开发"
选择hello_world工程模板
data:image/s3,"s3://crabby-images/2df23/2df237d3d59d8863a0e161fb85f35b2414eec2e9" alt="mpsoc开发"
新建gpio_emio工程完成后,如下图所示
data:image/s3,"s3://crabby-images/7a728/7a7281bd2313b1f69ef0eabdd4a0f7b8f24acb47" alt="mpsoc开发"
将我们提供的gpio_emio工程的程序复制到这个hello_world工程模板里
data:image/s3,"s3://crabby-images/8b770/8b7704d97c001e98a570fb42fb70771a4fd2f7d9" alt="mpsoc开发"
step10 生成boot.bin文件
右击 gpio_emio ->create boot image
data:image/s3,"s3://crabby-images/a7ea3/a7ea3341ed3abdd4c2f937063f984a46b1be93e0" alt="mpsoc开发"
点击create image,生成boot.bin启动文件
data:image/s3,"s3://crabby-images/6001b/6001bc8c913efb18160fcffb9fffa32b57071a27" alt="mpsoc开发"
将这个boot.bin文件拷贝到sd卡
data:image/s3,"s3://crabby-images/58385/58385dac97a56fd68e39647e8532807fa3b9e373" alt="mpsoc开发"
开发板模式设置,这里我们设置为sd卡启动模式
data:image/s3,"s3://crabby-images/e5a8d/e5a8da6dfb656727ee74ab0896f94b8199d821c5" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/28512/28512b648114941bae42cd34d8e39bc15d627c96" alt="mpsoc开发"
data:image/s3,"s3://crabby-images/61c30/61c30c963fe92881113ce7ac4ccfa3529b6dafca" alt="mpsoc开发"
开发板连接12v电源、连接uart串口、插入sd卡
data:image/s3,"s3://crabby-images/c92e9/c92e9136d40a6d3fd6a19cf3abb367a8dbed948c" alt="mpsoc开发"
开发板上电运行,两个led会同时闪烁
data:image/s3,"s3://crabby-images/d41d0/d41d0744d768dd36459b25fa6d1afe456f7be171" alt="mpsoc开发"