data:image/s3,"s3://crabby-images/97e9d/97e9de3dc77055f249c35f8f183fee6b3b3401f5" 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/cda16/cda1653f2148de21616e07d8f8b369b0ca762eef" alt=""
Step 2: Click Create Project
data:image/s3,"s3://crabby-images/285d2/285d20b11e3bcb5e51a2cc557d32389fb5fb8689" alt=""
Step 3: Click Next
data:image/s3,"s3://crabby-images/a630e/a630e7c1e72ba649d13678d4daeede39ea3ec6da" 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/55329/55329637ad97753691b20435f288607a8bbdc0dc" 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/110d5/110d50379af8610e437b8ce853e083c98feff78d" 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/fe616/fe61675cfa329cbbbfa17101d6656cf684e95517" alt=""
Step 7: Click Finish
data:image/s3,"s3://crabby-images/c94e1/c94e1655f000da9e9aa10d053674200ab40e05cd" 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/1bce9/1bce90f50544c547d85008169a7d18537be70d69" alt=""
Step 9: Use defaults and click OK
data:image/s3,"s3://crabby-images/f4f81/f4f819d40edb60184101e476ff87d56038286a4f" alt=""
Step 10: Click + to add IP (or Ctrl-I)
data:image/s3,"s3://crabby-images/7bbe5/7bbe5b89f6542a055e8a85c6abdc38fed966f960" alt=""
Step 11:
A. Type Zynq
B. Double click on ZYNQ7 Processing System
data:image/s3,"s3://crabby-images/27154/27154398da5b2cb5f4da1b6f605212ce1fe82101" alt=""
You'll see the Xilinx LogiCORE™ IP Processing System 7 core [doc]:
data:image/s3,"s3://crabby-images/5f2f3/5f2f34ad6fd5c6527ab03c179d2f4b972b4a74b6" 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/049e3/049e38f9db48db2b24fb2c8ca8381a6bec36410c" alt=""
Step 13: Use defaults and click OK
data:image/s3,"s3://crabby-images/72801/728011677130f61a9ac6217b6ac67500d27c63ea" alt=""
You'll see:
data:image/s3,"s3://crabby-images/d3f8d/d3f8d8de5595686505fc03fcb3755eacbae7fc4b" 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/f3ce7/f3ce7695b1825cdbe2a60f5cb78b17474050cf6a" alt=""
You should see:
data:image/s3,"s3://crabby-images/8aba5/8aba5d7945c69d5d9ff71efeae9e21818f22e93b" 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/27eac/27eac4a7e0b3670d83cf63d851e48841241a90e1" alt=""
Step 16:
A. Leave or select Let Vivado manage wrapper and auto-update
B. Click OK
data:image/s3,"s3://crabby-images/88249/88249aeea02541c176fc4657c07e73ed5654f013" 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/cb640/cb640b12c3ca185e19bb157050e0cefb14b157f4" 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/1899f/1899fe70580b21bd1ba4115c4a484a415982b7b3" alt=""
Step 19: Click OK and let the operation complete
data:image/s3,"s3://crabby-images/979bb/979bb71ce7d08b010fd1d8d5bc2e59fd19121164" alt=""
Step 20: Click Run Synthesis
data:image/s3,"s3://crabby-images/7bb74/7bb74c4dbd83e9d538a16b7774c9d03111705ffc" alt=""
Step 21: Use the defaults and click OK
data:image/s3,"s3://crabby-images/9d437/9d437750b8fa7499b1f0191dd20e7d19d67f53d3" alt=""
Wait for synth_design to complete
data:image/s3,"s3://crabby-images/58c54/58c541ee686a51d69fabba1e0da245e459e0fe9d" alt=""
Step 22:
A. Leave selected or select Run Implementation
B. Click OK
data:image/s3,"s3://crabby-images/5beaf/5beafd23ffebbc177379b3ef2f0923a7aff7a41a" alt=""
Step 23: Use the defaults and click OK
data:image/s3,"s3://crabby-images/bc50c/bc50c069342a2ba8708a058e024bc9c3806ca8b7" alt=""
Wait for the operation to complete:
data:image/s3,"s3://crabby-images/f056a/f056a4c5cd44746043fc4415ec7596a56a88c535" alt=""
data:image/s3,"s3://crabby-images/2cd08/2cd08d903e6e0fe2ce4eda2af7402771b3421df7" alt=""
data:image/s3,"s3://crabby-images/2927e/2927e307b4ff096378193c36305e4a7add6c75a8" alt=""
Complete:
data:image/s3,"s3://crabby-images/7c719/7c7191965cef00c3ada29e1b4d43ad9aea8347e9" alt=""
Step 23:
A. Select Generate Bitstream
B. Click OK
data:image/s3,"s3://crabby-images/0d692/0d6927c938eefc6864790551b96d709689fedc53" alt=""
Step 24: Use the defaults and click OK
data:image/s3,"s3://crabby-images/bc50c/bc50c069342a2ba8708a058e024bc9c3806ca8b7" alt=""
Wait for the operation to complete:
data:image/s3,"s3://crabby-images/70dbb/70dbb1e0e6d0db05e5dd2133f034f7e5b17ce043" alt=""
Complete:
data:image/s3,"s3://crabby-images/8a01c/8a01cfa4fb2b8c263c0f2739458425dfa03beab3" alt=""
Step 25: Click Cancel
data:image/s3,"s3://crabby-images/c08a4/c08a44e4ac9348fd3954ea131b18cdcc6c8c6594" 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/edaf0/edaf043de6287041f06b6a946f1bd081d025f061" alt=""
Step 2:
A. Click the Include bitstream checkbox
B. Leave <Local to Project>
C. Click OK
data:image/s3,"s3://crabby-images/35a43/35a43ae9017b74112fd116aa20e85e96da01d18e" alt=""
Step 3:
A. Click File
B. Click Launch SDK
data:image/s3,"s3://crabby-images/024be/024be4b6e854b1ae5d602f7653ed736181efced7" alt=""
Step 4: Use defaults and click OK
data:image/s3,"s3://crabby-images/401ec/401eca0d4c0a6e95b84f9a7ef91f50abaf6ca959" alt=""
Step 5:
A. Click File
B. Click Application Project
data:image/s3,"s3://crabby-images/24aca/24aca85f5d171a35c8dce0fe56dad460508020ad" alt=""
Step 6:
A. Type HelloWorld for Project name
B. See HelloWorld_bsp autopopulate
C. Click Next
data:image/s3,"s3://crabby-images/f780b/f780b71731fb06c5fa8b225625805ac3286e0762" alt=""
Step 7:
A. Ensure Hello World is selected (it should be)
B. Click Finish
data:image/s3,"s3://crabby-images/6808c/6808ce491be6a6ce20901391bd354884331fad81" alt=""
You should see:
data:image/s3,"s3://crabby-images/46321/463216dd84992efbc4edaaba00cf61c7ac61e046" 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/321db/321db2a4c6d9823731c169e571e20aa9b1782f52" 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/60dfe/60dfe9744e839a5d81f989fc2b22affe9d58a462" alt=""
Micro-B connector:
data:image/s3,"s3://crabby-images/1da16/1da16f729616a8623b98e7acdb776e279168c598" alt=""
Type-A connector:
data:image/s3,"s3://crabby-images/b6240/b6240b86d1a6de277716ac8cdd9df7d76eaa17d2" 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/cb02e/cb02eed8304c0db5e1bffc1d4e55eb889d9ac237" alt=""
Mini-B connector:
data:image/s3,"s3://crabby-images/5b1d5/5b1d5280c36cde772fb08759a65a221f9f940a7b" alt=""
Type-A connector:
data:image/s3,"s3://crabby-images/ef5fd/ef5fdd4aea0dc9c3b29c266e9440dc585eea0238" 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/6acad/6acadfa1007c0bf724873c12b8f21378fceece89" 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/53d8a/53d8a18ea5484ebcb1e1c98395d58a7f64023457" 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/8eafe/8eafebcf2cde03482fd1227ccf8f58a65316290e" alt=""
Step 2:
A. Click Window
B. Click Show View
C. Click Other
data:image/s3,"s3://crabby-images/33c4a/33c4a052f81716fc095c2ced91148a890b61f313" alt=""
Step 3:
A. Expand Terminal
B. Click Terminal
C. Click OK
data:image/s3,"s3://crabby-images/a4fba/a4fbaf54ab9b54da4628c059334961468f8d0fc0" alt=""
Step 4: Click Settings
data:image/s3,"s3://crabby-images/4b9f7/4b9f733ecf5131ad59ebec38849ebc78484286e1" 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/e475a/e475a53af5dba97cc4770602a9c944e521125317" 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/09f3c/09f3c9c87fc935a8188f245c7950cd6f6fc04e23" alt=""
D. Click Yes
data:image/s3,"s3://crabby-images/04228/04228fb8cb827b63bc227ab009d6ee3e9653565e" alt=""
E. Click Yes
data:image/s3,"s3://crabby-images/beeb2/beeb2ba8e94e24baa414fccbf6e1b05140c26da4" alt=""
Step 2:
A. Click Run
B. Click Run Configurations...
data:image/s3,"s3://crabby-images/ae829/ae82903c4c1f957bc4282ee83d417a078250270b" 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/23d7a/23d7a31c37490f73634b391b61159120dc64d065" alt=""
H. Switch back to the C/C++ View
data:image/s3,"s3://crabby-images/c3945/c3945b3b14b6a20fd7d42ebc5ef78cb8f53d5a35" alt=""
You should see:
data:image/s3,"s3://crabby-images/c7272/c7272d46669209845abfacf26ae49da3d94db3c8" 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/bb390/bb390a8c151b7d57f3b9c5695c9a7276cb57c84f" alt=""
C. Click OK
data:image/s3,"s3://crabby-images/1630a/1630a12dcbb5209be4642275a605fc8252c56f90" alt=""
You should see another Hello World:
data:image/s3,"s3://crabby-images/cc481/cc4819ff21bcbbc215b4e4b2b6b6e3a87b3012c8" alt=""
Part VI: Debug HelloWorld
Step 1: Click to disconnect Run terminal
data:image/s3,"s3://crabby-images/c9e6e/c9e6e2fa1ea565035c59736a957cb033acdf06d4" alt=""
Step 2:
A. Click Run
B. Click Debug Configurations...
data:image/s3,"s3://crabby-images/2deff/2deff3ee5a4b0384dc6a598d9332acfc1f76d7c1" 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/d56a9/d56a9aa424b82dc9946b72069b0eef27f4487ee2" alt=""
H. Click Yes
data:image/s3,"s3://crabby-images/bc38b/bc38baa82c1f3e63e255c3d57d1e6983df04cc27" alt=""
You should see:
data:image/s3,"s3://crabby-images/1cf8a/1cf8ac2c30169ab56a852b7d36d64c0027e48a22" alt=""
Step 4: Connect the serial port
A. Click SDK Terminal
B. Click the '+' (Connect to serial port.)
data:image/s3,"s3://crabby-images/713d4/713d4bb4fd4b2e205a684164a6589ca9719e14c8" alt=""
C. Use these settings and click OK
data:image/s3,"s3://crabby-images/9076c/9076c8249c0b3d92fbd23e35210611f3888cff36" alt=""
You should see:
data:image/s3,"s3://crabby-images/0ac56/0ac568ef5d957b35f08b6bc5da6a12e18e36212d" alt=""
Step 5: Click Resume (F8)
data:image/s3,"s3://crabby-images/31302/31302766727a3301847f8c2e96a092167fc6dd59" alt=""
You should see:
data:image/s3,"s3://crabby-images/e313b/e313be4a8d64b697355a1f4378068224cca488a8" 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/ee6c9/ee6c99157f8e8242289d1bbfc99dd767b74d6665" alt=""
C. Click OK
data:image/s3,"s3://crabby-images/84819/8481969951462614fe9eb624200c3245610316bf" alt=""
You should again see:
data:image/s3,"s3://crabby-images/1c118/1c118910529b5499d17829b62a8c133ea948bf0d" alt=""
Note: to disconnect the debuggers serial port click here:
data:image/s3,"s3://crabby-images/22083/220831c0b1f6e79dd0e0121be37ce728cddd3fa8" alt=""
You should see:
data:image/s3,"s3://crabby-images/5475d/5475da18a6a67e9f6c787a19d604eddc047e17af" 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]