从本文开始,将正式介绍VitisAI的工作流程。第一个流程就是Vivado Flow,在Vivado开发环境中创建一个硬件平台,最终的输出是xxx.xsa硬件描述文件,为后续的PetaLinux和Vitis提供基础。Vivado中的大部分的内容都是在Block Design中完成的,核心目标是创建一个Zynq UltraScale MPSoC的运行硬件环境,以及为DPU的正常运行提供硬件支持。这里需要注意,较老版本的VitisAI教程中,需要在Vivado中导入DPU的IP核,这种做法已经成为历史,本文介绍的流程中,在Vivado中是不需要导入DPU IP核的,只是对DPU运行环境进行支持,例如中断、时钟等
创建Vivado工程
打开vivado
1 | source /opt/pkg/xilinx/Vivado/2021.1/settings64.sh |
vivado打开后,点击Create Project->Next
data:image/s3,"s3://crabby-images/99cd4/99cd47eee2b79d99a4e1e877a5c9138eb0be66fc" alt=""
输入项目名称,这里我输入的是”dpu_hardware”,点击Next
data:image/s3,"s3://crabby-images/966d2/966d2292194d39a83724574fdb1a0d9bbed9cc8b" alt=""
在Project Type页面中选中RTL Project,并选中Project is an extensible Vitis platform,点击Next
data:image/s3,"s3://crabby-images/5dc72/5dc72a0ecd3d105ab50937f1239cb1be01cd7754" alt=""
在Default Part页面选择Family为Zynq UltraScale+ MPSoCs,Package为sfvc784,Temperature为E,Speed为-1,并在下方的表格中选中xczu2cg-sfvc784-1-e,点击Next,再点击Finish。这里需要注意,读者的芯片类型选择需要和自己的板子匹配
data:image/s3,"s3://crabby-images/aaf7e/aaf7e8a6266876d07e77a29506c99d178f7978c1" alt=""
Block Design IP核添加
在左侧PROJECT MANAGER→IP INTEGRATOR点击Create Block Design,在弹出框中直接点击Next创建一个Block Design
data:image/s3,"s3://crabby-images/20a8b/20a8b01110e557c80dcc06cd45dd3bc78a22df6c" alt=""
在Diagram界面中点击加号,在搜索框中输入zynq,选择Zynq UltraScale+MPSoC,将其添加到Block Design中
data:image/s3,"s3://crabby-images/ba602/ba6021b8df214a6127eb88b30f262169d97f9921" alt=""
添加后如下图所示
data:image/s3,"s3://crabby-images/b53db/b53dbf0eaff26e5361e1bfd632cf85bed424e072" alt=""
添加Clock
添加Clocking Wizard IP核
data:image/s3,"s3://crabby-images/37451/374510bb9318cfad486a1ef079fe9333120ff266" alt=""
添加后如下图所示
data:image/s3,"s3://crabby-images/8cb2c/8cb2c9a6272e83305ffd1f75a2f6f1c41db39700" alt=""
双击Clocking Wizard进入配置页面,在Output Clocks中选中clk_out1、clk_out2、clk_out3,并将Output Freq分别设置为100、200、400
data:image/s3,"s3://crabby-images/3d42a/3d42a7041008dcb383fbb82760dbf2c28c826343" alt=""
在Reset Type中选择Active Low,并点击OK
data:image/s3,"s3://crabby-images/072fd/072fd709b02615ef9bb5ee1b72909c53f963d0d8" alt=""
添加Processor System Reset
添加Processor System Reset
data:image/s3,"s3://crabby-images/1b33e/1b33e9e39520d2068fd269fa3a26b0c1bfa4c5b4" alt=""
因为有3路时钟,因此要创建3个对应的Reset模块,可点击添加的Reset,Ctrl+C/Ctrl+V复制2个出来
data:image/s3,"s3://crabby-images/81620/816205ffbe17863b01ebe91d57a991b7457dfe9c" alt=""
将Clocking Wizard的3路输出分别与Reset0/1/2的slowest_sync_clk管脚相连,将Clocking Wizard的locked与3个Reset的dcm_locked都相连
data:image/s3,"s3://crabby-images/ad6a5/ad6a5a50a3f8c7e1c11dafb529282ff5c7c7e2cf" alt=""
点击Run Connection Automation,在弹出框中将clk_in1选择为zynq的clk0,将3个reset都选择为zynq的resetn0,点击OK
data:image/s3,"s3://crabby-images/b7313/b73139b6c42a26f632bf94a07e1fd49aec896f51" alt=""
完成后Block Design如下图
data:image/s3,"s3://crabby-images/25801/2580118407014ef4a9645fa5bfa80cfb89569c06" alt=""
点击Platform Setup,选中Clock,将3个Clock都设置为Enable,ID号分别设置为0、1、2,并将clk_out2设置为default
data:image/s3,"s3://crabby-images/48579/485796ea66872e96a2c7c46c5a4a1e3c6cbaa2f2" alt=""
添加AXI Interrupt Controller
添加AXI Interrupt Controller IP核
data:image/s3,"s3://crabby-images/3b0f8/3b0f8f8084b4cd2f9e8d0deaddadeab52a83bb03" alt=""
双击AXI Interrupt Controller进入配置页面,将Interrupt Output Connection选择为Single,点击OK
data:image/s3,"s3://crabby-images/f40e7/f40e76b39faa2fa6e0f4dc1f04832310f35614ee" alt=""
双击ZYNQ进入配置页面,在PS-PL Configuration→PS-PL Interfaces→Master Interface中,确保两个FPD未选中,LPD选中
data:image/s3,"s3://crabby-images/55127/5512731302ec620fb732989a292dc7a3e95e932b" alt=""
在PS-PL Configuration→General→Interrupts→PL to PS中,将IRQ0[0-7]选择为1,点击OK
data:image/s3,"s3://crabby-images/9aaa2/9aaa28696a271d5c91bab69173cc0b21ca5ba775" alt=""
点击自动连接,默认都选择auto,点击OK
data:image/s3,"s3://crabby-images/46582/46582458d43030dcff67e65f9a88b655d3f5d120" alt=""
整个Block Design如图
data:image/s3,"s3://crabby-images/775af/775af9e64b9ccd3725145a6e65841e9d243fcf8c" alt=""
将axi_intc_0的irq连接到ZYNQ的pl_ps_irq0上,再点击图标刷新画布
data:image/s3,"s3://crabby-images/ef8b0/ef8b033e6a50d7f936fed27b11b928fb57db2074" alt=""
在Platform Setup中将中断使能
data:image/s3,"s3://crabby-images/685ab/685ab917c14f767be76253403a9b8468272b7ea2" alt=""
选择AXI Port,按照下图对端口进行配置
data:image/s3,"s3://crabby-images/4be9f/4be9f0d607f138c25ce7c088638adf6ef6b4ead0" alt=""
data:image/s3,"s3://crabby-images/b4800/b4800c8000b40ff796fef35ad37b678a84e3df64" alt=""
Zynq SoC配置
双击Zynq UltraScale MPSoC,打开其配置界面
data:image/s3,"s3://crabby-images/de744/de744a9f7eaa95b0dad8b3d7c10474a263ddc010" alt=""
I/O配置
在I/O Configuration中,配置Bank0~Bank2电压为LVCMOS18,Bank3电压为LVCMOS33
data:image/s3,"s3://crabby-images/d3b38/d3b38077e18fbd39289f9a3eebbd0954ae791039" alt=""
在下方展开Low Speed→Memory Interfaces→QSPI,勾选QSPI,设置模式为Single,Data Mode选择x4,勾选Feedback Clk
data:image/s3,"s3://crabby-images/607ab/607ab16b84d68d2ab56e6be80766407f882a0de4" alt=""
展开SD,并勾选SD0,配置Slol Type为eMMC,Data Transfer Mode为8Bit,勾选Reset,选择MIO23
data:image/s3,"s3://crabby-images/0ec82/0ec82a439c78c3ea43c04af26ac486d379b04871" alt=""
勾选SD1,Slot Type选择SD 2.0,Data Transfer Mode选择4Bit,勾选CD,用于检测SD卡的插入
data:image/s3,"s3://crabby-images/2ac21/2ac219d6451fe30e0263ea960850d2759757334d" alt=""
勾选I2C 1,用于EEPROM
data:image/s3,"s3://crabby-images/cd5a8/cd5a8e59081c676b68939e1188a8afd09a747588" alt=""
勾选UART1
data:image/s3,"s3://crabby-images/ef70e/ef70e47b60fcfb2637c5b42b9221805095d0e7a3" alt=""
勾选TTC 0~TTC3
data:image/s3,"s3://crabby-images/b31da/b31da290a5d643d3453e54550952f58a0e63edb7" alt=""
配置PS端以太网,勾选GEM3,勾选MDIO3
data:image/s3,"s3://crabby-images/54741/5474103ac902f4941fd9326b5c13b23cd1f2dce9" alt=""
勾选USB0,勾选USB3.0,选择GT Lane1,勾选USB Reset→USB 0
data:image/s3,"s3://crabby-images/ee49d/ee49d2fb1ee2e69d9988d2ee05084002aaf0665f" alt=""
勾选PCIe
data:image/s3,"s3://crabby-images/03885/03885a142b93a797619f746a4d151e3a5cc16b71" alt=""
点击左侧Switch To Advanced Mode,选择PCIe Configuration
- Basic Settings→Device Port Type:RootPort
- Devices IDs→Initial ID Values→Subsystem ID:0x7
- Devices IDs→Class Code→Base Class:0x06
- Devices IDs→Class Code→Sub Class:0x04
data:image/s3,"s3://crabby-images/7c6f0/7c6f0c18ef064160c0230c890a438be706da673b" alt=""
回到I/O Configuration,勾选Display Port,Lane Selection选择Dual Higher
data:image/s3,"s3://crabby-images/712b2/712b2d6dae98f19195ecc84961f0857f24fb5957" alt=""
时钟配置
在Clock Configuration界面,Input Clocks配置参考时钟,PCIe选择Ref Clk0,100MHz,Display Port选择Ref Clk2,27MHz,USB0选择Ref Clk1,26MHz
data:image/s3,"s3://crabby-images/1a5a7/1a5a78fe47d8d07eb318507a34b04a5325f7be3c" alt=""
在Output Clocks窗口,如果不是IOPLL,改为IOPLL,保持一致
data:image/s3,"s3://crabby-images/e94ef/e94eff207814704450f3ac431af9720dea13bb52" alt=""
PL的时钟保持默认
data:image/s3,"s3://crabby-images/658ad/658adaf556dcce44c9a56f87fe25d4d06f76ea18" alt=""
Full Power部分,其他保持默认,将DP_VIDEO改为VPLL,DP_AUDIO和DP_STC改为RPLL
data:image/s3,"s3://crabby-images/d8484/d848414373ddc788a292d3787d43756f0df1a2e0" alt=""
最下面的Interconnect修改如下
data:image/s3,"s3://crabby-images/6baef/6baef53537a555f75d1644a5cbe54383ceaa19cf" alt=""
DDR配置
在DDR Configuration窗口中,Load DDR Presets选择“DDR4_MICRON_MT40A256M16GE_083E”
data:image/s3,"s3://crabby-images/8f8cc/8f8cc7f09bbeb3d20e84e64b0324369247fee26b" alt=""
生成bit
BLOCK DESIGN→Sources→design_1,右键选择Create HDL Wrapper生成top文件
data:image/s3,"s3://crabby-images/32416/324165270c7576517b432366710e66cf24095ab6" alt=""
data:image/s3,"s3://crabby-images/bca71/bca711be7631d54d0098c0d292394c239fb9fcf6" alt=""
点击Generate Bitstream图标生成bit流,等待生成完成后,点击File→Export→Export Platform,选Next、选Hardware。选Pre-synthesis+include bitstream
data:image/s3,"s3://crabby-images/66ee0/66ee0699bf376db1da9f89abbf3cb2a11dd9de8d" alt=""
设置平台名称等信息,点击Next、Finsih,可看到在dpu_hardware路径下生成了design_1_wrapper.xsa文件