资料介绍
描述
今年早些时候,我的朋友偶然发现了这款采用 Xilinx Zynq 7010 的廉价板,名为 EBAZ4205。这些板是从 Ebang Ebit E9+ 比特币矿机中清理出来的,可以从 Aliexpress 购买。我想我会试一试,我很惊讶它们是多么便宜和强大。在玩过这个板之后,我很快就对每次创建新项目时都要配置 Zynq PS 系统感到恼火。因此,我决定学习如何创建 Xilinx Vivado 板文件,今天我将与您分享我的知识。
要求
在为您的定制电路板创建电路板文件之前,我强烈建议您阅读Xilinx UG895 Vivado 系统级设计附录 A。该文档描述了电路板文件的结构和内容。
板文件的结构
Xilinx Vivado 板文件存放在 Vivado 安装目录中:
//data/boards/board_files/
在这个目录中,我们可以创建新文件夹并以我们的板子命名(例如 ebaz4205)。在这个目录中,我们将创建另一个以板版本命名的文件夹(例如 1.0)。该文件夹将包含我们的电路板图片和三个重要的 XML 文件:
- board.xml - 定义关于板的所有信息。它包括基本信息(例如电路板名称、描述、供应商)、有关板上组件的信息(例如 FPGA 部件、LED、按钮)、有关板上组件所需接口的信息以及实现这些接口的首选 IP 内核。
- preset.xml - 为 board.xml 文件中指定的 IP 内核定义预设。
- part0_pins.xml - 为 board.xml 文件中指定的接口定义物理引脚和 I/O 标准。
创建所有必需的文件夹和文件后,我们的板文件文件夹结构应如下所示:
ebaz4205/
└── 1.0
├── board.xml
├── ebaz4205.jpg
├── part0_pins.xml
└── preset.xml
板子.xml
该文件以名为 的 XML 标记开头,我们将在其中提供有关该板的基本信息:
schema_version="2.1" vendor="miner.ebang.com.cn" name="ebaz4205" display_name="EBAZ4205 Development Board" url="http://miner.ebang.com.cn" preset_file="preset.xml">
首先,我们定义板文件架构版本 - 告诉 Vivado 软件如何解释文件中提供的数据的属性(在 Vivado 2020.1 中,我目前使用的架构的最新版本是 2.1)。接下来,我们为电路板供应商定义供应商名称、电路板名称和网页。在 标签中,我们还指定了稍后将使用的预设文件的名称。在此之后,我们必须通过在新行中写入 来关闭 标记。所有其他板信息必须在这两个标签之间定义。
为了确保板文件的正常工作,我们必须添加 和 标签:
<file_version>1.0file_version>
<compatible_board_revisions>
<revision id="1">1.0revision>
compatible_board_revisions>
标签用于跟踪电路板文件的版本,而 标签用于指定这些文件可以与哪些电路板 PCB 修订版一起使用。
我们可以通过在 中指定图像和在 标签中指定描述来添加板的图片和描述:
<images>
<image name="ebaz4205.jpg" display_name="EBAZ4205 Development Board" sub_type="board">
<description>EBAZ4205 Development Boarddescription>
image>
images>
<description>EBAZ4205 is mining board used in Ebang Ebit E9+ bitcoin miner machine. This board features 256MB DDR3 memory, 128MB NAND Flash memory, 10/100MBit Ethernet and speed grade -1 Zynq 7010.description>
创建新项目时,大部分信息将显示在板选择窗口中:
或在 Vivado 项目摘要窗口中:
提供基本信息后,现在我们可以通过在 标签之间添加信息来指定板上的组件:
<components>
<component name="part0" display_name="EBAZ4205" type="fpga" part_name="xc7z010clg400-1" pin_map_file="part0_pins.xml" vendor="xilinx" spec_url="www.xilinx.com">
<description>FPGA part on the boarddescription>
<interfaces>
<interface mode="master" name="ps7_fixedio" type="xilinx.com:display_processing_system7:fixedio_rtl:1.0" of_component="ps7_fixedio" preset_proc="ps7_preset">
<preferred_ips>
<preferred_ip vendor="xilinx.com" library="ip" name="processing_system7" order="0"/>
preferred_ips>
interface>
<interface mode="master" name="leds_2bits" type="xilinx.com:interface:gpio_rtl:1.0" of_component="leds_2bits" preset_proc="leds_2bits_preset">
<preferred_ips>
<preferred_ip vendor="xilinx.com" library="ip" name="axi_gpio" order="0"/>
preferred_ips>
<port_maps>
<port_map logical_port="TRI_O" physical_port="leds_2bits_tri_o" dir="out" left="1" right="0">
<pin_maps>
<pin_map port_index="0" component_pin="leds_2bits_tri_o_0"/>
<pin_map port_index="1" component_pin="leds_2bits_tri_o_1"/>
pin_maps>
port_map>
port_maps>
interface>
interfaces>
component>
<component name="ps7_fixedio" display_name="PS7 fixed IO" type="chip" sub_type="fixed_io" major_group=""/>
<component name="leds_2bits" display_name="LEDs" type="chip" sub_type="led" major_group="General Purpose Input or Output">
<description>LEDs, Active Lowdescription>
component>
components>
首先我们必须定义板上使用的 FPGA 部分,在 EBAZ4205 的情况下它是 xc7z010clg400-1。我们还定义了这个组件的供应商和引脚映射文件。所有用于实现 FPGA 和电路板组件之间接口的 IP 内核都必须在 FPGA 标签之间定义。
第一个定义的接口将是 Zynq 处理系统的固定 I/O。我们必须指定接口模式、名称、首选 IP 核来实现此接口和预设名称 (preset_proc),它将 IP 核与 preset.xml 文件中的预定义配置链接:
<interface mode="master" name="ps7_fixedio" type="xilinx.com:display_processing_system7:fixedio_rtl:1.0" of_component="ps7_fixedio" preset_proc="ps7_preset">
<preferred_ips>
<preferred_ip vendor="xilinx.com" library="ip" name="processing_system7" order="0"/>
preferred_ips>
interface>
第二个定义的接口用于 LED。为了实现这个接口,我们将使用 AXI GPIO IP 内核。对于此接口,我们还必须定义端口引脚映射,因为 AXI GPIO IP 内核端口引脚必须连接到物理 FPGA 引脚:
<interface mode="master" name="leds_2bits" type="xilinx.com:interface:gpio_rtl:1.0" of_component="leds_2bits" preset_proc="leds_2bits_preset">
<preferred_ips>
<preferred_ip vendor="xilinx.com" library="ip" name="axi_gpio" order="0"/>
preferred_ips>
<port_maps>
<port_map logical_port="TRI_O" physical_port="leds_2bits_tri_o" dir="out" left="1" right="0">
<pin_maps>
<pin_map port_index="0" component_pin="leds_2bits_tri_o_0"/>
<pin_map port_index="1" component_pin="leds_2bits_tri_o_1"/>
pin_maps>
port_map>
port_maps>
interface>
在定义 FPGA 部分及其接口之后,我们必须定义其他组件。默认情况下一个是 Zynq 7000 处理系统,另一个是 LED。之前创建的接口将通过称为组件名称的属性链接到这些组件:
<component name="ps7_fixedio" display_name="PS7 fixed IO" type="chip" sub_type="fixed_io" major_group=""/>
<component name="leds_2bits" display_name="LEDs" type="chip" sub_type="led" major_group="General Purpose Input or Output">
<description>LEDs, Active Lowdescription>
component>
该声明还让我们可以在 Vivado 模块设计窗口的 Board 选项卡中找到我们的组件:
在 board.xml 文件中,如果适用,我们还必须为板上的所有组件定义 JTAG 链。在这种情况下,我们只有一个用于 FPGA 部分的 JTAG 链:
<jtag_chains>
<jtag_chain name="chain1">
<position name="0" component="part0"/>
jtag_chain>
jtag_chains>
当然,我们必须指定将我们的组件接口链接到在 part0_pins.xml 文件中声明的物理 FPGA 引脚的连接:
<connections>
<connection name="part0_leds_2bits" component1="part0" component2="leds_2bits">
<connection_map name="part0_leds_2bits_1" c1_st_index="0" c1_end_index="1" c2_st_index="0" c2_end_index="1"/>
connection>
connections>
这里 c1_st_index 和 c1_end_index 对应 part0_pins.xml 文件中的 pin 索引,而 c2_st_index 和 c2_end_index 对应 IP 核端口 pin 索引。
预设.xml
preset.xml 文件以名为 的 XML 标记开头,我们必须在其中提供此文件架构版本。预设文件的当前架构版本是 1.0:
<ip_presets schema = "1.0">
我们必须通过在新行中写入 来关闭 标记。IP 核的预设将列在这两个标签之间。
首先我们为 Zynq 处理系统 IP 核添加配置。这些配置通过名为 preset_proc_name 的属性链接到 board.xml 文件:
<ip_preset preset_proc_name="ps7_preset">
<ip vendor="xilinx.com" library="ip" name="processing_system7" version="*">
<user_parameters>
<user_parameter name="CONFIG.PCW_UART1_PERIPHERAL_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_UART1_UART1_IO" value="MIO 24 .. 25"/>
<user_parameter name="CONFIG.PCW_SD0_PERIPHERAL_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_SD0_SD0_IO" value="MIO 40 .. 45"/>
<user_parameter name="CONFIG.PCW_NAND_PERIPHERAL_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_NAND_GRP_D8_ENABLE" value="0"/>
<user_parameter name="CONFIG.PCW_ENET0_PERIPHERAL_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_ENET0_ENET0_IO" value="EMIO"/>
<user_parameter name="CONFIG.PCW_ENET0_GRP_MDIO_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_ENET0_PERIPHERAL_FREQMHZ" value="100 Mbps"/>
<user_parameter name="CONFIG.PCW_GPIO_MIO_GPIO_ENABLE" value="1"/>
<user_parameter name="CONFIG.PCW_GPIO_MIO_GPIO_IO" value="MIO"/>
<user_parameter name="CONFIG.PCW_ENET_RESET_ENABLE" value="0"/>
<user_parameter name="CONFIG.PCW_USB_RESET_ENABLE" value="0"/>
<user_parameter name="CONFIG.PCW_I2C_RESET_ENABLE" value="0"/>
<user_parameter name="CONFIG.PCW_UIPARAM_DDR_BUS_WIDTH" value="16 Bit"/>
<user_parameter name="CONFIG.PCW_UIPARAM_DDR_PARTNO" value="MT41K128M16 JT-125"/>
user_parameters>
ip>
ip_preset>
在 Zynq 7000 处理系统中,我们启用 UART1、SD0、NAND、ETHERNET0 和其他外设,为这些外设选择 MIO 引脚并配置 DDR 内存。
接下来,我们为 AXI GPIO IP 内核添加配置,该内核将用于在板上实现 FPGA 和用户 LED 之间的接口:
<ip_preset preset_proc_name="leds_2bits_preset">
<ip vendor="xilinx.com" library="ip" name="axi_gpio" ip_interface="GPIO">
<user_parameters>
<user_parameter name="CONFIG.C_GPIO_WIDTH" value="2"/>
<user_parameter name="CONFIG.C_ALL_OUTPUTS" value="1"/>
<user_parameter name="CONFIG.C_ALL_INPUTS" value="0"/>
<user_parameter name="CONFIG.C_DOUT_DEFAULT" value="0x00000003"/>
user_parameters>
ip>
ip_preset>
在这里,我们将 AXI GPIO IP 内核配置为只有 2 个引脚将用作默认逻辑值为 1 的输出,因为此板上的 LED 低电平有效(通过提供逻辑 0 打开)。
part0_pins.xml
part0_pins.xml 文件以 标签开头,我们必须在其中指定板上使用的 FPGA 部件。在这两个标签之间,我们将提供所有引脚映射信息:
<part_info part_name="xc7z010clg400-1">
<pins>
<pin index="0" name ="leds_2bits_tri_o_0" iostandard="LVCMOS33" loc="W14"/>
<pin index="1" name ="leds_2bits_tri_o_1" iostandard="LVCMOS33" loc="W13"/>
pins>
part_info>
此处列出的引脚通过引脚名称属性链接到 board.xml 文件中指定的 IP 核端口引脚。我们将 I/O 标准设置为 LVCMOS33,因为这些引脚所在的 FPGA bank 的电压在 EBAZ4205 板上设置为 3.3V。最后,我们通过提供位置属性 loc 将 IP 核端口引脚链接到物理 FPGA 封装引脚。
我希望本教程能帮助您更好地了解 Xilinx Vivado 电路板文件结构以及如何为您的定制电路板创建这些文件。
完整的 EBAZ4205 板文件可以在我的存储库中找到。
- 迅为i.MX6Q开发板Openwrt 文件系统构建
- 如何创建和使用LabVIEW中的LLB文件 0次下载
- Vivado生成、固化烧录文件 49次下载
- Xilinx_Vivado_zynq7000入门笔记 71次下载
- 【Vivado那些事】Vivado下头文件使用注意事项
- Vivado 开发教程(一) 创建新硬件工程
- Xilinx的库文件免费下载 0次下载
- Xilinx Vivado SDK 2017.2 0616 1 Win64软件免费下载 320次下载
- 用Vivado-HLS为软件提速 8次下载
- 基于Vivado 的Basys3开发板的解码教程 66次下载
- Xilinx_SP605开发板原理图PCB 46次下载
- xilinx实验板原理图
- 基于FPGA的mif文件创建与使用
- 利用XILINX解决方案快速创建存储器接口设计
- 4205E.pdf 电子管资料数据手册
- e² studio创建lib文件及使用 242次阅读
- 如何在Post Synthesis工程中加入XCI文件 1084次阅读
- 用TCL定制Vivado设计实现流程 932次阅读
- Xilinx FPGA Vivado开发流程介绍 3329次阅读
- Xilinx Vivado LOCK_PINS属性介绍 1035次阅读
- Vivado里如何手动调整编译顺序 3471次阅读
- 如何升级Vivado工程脚本 1709次阅读
- Xilinx Vivado I/O延迟约束介绍 4938次阅读
- 基于Project模式Vivado GUI使用的配置文件自动化生成管理 2790次阅读
- xilinx Vivado工具使用技巧 3934次阅读
- 设置Vivado压缩BIT文件的两种方法 9076次阅读
- TCL脚本简介 vivado hls 的设计流程 6542次阅读
- Vivado技巧:.dcp 文件代替 .xci 文件 5036次阅读
- 基于Xilinx的软件工程的创建 1570次阅读
- xilinx IP建立向导创建的目录和文件的作用分析 7735次阅读
下载排行
本周
- 1山景DSP芯片AP8248A2数据手册
- 1.06 MB | 532次下载 | 免费
- 2RK3399完整板原理图(支持平板,盒子VR)
- 3.28 MB | 339次下载 | 免费
- 3TC358743XBG评估板参考手册
- 1.36 MB | 330次下载 | 免费
- 4DFM软件使用教程
- 0.84 MB | 295次下载 | 免费
- 5元宇宙深度解析—未来的未来-风口还是泡沫
- 6.40 MB | 227次下载 | 免费
- 6迪文DGUS开发指南
- 31.67 MB | 194次下载 | 免费
- 7元宇宙底层硬件系列报告
- 13.42 MB | 182次下载 | 免费
- 8FP5207XR-G1中文应用手册
- 1.09 MB | 178次下载 | 免费
本月
- 1OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 2555集成电路应用800例(新编版)
- 0.00 MB | 33566次下载 | 免费
- 3接口电路图大全
- 未知 | 30323次下载 | 免费
- 4开关电源设计实例指南
- 未知 | 21549次下载 | 免费
- 5电气工程师手册免费下载(新编第二版pdf电子书)
- 0.00 MB | 15349次下载 | 免费
- 6数字电路基础pdf(下载)
- 未知 | 13750次下载 | 免费
- 7电子制作实例集锦 下载
- 未知 | 8113次下载 | 免费
- 8《LED驱动电路设计》 温德尔著
- 0.00 MB | 6656次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935054次下载 | 免费
- 2protel99se软件下载(可英文版转中文版)
- 78.1 MB | 537798次下载 | 免费
- 3MATLAB 7.1 下载 (含软件介绍)
- 未知 | 420027次下载 | 免费
- 4OrCAD10.5下载OrCAD10.5中文版软件
- 0.00 MB | 234315次下载 | 免费
- 5Altium DXP2002下载入口
- 未知 | 233046次下载 | 免费
- 6电路仿真软件multisim 10.0免费下载
- 340992 | 191187次下载 | 免费
- 7十天学会AVR单片机与C语言视频教程 下载
- 158M | 183279次下载 | 免费
- 8proe5.0野火版下载(中文版免费下载)
- 未知 | 138040次下载 | 免费
评论
查看更多