Part 4: Synthesizing and creating the Bitstream
Creating the top-level wrapper and adding user constraints
Head back to PlanAhead, which will now be available again. Note that in the Sources
pane you will find a new file, your-module.xmp
. This is the system definition
we just edited and you might double-click that at any time to head back to XPS.
data:image/s3,"s3://crabby-images/8261f/8261fc6cea5c173a425bb59b2740bb981e7bc5a8" alt="PlanAhead: Project Sources: XMP File"
Right-click the XMP file and select Create Top HDL
to let PlanAhead generate another wrapper file for you. This will be the main HDL file that instantiates all the PCores added to the design. Think of it as the construction root in a regular software project.
data:image/s3,"s3://crabby-images/acd2e/acd2e8f5397c8c5e33f6d41f221aac2c02a59582" alt="PlanAhead: Project Sources: Create Top HDL"
After a while, the file should be created and be listed above your XMP module. In case anything goes wrong, simply delete that item and re-create the wrapper again. Deleting it will not delete the XMP file even if it looks that way. Double-click it to open the wrapper HDL file. You will see that the external port names are listed in this file as well. If they are not, try re-importing the IP in XPS and create a new wrapper.
data:image/s3,"s3://crabby-images/637d3/637d3e61c4ee98dc3fbddef43333cad8add32fbc" alt="PlanAhead: Project Sources: Top HDL stub"
Now we will add user constraints to the design that maps signals to actual pins. This step is not required until after the actual synthesis, but we can as well do this right now.
To do so, click Add Sources
again in the Project Manager section of the Flow Navigator
data:image/s3,"s3://crabby-images/43482/43482b6a4823cc9c4f4fae5609c4c8c871d7fec3" alt="PlanAhead: Add Sources"
This time, select Add or Create Constraints
and click Next
.
data:image/s3,"s3://crabby-images/d14ab/d14abba483c7073bc73a3ff2a050efd28880ead4" alt="PlanAhead: Add or Create Constraints"
Download the ZYBO_Master.ucf
for ISE designs from Digilent. Click Add Files...
and browse to it.
data:image/s3,"s3://crabby-images/73bb7/73bb74e783bdeca15c757769060974b9f479524a" alt="Add Sources: Add or Create Constraints: Add Files"
The file will now be listed in the dialog. Check Copy constraints files into project
to keep the original UCF file and select Finish
to return to PlanAhead.
data:image/s3,"s3://crabby-images/8ca4d/8ca4ddf1a57fc893d0d7fd7ae7eea5ee5ee97ffe" alt="Add Sources: Add or Create Constraints: Copy ZYBO Master UCF"
In the Sources
pane you will find a new entry, constrs_1
in the Constraints
tree. Double-click the UCF file to open it.
data:image/s3,"s3://crabby-images/a73ad/a73adf4826ffc51d857bb4ed74a3d9141f703fb5" alt="PlanAhead: ZYBO Master UCF"
As you can see from the file name, this file has been copied to your-project.srcs/constrs_1/imports/xilinx
of your project directory.
data:image/s3,"s3://crabby-images/774d3/774d3f41df1812f9ae158b196ad0ae05f357b292" alt="PlanAhead: UCF location"
Within the editor, uncomment all the sw<..>
, btn<..>
and led<..>
lines. The number of constrained pins should match the number of your signals,
so this effectively is where your C_NUM_LEDS
generic comes into play.
data:image/s3,"s3://crabby-images/4f83d/4f83db47db9386034159833bac81b7a52a739531" alt="PlanAhead: Edit UCF"
Rename the net entries according to the signal names you gave in XPS. In case you didn't write them down, simply open the top-level HDL file again to find them.
In this tutorial, they are called ledbtnsw_0_Switches_pin
, ledbtnsw_0_Buttons_pin
and ledbtnsw_0_LEDs_pin
.
data:image/s3,"s3://crabby-images/8b330/8b330577e9194c358a60a9a984bd1bc553101d67" alt="PlanAhead: Set internal pin names"
Synthesizing the design
Now it is time to synthesize the design. In the Synthesis section of the Flow Navigator, select Run Synthesis
.
data:image/s3,"s3://crabby-images/f90f3/f90f31ce9bdb85fec48eaeba0a1dd292371df5a6" alt="PlanAhead: Synthesize"
A wait window will appear to show that synthesis has started, but don't get too excited when you see it disappear.
data:image/s3,"s3://crabby-images/d5319/d53196968f1f5e0b7ac416c2f184b1b9809a6abb" alt="PlanAhead: Starting Synthesis"
In the upper right of PlanAhead you will now find a smaller progress bar reading Running XST
. This is the actual synthesis process.
data:image/s3,"s3://crabby-images/e61b2/e61b218189edab43bf51b518b7f713d6cae02311" alt="PlanAhead: Running XST"
After a while, the Synthesis Completed dialog pops up. Select Run Implementation
to start the implementation stage, which leads to the place & route process.
If you had not entered the user constraints before, now would be the time to do so before continuing, or otherwise the implementation will fail.
data:image/s3,"s3://crabby-images/b9be0/b9be0a76fb768f5546e3935e25d0d6ec9c241302" alt="PlanAhead: Synthesis completed"
Implementing the design
Again, a progress dialog appears.
data:image/s3,"s3://crabby-images/42683/42683f9a7bd244c58089388df5e9d2e8eedb964b" alt="PlanAhead: Starting implementation"
As you can see, the user constraints are processed here.
data:image/s3,"s3://crabby-images/3a33f/3a33fc2f64eb3e11ed79201c499be0c19e2638f2" alt="PlanAhead: Reading and processing constraints"
You may be confronted with three "Critical Messages" about the PS7 instance that turn out to be entirely uncritical to us. These
non-warnings appear on both the ZYBO and the ZedBoard and I can not explain their cause, but since ignoring them doesn't
seem to do any harm - just click OK
.
data:image/s3,"s3://crabby-images/b6b23/b6b2344a8edf0adaea648cbeee47d724dc7a3ba5" alt="PlanAhead: Launch Run Critical Messages"
Again, the dialog disappears just to leave us with the smaller progress bar in the upper right. You'll find Running NGDBuild
...
data:image/s3,"s3://crabby-images/9fd2d/9fd2d8d43bffc0e1f6f7b6f4d6de18e8e3be586a" alt="PlanAhead: Running NGDBuild"
... Running MAP
...
data:image/s3,"s3://crabby-images/f4a64/f4a641ebaaccceaaf9f5c3551aa5c41ac6abec5d" alt="PlanAhead: Running MAP"
... Running PAR
— which is the place and route process — ...
data:image/s3,"s3://crabby-images/bfb71/bfb7166a6749e419b559acdc527aa63acad11f37" alt="PlanAhead: Running PAR"
... Running TRCE
...
data:image/s3,"s3://crabby-images/01023/01023fc36bf85f1859eddc88519b5551dd5edff1" alt="PlanAhead: Running TRCE"
... and Running XDL
.
data:image/s3,"s3://crabby-images/1b061/1b06156739a6db3b88480a5f3848faa11c9eecb3" alt="PlanAhead: Running XDL"
After that, the implementation is complete and we can now generate the bitstream, which is the required end result to configure the programmable logic, much like an executable file for the processing system.
To do so, select Generate Bitstream
.
data:image/s3,"s3://crabby-images/1f918/1f9186e26ea17a068eaf8c71d2fe389932b8da0e" alt="PlanAhead: Implementation Completed"
Creating the Bitstream
If we had not clicked Generate Bitstream
in the last dialog window but instead canceled it, we would chose the Generate Bitstream
action under the Program and Debug section in the Flow Navigator now.
Since we did chose it, however, we find the message Running Bitgen
in the top right status bar.
data:image/s3,"s3://crabby-images/c8ab5/c8ab5726187123ef362165bec66ce685c5ddafd7" alt="PlanAhead: Running Bitgen"
After a short while the "Bitstream Generation Completed" dialog appears where we chose to open the implemented design.
data:image/s3,"s3://crabby-images/95598/9559894977c044af59da5140ee140957ead28e07" alt="PlanAhead: Bitstream Generation Completed"
While we do not need the information at the moment, this will be a required step when exporting the hardware to the
SDK. We can do that now using the File, Export, Export Hardware for SDK
menu.
data:image/s3,"s3://crabby-images/c48b6/c48b6281b99650766e6c8d53f6b315ceb2a3b2d3" alt="PlanAhead: Export Hardware for SDK"
In the upcoming dialog, among Export Hardware
and Launch SDK
, select Include bitstream
. If this option is greyed out, press Cancel and select
Open Implemented Design
in the Implementation section of the Flow Navigator pane, then export again.
This is also a quick way to re-launch SDK should you need to do so.
data:image/s3,"s3://crabby-images/ee607/ee607a5de4dd3453d6448fd46478bb097de9f0ef" alt="Export Hardware for SDK"
After that, you might skip to the next part or read on if you are interested.
Optional: Programming the FPGA using iMPACT
Alternatively to using the SDK — or in addition to it — the FPGA can be configured (i.e. "programmed") right now using Xilinx iMPACT. We can do so by clicking Launch iMPACT
in the Program and Debug section.
Note that generally the Zynq AP SoCs are bootstrapped by the ARM core, much like a regular microcontroller system where the FPGA acts as a slave during startup. That means that generally using the FPGA logic will only work after the FPGA has been initialized by the ARM core, i.e. when the ARM core is already flashed with a program that initializes the FPGA. When using iMPACT to configure the FPGA on the fly, this restriction does not apply.
If you happen to have the Digilent Adept suite and the Digilent Plugins for Xilinx Tools installed
data:image/s3,"s3://crabby-images/17579/17579d9ce815573891c1cb1d9a2dce6d65ef64bd" alt="iMPACT: Boundary Scan"
If you find an empty window or want to make sure everything is correct, check your cable setup by selecting Output, Cable Setup...
.
data:image/s3,"s3://crabby-images/f413f/f413f954a047e647f59a346a3f86b6e7544231ac" alt="iMPACT: Cable Setup"
In the following dialog select the Digilent USB JTAG Cable
option (available after installing Adept and the Digilent Plugins) and select your board in the Port
dropdown. Close the dialog, accepting the changes.
Should the cable option appear and the Port dropdown remain empty, make sure you really installed the latest version of Adept.
data:image/s3,"s3://crabby-images/7f525/7f525d8d432d2c2eb252badbbbb449d9f67d95cc" alt="iMPACT: Cable Communication Setup"
In the Boundary Scan
flow, both the ARM core and the FPGA should be detected now. Right-click the FPGA
and select Set Target Device
to feel good.
data:image/s3,"s3://crabby-images/07191/07191bdd9630aca132f922c7c51c815076023834" alt="iMPACT: Setting the target device"
Next, by right-clicking the FPGA again, select Program
.
data:image/s3,"s3://crabby-images/c6c8b/c6c8b19efc9288fdfe7683bb47f604c87f1ffa93" alt="iMPACT: Program"
In the Device Programming Properties dialog that pops up, just click OK
.
data:image/s3,"s3://crabby-images/f75a0/f75a0f5dc201b6f8144189689d2b2af888423394" alt="iMPACT: Device Programming Properties"
After a short while, the FPGA should be programmed and already responding to your inputs. Try fiddling with the switches and buttons to see if it works. If it does not, make sure the ARM core is initialized first and/or move on to the SDK.
data:image/s3,"s3://crabby-images/e0418/e04188eb1dd3151a3dba182e517a3760be66cc5f" alt="iMPACT: Program Succeeded"
After that, close iMPACT and export the hardware for the SDK for profit and cake.
data:image/s3,"s3://crabby-images/1d604/1d6047478591ac2e3916b0fdae871abffb50b810" alt="iMPACT: Program Succeeded"
You may ignore the save dialog, as your changes here will be remembered anyway.