描述
Xilinx 用两个 96 位独特器件标识符(称为器件 DNA)为每个 Zynq UltraScale+ 器件编程。
一个 DNA 值位于可编程逻辑 (PL) 中,另一个 DNA 值位于处理系统 (PS) 中。
这两个 DNA 值是不同的,但每个 DNA 都有以下属性及读取访问方法。
DNA 位置 | 大小 | 不可修改(写保护) | 只读访问方法 |
---|---|---|---|
PL DNA | 96 位 | 有 | PL DNA_PORTE2 原语(参见 UG974), or 通过 FUSE_DNA 指令 (opcode[11:0]=100100110010) JTAG PL TAP。 Vivado 硬件管理器显示 PL DNA 值。 |
PS DNA | 96 位 | 不 | PS APB(32 位)寄存器,地址: 0xFFCC100C (DNA_0) 0xFFCC1010 (DNA_1) 0xFFCC1014 (DNA_2) SDK XilSKey_ZynqMp_EfusePs_ReadDna API 返回 PS DNA 值。 |
PL DNA[93:57] 位值可能与 Xilinx 编程的 PS DNA[93:57] 位值不同。
如欲了解有关如何注册接收新设计报告的通知信息,请查看 (Xilinx 答复 18683)。
解决方案
PL DNA 建议用于通过 Xilinx 二维码器件查找工具/请求识别器件的应用,或用于依靠不可修改独特器件标识符的安全应用。
实例:
如何使用附带的 AXI_DNA 内核从处理器访问 PL DNA。(在 Vivado/XSDK 2018.2 中完成测试)。
1) 在 ip_repo 文件夹中提取压缩文件附件。
2) 将 ip_repo 目录添加到资源库中。
3) 将 AXI_DNA IP 添加到模块设计中,“运行自动”会其连接至处理器子系统并验证分配给 AXI DNA 的地址。
4) 将硬件导出至 XSDK,创建一个空项目并导入这三个文件(在 71342.zip 中附加到此答复记录):
5) 编译,创建一个可引导的映像,观察 UART 终端上的以下输出:
***************************************
The PL DNA is: 400000000113746804416305
***************************************
附件
文件名 | 文件大小 | File Type |
---|---|---|
xilinx.com_user_AXI_DNA_1.0.zip | 13 KB | ZIP |
71342.zip | 2 KB | ZIP |