获取Xilinx FPGA芯片IDCODE的4种方法(支持任何FPGA型号)

news2024/11/15 10:52:14

文章目录

      • 方式1:官方文档
      • 方式2:一个头文件
      • 方式3:BSDL文件
      • 方法4:芯片IDCODE在线搜索网站
      • Xilinx FPGA部分型号IDCODE汇总

方式1:官方文档

对于常用的Spartan-6系列可以在UG380文档中找到对应的IDCODE,Spartan-7、Artix-7、Kinte-7、Virtex-7可以在UG470文档里找到对应的IDCODE。

文档下载:

  • xilinx_spartan6_config_ug380.pdf
  • UG470_7Series_Config.pdf

Spartan-6系列的IDCODE对照表位于UG380:Table 5-13: ID Codes

7系列的IDCODE对照表位于UG470:Table 1-1: Bitstream Length

ZYNQ系列没有找到对应的IDCODE说明文档。

方式2:一个头文件

在ISE开发环境下,最后一个版本14.7,可以在以下安装路径的文件中获取到一些旧型号的IDCODE:

安装路径\Xilinx\14.7\ISE_DS\EDK\sw\XilinxProcessorIPLib\drivers\hwicap_v8_01_a\src\xhwicap_l.h


在Vivado开发环境下的xhwicap_l.h文件中,删除了IDCODE。

安装路径\Vivado\SDK\2018.3\data\embeddedsw\XilinxProcessorIPLib\drivers\hwicap_v11_0\src\xhwicap_l.h

方式3:BSDL文件

对于ZYNQ-7000系列,一只没有找到IDCODE相关的说明文档,终极解决办法就是直接从BSDL边界扫描文件中查找,关于边界扫描,这是一个非常有意思的JTAG技巧,我们后面再介绍。只要有了FPGA芯片型号对应的BSDL文件,就可以获取到IDCODE,而且BSDL文件在安装ISE或安装Vivado时,就会保存在安装路径下。

以查找ZYNQ-7000系列XC7Z100的IDCODE为例,ISE开发环境,BSDL文件位于:

D:\Program\Xilinx\14.7\ISE_DS\ISE\zynq\data\xc7z100*.bsd

Vivado开发环境,BSDL文件位于:

D:\Program\Xilinx\Vivado\SDK\2018.3\data\parts\xilinx\zynq\public\bsdl\xc7z100*.bsd

D:\Program\Xilinx\Vivado\Vivado\2018.3\data\parts\xilinx\zynq\public\bsdl\xc7z100*.bsd

所谓的BSDL文件,其实就是一个VHDL文件,我们以文本方式打开,直接搜索关键字IDCODE_REGISTER,会定位到如下位置:

二进制合并转换之后,就得到了我们想要的IDCODE:

attribute IDCODE_REGISTER of XC7Z100 : entity is
	"XXXX" &	-- version
	"0011011" &	-- family
	"100110110" &	-- array size
	"00001001001" &	-- manufacturer
	"1";		-- required by 1149.1


--二进制合并处理后
attribute IDCODE_REGISTER of XC7Z100 : entity is
	"XXXX" &	-- version
	0011011100110110000010010011        --0x03736093

所以,如果想要获取任何FPGA芯片的IDCODE,只需要获取对应的BSDL文件即可。

方法4:芯片IDCODE在线搜索网站

这里推荐一个在线的IDCODE搜索网站,其实本质是一个BSDL汇总网站:BSDL Files Library for JTAG

https://bsdl.info/index.htm

理论上任何一个支持JTAG的芯片型号,都会有一个IDCODE用来作为唯一标识。
直接输入想要查找的芯片型号:

点开对应的BSDL文件:

可以看到IDCODE为0x03736093。

Microchip A3P125 FPGA芯片的IDCODE


Altera EP4CE40F29 FPGA芯片IDCODE

Xilinx FPGA部分型号IDCODE汇总

/* Virtex4 Devices. */
#define IDCODE_XC4VLX15    0x01658093
#define IDCODE_XC4VLX25    0x0167C093
#define IDCODE_XC4VLX40    0x016A4093
#define IDCODE_XC4VLX60    0x016B4093
#define IDCODE_XC4VLX80    0x016D8093
#define IDCODE_XC4VLX100   0x01700093
#define IDCODE_XC4VLX160   0x01718093
#define IDCODE_XC4VLX200   0x01734093
#define IDCODE_XC4VSX25    0x02068093
#define IDCODE_XC4VSX35    0x02088093
#define IDCODE_XC4VSX55    0x020B0093
#define IDCODE_XC4VFX12    0x01E58093
#define IDCODE_XC4VFX20    0x01E64093
#define IDCODE_XC4VFX40    0x01E8C093
#define IDCODE_XC4VFX60    0x01EB4093
#define IDCODE_XC4VFX100   0x01EE4093
#define IDCODE_XC4VFX140   0x01F14093

