# 18-240: Structure and Design of Digital Systems



# **Lab1: Combinational Logic Design**

## **Objective and Overview**

This lab provides an opportunity to learn how to design, implement, debug and evaluate a combinational logic circuit. You will design minimized SOP and POS implementations of a combinational 6-input function. You will write SystemVerilog code to describe the circuit and implement it on the FPGA board.

As you design and implement the function, you will sharpen the digital design skills you first tried out in Lab 0 — writing multi-module SystemVerilog code, using the simulator and synthesizing designs for download to the DE2-115 FPGA board.

### Schedule and Scoring

One week of lab time is scheduled for this exercise. A demo and lab report are due in subsequent weeks.

| 12 – 14 September | Simulation / Synthesis. Briefing due by 9:50pm.                  |
|-------------------|------------------------------------------------------------------|
| 19 – 21 September | Demo deadline, 6:30pm on the day of your lab 2 session.          |
| 20 – 22 September | Lab report is due at 8:00pm on the day AFTER your lab 2 session. |

The 18-240 lab room is available during the day for you to work. You are free to go into the lab to work on your own! Lab office hours are held on Tuesday – Thursday from 6:00-7:00pm. During office hours, TAs are available for help and for demos.

**Advice:** Don't show up in lab and say "I wonder what this lab is about." Unlike Lab 0, the remaining labs in this course require time to design, implement, and test. Your lab time is precious because it is limited and because the TAs are easily available. Come to lab prepared to take advantage of your time.

The lab is worth 70 points:

**15 points:** A briefing to your TA is due by the end of your lab session.

• Show the lab TA the SystemVerilog description of your testbench and explain your testing strategy. (See the Appendix, with suggestions on building a testbench).

• Show the lab TA your truth-table, K-map, minimized POS expression, and (possibly still buggy) SystemVerilog description of your combinational function.

**20 points:** The final demo is due by the beginning of the Lab 2 session. You must be checked off for the demo to receive any credit for this lab.

• Demonstrate the simulation of your design against your testbench to show the design is correct. Download and demonstrate your design on the DE2-115 board.

**10 points:** Your SystemVerilog code is well-written, using good style, and follows the course coding guidelines (see **SystemVerilog\_CodingStandards.pdf** on Canvas)

**25 points:** A lab report is required, one per group. You must do a lab report to get any credit for this lab. Submit your lab report to Gradescope (make sure to include your partner in the submission). In the uploaded PDF, you may include pages that are scans of neatly-drawn schematic diagrams. You will also submit all your code using **handin240**.

- 10 points will be based on a write-up documenting your work including logic equations, K-maps, logic diagrams corresponding to the SystemVerilog, gate count, documented SystemVerilog code, and simulation results from the demonstrated design. Be sure to address any questions specifically posted in this document. See the document LabReport.pdf on Canvas for more guidance on how to write a good lab report.
- 5 points will be based on how well you minimized the number of gates. Note if you don't correctly follow the rules on using the set of allowable gates, we can't give you any points here!
- 10 points will be based on your SOP simulation work in Step 6.

#### As a guideline, your lab report needs to have at least the following:

- A discussion of how you worked through the lab.
  - Your truth table/K-map/minimized SOP equation
  - Your truth table/K-map/minimized POS equation
- Report and compare on the costs of the two implementations.
- The thoroughly documented SystemVerilog descriptions for this lab, including the testbench. Submit as separate .sv files, not in your PDF report.
- The discussion of how you developed the tester.

**Late demo:** You must demo to get any points for the lab. You will lose 10% for each day late up to a week late. After a week, you will get zero points. We don't count any days that do not have office hours available (Saturdays, primarily).

Late lab report: You must do a lab report to get any points for a lab, including the demo. You will lose 10% for each day late—weekends not included—up to a week late. After a week late, you will get zero points for the lab.

**Collaboration:** Recall from the Syllabus that you are expected to only turn in work that is fully your own. This policy applies to labs, with the obvious exception that you are expected to work with your lab partner. You may get advice from TAs and talk in general terms with other people. But, every bit of the lab code and reports must be your own work.

#### **A Note About Teams**

As discussed in class, you will work in a randomly assigned team of two people. You are expected to work together. This means that you must communicate well (including answering email prior to lab), discuss your design and share responsibilities throughout the performance of the lab. Exhibiting good teamwork skills is inherently included in the grade you receive. Therefore, the following sorts of behaviors will cost you points:

- Not answering email from a partner who wishes to meet and prepare prior to lab.
- Showing up late or not at all for lab time. Leaving early when there is still work to do.
- One teammate daydreaming while the other teammate cranks in all the SV code.
- Showing up with all the work completed before you've even talked to your partner.
- Letting your teammate do all the work.
- Doing all the work without involving your teammate.

