data:image/s3,"s3://crabby-images/0f40c/0f40cf9c664728ded0a01b815a2b2c1b7a70fef5" alt=""
This post shows how to create a Xilinx Zynq-7000 + AXI slave in Vivado 2018.2 and read/write the AXI slave from the ARM9 of the Zynq-7000 using bare-metal code built with the SDK on the ZC702.
Versions Used
Xilinx Vivado 2018.2 & SDK 2018.2
ZC702 Rev 1.1
Windows 7 SP1
Before you Start
Review ZC702 JTAG and serial port set up instructions @ [link]. These instructions are also reviewed below.
Contents
Part 1: Create the Vivado Project
Part 2: Create the AXI Slave IP and Add it to the Repo
Part 3: Create the Zynq-7000 in IP Integrator
Part 4: Connect the AXI Slave
Part 5: Build the Bitstream (to Program the FPGA)
Part 6: Export the Design and Open the SDK
Part 7: Install the USB-to-UART Driver and Get the COM Assignment
Part 8: Configure the Board to Boot from JTAG, Connect it to the PC and Power it On
Part 9: Create the Test App and BSP
Part 10: Test Debug Run + Further Config
Part 11: Test the AXI module
Part 1: Create the Vivado Project
Step 1: Start Vivado
data:image/s3,"s3://crabby-images/1282c/1282c8e3b3c0e3aefd299273a5fbca0d2dfb547c" alt=""
Step 2: Click Create Project
data:image/s3,"s3://crabby-images/0d42a/0d42aff0def8a0c3762d6244d74642d083050a5d" alt=""
Step 3: Click Next
data:image/s3,"s3://crabby-images/c1960/c19600c488808da010e40aed7b8d6f0f12ea9c75" alt=""
Step 4:
A. Set Project name to axislave
B: Set Project location to C:/vivadoprjs (create C:/vivadoprjs if it doesn't exist)
C. Click the Create project subdirectory checkbox
D. Click Next
data:image/s3,"s3://crabby-images/61dff/61dff571139de578e90c31f13111a06f33537493" alt=""
Step 5:
A. Select RTL Project
B. Check the Do not specify sources at this time check box
C. Click Next
data:image/s3,"s3://crabby-images/2cf8f/2cf8f676677c693291bda70b7fa2d18d7767cfaa" alt=""
Step 6:
A. Click Boards
B. Type ZC702
C. Click on the ZYNQ-7 ZC702 Evaluation Board box
D. Click Next
data:image/s3,"s3://crabby-images/00297/00297289430c8051bfc2272f29043031d73fa93d" alt=""
Step 7: Click Finish
data:image/s3,"s3://crabby-images/fc197/fc197467dd9f00da9854160ffd801c7da5d78d43" alt=""
Part 2: Create the AXI Slave IP and Add it to the Repo
Step 1:
A. Click Tools
B. Click Create and Package New IP...
data:image/s3,"s3://crabby-images/bf1b0/bf1b05fb025a887ded8b4ad8b06856d53ba81bd4" alt=""
Step 2: Click Next
data:image/s3,"s3://crabby-images/6061c/6061c8994043bec3231af660d809edeba31b3f8e" alt=""
Step 3:
A. Select Create a new AXI4 peripheral
B. Click Next
data:image/s3,"s3://crabby-images/e80d9/e80d9ffda30e61f87c5e22615077d8d413e07edb" alt=""
Step 4:
A. Use defaults except, set IP location to: C:/vivadoprjs/axislave/ip_repo
B. Click Next
data:image/s3,"s3://crabby-images/4f25c/4f25cdbbdd4ebd33ac2b8b7c0b006d6bd9cdea62" alt=""
Step 5: Use defaults, click Next
data:image/s3,"s3://crabby-images/fdbfd/fdbfd96a1ed8feeac42ac1a8e633f8622de83816" alt=""
Step 6: Use defaults, click Finish
data:image/s3,"s3://crabby-images/552f1/552f1b98b06f127b1ffbc0e2883ad8aac04c0cb9" alt=""
Part 3: Create the Zynq-7000 in IP Integrator
Step 1: Click Create Block Design
data:image/s3,"s3://crabby-images/8789f/8789f1fefa8171c054e39adbc5c3fde6fe4a6059" alt=""
Step 2: Use defaults, click OK
data:image/s3,"s3://crabby-images/a5959/a59590171fa22399a70d0252fffff7f63695bb34" alt=""
Step 3: Click +
data:image/s3,"s3://crabby-images/349ad/349ad2944db033ee2f6f272feaac52c6e9ed31d3" alt=""
Step 4:
A. Type Zynq
B. Double-click on ZYNQ7 Processing System
data:image/s3,"s3://crabby-images/72360/723600d10ca0a1954afad9323fe3a8bb3ffdb196" alt=""
Step 5: Click Run Block Automation
data:image/s3,"s3://crabby-images/4c7b1/4c7b19f905964e7016da6ce2a1391041aa016f68" alt=""
Step 6: Use defaults, click OK
data:image/s3,"s3://crabby-images/2aac1/2aac13e66144d1d31eaa99c7510b71a1e03a5073" alt=""
You should see:
data:image/s3,"s3://crabby-images/e1d64/e1d6482fcef5ec917551c14f3a9b352fa65471a7" alt=""
Part 4: Connect the AXI Slave
Step 1: Click +
data:image/s3,"s3://crabby-images/349ad/349ad2944db033ee2f6f272feaac52c6e9ed31d3" alt=""
Step 2:
A. Type myIP
B. Double-click myip_v1.0
data:image/s3,"s3://crabby-images/2c8ae/2c8ae0a5dd25e78966f5771cca06242cdbcf6d40" alt=""
Step 3: Click Run Connection Automation
data:image/s3,"s3://crabby-images/c5077/c5077457393b2ad6a382782dac05cc1cbb3e52f2" alt=""
Step 4: Use defaults, click OK
data:image/s3,"s3://crabby-images/3f279/3f279f51f60672ca09fd33595bbcd10330ead8f4" alt=""
You should see:
data:image/s3,"s3://crabby-images/5d905/5d905dcf9f44b24aae6378950c4be186759f0ba4" alt=""
Step 5: Click Sources
data:image/s3,"s3://crabby-images/a1b0f/a1b0f73999d7b319068fb20e9f19f3255c45d6d7" alt=""
Step 6:
A. Right-click design_1 (design_1.bd)
B. Click Create HDL Wrapper...
data:image/s3,"s3://crabby-images/51fd0/51fd0766b9b380afb8c5417e649b437e4d71c6bc" alt=""
Step 7: Use default, click OK
data:image/s3,"s3://crabby-images/dc5a0/dc5a0b562918b982e5a05e7ba74a1bc657df4585" alt=""
You should see:
data:image/s3,"s3://crabby-images/1e4db/1e4db32af03f52a55d02daeac895b181306bf19d" alt=""
Step 8:
A. Click to expand design_1_wrapper (design_1_wrapper.v)(1)
B. Right-click on design_1_i: design_1 (design_1.bd)(1)
C. Click Generate Output Products...
data:image/s3,"s3://crabby-images/130eb/130eb310486c0ad1498956784494b73e3a30416b" alt=""
Step 7:
A. Leave selected or select Out of context per IP
B. Leave Number of jobs at 2
C. Click Generate
data:image/s3,"s3://crabby-images/1f5cf/1f5cf24241ed562a4632aae8c53b88e31b7a377a" alt=""
Step 8: Click OK and let the operation complete
data:image/s3,"s3://crabby-images/c020c/c020ca1803a016dc9d799b161a5c3b9bd831e847" alt=""
Part 5: Build the Bitstream (to Program the FPGA)
Step 1: Click Run Synthesis
data:image/s3,"s3://crabby-images/f439d/f439d27453721f7a0f1ba88ba8b949b9c16efb55" alt=""
Step 2: Use defaults, click OK
data:image/s3,"s3://crabby-images/ed9f2/ed9f21633e215b3e66a48f343514575022eb81ea" alt=""
You'll see the status in the upper right corner:
data:image/s3,"s3://crabby-images/b2a3e/b2a3e8a2d5edcd7c3dbf1e80f139839a97707d11" alt=""
Step 3:
Wait approximately 1 to 5 min until you see Synthesis Complete in the upper right corner...
data:image/s3,"s3://crabby-images/f4b90/f4b90fa09825eff6cf5711df5fbb3e41a8aa0c86" alt=""
...and click OK to Run Implementation:
data:image/s3,"s3://crabby-images/62e98/62e98b89f8e0f80242ed8382a2eb15e1f799301d" alt=""
Step 4: Use defaults, click OK
data:image/s3,"s3://crabby-images/c5280/c52803212d1f7b58f958d57bdf8a6fd0d5d3db69" alt=""
Again, you'll see status in the upper right:
data:image/s3,"s3://crabby-images/bb50d/bb50dcff0b4bfa274ada15dfb1c59ae9156c56fc" alt=""
Step 5:
Wait approximately 1 to 5 min until you see Implementation Complete in the upper right corner...
data:image/s3,"s3://crabby-images/7ec53/7ec531a4438258a3022aa4d43ab4e4af0b84df2a" alt=""
A. Select Generate Bitstream
B. Click OK
data:image/s3,"s3://crabby-images/55967/559675b4d31d8ecd07469c213a67b044baecd9cc" alt=""
Step 6: Use defaults, click OK
data:image/s3,"s3://crabby-images/dd34d/dd34da4c4e8b34f52b51cc534112f8a90eecc9d3" alt=""
Again, you should see the status in the upper right:
data:image/s3,"s3://crabby-images/00371/0037167384a88344d9d7cb9ea30a28eba87ac032" alt=""
Step 7: Click Cancel
data:image/s3,"s3://crabby-images/dadce/dadce407c657b86e33525a3ad3a9259be259679a" alt=""
You may see this window pop-up:
data:image/s3,"s3://crabby-images/159e4/159e4318a8a8fc3bfcf7f0486cdf51c3fd41f9e8" alt=""
Feel free to send feedback, set a reminder or click No. If you click No you may see:
data:image/s3,"s3://crabby-images/d5863/d586319713364711e0bc0574afc8a8cb19b22920" alt=""
...click OK to dismiss.
Part 6: Export the Design and Open the SDK
Step 1:
A. Click File
B. Click Export
C. Click Export Hardware...
data:image/s3,"s3://crabby-images/ce7dd/ce7dd99c176ccfdb8dc21effc8650c04a949cc47" alt=""
Step 2:
A. Click the Include bitstream checkbox
B. Click OK
data:image/s3,"s3://crabby-images/72b93/72b9349c60a8e56d05e6fd6a07c0642ce65edd51" alt=""
Step 3:
A. Click File
B. Click Launch SDK
data:image/s3,"s3://crabby-images/67d8d/67d8dbe4779dc22fee894cb2c7523aff705813eb" alt=""
Note: you can open up the workspace from the SDK by launching the SDK and selecting C:\vivadoprjs\axislave\axislave.sdk as the workspace.
Step 4: Use defaults, click OK
data:image/s3,"s3://crabby-images/9e636/9e63615c305ee87163a72c66e6b8bd9460c71489" alt=""
Step 5: After the SDK launches, note the Base Addr of myip_0:
data:image/s3,"s3://crabby-images/17621/176213b4150f6a291841ce9c99bed1e601d9c966" alt=""
Part 7: Install the USB-to-UART Driver and Get the COM Assignment
Steps:
A. Goto [link] for the Silicon Labs CP210x USB to UART Bridge VCP Drivers
B. Download and unzip the correct installer for your OS
C. Install the driver (I did not need to restart on Windows 7 SP1)
D. Click Windows
E. Click Devices and Printers
data:image/s3,"s3://crabby-images/63c68/63c68c8bc439536f510f93dc7b2a8dd4d1c65231" alt=""
F. You should see Silicon Labs CP210x USB to UART BridgeG. Note the COM port (you'll need this later)
data:image/s3,"s3://crabby-images/5f525/5f52587b6fb55fb822e435412208837e2998544b" alt=""
Part 8: Configure the Board to Boot from JTAG, Connect it to the PC and Power it On
Step 1: Set SW16 to JTAG mode [mode documentation see p.16]
data:image/s3,"s3://crabby-images/70f1b/70f1b43d4de3b8fb4607900e147c6530b5674c6b" alt=""
For the rest of the jumpers see the high-resolution photo of the board in the correct state at [link]. Step 2: Connect a Micro-B to Type-A (host connection) USB cable from U23 (Diglent USB JTAG interface) to the host PC
U23:
Micro-B connector:
Type-A connector:
Step 3: Connect a Mini-B to Type-A (host connection) USB cable from J17 (CP2103GM USB-to_UART Bridge) to the host PC.
J17:
Mini-B connector:
Type-A connector:
Step 4: Turn on the board
Part 9: Create the Test App and BSP
Step 1:
A. Click File
B. Click New
C. Click Application Project
data:image/s3,"s3://crabby-images/449dc/449dcbe93f57dd8617b00918df1f335bae8d26ef" alt=""
Step 2:
A. Type testaxislave
B. Ensure the Board Support Package: Create New radio button is clicked and the name given is testaxislave_bsp
C. Click Next
data:image/s3,"s3://crabby-images/412ef/412efff57c258c5df14fee93da0caf0f402a9e0f" alt=""
Step 3:
A. Click Hello World
B. Click Finish
data:image/s3,"s3://crabby-images/a2dc3/a2dc3a8308ffa79d055d308a07573a695143aa00" alt=""
Part 10: Test Debug Run + Further Config
These instructions allow debug to be set up more easily than entering in the details manually. After running a debug session, the Debug Configuration is fixed up to reset the FPGA and program the bitstream. The debugger COM port is also configured so that output can be read and the steps to test it and see Hello World are listed.
Step 1:
A. Right-click testaxislave
B. Click Debug As
C. Click Launch on Hardware (System Debugger)
data:image/s3,"s3://crabby-images/2c680/2c680f2099ca11faf1cf4820e3a0f6e531888711" alt=""
Step 2: Click OK
data:image/s3,"s3://crabby-images/a448b/a448ba5c6eca371520236e359ea3f43621579fc3" alt=""
If you see this message click Yes. We'll handle this in the next part.
data:image/s3,"s3://crabby-images/160a4/160a4b7e48794a8fba2f942afcf00a996acd79f7" alt=""
You should see the Debug Perspective display the code broken on init_platform():
A. Debug context on main()
B. helloworld.c on init_platform()
data:image/s3,"s3://crabby-images/24a7a/24a7ae0544a9f14f38704928de69a8f640d6b9e8" alt=""
Step 3:
A. Click Run
B. Click Debug Configurations...
data:image/s3,"s3://crabby-images/d03f0/d03f020aba051cc52eb8a5787e530c72460fa087" alt=""
Step 4:
A. Ensure System Debugger using Debug_testaxislave is selected (it should be)
B. Click the Reset entire system checkbox
C. Click the Program FPGA checkbox
D. Click Apply
E. Click Close
data:image/s3,"s3://crabby-images/c4848/c48488489c330d64a0d392b26c014b8595cbfb00" alt=""
Step 5: Configure Debug View COM
A. Click SDK Terminal
B. Click the '+' (Connect to serial port.)
data:image/s3,"s3://crabby-images/c6b67/c6b678a88c1607ba9b9b535fc0385492241fe151" alt=""
Step 6: Set Debug View COM settings
A. Enter the COM# from above
B. Click OK
data:image/s3,"s3://crabby-images/0d916/0d916f1e5ee3c315a9a85947a3e9b2a9deaa890f" alt=""
Step 7: Make sure you see Hello World on the console
Click on the bug
data:image/s3,"s3://crabby-images/7b625/7b62580c7e49418af23f376b9fa34369f9d78ad6" alt=""
Step 8: Click OK
data:image/s3,"s3://crabby-images/764bb/764bb5562d0e0930f70d152c87e50356ed8c6306" alt=""
Step 9: Wait for the system to hit the breakpoint on main()
data:image/s3,"s3://crabby-images/bc4bc/bc4bc0d158a5d9619a2477b7b1bb4ddc5eb5efd0" alt=""
Step 10: Click Resume
data:image/s3,"s3://crabby-images/f1884/f1884378f5ef6626a03aff4e7ac3613195e31c04" alt=""
...and wait until you see exit():
data:image/s3,"s3://crabby-images/b63d9/b63d9ce64a3725993507e8542e47d4644589b078" alt=""
Step 11: Click on SDK Terminal...
data:image/s3,"s3://crabby-images/b0994/b099456dc5ee1e05d0041abe19682a762da48aef" alt=""
...to see Hello World:
data:image/s3,"s3://crabby-images/f03e2/f03e21a841558cbf38d911fed6325df0db9b9727" alt=""
Part 11: Test the AXI module
Step 1: Click on the C/C++ view
data:image/s3,"s3://crabby-images/6b504/6b50451531005c2cd6ab5fb1a11e8596579da875" alt=""
Step 2: Show myip tests
A. Right-click on design_1_wrapper_hw_platform
B. Click Refresh
data:image/s3,"s3://crabby-images/f61f6/f61f63156aeb25b7205249e049812b55d6131875" alt=""
Step 3:
A. Expand design_1_wrapper_hw_platform, drivers, myip_v1_0, src
B. Double click on myip_selftest.c
data:image/s3,"s3://crabby-images/0a787/0a7870a1b5b100f425781993e6bc9d6b8529d45f" alt=""
Step 4: Select XStatus MYIP_Reg_SelfTest(void * baseaddr_p)
data:image/s3,"s3://crabby-images/d1fc8/d1fc8dcebf644079697967ea81a04168b829bac8" alt=""
Step 5:
A. Click Edit
B. Click Copy
data:image/s3,"s3://crabby-images/c074a/c074a89c9852b3d994c3f4478d27fa7b3b3b2997" alt=""
Step 6:
A. Expand testaxislave
B. Expand src
C. Double-click helloworld.c
data:image/s3,"s3://crabby-images/9226b/9226ba3e47bc2b9f7ea2dbdce716b60f50250e4b" alt=""
Step 7:
A. Press ENTER to make room
B. Click Edit
C. Click Paste
data:image/s3,"s3://crabby-images/7c3a6/7c3a62d64629bb511298eaa9d6ae232dac032f94" alt=""
Step 8: Get the base address of myip_0
A. Double-click the system.hdf file
B. Note the address (it won't let you copy-paste it)
data:image/s3,"s3://crabby-images/22cbf/22cbf969bfc5372cb3ac7ac0dfe7383db0e02c7e" alt=""
Step 9:
A. Double-click on helloworld.c
B. Fix up the code so it reads: MYIP_Reg_SelfTest(0x43c00000);
data:image/s3,"s3://crabby-images/0ba39/0ba3941d59995b64c2a0dd331b51da4c7bc6fe13" alt=""
Step 10: Click the bug to restart debugging
data:image/s3,"s3://crabby-images/a3e21/a3e214bd74180b287200d37959b63e1419e95736" alt=""
Step 11: Click OK
data:image/s3,"s3://crabby-images/99b93/99b93ed4faaf5511f2ea29f7b98ea7a5e8617bcd" alt=""
Step 12: Click OK
data:image/s3,"s3://crabby-images/ebad8/ebad85aeda295c18403319dcebe8d7d0938e874a" alt=""
Step 13: Click Yes
data:image/s3,"s3://crabby-images/a5593/a559302176f061a41e42a2887ee00788caaca2e6" alt=""
You should see the code stopped at the breakpoint on main()
data:image/s3,"s3://crabby-images/1ac47/1ac47b555b28398f073287803668d0443b92fa48" alt=""
Step 14: Click Resume
data:image/s3,"s3://crabby-images/c0500/c0500bdb4e9fd6e1d5ae11cb56a6122d5b830686" alt=""
You should see:
data:image/s3,"s3://crabby-images/14c7b/14c7b6e4f5e30ff6443d788ad4e9d935378d1497" alt=""
References
Xilinx logo found via https://twitter.com/xilinxinc at [link]