FPGA开发技能(9)快速生成约束XDC文件

文章目录

前言: 作为一名FPGA工程师,通常公司会对该岗位的人有一定的硬件能力的要求,最基础的就是需要依据原理图的设计进行FPGA工程内的XDC约束添加。人工的看图写约束容易出错,写一个python程序,并由此生成一个可执行程序,双击该程序选择一个由cadence导出的csv文件,即可将csv文件转成xdc文件。不同设计软件导出文件的类型和格式不同,这里仅支持由cadence导出的csv文件。以下是具体的操作步骤。

1.从Cadence导出csv约束文件

选择导出出现如图所示设置框。FPGA Component用于选择所有导出的部分,通常只需导出FPGA各个bank的连接情况即可。Generate Wrapper File勾选会生成一个.v文件,这个.v包含各个引脚的名称,是与csv文件中的名字对应的,但是由于尖括号等格式问题,还是略有不同,所以最好还是在生成的xdc文件上对应vivado工程的top层使用vs code批量修改即可。Exclude Power pins选项勾选会将电源、地等管脚不导出,但是需要在原理图库设计的时候分门别类的设置好,否则cadence软件不能识别这里的设置。语言就勾选与自己对应的即可。File Format中的pin name指的是FPGA Bank上的定义,因此要选择Net Name才是管脚的名字。File Type选择csv格式,cadence无法导出vivado可以直接使用的xdc文件。最后在选择一个导出路径即可。

2.python程序将csv导出为xdc文件。

Vivado工程需要引脚之间的连接才能生成bit流。使用cadence软件设计的原理图可以导出csv文件或者ucf文件,而使用vivado使用以xdc为后缀的文件。使用python读入csv文件,按照一定的格式转换成xdc文件保存,省去了手动添加的步骤。下图是导出csv文件的部分截图,python代码主要执行以下操作:

导出后缀为xdc,前缀与csv文件名一致的文件;

将图中的尖括号替换成中括号;

遍历所有的引脚,将一列当作引脚,将第二列当作引脚名称,结合set_property PACKAGE_PIN形成管脚约束;根据第四列的电压标准生成接口电平约束。

为python代码写一个弹出文件资源管理器选择csv文件的筛选器即可。

源码如下:

python 复制代码
import sys
import csv
import tkinter as tk
from tkinter import filedialog

def convert_csv_to_xdc(inputfile):
    outputfile = inputfile.replace(".csv", "") + '.xdc'
    with open(inputfile, 'rt') as f:
        cr = csv.reader(f)
        fo = open(outputfile, 'w+') 
        i = 0
        for row in cr:
            # 替换总线为方括号
            row[1] = row[1].replace("<", "[")
            row[1] = row[1].replace(">", "]")
            # 生成约束
            constraint_pinNumber = "set_property PACKAGE_PIN " + row[0] + " [get_ports {" + row[1] + "}]\n"
            level_standard = "set_property IOSTANDARD " + row[2] + " [get_ports {" + row[1] + "}]\n"

            # 写约束文件
            fo.write(constraint_pinNumber + level_standard)
        fo.close()
        f.close()
def select_file():
    root = tk.Tk()
    root.withdraw()
    file_path = filedialog.askopenfilename(filetypes=[('CSV Files', '*.csv')])
    if file_path:
        convert_csv_to_xdc(file_path)

if __name__ == "__main__":
    select_file()

3.python生成exe

请先使用pip命令安装pyinstaller工具,可以在命令行中使用pyinstaller -v命令查看是否已安装。使用前两条命令切换至工作目录,使用第三条命令在生成目录中的dist文件夹中找到exe文件即可单独使用。

4.exe使用注意事项

点击exe文件,在弹出的对话框中选择csv文件即可生成对应的xdc文件,其中有一些注意事项如下:

①在单击exe之前,将从cadence提取的csv文件要先把表头信息全部去掉包括pin number这一行表头。

②原理图中一个位宽是32的变量会有32个不同的名字,但在verilog中通常用a[0],a[1]...表示。因此需要手动修改与vivado top文件匹配。

③如果cadence导出电压的一些管脚,删除即可。

5.传送门

|-----|
| END |


💎文章原创,首发于CSDN论坛。

💎欢迎点赞💖收藏✨打赏💷!

💎欢迎评论区🎤或私信指出错误🎤,🗣️提出宝贵意见或疑问。


相关推荐
知否&知否24 分钟前
Path does not exist: file:/D:/pythonProject/spark/main/datas/input/u.data
大数据·分布式·python·spark
a computer's friend1 小时前
服务器jupyter lab 设置:密码+远程访问
python·jupyter
思忖小下1 小时前
Python基础学习-09文件操作
python·文件
FPGA狂飙1 小时前
FPGA 常用 I/O 电平标准有哪些?
信号处理·verilog·fpga·vivado·xilinx
hfhua1 小时前
2024新版pycharm如何切换anaconda虚拟环境
ide·python·pycharm·anaconda
黑心萝卜三条杠2 小时前
PyTorch 介绍与实战:从数据加载到模型训练与测试
python·深度学习·机器学习
拼才会有未来2 小时前
智谱AI批量文章生成工具:Python + PyCharm从安装到实战
人工智能·python·pycharm·ai自动写文章
乘风~&2 小时前
spi 回环
fpga开发
计算机学姐3 小时前
基于Python的招聘信息推荐系统
开发语言·vue.js·python·mysql·pycharm·django·mvc