**Read all directions before starting**. For this lab, work in teams of two. You may seek help from any ECE 281 instructor and reference any publication in its completion, but may not utilize any student. Normal documentation is required (you do not need to document work with your partner). We expect all the code your own work.

All prelab work should be computer generated or ***neatly*** hand drawn.

**Resources:**

* “Lab1” or “Data Sheets” pages on Blackboard
* K:\df\dfec\ECE281\Lab1 or K:\df\dfec\ECE281\Datasheets

***Prelab (Due Lesson 9):***

You are creating a circuit that will take a month as a 4-bit binary input. **January is equivalent to 0001**. For each month that has 31 days, you should turn on the red light (your output value Y is ‘1’). All other months and the unused binary inputs should produce an output of ‘0’.

1. **(5 pts)** Draw a truth table to describe these conditions.
2. **(5 pts)** Use a K map to find the simplified equation for Y.
3. **(32 pts)** Using the provided datasheets, draw four separate schematics that can implement your truth table.
   1. The first shall use an 8:1 multiplexer and an inverter(s).
   2. The second shall use a 4:16 “one-cold” (active low output) decoder, inverter(s), and two-input OR gate(s). Using 2-input NANDs is also acceptable.
   3. The third shall use only an inverter(s), two-input OR gate(s), and three-input AND gate(s).
   4. The fourth shall use only NAND gates with either two or four inputs.
4. **(8 pts)** For each schematic, list how many chips of each type you will need to build that schematic and how much it will cost. Keep in mind that **some chips may have multiple gates**; for example, each hex inverter chip contains six inverters. You will need to consult the datasheet for each available part to see how many gates each contains. The available parts list is below, and the datasheets can be found in the resources listed above.

Device Part Number Price per chip

8:1 mux 74151 $0.75

4:16 decoder 74154 $4.95

2-input OR 7432 $0.45

4-input NAND 7420 $0.79

3-input AND 7411 $0.49

Hex NOT 7404 $0.65

Double NAND 7400 $0.45

1. **(10 pts)** Answer the following questions:
   1. **(2 pts)** If you only have a 4-input NAND gate to use, but your circuit design calls for a 3-input gate, what would you connect the other input to for your circuit to function properly?
   2. **(3 pts)** The multiplexer (74151) has a signal called . What function does this signal serve?
   3. **(2 pts)** The 4-input NAND gate chip (7420) has a connection labeled NC. What does this mean?
   4. **(3 pts)** If you were contracted to build a circuit to satisfy the given requirement, what aspects of the design would you need to consider? How would these considerations affect your design?

***During class (Due Lesson 11):***

You will build **circuit 3a** designed above and **demonstrate** that it works to an instructor, who will sign your schematic.

1. Before you can build your circuit, you must set up the breadboard the same way you did for ICE1 (Parts A, B, and eventually D).
2. Once you have your layout, start connecting your chips.

**Hints on wiring and debugging:**

* Reference back to ICE1 if you need a refresher on how the breadboard functions. You may also reference the breadboard handout in the Datasheets Library to see how things are connected.
* DO NOT leave floating inputs or control signals. All unused input pins need to be grounded or connected to Vcc.
* If note already done, connect the Vcc and ground tracks on top to the columns on the breadboard. Don’t forget to connect the top and bottom half of the columns over the break (if necessary).
* Double check all connections before turning on power
* Do not change your circuit with the power on

***After Class (Due Lesson 13)***

You will implement the same design in VHDL and demonstrate that it works to an instructor.

## 1. Implement SSD component in VHDL

### Get the VHDL templates

1. You should have them as part of the course download in the Lab1 folder
2. Special templates have been provided for this Lab
   1. thirtyOneDayMonth.vhd
   2. thirtyOneDayMonth\_tb.vhd
3. Add your sources to Vivado.
   1. Remember to leave “Copy sources into project” **unchecked**
4. Edit the file headers as needed.

### Create your SSD entity

**Create your interface (ports) for thirtyOneDayMonth according to Figure 3 below**. Figure 3 shows the thirtyOneDayMonth module entity interface in blue and the architecture in purple. Notice that the figure indicates that the input, i\_sw, is a bus of 4 wires. This can be created in VHDL by using a **std\_logic\_vector** signal type. For instance, i\_sw could be created in the **port** statement with the following:

![](data:image/png;base64,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)

Remember, the “i\_” follows the naming convention provided in the header that indicates the signal is an input. The statement above “3 downto 0” indicates that BIT3 is the MSB and BIT0 is the LSB. You could easily reverse this by swapping the locations of the two numbers. **This has been created for you in the template.**

To access each wire from the bus you created simply refer to the bit number in parentheses. For instance, i\_sw(3) refers to the MSB of the input, D.

The output, o\_led0 is a single wire. This can be created in VHDL by using a **std\_logic** signal type. For instance, led could be created in the **port** statement with the following:

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAKcAAAASCAIAAACxc1l9AAAAAXNSR0IArs4c6QAABLJJREFUaEPtWDtv4lgUvt5fEJMqGZoQQGkoMjBIpkUiglBQDKvZaprB1qYLmj5B20amWhJMlSqRSMFKHthhhxakYKBIM8KENBnYZuyf4D3XDx4hxkCW2WjDFYV97znfed3zMISiKGi1XpgHfnph9q7MxR5YRf0l3oPFoy4KAeKUIDJMaWa/lcpj9KVyIJAhiMu0ODPCsyG8yxFXnx7XG46yCdNTsED+FMjSBDeVxsLQfvoqQVRai7pj8ai7fFXlV4W1zSE5HBrSiwJTcFarB4qyh06EHx53sZFi7uZQfQ7SrYQS8k+jJ/erDNf22ufAfEi6cfg2pwR3F0WYiLqcZi4JnMSXTFqeG1UvACp7yWAXuwzO6VMiUB7WBb6DYg4Vn9xBHX66JA2W6VrpIzZyWhoFKloithhIOzUnShV1v4F34dnd+Mb9BTt4c2r4+6VKisCYGnsf2OHGEOU6kv5wj2wiNKAEsp6Vpo+cTygPNP30ULpaHipNs1Ih3mm2z1RFYIYfWUX6gm3r7232gi6OH0++jdFILF03uJU2+1mFkljKwGzXafS7jjnKaCmoXadQBtG307XpcpTQ00kknvrSVJ8HD4qCCQzjhGO6a2UcnHc5lOdUL/SKXz4M8fE+P7AVjtvCsb4jNemzDw9OJyUN6dUz/HrGFSVdkMYOEscwdYsM+lEFQJ+zYxazazqP6TYhfTzXu4UbZ9Sl30NX1HlTsEyvkUsr3ua5uhvXCfxzJzt5Xkaw6fEfapgu30d6gSTAjLibZLXaYLZK3V7csaGfkq/jsjD7xGEKurZJfa9HcA/mCmsH514D/yFD60S4p7372E5y96Nv3urd5+/u6VAiTAL/Rvh1jPou8HKr0LGzwZkwS91rykcfYnaEoMW8VblM1+J9fRLSZfNQb9oQHv13UNXVsIi0+BXthBe6Dctngh78c6rojdEk4oSMe9oAZd9ZM/LFtvkkzchNz5P4LZnHo+6IeTq8MVmJfMejt15LGI0As58M2rm259qO31zrU7oonHAGVNSJvmqFROahwEyXMFNfDzs2813cd1XQZp706VdJ7oFJIkzO5etRMTeS2qRxO8yZVYVSJRFo/u307meDR0WnHalQeOEa0OtgQS3mKpeWd2PO+2SzpZ72040xQTN4byO6ZefKOdV3MB9kuHVflFQxtQFFxrVkCk7Y4a8JvO56rFJq6lBGPPxvDqa5z0kOpJM0u5c1T9YSk4lwhKGIQrG/qJk9YFcoyhk/D+HaDtPc+z+5GoGo7WJciiQRq7w7BM50mUjegiC2/U5vAWZ2QdTd9Rq9Z1XkYSB6L9RrhEJtx8612ohnt1Skc4/W/ewWSgrXdCiX3YJtcM0pJynI5meDCTM7Ye6LgIp4YcpiUCvCA9hviHhFe+ksrvwweXHJEUFoPdZ+rNKOYGpIb4p0Ai7oY8prmCBFoWyoRh7A3G7FDoADlcz8ORH1GS7miuQ/8ADc3d/W6KrpYDGXSquoz+WuH05sZPZY9XqyFlZRl9OBiyQU5wfLutg+WbMVwPI8YBX15Un+vyPDn6ZHSWnSylds/Gi2b5vleWgV9eX59vki/5vf68/XypVm4x5YRf0l3oh/APCaqdijDja8AAAAAElFTkSuQmCC)

**This has been done for you in the template.**

