Skip to content

IP core with AXI interface for reading the Device DNA from the PL of Zynq 7000 devices

License

Notifications You must be signed in to change notification settings

abr/zynq-axi-dna

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

9 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

What is this?

This is a method of reading the Device DNA from the PL for Zynq 7000 devices wrapped in an AXI interface for easy MMIO access on the PS.

This is built with Vivado 2018.3 and is based off the Xilinx AXI_DNA core provided for the Ultrascale+ devices

IP core

In the ip_repo folder you will find an IP core, zynq_AXI_DNA that reads the 57bit Device DNA from the PL of a Zynq 7000 device. The core uses an AXI interface and will return a 64bit value where the 7 MSBs beyond the 57 DNA bits are tied to zero.

PYNQ Example

This has been tested with the PYNQ-Z1 board.

Build the project

In the pynq_dna directory you will find an example project for the PYNQ-Z1 that uses this zynq_AXI_DNA core in the design. To build the project run:

./build_DNA_extractor.sh

This will create a project directory, DNA_extractor, and create the Vivado project. It will also generate the bitstream and save the output files in the bin directory.

Test it out

You can now copy dna_extractor.bit and dna_extractor.hwh from the bin directory to the /home/xilinx directory of your PYNQ board and copy the DNA_test.ipynb notebook to the /home/xilinx/jupyter_notebooks directory.

In your browser open up the PYNQ jupyter server and run through the DNA_test notebook to see your Device DNA!

Using with HLS

If you are connecting this IP to an HLS block, you will need to create an AXI master port. You can then use memcopy to read values with an offset since we don't have access to the AXI address line directly. For example:

void foo(..., unsigned int *DNA_in){
  // Make DNA a master port to read from zynq_AXI_DNA block
  #pragma HLS INTERFACE m_axi port=DNA_in bundle=DNA offset=off

  unsigned int DNA0, DNA1;

  memcpy(&DNA0, DNA_in, 4);  // Read first 32b
  memcpy(&DNA1, DNA_in + 0x01, 4);  // Read next 32b

  // Combine into a single 64b value if desired
  unsigned long DNA_full = (((unsigned long) DNA0) << 32) |
                            ((unsigned long) DNA1);


  ...

}

About

IP core with AXI interface for reading the Device DNA from the PL of Zynq 7000 devices

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages