Simulation and Debugging Techniques in Vivado IP Integrator
This Tutorial will demonstrate how to create a custom pulse IP that can be used to reset the
Microblaze via Software in Vivado by utilising the IP packager. This IP will then be simulated using
the VSIM simulator. The IP will be added to a Microblaze design, and exported to SDK. In SDK, a
simple application will be created that will reset the Microblaze via the pulse IP. This whole system
will be again simulated. We shall then add an ILA to the pulse IP and preform a cross trigger
debugging using the SDK application. Finally, this will be run on Hardware.
Requirements:
This tutorial requires at least Vivado 2014.4. For hardware test, a KC705 is needed. However, the
board is only needed for the last two steps.
Note: There is a Zip file that accompanies this tutorial. Please download this first before continuing.
© Copyright 2015 Xilinx
Step 1: Create the Pulse IP.
First we need to create a mechanism to reset the Microblaze. Here, we need a reset pulse that we
can control. To achieve this, we can use a simple counter in HDL that when enabled will toggle the
pulse, count to 16 ticks, toggle again. The HDL code is seen below on the right, and the
corresponding wave diagram on the left.
This IP will sit between the mb_reset on the reset IP, and a generated pulse from the GPIO. These
two reset’s, are OR’ed together. This will allow the Microblaze to be reset as normal via the reset IP,
and will allow the user the ability to reset via the software.
© Copyright 2015 Xilinx
To create the pulse_ip, open Vivado, right click on Design Sources -> Add Sources. Select Add, and
navigate to the pulse_ip_hdl folder and add all the sources here.
Once the HDL is added, select Tools -> Create and Package New IP. Select Package your current
project:
© Copyright 2015 Xilinx
Select an IP location. Select “my_ip” in the project directory. This will create a my_ip folder and
place the newly created IP into this folder. Select Include IP generated files:
Select Finish to exit:
© Copyright 2015 Xilinx
In the Package IP GUI, select Ports and Interfaces. Here, you will see a list of all the interfaces for
your IP. We will be setting the POLARITY of the reset to Active High to match our HDL code. To do
this, right click on the signal_reset -> Edit Interface:
Under the Parameters tab, change the Value to ACTIVE_HIGH:
Repeat this for all the reset signals (inp, and outp)
Once you are happy with the settings, select Review and Package -> Package IP
© Copyright 2015 Xilinx
Step 2: Simulate the newly created IP
Here, we will be creating a Testbench to test our newly created pulse IP. To add/create the
Testbench right click on Simulation Sources -> Add Sources:
Navigate to the pulse_ip_testbench folder and add the Testbench.
The Testbench sets up the clocks, and the reset, and will simulate a reset on the mb_reset, and an
input pulse.
Once the Testbench is added, run the simulation. The results will look something similar to below:
© Copyright 2015 Xilinx
Step3: Create Microblaze system
Now that the pulse IP is created and verified in step 1, and 2. We can now proceed to create the
Microblaze system In Vivado IP Integrator. To create the Microblaze system, follow the steps below:
Create BD (IP Integrator -> Create Block Design), and name it “mb_system”
Add Microblaze from IP Catalog
o Run Block Automation
Increase Local memory from 8KB to 32KB
Double Click on Microblaze, and Enable Trace Bus Interface
Run Connection Automation
o Connect the Clock, and Reset
Add AXI GPIO from IP catalog
o Double Click on AXI GPIO
Under the IP Configuration -> GPIO
Tick All Outputs
GPIO Width = 1
o Run Block Automation -> S_AXI
o Un-tick the GPIO box
Add AXI UART
o Run Block Automation
Add Pulse IP
Make the connections as shown below:
© Copyright 2015 Xilinx
Step 4: Create application
Once the HW is built in step 3, we can now export to SDK. Firstly, we need to Generate the output
Products, and Generate HDL wrapper:
The Export to SDK, File ->Export Hardware -> OK:
File -> Launch SDK
© Copyright 2015 Xilinx
In SDK, create a hello world application that we can use as a base application
File -> New -> Application Project
Select the Hello World Template:
Click Finish to continue
© Copyright 2015 Xilinx
Open the helloworld.c file, and modify it with the code below. This simple code will initialise the
GPIO output to 0. In the soft_reset function, the GPIO is set to 1. Also, the Microblaze is placed in
sleep.
Navigate to the application folder to reference the code below.
Note: The print is commented out here, as we shall be simulating this. In the HW test, this will be re-
added
Once the application is built (the SDK will build automatically. If not, go to project -> build all)
Exit SDK
© Copyright 2015 Xilinx
Step 5: Build test application
Add the ELF created in step 4 to the Vivado project simulation sources. To Associate the ELF, right
click on the ELF -> Associate ELF files…
Add the mb_sys_reset.elf as the associated ELF for the simulation Microblaze
© Copyright 2015 Xilinx
Next, we will be creating a Testbench for the top level. Right click on the simulation sources, and add
a new Testbench. This is similar to how this was done in step 2.
Navigate to the top_level_testbench folder and add the Testbench.
Once the testbench is created, you need to set this as top module. To do this, right click on the
Testbench -> Set as Top
Run Simulation
© Copyright 2015 Xilinx
Let’s investigate…
What should happen?
Application code should be executing
This will set GPIO to 0, then 1
The GPIO input is fed into the inp_pulse port on the pulse IP
Once a input is detected on the inp_pulse this will cause a 16 tick pulse
inp_reset is fed to the mb_reset on the proc reset IP
pulse and inp_reset are OR’ed together
Is this what we are seeing in the simulation?
© Copyright 2015 Xilinx
If we zoom in on the Trace port, we can see that the code is executing on the Microblaze after
coming out of reset. We can verify the code by opening the ELF in SDK:
The GPIO goes to 1, then back to 0. The application is effectively looping as it is continuously getting
reset. This GPIO set to 1 is creating a pulse on the pulse IP, and it is this that is resetting the
Microblaze.
© Copyright 2015 Xilinx
Step 6: Cross trigger debugging
Here, we shall use the Vivado logic analyser, and the SDK software debugger to perform a cross tool
debugging. We will be debugging the pulse IP to verify that the system is working as expected.
To add a net for debug, open the block design, and mark the outp_reset net. To do this, highlight the
net -> right click -> Mark Debug
You will see a green bug symbol on the net:
© Copyright 2015 Xilinx
Validate the Design, Generate Output Products, and synthesise the design. Once this is completed,
open the syntheses design.
Here, we shall be adding the ILA Core. Open the Debug Layout in the drop down in Vivado:
In the Debug window, you will see a list of nets in Unassigned Debug nets folder. These nets
correspond to the various signals that make up the interface connection that you marked for debug
(in our case the outp_reset):
Use the Set up Debug wizard to add the ILA debug core to the design. Here, the unassigned nets will
be assigned and connected to the ILA.
Click on the Set Up Debug wizard:
© Copyright 2015 Xilinx
This will launch the GUI.
Select Next to Continue.
Verify that the Clock Domain is set. This will be set to undefined if not set.
Select Next to Continue.
© Copyright 2015 Xilinx
Select Next to continue.
Verify the summary, and select Finish to Exit:
© Copyright 2015 Xilinx
Here, you will see that the ILA core has been added. Save the project.
Save the project. This will update the XDC file with the commands to add and configure the ILA.
Now that the debug logic has been added, we can continue to implement the project (Generate
Bitstream)
Once the bitstream is complete, Re-export to SDK. This time tick the “Include Bitstream” box
We will be using the same application that was created in step 5.
Configure the FPGA. Xilinx Tools -> Program FPGA -> Program
Highlight the application under Project Explorer and right click -> Debug As -> Debug Configurations.
Double click on Xilinx C/C++ application (System Debugger) to create a debug configuration. Select
Debug to continue. This will open the debug perspective.
By default, the debugger will place a breakpoint at main().
Return to Vivado, without exiting the SDK in debug perspective. In the Flow Navigator in Vivado,
under the Program -> Open Hardware Manager -> Open Target -> Open New Target to open the GUI.
Select Next -> Finish to continue.
This procedure will open a logic analyser waveform window and initialise the analyser triggering
mechanisms.
© Copyright 2015 Xilinx
Select the Hardware window and select the hw_ila_1 core:
Note: the Status of the ILA core is Idle
In the Debug Probes window, select the outp_reset and drag and drop this into the Basic Trigger
Setup window. Set the Compare Value to 1. Also, set the Trigger position to be in the middle of the
1024 sample window by setting this to 512:
Finally, arm the ILA core by select the Run Trigger in the hardware window:
Note: the Status of the ILA core is Waiting
© Copyright 2015 Xilinx
Go back to SDK, without closing the hardware manager. In the debug perspective which is still at the
breakpoint at main. In SDK, we have a list of options:
Step to
Step Over
Step into
Resume
Use the step over icon until we reach the software_reset function. Once we reach this, use the
step into icon to step into this function:
Once, we are at the line highlighted above, use the step over icon. This will set the GPIO to 1,
and will cause the outp_reset to go to 1. Once this is done, you will see the trigger was hit in Vivado:
© Copyright 2015 Xilinx
Step 7: Testing on hardware
We have verified both the IP, and how this IP operated in the Microblaze system in the previous
steps. It is now time to test on Hardware.
We should still have the FPGA configured from the last step. However, if not go to Xilinx Tools ->
Program FPGA -> Program.
Highlight the application under Project Explorer and right click -> Run As -> Run Configurations.
Open a serial console, and set the BAUD to 9600.
Double click on Xilinx C/C++ application (System Debugger) to create a run configuration. Select Run
to continue.
You will see the print statement “We expect and endless loop…” printed on the console.
This is expected, as we are constantly resetting the Microblaze, which will re-run the app, which will
reset, ect..
© Copyright 2015 Xilinx