#### Lotería

Lotería is a Bingo-like game played in Mexico. It uses images on a deck of cards instead of plain numbers. Lotería boards (called *tabla*) are 4x4 cards without a free space. A winning combination is four pictures in a horizontal row, vertical row, one of 9 squared patterns or the four corners. The image on the next page represents 12 tabla, shaded to show allowable winning combinations. There are three more rows and three more column combinations that are not shown. Check out the "book of all knowledge" for more information at en.wikipedia.org/wiki/Loteria.



## **Your Design Problem**

You will design a combinatorial function to determine if a particular card would result in a win on a specified tabla, i.e. on the tabla shown at right. As images are difficult to represent, we will use numbers instead. For the tabla at right, where the shaded cards have already been called, which numbers represent a win? For instance, if card #30 is called, then the four center cards are matched and you can shout "¡Lotería!".

Being able to count 54 cards requires 6 bits, mapped to bit values 6'b000000 through 6'b110101. Use binary numbers to map the 6 input bits (a through f) to specific cards. For instance, if a=0, b=1, c=0, d=0, e=1, f=1, that represents card number 19 (the heron, if we were playing with pictures). 19 is a card on this tabla, but it doesn't lead to a win.

You will also design a second combinatorial function to determine if there is an error with the input. There are two classes of errors that we will look for. One is the invalid card number. Cards with numbers above 6'b110101 don't exist, so if those values are input, the error function should let us know. Secondly, it would be an error to call a card that has already been called. Any input corresponding to the shaded cards is an error. Note that the user probably won't care about the win signal in any case where the input is an error.



Arrangment of cards for this lab

#### What to do?

- **Step 1:** To begin your design, first work out the truth table for this 6-bit input, 2-bit output function. For the sake of consistency, keep the most significant input bit (a) on the left in your truth table. Also, show win on the left for your outputs and error on the right. With 6 input bits (a through f), you have to consider two outputs for 64 different input combinations.
- **Step 2:** Once you have the truth table, apply a K-map to derive a minimal POS equation for this combinational function. When developing the 64-entry K-map, you must follow the class guidelines (i.e. the **KmapFormats.pdf** document). As designs go, this design task isn't too bad, (though a bit annoying due to the character of this particular circuit). However, some of the things you will need to manipulate along the way are fairly complicated. Try to be systematic. We don't want to see ad hoc Boolean bit hacking. Double check your completed truth table against the TAs' before proceeding any further, since one wrong output may require a time consuming revision of your whole design.
- **Step 3:** Implement the minimized 2-level POS logic circuit using only NOR gates (with four or fewer inputs per gate). You may use inverters to get the complement of your inputs if you need them. A part of your grade depends on minimizing the number of gates in your implementation. Inverters to complement primary inputs don't count. Write up the circuit in a structural-level SystemVerilog description.
- **Step 4:** Testing is a very important part of the design process. You will need to write a SystemVerilog tester for your design. Hmm... how many cases are there? Do you need to exhaustively test? Be prepared to show your TA how well it tests your circuit and also explain this in the lab report. See the Appendix section on *Making a tester* for more information.
- **Step 5:** Once your design has been fully debugged and tested in simulation, synthesize the SystemVerilog circuit description and download it to the DE2-115 FPGA board. Demonstrate it to your TA. Connect the six rightmost switches (SW5...SW0) to the 6 bits of your input in a, b, c, d, e, f order. Connect the win output to LEDR17 and error to LEDR16.

<sup>&</sup>lt;sup>1</sup>The answer is 'NO!' Exhaustive testing will lose you points on this lab.

**Step 6:** As a part of your lab report only, design, simulate and synthesize, but do not download to the DE2-115 boards, a minimized 2-level SOP implementation using only NAND gates (with four or fewer inputs per gate) and inverters to get the complement of your inputs if you need them. Show your work to design this circuit. Include a gate-level SystemVerilog description of this circuit and a simulation trace showing the correct results. Answer these questions:

- How many NAND gates of each type? (How many 2 input gates, 3 input gates, 4 input gates, etc.) Don't count the inverters on the inputs.
- Compare the cost of the POS vs. the SOP implementation based on the number of gates.
- Compare the cost of the POS vs. the SOP implementation based the logic element usage reported by the Quartus synthesis tool.<sup>2</sup> Does the comparison agree with your gate-count estimate? Why or why not?

<sup>&</sup>lt;sup>2</sup>Find this value on the *Compilation Report*, that page that overlays your source code whenever you compile your design.

## Appendix A: Making a Testbench

