本文主要是介绍Vivado工具TCL脚本使用--一键生成MCS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
前言
通过Vivado固化MCS到Flash的过程中,需要将Bit文件转换为MCS文件,每次通过Vivado界面点击步骤相对繁琐,为了简化转换MCS文件的过程,通过执行一条脚本的方式来一键生成MCS文件。
TCL脚本
TCL(Tool Command Language)是一种解释执行的脚本语言(Scripting Language)。 它提供了通用的编程能力:支持变量、过程和控制结构;同时TCL还拥有一个功能强大的固有的核心命令集。
TCL脚本转换MCS实现
set Current_Time [clock format [clock second] -format "%Y%m%d_%H%M%S"] ;
set PrjPath [get_property directory [current_project]] ;
set PrjName [get_projects [current_project]] ;
set RunsName [glob *.runs] ;
set BitPath $PrjPath/$RunsName/impl_1 ; if {[file exists $PrjPath/mcs]==0} {file mkdir $PrjPath/mcs ;}
set McsPath $PrjPath/mcs ;set BitName [glob $BitPath/*.bit] ;
set McsName $McsPath/${PrjName}_$Current_Time.mcs ;set BitFile "$BitName" ;
set McsFile "$McsName" ;
set LoadBit "up 0x00000000 $BitFile" ;write_cfgmem -format mcs -size 32 -interface SPIx4 -loadbit $LoadBit \
-checksum -force -disablebitswap -file $McsFile
代码分析
第1行用于获取当前时间;
第2行用于获取当前工程绝对路径;
第3行用于获取当前工程名;
第4行用于获取布局布线运行路径;
第5行用于获取生成BIT的路径,一般情况下只会生成一个布局布线(imp_1)目录,当有多个布局布线进程时注意更改对应目录;
第7、8、9行用于判断当前工程路径是否存在mcs的目录,如果不存在则创建;
第10行用于设置mcs生成路径;
第12行用于获取bit名;
第13行用于设置mcs名称,前半段为当前工程名,后半段为生成时间(年月日_时分秒),后缀为.mcs;
第17行用于设置bit加载的起始地址;
第19行用于生成mcs文件,其中 “-format” 设置生成文件的格式,这里是mcs 也可以是bin等; “-size"设置Flash的大小(MB); “-interface” 设置Flash加载方式 这里是SPIx4,也可以是SPIx8或者其他;”-loadbit"设置带加载起始地址的bit 文件;"-checksum"设置是否加和校验;"-disablebitswap"设置是否进行位交换;
实际演示
将上述代码复制,保存为.tcl为后缀的文件,将此文件放入到Vivado工程.prj为后缀的同级目录内,如下我建立了一个名为axi_jtag的工程,保存上述代码为gen_mcs.tcl;
上图中MCS名称前面为工程名,后面为年月日-时分秒,生成成功,当后续需要更改设计时,生成MCS就比较方便了;
这篇关于Vivado工具TCL脚本使用--一键生成MCS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!