#define IDCODE_V4_NUM_DEVICES    17

/* Virtex5 Devices */
#define IDCODE_XC5VLX30      0x0286E093
#define IDCODE_XC5VLX50      0x02896093
#define IDCODE_XC5VLX85      0x028AE093
#define IDCODE_XC5VLX110     0x028D6093
#define IDCODE_XC5VLX220     0x0290C093
#define IDCODE_XC5VLX330     0x0295C093
#define IDCODE_XC5VLX30T     0x02A6E093
#define IDCODE_XC5VLX50T     0x02A96093
#define IDCODE_XC5VLX85T     0x02AAE093
#define IDCODE_XC5VLX110T    0x02AD6093
#define IDCODE_XC5VLX220T    0x02B0C093
#define IDCODE_XC5VLX330T    0x02B5C093
#define IDCODE_XC5VSX35T     0x02E72093
#define IDCODE_XC5VSX50T     0x02E9A093
#define IDCODE_XC5VSX95T     0x02ECE093
#define IDCODE_XC5VFX30T     0x03276093
#define IDCODE_XC5VFX70T     0x032C6093
#define IDCODE_XC5VFX100T    0x032D8093
#define IDCODE_XC5VFX130T    0x03300093
#define IDCODE_XC5VFX200T    0x03334093

#define IDCODE_V5_NUM_DEVICES    20

/* Virtex6 Devices */
#define IDCODE_XC6VHX250T    0x042A2093
#define IDCODE_XC6VHX255T    0x042A4093
#define IDCODE_XC6VHX380T    0x042A8093
#define IDCODE_XC6VHX565T    0x042AC093
#define IDCODE_XC6VLX75T     0x04244093
#define IDCODE_XC6VLX130T    0x0424A093
#define IDCODE_XC6VLX195T    0x0424C093
#define IDCODE_XC6VLX240T    0x04250093
#define IDCODE_XC6VLX365T    0x04252093
#define IDCODE_XC6VLX550T    0x04256093
#define IDCODE_XC6VLX760     0x0423A093
#define IDCODE_XC6VSX315T    0x04286093
#define IDCODE_XC6VSX475T    0x04288093
#define IDCODE_XC6VCX75T     0x042C4093
#define IDCODE_XC6VCX130T    0x042CA093
#define IDCODE_XC6VCX195T    0x042CC093
#define IDCODE_XC6VCX240T    0x042D0093

#define IDCODE_V6_NUM_DEVICES     17

/* Spartan6 Devices. */
#define IDCODE_XC6SLX4      0x04000093
#define IDCODE_XC6SLX9      0x04001093
#define IDCODE_XC6SLX16     0x04002093
#define IDCODE_XC6SLX25     0x04004093
#define IDCODE_XC6SLX25T    0x04024093
#define IDCODE_XC6SLX45     0x04008093
#define IDCODE_XC6SLX45T    0x04028093
#define IDCODE_XC6SLX75     0x0400E093
#define IDCODE_XC6SLX75T    0x0402E093
#define IDCODE_XC6SLX100    0x04011093
#define IDCODE_XC6SLX100T   0x04031093
#define IDCODE_XC6SLX150    0x0401D093
#define IDCODE_XC6SLX150T   0x0403D093

#define IDCODE_S6_NUM_DEVICES    13

/* Kintex7 Devices. */
#define IDCODE_XC7K30T     0x03642093
#define IDCODE_XC7K70T     0x03647093
#define IDCODE_XC7K160T    0x0364C093
#define IDCODE_XC7K325T    0x03651093
#define IDCODE_XC7K410T    0x03656093
#define IDCODE_XC7K235T    0x0365B093
#define IDCODE_XC7K125T    0x0365C093
#define IDCODE_XC7K290T    0x0365D093
#define IDCODE_XC7K355T    0x03747093
#define IDCODE_XC7K420T    0x0374C093
#define IDCODE_XC7K480T    0x03751093