4

i\_sw

o\_led0

**thirtyOneDayMonth**

Combinational Logic

**Figure 3 – thirtyOneDayMonth entity and architecture**

### Create your SSD architecture

After you have created your component interface, you need to describe the architecture. For easy of understanding you can utilize combinational signals (denoted by the “c\_” at the beginning) and wire them to the input bus i\_sw. For instance, BIT3 of i\_sw is wired to c\_A.

1. For clarity, declare intermediate combinatorial signals (e.g., c\_A) that break out input i\_sw and set them to a default value of ‘0’ (off). This should be done *before* **begin**.
2. There are no PORT MAPS or PROCESSES needed for this module, so you can delete those sections.
3. In the CONCURRENT STATEMENTS section, map the input i\_sw to the signals you created above per Figure 3. For instance:

![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHgAAAARCAIAAACZ/f8XAAAAAXNSR0IArs4c6QAAAltJREFUWEftVztygzAQFTlLmHGjA8AN7KFw4zqdqJ1JmyptBmp8BZoUDtzAPgANA4chqx8/gyTb4EkmqLGtWe3n6Wnf2qqqCi1rfgSe5g+xRKAILEA/iAcTAV2GrsWXG5bzp07D+ekMccBxq4Ay9VlZrp/WRcHWbRVCj55qFYFDAuIEhaHDIgFrkpiaG3q9x6wgiCTSQSKTK9g3ud2xMQ+GNKY0CGeOQwhRYkhxLqrCDGnq1wnq7M0TrhLC82lKHz1cJw+5O+RbHJVMgHx7fsD1kNcu0NTLJZm4MwXJ1EDDcUCDU459V7CP4kyBAwTVnL4ksii51Qq0z0IEU15QTckKoOIQ9pLr/hxAUOAHBGqtofu4D2iJnQnfGlsl0rRkLYoG8UyAprCKy5NPn2dJHwX/7KQCpBx8Jj1Gc0ob5NgxmUgMUXmMz4cNk8PN4Rwfx4TKXkfFO/r0W/KCUCOlQlEnktR1dOKPMdllH0zCbA9neZlnJNhlX2meYc/WSyrkTK31hioLJdC2JxMEMMrQd/0xwQWccdNwExwrlNle76PojYIdiuTtPQekWae9AQCaylMfJhM2LdjPtam9xflLjFYeLS3G23aYFUZwC9K09GEAYedh+HhFq8YHbOFVLzgEs9SD0BViONZ66xYr2qAQT+30cdPUIbVQ9oTxKLRFN0ouaUCTZQ9/QHN6zbelpe3RaKhFs2akLFg3dVzbiv62vcnoNmRjIDwL0B1qsL8CysFeO1SNUO1KoC8HMdOZdjaq/8KUhmq1YPM+OV1OGyEw1XhnFOw/Gy1AP+j2fwCUH3edCp349wAAAABJRU5ErkJggg==)

1. If you are wanting to create a vector that is a subset of another vector you can do![](data:image/png;base64,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)

![](data:image/png;base64,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)

1. You may need to create other intermediate wires to implement your logic.
2. Implement your prelab equations using behavioral modelling
   1. Reference the VHDL Reference sheet for assistance in implementing the circuits
   2. Helpful hint: When the example code uses “0001” it is referring to a 4 bit signal. You can instead use x”1” to represent the number in HEX. Ex: “11100011” would become x”E3”

## 2. Create SSD testbench and simulate

### Edit the VHDL template

