data:image/s3,"s3://crabby-images/0f40c/0f40cf9c664728ded0a01b815a2b2c1b7a70fef5" alt=""
This post shows how run Hello World on a Xilinx ZC702. It covers: creating a design in Vivado, exporting the design to the SDK and running Hello World on the dual-core ARM Cortex-A9 processor in the Zynq-7000.
Contains
Part I: Build a PS and Generate a Bitstream
Parr III: Set up the ZC702
Part IV: Set up the Terminal
Part V: Run HelloWorld
Part VI: Debug HelloWorld
Note
This write up follows the steps presented in Zynq-7000 All Programmable SoC: Embedded Design Tutorial and adds corrections, clarifications and additional information.
Versions
Vivado 2018.2 available @ [link] (install the free WebPACK edition)
Windows 7 SP1
Part I: Build a PS and Generate a Bitstream
Step 1: Start Vivado 2018.2
A. Click Start
B. Click Vivado 2018.2
data:image/s3,"s3://crabby-images/4fca6/4fca6bcd7efd53192bbef98d96d7536f724baa76" alt=""
Step 2: Click Create Project
data:image/s3,"s3://crabby-images/4007e/4007e90fdcef7691cd0717e9b92e38be2b2c4966" alt=""
Step 3: Click Next
data:image/s3,"s3://crabby-images/83eaa/83eaab2f1877b62e80e9cccb21091d7a45c64703" alt=""
Step 4:
A. Set Project name to helloworld (always use a name without spaces [moreinfo])
B. Set Project location to C:/vivadoprjs (keep paths less than 200 chars)
C. Check the Create project subdirectory checkbox
D. Click Next
data:image/s3,"s3://crabby-images/11fca/11fca29c972aab695487f7a9ab32c61e5bc68795" alt=""
Step 5:
A. Select the RTL Project radio button if its not selected
B. Check the Do not specify source at this time checkbox
C. Click Next
data:image/s3,"s3://crabby-images/2d396/2d39622793099fbda47bd8f4d1da3322f97bce75" alt=""
Step 6:
A. Click Boards
B. Type ZC702
C. Click the ZYNQ-7 ZC702 Evaluation Board
D. Click Next
data:image/s3,"s3://crabby-images/9bb9d/9bb9da5def0acfefa446dcc336de33b58f87a451" alt=""
Step 7: Click Finish
data:image/s3,"s3://crabby-images/154ee/154ee96ef0f36196fcbc75d770a93facc906f217" alt=""
Text Listed, More Info and Links to Docs
New Project Summary
A new RTL project named 'helloworld' will be created.
The default part and product family for the new project:
Default Board: ZYNQ-7 ZC702 Evaluation Board
Default Part: xc7z020clg484-1 [speedgrade and part # decode (datasheet p.23)]
Product: Zynq-7000 [product page]
Family: Zynq-7000
Package: clg484 [Pinout Files & Packaging and Pinout p.79]
Speed Grade: -1
Step 8: Click Create Block Design
data:image/s3,"s3://crabby-images/40f74/40f741c778eaca6dc1445332ccd52e519123d208" alt=""
Step 9: Use defaults and click OK
data:image/s3,"s3://crabby-images/83863/83863ff4a6456589c3f656ce90a2bd8dc129555c" alt=""
Step 10: Click + to add IP (or Ctrl-I)
data:image/s3,"s3://crabby-images/26b02/26b02ccc04ea33dfca4410592a16c37821608c81" alt=""
Step 11:
A. Type Zynq
B. Double click on ZYNQ7 Processing System
data:image/s3,"s3://crabby-images/e9024/e9024858fbd0c83cc06dc9e369a57016a6192a2b" alt=""
You'll see the Xilinx LogiCORE™ IP Processing System 7 core [doc]:
data:image/s3,"s3://crabby-images/17f52/17f523700875fd2186104b31703673f607fb0788" alt=""
Interfaces:
M_AXI_GP0_ACLK (input, global clock, all signals sampled on rising edge of the global clock)
DDR
FIXED_IO
M_AXI_GP0
FCLK_CLK0 (output, fabric aka PL clock, clock for the PL)
FCLK_RESET0_N
Step 12: Click Run Block Automation
data:image/s3,"s3://crabby-images/f0817/f0817be10e5b0c8f6a6b21a97275666a9a8c94fc" alt=""
Step 13: Use defaults and click OK
data:image/s3,"s3://crabby-images/02abf/02abf4e14201b66d5acd6d04858cdd7c16b62f75" alt=""
You'll see:
data:image/s3,"s3://crabby-images/27c82/27c820b381811a0aae73e5f47096fb6da5c07869" alt=""
Step 14: Connect the PL clock (FCLK_CLK0) to the global clock (M_AXI_GP0_ACLK)
A. Click and hold on FCLK_CLK0
B. Drag the connection to M_AXI_GP0_ACLK and release mouse button
data:image/s3,"s3://crabby-images/9647c/9647c88c3ca2f4085e0b1818e76951dd21d52dbb" alt=""
You should see:
data:image/s3,"s3://crabby-images/bcb94/bcb9445fa1f3ae7a8702c6a9af75cb2c6af59d17" alt=""
Step 15: Create an HDL Wrapper
A. Click Sources
B. Click Hierarchy
C. Right-click design_1 (design_1.bd)
D. Click Create HDL Wrapper...
data:image/s3,"s3://crabby-images/fef1c/fef1cbab3e07d11c68a20e4bc37bf732850bd0ff" alt=""
Step 16:
A. Leave or select Let Vivado manage wrapper and auto-update
B. Click OK
data:image/s3,"s3://crabby-images/c020c/c020ca1803a016dc9d799b161a5c3b9bd831e847" alt=""
Step 17:
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 18:
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 19: Click OK and let the operation complete
data:image/s3,"s3://crabby-images/21964/219642568cb4570abdb0f960788761e854f46383" alt=""
Step 20: Click Run Synthesis
data:image/s3,"s3://crabby-images/205d7/205d74aec751ae5f0c544c78d6eb594d7fc01983" alt=""
Step 21: Use the defaults and click OK
data:image/s3,"s3://crabby-images/d5b78/d5b783ad10b42635b532395ba2724261fb525bae" alt=""
Wait for synth_design to complete
data:image/s3,"s3://crabby-images/25803/258038d8a515955b744f8b5d89beefaea68f3812" alt=""
Step 22:
A. Leave selected or select Run Implementation
B. Click OK
data:image/s3,"s3://crabby-images/2a128/2a128a449c9a27ccc2c77b31ae25d10a504b5bc6" alt=""
Step 23: Use the defaults and click OK
data:image/s3,"s3://crabby-images/303e6/303e688ef1353651630a8fb20adaf08787228e71" alt=""
Wait for the operation to complete:
data:image/s3,"s3://crabby-images/69fbd/69fbd769052c4cb5c44c36f870708f076da6c43c" alt=""
data:image/s3,"s3://crabby-images/5e148/5e1488380330e08f3abc68354705abd636b7451d" alt=""
data:image/s3,"s3://crabby-images/2bd39/2bd390cfb904aa2db9db03baa4f27f815d07c6f0" alt=""
Complete:
data:image/s3,"s3://crabby-images/be3bd/be3bd65f4f0d72ca1e52578a0d3b61df55516476" alt=""
Step 23:
A. Select Generate Bitstream
B. Click OK
data:image/s3,"s3://crabby-images/f802b/f802b42d46bc424e36bc303f5d71db9db5518e17" alt=""
Step 24: Use the defaults and click OK
data:image/s3,"s3://crabby-images/303e6/303e688ef1353651630a8fb20adaf08787228e71" alt=""
Wait for the operation to complete:
data:image/s3,"s3://crabby-images/7470d/7470d0f5cbe6fad73b965aea433cec319b229ecf" alt=""
Complete:
data:image/s3,"s3://crabby-images/46d6d/46d6db3e25550ab092ee0748edd4b84be5b82609" alt=""
Step 25: Click Cancel
data:image/s3,"s3://crabby-images/b0630/b063064e5872b97838b8a1cf98564e6bd42d96eb" alt=""
Part II: Export Hardware Design and the Open SDK
Step 1:
A. Click File
B. Click Export
C. Click Export Hardware
data:image/s3,"s3://crabby-images/b1e6c/b1e6c099f98753f1306f77405e608796edf1291e" alt=""
Step 2:
A. Click the Include bitstream checkbox
B. Leave <Local to Project>
C. Click OK
data:image/s3,"s3://crabby-images/f3bff/f3bffb8a945721558a46537020fa614c549f7b75" alt=""
Step 3:
A. Click File
B. Click Launch SDK
data:image/s3,"s3://crabby-images/09c84/09c849be9a7f241515b60c70adba9f4ba0afd599" alt=""
Step 4: Use defaults and click OK
data:image/s3,"s3://crabby-images/976c9/976c9590a671d524028df2b1b94f272a8408a530" alt=""
Step 5:
A. Click File
B. Click Application Project
data:image/s3,"s3://crabby-images/f75ff/f75ff368a34f7b803d9f1a3c9b7c46ad51f75c6b" alt=""
Step 6:
A. Type HelloWorld for Project name
B. See HelloWorld_bsp autopopulate
C. Click Next
data:image/s3,"s3://crabby-images/c2822/c28228573e6f98193a95a8d8294d8a8451760f16" alt=""
Step 7:
A. Ensure Hello World is selected (it should be)
B. Click Finish
data:image/s3,"s3://crabby-images/72531/7253160067fbc4db0771a25aa80c3792030f3f0a" alt=""
You should see:
data:image/s3,"s3://crabby-images/436c8/436c8dc3cfdc1db1fbd88b1699ec68e74c7cc6bc" alt=""
Part III: Set up the ZC702
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:
data:image/s3,"s3://crabby-images/c17f8/c17f8a4d556ae7d0e2cfd680adf8b7b93731df9d" alt=""
Micro-B connector:
data:image/s3,"s3://crabby-images/4f952/4f95242b887893712d0ba9d78b1ecd7eb9193878" alt=""
Type-A connector:
data:image/s3,"s3://crabby-images/0eeea/0eeea7a1fbe52d9e3a3bbbdd8a4828ab7f464e90" alt=""
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:
data:image/s3,"s3://crabby-images/90540/90540ccd58d04b487f6c75bd0d945228c8f5fa32" alt=""
Mini-B connector:
data:image/s3,"s3://crabby-images/27013/27013b43f27232c8b3ae98fcd251eaa12d7807a7" alt=""
Type-A connector:
data:image/s3,"s3://crabby-images/884f1/884f17f6c9568942843c1450521249ab0eec95eb" alt=""
Step 4: Power on the board (you'll need to power on the board to see the USB-to-UART device in the next step).
data:image/s3,"s3://crabby-images/2c77d/2c77daafc8cfde68274da652e11db36e285c2736" alt=""
Part IV: Set up the Terminal
Step 1: Install the Silicon Labs CP210x USB to UART Bridge VCP Drivers
A. Goto [link]
B. Download and unzip the correct installer
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 Bridge
G. Note the COM port (you'll need this later)
data:image/s3,"s3://crabby-images/5f525/5f52587b6fb55fb822e435412208837e2998544b" alt=""
Step 2:
A. Click Window
B. Click Show View
C. Click Other
data:image/s3,"s3://crabby-images/b8563/b8563b5286ec9e36595c8fc72a60b5b51634c7af" alt=""
Step 3:
A. Expand Terminal
B. Click Terminal
C. Click OK
data:image/s3,"s3://crabby-images/db16c/db16cb3f05c68313408d3fe4cd70bc9c2c9d6a97" alt=""
Step 4: Click Settings
data:image/s3,"s3://crabby-images/bdc11/bdc11685d9830b310e880c0ea0723faffdf3787e" alt=""
Step 5:
A. Use the COM port listed in Devices and Printers (or type it in: COM9 for instance)
B. Click OK
data:image/s3,"s3://crabby-images/8c97c/8c97c3ebe94bd1df1441e3f3e1ddf615ad29642a" alt=""
Part V: Run HelloWorld
Step 1: Run Debug once
A. Right click HelloWorld
B. Click Debug As
C. Click Launch on Hardware (System Debugger)
data:image/s3,"s3://crabby-images/5d646/5d646d9af4d5fb1f98007a8ff5c4c9f44963e23f" alt=""
D. Click Yes
data:image/s3,"s3://crabby-images/cfb3a/cfb3a492c87b77d37ef75c4ffc7bfaf1d6d6d631" alt=""
E. Click Yes
data:image/s3,"s3://crabby-images/12ade/12ade27811aaa6c6e065279eeee8dc06ef073bc1" alt=""
Step 2:
A. Click Run
B. Click Run Configurations...
data:image/s3,"s3://crabby-images/596ac/596ac4ce4d5e666e1834f5d6314c69a1bb8a4768" alt=""
Step 3:
A. Make sure System Debugger using Debug_HelloWorld.elf on Local is selected
B. Check the Reset entire system check box
C. Check the Program FPGA check box
D. Ensure the Run ps7_init check box is checked
E. Ensure the Run ps7_post_config is checked
F. Click Apply
G. Click Run
data:image/s3,"s3://crabby-images/03d71/03d715f2e5c96c7dc29dda46629a1329b11c1ad6" alt=""
H. Switch back to the C/C++ View
data:image/s3,"s3://crabby-images/942a3/942a3bb5083f710afc9c15205227bb50163f4c35" alt=""
You should see:
data:image/s3,"s3://crabby-images/afd63/afd6336da4010e58c26f166079d889e8fad3a0f0" alt=""
Step 4: Run the program again
A. Click Run
B. Click Run (this will use the Run Config you set up previously)
data:image/s3,"s3://crabby-images/159ec/159eca2ea4f39bb0fcf6a0e525123e88035167a4" alt=""
C. Click OK
data:image/s3,"s3://crabby-images/b1c4a/b1c4a0c5541dc1c0ce008cf7d3845daf3d249ab2" alt=""
You should see another Hello World:
data:image/s3,"s3://crabby-images/8ebf2/8ebf2de370bbdd350e02ed9acd45131eaf9399a8" alt=""
Part VI: Debug HelloWorld
Step 1: Click to disconnect Run terminal
data:image/s3,"s3://crabby-images/1a77f/1a77fbbfdc115857e1fb594c54b96c181cd96151" alt=""
Step 2:
A. Click Run
B. Click Debug Configurations...
data:image/s3,"s3://crabby-images/60724/6072475831368b40d69a2089b345789aad9a730d" alt=""
Step 3:
A. Make sure System Debugger using Debug_HelloWorld.elf on Local is selected
B. Make sure the Reset entire system check box is checked
C. Make sure theProgram FPGA check box is checked
D. Ensure the Run ps7_init check box is checked
E. Ensure the Run ps7_post_config is checked
F. Click Apply if anything changed (the Apply button will be grayed out if no changes were needed).
G. Click Debug
data:image/s3,"s3://crabby-images/c86f8/c86f878e87b214b9f957320b00004e7bd378ee38" alt=""
H. Click Yes
data:image/s3,"s3://crabby-images/5e516/5e516b0d12f37042ecaab1cedced2ad79c9e9bae" alt=""
You should see:
data:image/s3,"s3://crabby-images/8630c/8630c41ae0ac03d73bf946a97982507a15323f82" alt=""
Step 4: Connect the serial port
A. Click SDK Terminal
B. Click the '+' (Connect to serial port.)
data:image/s3,"s3://crabby-images/c6b67/c6b678a88c1607ba9b9b535fc0385492241fe151" alt=""
C. Use these settings and click OK
data:image/s3,"s3://crabby-images/6d0b6/6d0b649fad66328aa770153c61011ab5e323b515" alt=""
You should see:
data:image/s3,"s3://crabby-images/449d5/449d5eb36fee782cf4891f3e4174057c28433ab0" alt=""
Step 5: Click Resume (F8)
data:image/s3,"s3://crabby-images/e40a7/e40a7e601d9aa40da757185bb277469d8e799706" alt=""
You should see:
data:image/s3,"s3://crabby-images/b8f86/b8f8664b70f0273d294a747feb9f688190f78122" alt=""
Step 6: Restart Debug
A. Click Run
B. Click Debug (this will use the Debug Config you set up previously)
data:image/s3,"s3://crabby-images/2b9a0/2b9a098bf7f3a0d859281d6171da255c277a8c78" alt=""
C. Click OK
data:image/s3,"s3://crabby-images/4f530/4f530352ff016150ed2b1a288a87496391f05475" alt=""
You should again see:
data:image/s3,"s3://crabby-images/7ab88/7ab8888a9a07d27004873526277d0cdd1558e617" alt=""
Note: to disconnect the debuggers serial port click here:
data:image/s3,"s3://crabby-images/f35d2/f35d23a78038aaa0439b5b22311b53ad1c4e88db" alt=""
You should see:
data:image/s3,"s3://crabby-images/69158/691583745e469768282157273de3ea7966632322" alt=""
References
2018.2 Zynq-7000 All Programmable SoC: Embedded Design Tutorial (UG1165) @ [link] (p.15 to 30)
Xilinx logo found via https://twitter.com/xilinxinc at [link]