data:image/s3,"s3://crabby-images/f551a/f551a1086c466fa3fb31e303c24950c97b97edbe" alt=""
This post is my run through of SDSoC Lab 1 Tutorial at [link].
Prerequisites
Install SDSoC on Linux using a free 60-day trial and launch it [instructions]
Have a ZC702 (I used a ZC702 Rev 1.1)
Notes
Use the Zynq-7000 on the ZC702 or the ZedBoard available at [link] and [link] to play around with SDSoC.
The ZC702 is $895.00 and the ZedBoard is $449.00.
The key benefit is that you'll only need 2 GB of host memory to build images for the board.
If you use a Zynq UltraScale+ MPSoC on a ZCU102 (available at [link]), you'll need 14 GB of host memory and $2495.00 for the board.
This advice applies to other situations where you'd like to use a Arm + FPGA fabric. Also long as you don't need a hypervisor or the performance, the Zynq-7000 is a good, economical and fast platform for development (Zynq-7000 projects build in much less time).
Steps
1. Click Create SDx project
data:image/s3,"s3://crabby-images/4698f/4698f28272e6e8a4f859c94951f1941ee16155b6" alt=""
2. Keep Application selected and click Next >
data:image/s3,"s3://crabby-images/6b28f/6b28fb87873953fe8b84295a959d0909676f1abf" alt=""
3. Name your project lab1, keep Use default location clicked and click Next >
data:image/s3,"s3://crabby-images/ab4a2/ab4a2643993125e50312ea9b2b9851a263c58654" alt=""
Note: You can use any 3 to 40 character sequence of a-z, A-Z, 0-9, _ and -
Note2: In a regex: [a-zA-Z0-9_ -]{3,40}
4. (A) Select the zc702 and (B) click Next
data:image/s3,"s3://crabby-images/91d15/91d15451e4b28ae1801f40595db99a19749e222f" alt=""
5. Accept defaults and click Next on the System configuration window
data:image/s3,"s3://crabby-images/d8810/d8810c4b8c37afe9a8f096905ebad58142faff97" alt=""
6. (A) Select Matrix Multiplication and Addition and (B) click Finish
data:image/s3,"s3://crabby-images/c1d8a/c1d8a8c300e5118a7758c0a8b71f33e6f8398341" alt=""
You should see:
data:image/s3,"s3://crabby-images/d3b01/d3b01a461c722cd8635b87e5a26387517bd1d51c" alt=""
At this point I diverge from the tutorial a little.
7. Click build (this step will take a significant amount of time).
data:image/s3,"s3://crabby-images/ea179/ea179e869a464475aae962cf68d42b3177c76a04" alt=""
Note: this step took 1h:24m:29s.132ms, the entire output is [here].
If you need help accessing an SD card from in Ubuntu running on VirtualBox, running on Windows 7 click [here].
8. To copy the files to the SD card...
Type cd ~
Type cd workspace/lab1/Debug/sd_card
Type ls
You should see:
data:image/s3,"s3://crabby-images/7ca6e/7ca6e4ad4f97845fae9d4621c3a5f0d2fd9f415e" alt=""
ls
BOOT.BIN
image.ub
lab1.elf
README.txt
After replacing pfefferz with your path, type cp -f * /media/pfefferz/C002-DEEF/
Type ls -l /media/pfefferz/C002-DEEF/ to check that the files were copied
9. Eject the SD card
data:image/s3,"s3://crabby-images/84067/8406707865364642d27faa6a87816ead2f5c826b" alt=""
10. Set up minicom
Close SDx and everything else (you'll need to log out and back in)
Type sudo apt-get install minicom
Type sudo adduser $USER dialout
Log out, (A) click the gear icon, (B) click Log Out...
data:image/s3,"s3://crabby-images/96f51/96f512bfa4bdef74943b8e8606c2aaff37f437e8" alt=""
data:image/s3,"s3://crabby-images/6b703/6b703c13dccf1aff0aef9e22ee59306a142d765d" alt=""
Log in, type your password and hit enter
data:image/s3,"s3://crabby-images/7f7ef/7f7efcc82d10c35a2a0a8020ee5a88bdf5cc17c9" alt=""
Open a terminal and type sudo minicom -s
At this screen:
data:image/s3,"s3://crabby-images/86ca3/86ca37f2b599d9b56773badae49b89c867aa5ae9" alt=""
Hit the down arrow until you hit Serial port setup
data:image/s3,"s3://crabby-images/f6a67/f6a67fc928e655fc66be7f59bcbfc94c80772697" alt=""
Press Enter
At this screen type F to turn off Hardware Flow Control and type A, changing the serial device to /dev/ttyUSB0
data:image/s3,"s3://crabby-images/f7612/f761205d508f490c6a6587146e8526e3bec23a41" alt=""
Things should look like:
data:image/s3,"s3://crabby-images/f3d88/f3d8832f55949cec5a9d1520fd396f89e1a3a67b" alt=""
Press Enter to return to the previous menu
Press down until you get to Save setup as dfl
data:image/s3,"s3://crabby-images/7befc/7befcd66170f08ca424c02e35acf1b85fea67478" alt=""
Press Enter
You should see:
data:image/s3,"s3://crabby-images/2d3ef/2d3ef84b0106a8ea1e2316241e5842835a54edd8" alt=""
Press down until you get to Exit from Minicom
data:image/s3,"s3://crabby-images/29c9e/29c9e29457f6042d06e50d86682f9ca3399d4558" alt=""
Press Enter
11. Set up the board
Plug the SD card in
Push it in:
data:image/s3,"s3://crabby-images/84d6e/84d6eb813cd4fecf0edb3240bc528c4fe7018adb" alt=""
...till it clicks
data:image/s3,"s3://crabby-images/8f1fd/8f1fd0d8714c12c32b3c4e2b78f1bf3a0e486c3f" alt=""
Set SW16 to boot from the SD card:
data:image/s3,"s3://crabby-images/944d0/944d014f4442003bffe065038da278bde6d2a21f" alt=""
Plug in the USB UART:
data:image/s3,"s3://crabby-images/be639/be639c9f976c48b05fb2bf36a80b04a5e022e01b" alt=""
data:image/s3,"s3://crabby-images/b3b70/b3b70487957770e1240ed88c648505f262d719f4" alt=""
12. If you're running this in a virtual machine, managed by VirtualBox, then capture the USB UART in VirtualBox by (A) clicking Devices, (B) clicking USB and (C) clicking Silicon Labs CP2103 USB to UART Bridge Controller [0100]
data:image/s3,"s3://crabby-images/10fd7/10fd799ff311442d8159e4fa307d13057fa11495" alt=""
13. Run minicom by typing minicom in a terminal
Note: exit minicom by typing Control-a x
You should see
data:image/s3,"s3://crabby-images/f893e/f893ebd8ae2c33fcf41d72985badaaaf3844a388" alt=""
14. Power on the ZC702
data:image/s3,"s3://crabby-images/19e1f/19e1f862de5c02db69d3928763472bc4d14a4716" alt=""
data:image/s3,"s3://crabby-images/65041/6504141482dbb17b00b1f5d3a6cba515c8c7958d" alt=""
You should see output in the minicom terminal end with:
data:image/s3,"s3://crabby-images/2f609/2f609bd63e3e489aa564d53f50cae5b943fe48f2" alt=""
Full output is [here].
15. Type /mnt/lab1.elf
You should see the :
data:image/s3,"s3://crabby-images/f55a7/f55a7bdca3a676d234697fed254fed3d8ae3284f" alt=""
Congratulations! You completed Lab 1 of the SDSoC tutorial on the ZC702.
Share this post if you feel like it would benefit others!
Reference
SDSoC Environment Tutorial: Introduction - Lab 1: Introduction to the SDSoC Development Environment at [link]