The first step toward effective debugging is to make sure that you have an accurate simulation. This process has been covered in class and was a major learning goal of Lab 0. However, understanding how to create testbenches is so critical, that I've included this short review as a reference and guide.

Creating a testbench involves making a test module and connecting it to the circuit that you designed. A common organization involves a **top** module that contains the module for your design and tester modules — shown here as **Loteria** and **Loteria\_test**. The **Loteria\_test** has the same inputs and outputs as the **Loteria** module only the directions are



reversed; so if a is an input to the Loteria module then it is an output of the Loteria\_test.

In operation, the **Loteria\_test** module will set the inputs of the **Loteria** module (i.e. the outputs of **Loteria\_test**) and then check or display the outputs of the **Loteria** module so that you can check it in the simulation output. The number of input combinations that you test is fully up to you, but you should be prepared to justify your decision. A poorly justified low number of tests will result in point deductions! Running through an exhaustive list of all potential inputs is also, in general, a poor decision (though possible for this lab, impossible as the number of inputs increases).

An example SystemVerilog description, corresponding to the diagram, is given below.

```
`default_nettype none
module Loteria
  (input logic a, b, c, d, e, f,
  output logic win, error);
  //Replace this comment with your work
endmodule: Loteria
module Loteria_test
  (output logic a, b, c, d, e, f,
   input logic win, error);
  //blah blah.
                Replace this too
endmodule: Loteria_test
module top();
  logic win, error, a, b, c, d, e, f;
             DUT(.a, .b, .c, .d, .e, .f, .win, .error);
  Loteria
  Loteria_test T(.a, .b, .c, .d, .e, .f, .win, .error);
endmodule: top
```

## Appendix B: Synthesizing a Circuit vs. Simulating It

When you are convinced that your design is correct in simulation, you can synthesize it. When synthesizing, you no longer need the tester (and you can't synthesize it anyway, because it has an initial block and lots of timing related statements). However, you will want to connect the ports of the design module to the physical I/O pins on the FPGA chip. Note that the design module hasn't changed at all from the simulation version. You simply want to connect its inputs and outputs to the FPGA pins. You have two choices on how to proceed:



- Synthesize the design module and then configure **design**'s ports directly to the pins.
- Introduce an interface module to connect your design to the FPGA pins. I commonly call this module **ChipInterface**, though you can pick another name if you like. The interface module lets you change names (and perhaps types) of your ports and has a bit more flexibility to it. Also, since the signals going to the FPGA pins can have a different name from the signal generated by the design, you can more easily use the provided .qsf file.

Should you choose the second method<sup>3</sup>, your interface module would look something like:

Follow the same procedure as in Lab 0 to specify the required port-to-pin connections during synthesis. As an added bonus, if you use common naming conventions, you can reuse **ChipInterface** for many different designs, simply by changing the module instantiation statement-lines 5 and 6 above. This advantage doesn't sound like much right now, but as the labs get bigger and more complex, this strategy can pay off.

<sup>&</sup>lt;sup>3</sup>and, you should

## Appendix C: How to Debug "Hardware"

One of the few drawbacks of doing development using an FPGA versus using a protoboard is that you do not have access to the internal signals of your design. On a protoboard, you can probe any wire to see what the logic value is at that point. Debugging your design on the DE2-115 board requires that you give yourself access to the internal workings of your design by assigning internal signals to pins on the FPGA chip.

In the example code below, **mycircuit** has an internal wire (i.e. logic signal) called **temp** that is not visible on any pin on the FPGA. Trying to debug a problem with **temp** would require guess work to determine what part of the SystemVerilog description is buggy.

```
`default_nettype none
module mycircuit
  (input logic [2:0] X, Y,
   output logic [1:0] N);

logic temp;

not n( N[1], Y[0]);
  and a( temp, X[2], Y[1] );
  or o( N[0], temp, X[0] );

endmodule: mycircuit
```

To improve the debugability<sup>4</sup> of **mycircuit**, the signal **temp** can be brought outside the chip by adding it to the port list as an output and specifying which pin **temp** should connect to on the FPGA. Now the value of the signal connecting the AND and the OR gates could be determined by probing the exact corresponding pin on the FPGA. Rather than probe the pin directly (with a logic probe or o-scope or logic analyzer), drive an unused LED. The pins are much too small to reliably probe without carefully designed hardware.

Keep in mind, you should always fully debug your design in simulation where it is easy to diagnose an internal problem. This type of "hardware" debugging is your last resort when your design works in simulation but does not work in real life. This is very unlikely in the 18240 labs, provided you adhere to proper coding discipline for synthesizability<sup>5</sup>.

<sup>&</sup>lt;sup>4</sup>Don't bug me about the validity of some of my words.

<sup>&</sup>lt;sup>5</sup>See previous footnote