Description
2 Learning Outcomes
After completing this assignment you should know how to:
-
Use Quartus Timing Analyzer tools to find the critical path of a ripple-carry adder designed in a previous assignment
-
Use CAD tools to design and implement a BCD to 7-segment LED decoder on the Altera DE1-SoC board
-
Test digital circuits on the Altera DE1-SoC board
-
Use the sliding switches on the Altera DE1-SoC board to specify the inputs to your circuits
-
Use the 7-segment LED display on the Altera DE1-SoC board to display the output of your circuits
3 Introduction
In this assignment, you will use a previously designed BCD adder circuit, you will implement and test the circuit on the Altera DE1-SoC board. You will learn how to work with the Altera DE1-SoC board, use switches, and the 7-segment LED display.
If you need any help regarding the lab materials, you can
-
Ask the TA for help during lab sessions and office hours.
-
Refer to the text book. In case you are not aware, Appendix A “VHDL Reference” provides detailed informa-tion on VHDL.
-
You can also refer to the tutorial on Quartus and ModelSim provided by Intel (click here for Quartus and here for ModelSim).
It is highly recommended that you first try to resolve any issue by yourself (refer to the textbook and/or the multitude of VHDL resources on the Internet). Syntax errors, especially, can be quickly resolved by reading the error message to see exactly where the error occurred and checking the VHDL Reference or examples in the textbook for the correct syntax.
4 Critical Path of Digital Circuits
In this part, you will learn how to use the Quartus CAD tool to determine the delay of a given path in digital circuits. To this end, in this section, we use the ripple-carry adder circuit (that you designed in VHDL assignment #3) as the “circuit under examination”.
VHDL Assignment #4 |
2 |
Follow the instructions described in VHDL Assignment #1 to create a project. Make sure to select the Cyclone V family of FPGAs, with the following part number: 5CSEMA5F31C6 when creating a project. Once created, import the VHDL description of your digital circuit into the project and compile it to make sure there are no syntax errors in your design.
The critical path is the longest path in the circuit and limits the speed of the circuit speed. The speed of a digital circuit is measured in terms of latency and throughput. Latency is the time needed for the circuit to produce an output for a given input (i.e., the total propagation delay (time) from the input to the output), and it is expressed units of time. Alternatively, throughput refers to the rate at which data can be processed. In this assignment, we only consider the latency as a metric to measure the speed of the circuit. In general, digital circuits are subject to timing constraints dictated by the target application. Whether a circuit meets these timing constraints can only be known after the circuit is synthesized. After synthesis is performed, the designer can analyze the circuit to determine whether timing constraints were satisfied using the term slack . Slack is the margin by which a timing requirement is met or not met; it is the difference between the required arrival time and the actual arrival time. A positive slack value indicates the margin by which a requirement was met. A negative slack value indicates the margin by which a requirement was not met.
To insert timing constraints in Quartus, select “Synopsys Design Constraints File” from the “File–>New” menu.
The maximum delay can be specified in the Synopsys Design Constraints File using the following command:
set_max_delay -from [get_ports <name_of_input_port>] -to [get_ports <name_of_output_port>] <time in nano seconds>
For example, we can specify a maximum delay of 12 ns for all the possible paths from the inputs of the ripple-carry adder to its outputs as shown below.
Once the timing constraints are inserted, save the file with the name “firstname_lastname_sdc.sdc”. Recompile your design by double clicking on “Timing Analysis” in the Tasks window of Quartus. Before recompilation, make
sure that the .sdc file is added to the project.
VHDL Assignment #4 |
7 |
|||
l i b r a r y i e e e ; |
||||
u s e i e e e . s t d _ l o g i c _ 1 1 6 4 . a l l ; |
||||
u s e i e e e . n u m e r i c _ s t d . a l l ; |
||||
e n t i t y s e v e n _ s e g m e n t _ d e c o d e r i s |
||||
p o r t ( code |
: i n s t d _ l o g i c _ v e c t o r (3 |
downto 0) ; |
||
s e g m e n t s _ o u t |
: o u t |
s t d _ l o g i c _ v e c t o r (6 downto |
0)); |
|
end s e v e n _ s e g m e n t _ d e c o d e r ; |
||||
a r c h i t e c t u r e decoder |
o f s e v e n _ s e g m e n t _ d e c o d e r i s |
|||
b e g i n |
||||
WITH code SELECT |
||||
s e g m e n t s _ o u t <= |
||||
” 1000000 “ WHEN ” 0000 “, — 0 |
||||
” 1111001 “ WHEN ” 0001 “, — 1 |
||||
” 0100100 “ WHEN ” 0010 “, — 2 |
||||
” 0110000 “ WHEN ” 0011 “, — 3 |
||||
” 0011001 “ WHEN ” 0100 “, — 4 |
||||
” 0010010 “ WHEN ” 0101 “, — 5 |
||||
” 0000010 “ WHEN ” 0110 “, — 6 |
||||
” 1111000 “ WHEN ” 0111 “, — 7 |
||||
” 0000000 “ WHEN ” 1000 “, — 8 |
||||
” 0010000 “ WHEN ” 1001 “, — 9 |
||||
” 1111111 “ WHEN |
o t h e r s ; |
|||
end decoder ; |
||||
In the next section, you will use the 7-segment LED decoder to display the inputs/outputs of the one-digit BCD adder.
6 Wrapper Design
In this part of the lab, you will design a circuit (that is called “wrapper” circuit) that performs addition of two 4-bit BCD-formatted inputs A and B, and displays the inputs as well as the result of the addition in BCD format using the 7-segment LEDs on the DE1-SoC board. You will need, therefore, to use four 7-segment LEDs on the board: the first two 7-segment LEDs will be used to display the inputs A and B, while the other two 7-segment LEDs will be used to display the result of the addition. We need two LED displays for the output as the result may be two BCD digits long. Note that you should use the binary-to-7-segment LED decoder to obtain appropriate 7-segment display codes.
Use the following entity declaration to write a VHDL description of the wrapper circuit. Note that you will need four instances of the seven_segment_decoder component and one instance of firstname_lastname_bcd_adder component in your VHDL description. You can use the BCD adder that one of the members of your group designed in the previous assignment.
l i b r a r y |
IEEE; |
||||
u s e IEEE.STD_LOGIC_1164.ALL; |
|||||
u s e IEEE.NUMERIC_STD.ALL; |
|||||
e n t i t y f i r s t n a m e _ l a s t n a m e _ w r a p p e r i s |
|||||
P o r t ( |
A, B |
: i n s t d _ l o g i c _ v e c t o r (3 |
downto 0) ; |
||
d ec od ed _ A |
: o u t |
s t d _ l o g i c _ v e c t o r (6 |
downto |
0) ; |
|
d ec od ed _ B |
: o u t |
s t d _ l o g i c _ v e c t o r (6 |
downto |
0) ; |
|
d e c o d e d _ A p l u s B |
: o u t |
s t d _ l o g i c _ v e c t o r (13 |
downto |
0)); |
end f i r s t n a m e _ l a s t n a m e _ w r a p p e r ;
where firstname_lastname in the name of the entity is the name of one of the students in your group.
The wrapper circuit has two 4-bit inputs, A and B, each representing a BCD digit. The outputs are: a 7-bit display code for A, a 7-bit display code for B, and two 7-bit display codes for the sum A+B.
VHDL Assignment #4 |
8 |
7 Testing the Wrapper on the Altera Board
You will now test the wrapper circuit you designed in Section 6. Follow the instructions described in Assignment #1 to create a project. Make sure to select the Cyclone V family of FPGAs, with the following part number: 5CSEMA5F31C6 when creating a project. Once created, import the VHDL description of the wrapper circuit and its components into the project and compile to make sure there are no syntax errors in your design. Once you have compiled the wrapper circuit, it is time to map it onto the target hardware, in this case the Cyclone V chip on the Altera DE1-SoC board.
Since you will now be working with an actual device, you have to consider to which device package pins (physical pins) the various inputs and outputs of the project are connected. The FPGA chip on the board communicates with the outside world by sending and receiving binary signals using physical pins. You can think of these pins as the ports of an VHDL entity. Some of the input pins are connected to the sliding switches on the board, and some of the output pins are connected to the LED displays. In particular, you will want to connect the LED segment outputs from the instances of the seven_segment_decoder circuit (i.e., the outputs of the wrapper circuit) to the corresponding pins of the four 7-segment LED displays on the board. See Section 3.6.2 of the DE1-SoC User Manual. The mapping segments of the each 7-segment LED on the board to the pins on the Cyclone FPGA device, is listed in Table 3-9 on page 27 of the DE1-SoC User Manual.
You will also want to connect, for testing purposes, four of the slide switches on the DE1-SoC board to the input A, and another four switches to the input B of the wrapper circuit. See Section 3.6.1 of the DE1-SoC User Manual. The mapping of the slide switches to the FPGA pins is listed in Table 3-6 on page 25 of the DE1-SoC user manual.
You must now notify the compiler to which pins the input and output signals of your wrapper circuit should be connected. For example, if B[0] is connected to switch SW0 (See Fig. 3-15 of the manual on page 24), you should notify the compiler that B[0] is assigned to pin PIN_AB12. You specify the pin assignments for your inputs and outputs by using the Pin Planner, which can be done by choosing the Pins item in the Assignments menu. See example below. Note that this figure is just an example, and does not correspond to the wrapper circuit that you are supposed to design in this assignment.
VHDL Assignment #4 |
9 |
Once you have assigned all of the inputs and outputs of your circuit to appropriate device pins, re-compile your design. Your design is now ready to be downloaded to the target hardware. You may want to go over Section 4.1 of the DE1-SoC user manual for information on configuring (programming) the Cyclone V FPGA on the board. You will be using the JTAG mode to configure the device. Take the board out of the kit box, connect the USB cable to the USB port of the computer and to the USB connector on the board. Next, select the Programmer item from the Tools menu. Click Auto Detect and then select the correct device (5CSEMA5), as shown below. Both FPGA device and HPS should be detected.
Next, double-click the FPGA device (5CSEMA5), from the window that pops up, add the .sof file created by Quartus. Finally, check the “Program/configure” box beside the 5CSEMA5 device, and then click “Start”. See also Section “Configuring the FPGA in JTAG Mode” on p. 12 of the manual. Now, you should be able to use the slide switches to insert values for inputs A and B. The 7-segment LEDs should also display inputs and outputs in BCD format.
-
Questions
-
-
Briefly explain your VHDL code implementation of all circuits.
-
-
-
Perform timing analysis and find the critical path(s) of the one-digit BCD adder circuit for the Fast 1,100 mV 85C Model. Show the obtained timing waveform(s) of the critical path(s) that you found.
-
-
-
Provide the VHDL code that you wrote for the wrapper circuit.
-
-
-
Show a representative photo of the board displaying the result of the addition of A and B, where A is the last (rightmost) digit of the McGill ID number of one of the students in your group and B is the last (rightmost) digit of the McGill ID number of the other student in the group (if there are three members in your group, choose two IDs and state which were chosen). Clearly indicate which 7-segment LEDs/sliding switches are assigned to which inputs/outputs of the circuit on the photo.
-
-
-
Report the number of pins and logic modules used to fit your designs on the FPGA board.
-
9 Deliverables
You are required to submit the following deliverables on MyCourses. Please note that a single submission is required per group (by one of the group members).
VHDL Assignment #4 |
10 |
-
Lab report. The report should include the following parts: (1) Names and McGill IDs of group members,
(2) an executive summary (short description of what you have done in this VHDL assignment), (3) answers to all questions in previous section (if applicable), (4) legible figures (screenshots) of schematics and simulation results, where all inputs, outputs, signals, and axes are marked and visible, (5) an explanation of the results obtained in the assignments (mark important points on the simulation plots), and (6) conclusions. Note – students are encouraged to take the reports seriously, points will be deducted for sloppy submissions. Please also note that even if some of the waveforms may look the same, you still need to include them separately in the report.
-
Project files. Create a single .zip file named VHDL#_firstname_lastname (replace # with the number of the current VHDL assignment and firstname_lastname with the name of the submitting group member). The
.zip file should include the working directory of the project.
McGill University ECSE 222 – Digital Logic (Fall 2022)