#define IDCODE_K7_NUM_DEVICES   11

/* Virtex7 Devices. */
#define IDCODE_XC7VX80T     0x03680093
#define IDCODE_XC7VX82T     0x03681093
#define IDCODE_XC7VX330T    0x03667093
#define IDCODE_XC7VX415T    0x03682093
#define IDCODE_XC7V450T     0x0366C093
#define IDCODE_XC7VX485T    0x03687093
#define IDCODE_XC7VX550T    0x03692093
#define IDCODE_XC7V585T     0x03671093
#define IDCODE_XC7VX690T    0x03691093
#define IDCODE_XC7VX980T    0x03696093

#define IDCODE_V7_NUM_DEVICES  10

/* Artix7 Devices. */
#define IDCODE_XC7A15      0x03627093
#define IDCODE_XC7A30T     0x0362D093
#define IDCODE_XC7A50T     0x0362C093
#define IDCODE_XC7A100T    0x03631093
#define IDCODE_XC7A200T    0x03636093
#define IDCODE_XC7A350T    0x0363B093

#define IDCODE_A7_NUM_DEVICES 6

/* Zynq Devices. Latest as of July 2023 */
#define IDCODE_XC7Z007        0x03723093
#define IDCODE_XC7Z010        0x03722093
#define IDCODE_XC7Z012        0x0373C093
#define IDCODE_XC7Z014        0x03728093
#define IDCODE_XC7Z015        0x0373B093
#define IDCODE_XC7Z020        0x03727093
#define IDCODE_XC7Z030        0x0372C093
#define IDCODE_XC7Z035        0x03732093
#define IDCODE_XC7Z045        0x03731093
#define IDCODE_XC7Z100        0x03736093

#define IDCODE_ZYNQ_NUM_DEVICES      10

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/709349.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CM+CDH 构建企业大数据平台

📢📢📢📣📣📣 哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】!😜&am…

电磁阀位、通、开/闭原理精髓

一、引用 电磁阀在液/气路系统中,用来实现液路的通断或液流方向的改变,它一般具有一个可以在线圈电磁力驱动下滑动的阀芯,阀芯在不同的位置时,电磁阀的通路也就不同。 阀芯在线圈不通电时处在甲位置,在线圈通电时处在…

ChatGPT助力校招----面试问题分享(八)

1 ChatGPT每日一题:有源和无源滤波器 问题:有源和无源滤波器的区别 ChatGPT:有源滤波器和无源滤波器是指使用不同的电路元件来实现滤波功能的电路 有源滤波器使用了一个或多个有源元件,例如晶体管、运算放大器等,以…

浅浅总结一下雅思听力技巧

1. 地图题 读题步骤要明确 (1)看图,要看看题目中是否有东南西北的标志,如果有的话,那么大概率题目中就会用到。同时也标记好左右的标志,防止考试的时候太紧张分不清。 弄清楚个元素的相对位置&#xff0…

华为OD机试真题 Python 实现【开心消消乐】【2023 B卷 100分】,附详细解题思路

目录 一、题目描述二、输入描述三、输出描述四、Python算法源码五、效果展示1、输入2、输出3、说明 一、题目描述 给定一个N行M列的二维矩阵,矩阵中每个位置的数字取值为0或1。矩阵示例如: 1 1 0 0 0 0 0 1 0 0 1 1 1 1 1 1 现需要将矩阵中所有的1进行…

卷积神经网络--猫狗系列之构建模型【ResNet50】

在上一期:卷积神经网络--猫狗系列之下载、导入数据集,如果测试成功就说明对数据的预处理工作已经完成,接下来就是构建模型阶段了: 据说建立一个神经网络模型比较简单,只要了解了各层的含义、不同层之间参数的传递等等&…

leetcode 1232. 缀点成线

题目描述解题思路执行结果 leetcode 1232. 缀点成线 题目描述 缀点成线 给定一个数组 coordinates ,其中 coordinates[i] [x, y] , [x, y] 表示横坐标为 x、纵坐标为 y 的点。请你来判断,这些点是否在该坐标系中属于同一条直线上。 示例 1&a…

进程的调度常用算法

目录 先来先服务(FCFS)调度算法 短作业优先(SJF)的调度算法 基于时间片的轮转调度(RR)算法 先来先服务(FCFS)调度算法 系统将按照作业到达的先后次序来进行作业调度,或…