1. Edit the header as needed.
2. Much of the tb is filled out for you. Read through the provided template to see how it was set up
3. Finish the test process. Remember, you can use hex values with busses: ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAHUAAAAVCAIAAAD3kjaxAAAAAXNSR0IArs4c6QAAAvNJREFUWEftmDFu4kAUhsd7BhxfAArQ5gK2tkkHVURBm25AonCa1ARpD2AXK0i6tEigNLG7LYi8F0hEJOACUXKHyZsZbI+NMeOQUVbIT0hBnpk3z9/8/p+JRghBZSgj8ENZ5jIxJVDyVauDkm/JVy0Btdm1o+9vj+Ph31dknPV7lflw8oTQaWfQrstRPWQt3+H4/aFyQu/zpFLZIDX0CO478MuM2QufnLNW7oC+j6/fHWrasOtL1nngNEPXEdJ1g5GOclV+9fpnBhW0GJ3T5GbZayUL2tLv2rW0MLq+39U4gvCq5a7DzNFMy5XcjE9bu2Mg27qFr0ajVmjp9mQokAcrLC4+PjhOlamRy7FASK1dP1oaaGUckxF2SPH1u7XLnx54Mg0PtRgFGnbgYYQ9EtjVcHXVDghxTOwFtmTJnGzt8hXmY29ASA+y8YuZH8t935e5eUOgMMjGCqvad46JTIeQm2a4klHl9lAH1EyNWfEyG3JbqLcjf5Zdu7vKVH8DOfxurASIwkrXstBdcgj0coECGb7+TGtBb6EBZOO7Z3LmxLfDdPqBHT/Ou+8Cym4hj1wtrdqkAxrYdyrxOFjwH2h/PAp0PukdNlqN/qxAAFGYzioehxEQMASdQTUCCmeazg9vitA1/5jO257Jnx+mKqZnVzDD23x0PV3QRYvp5kvBDPnTUd4wZS0g5jQpZozZdRm8odfElFMMVs4oOoDUlwLnwfEWBxzz/VKsUbLc9zNqZ2jyEHa05jl+Xq4fJqhxdY7/wfXlsynboJptQgYrh7aa29ZXvzls7IG3jE1Dln6AFU8Uj43qNaEuUEXCIkC6psmucL1wlygYgmBHov8UTBNO5+0t4W+JmvPTHq5fD+dZX8IfEt6b9bhxw2AVM8CF7U50c2oLBySIq2CVMqbCDchkpnCFGM0/0R4WGFoLZg6eFcf/+1jt80/fi+DNpR29Dqa2O/7fx0r5+vdP2NsJF7Yu9auU//f9/0Htbf032Ut/UHsUH52xjpS1/8X0AAAAAElFTkSuQmCC)
4. Fix any syntax errors, and run the simulation.
5. Groups inputs and outputs and change the radix to hex. Makes sure the signals are in the proper order so the hex values make sense. This makes verification easier.
6. Make sure the simulation results match your truth table, and then **include a waveform screenshot in your repo**.

## 3. Modify the constraints file

1. Add your Basys3Master.xdc file to your project as a constraint and open it.
2. Uncomment the lines you will need to use. This will include the first 4 switch statements (8 lines) and the first led statement (two lines). **This has been done for you in the template.**
3. Rename the section inside the {} to match your signals ex: sw[0]->i\_sw[0] and led[0]->o\_led0. **This has been done for you in the template.**

## 4. Implement the design in hardware

1. Generate the bitstream (.bit) file and download it to your FPGA.
   * Do not forget to commit the .bit file to your Git repo.
   * The default location of the file should be: Lab1\Lab1.runs\impl\_1\thirtyOneDayMonth.bit
2. Verify that your design functions correctly.

Demo the working final product to your instructor.

# C:\Users\daniel.johnson\AppData\Local\Microsoft\Windows\INetCache\Content.Word\IMG_2940.jpg

# Lab 1 Deliverables

Table 3 below shows how the points will be distributed for this assignment. Details for how each item will be scored follows.

**Table 3: Point distribution for Lab 1**

|  |  |
| --- | --- |
| **Item** | **Out of** |
| Prelab | 60 |
| TTL Hardware Demo | 40 |
| VHDL Hardware Demo | 30 |
| Simulation Results Waveform | 10 |
| VHDL, XDC, and Bit Files | 10 |
| **Total** | **150** |

## (60 pts) Prelab

* Picture of the graded hardcopy you turned in acceptable

## (40 pts) TTL Hardware Demo

* Demonstrate proper LED behavior on the protoboard as you switch from 0 to 16 (in binary)

## (30 pts) VHDL Hardware Demo

* Demonstrate proper LED behavior on the FPGA as you switch from 0 to 16 (in binary)
* Demo can be performed live with an instructor (preferred) OR documented in the report.
  + If documented in the report, include a brief video (online link is fine) or series of pictures for complete proof of correct functionality.

## (10 pts) Simulation Results Waveform

* Clearly shows that that all possible inputs and outputs match the correct Prelab truth table.

## (10 pts) VHDL, XDC, and BIT files

* thirtyOneDayMonth.vhd and thirtyOneDayMonth\_tb.vhd included in **code** folder
  + Fill out headers as appropriate
  + Remove extraneous code and comments
* Basys3\_Master.xdc file included in **code** folder
* Bitstream (.bit) file used for hardware demo in repo