RT-Thread 5.0.1 qemu-virt64-aarch64 解决网络问题

参考文章 qemu 源码编译 qemu-system-aarch64 的方法 RT-Thread 5.0.1 qemu-virt64-aarch64 解决编译问题 前言 最近需要使用 RT-Thread qemu-virt64-aarch64,验证 aarch64 平台,也就是 ARM64 平台的一些网络功能,需要开启 qemu-virt64-aa…

UE4/5用贴图和GeneratedDynamicMeshActor曲面细分与贴图位移制作模型

目录 制作逻辑: ​编辑 曲面细分函数: 添加贴图逻辑: 代码: 制作逻辑: 在之前的文章中,我们使用了网格细分,而这一次我们将使用曲面细分函数,使用方法和之前是一样的&#xff1a…

高精度定位|RTK定位模块常见应用领域_厘米级室外定位解决方案

在室外场景,北斗、GPS等GNSS定位技术在持续的演变,精度越来越高,应用面也越来越广。随着新基建热潮的到来,借助5G新基建,无人驾驶、自动驾驶等技术正在逐步完善,对于定位的需求已经不仅仅只是粗略的轨迹&am…

uniapp-ios打包步骤

前置条件:已申请Apple ID并注册Apple Developer Program 一、登录苹果开发者官网 登录:https://developer.apple.com/ 点击账户(Account)进行登录,登录成功出现如下页面 二、创建证书、标识符、描述文件等 点击…

vue3基本指令使用

<script setup lang"ts"> import {ref} from vue //响应式数据 const num: number 1 const arr1: number[] [1, 2, 3, 4, 5] const str: string "我是一段文字" const htmlstr: string <section style"color:red">我是一个secti…

微服务-基于Docker安装Sentinel

目录 1、拉取Sentinel镜像 2、构建Sentinel容器 3、访问Sentinel 1、拉取Sentinel镜像 代码&#xff1a; docker pull bladex/sentinel-dashboard:1.8.0 实例&#xff1a; rootlocalhost howlong]# docker pull bladex/sentinel-dashboard:1.8.0 1.8.0: Pulling from blade…

集合及Collection集合

1&#xff1a;集合特点&#xff1a; 集合的大小不确定&#xff0c;启动后可以动态变化&#xff0c;类型也可以选择不固定。集合更像气球集合非常适合做元素的增删操作注意&#xff1a;集合只能存储引用类型数据&#xff0c;如果要存储基本类型数据可以选用包装类。 2&#xf…

2.FreeRTOS系统任务调度简介及任务状态

目录 一、基础知识 1、FreeRTOS 任务状态 (1)运行态 (2)就绪态 (3) 阻塞态 (4) 挂起态 二、任务调度简介 1.抢占式调度 2.时间片调度 3.协程式调度 一、基础知识 1、FreeRTOS 任务状态 FreeRTOS 中任务存在四种任务状态&#xff0c;分别为运行态、就绪态、阻塞态和挂…

Word模板替换,并转PDF格式输出,Linux服务器乱码问题解决

Poi-tl参考文档地址&#xff1a;http://deepoove.com/poi-tl/1.8.x/#hack-loop-table word模板替换&#xff0c;转pdf 1. 依赖引入&#xff1a;2. word模板配置&#xff1a;3. 示例demo:4 . 效果图5. 本地测试没问题&#xff0c;上Linux服务乱码&#xff0c;出现小方框 1. 依赖…

Python———运行环境搭建

不管用什么工具开发 Python 程序&#xff0c;都必须安装 Python 的运行环境。 目前最常用的是Windows 、 Linux 平台。这里 我们以Windows10为主讲解。 其实编程和平台关系不大。大家也可以使用Linux、Mac。 Windows 平台下 Python 环境搭建 第一步&#xff1a;进入 python 官…

python绘制热力图,数据来源pandas.dataframe

通过pandas.dataframe绘制热力图&#xff0c;并标出颜色最深即z轴数据最大的点。 import matplotlib.pyplot as plt import pandas as pd import numpy as npclass Heatmap:def __init__(self, data, marker*, marker_colorwhite, marker_size10):self.data dataself.size l…

排序的概念,插入排序,希尔排序,选择排序

文章目录 排序的概念排序的概念&#xff1a;排序运用常见的排序与时间复杂度 插入排序希尔排序希尔排序的概念希尔排序总结 选择排序概念 排序的概念 排序的概念&#xff1a; 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小…