## Design 1.2 - A Three-Bit Adder

Your next design will consist of an adder module which sums two three-bit numbers and a carry input and displays the four-bit sum on a seven-segment LED (Figure 6).



## Figure 6: Block diagram of a three-bit adder that displays its sum on a sevensegment LED display.

You can use the previous design as a starting point for this design. Start FastChip and open the *Chapter1.1* project. Click on File⇒Save Project Copy As... and type Chapter1.2 in the Project Name field. Then click on OK.

| sce    | nd FastChip: Save Project ( | Copy As 🔀            |
|--------|-----------------------------|----------------------|
| $\geq$ | -Specify Project Name       | )                    |
|        | Project Name:               | Chapter1.2           |
|        |                             |                      |
|        |                             |                      |
|        | 🔆 🖌 Apply 🖌 🖌 OK            | Cancel <b>?</b> Help |
|        | <u> </u>                    |                      |

After this, your FastChip project name is changed to *Chapter1.2*. Click on the Library icon in the toolbar to display the library of soft modules.

Your new design requires three sets of inputs, so click-and-drag two more Input icons from the Triscend Library pane and drop them into the Programmable I/O Pins area. Next, select an Adder icon from the Logic Modules⇒Arithmetic section of the Triscend Library pane and drop it into the Configurable System Logic area.



Now you need to specify the signals that interconnect the modules. Click on the Input\_A icon and then decrease the bus from four to three bits by clicking on the right-hand side of the Width field. As a result, the input signal name changes from A[3:0] to A[2:0]. This is all you need to change, so click on OK to close the window.

| Trisc                   | end FastChip: Module - Input (Input_A) |    | ×                                                                              |
|-------------------------|----------------------------------------|----|--------------------------------------------------------------------------------|
| Component Name: Input_A |                                        |    | Properties<br>Input Width<br>Width:3                                           |
| ⊡≁                      | 3                                      | 4  | Bus Minder -<br>None<br>Pull-Up Resistor<br>Pull-Down Resistor<br>Bus Follower |
|                         |                                        |    | Power-Down Operation 🔸                                                         |
|                         | Des (Asian and                         |    | Input Hysteresis 🔸                                                             |
|                         |                                        |    | Synchronize Input 🔸                                                            |
|                         | Apply 🖌 OK 🗶 Cance                     | el | ? Help                                                                         |

Next, click on the lnput\_B icon. Click twice on the  $\blacksquare$  arrow to increase the input width to three bits. Then type B into the <input> field as the signal name. Click with your mouse outside the field and the window should appear as follows. Then click on OK to close the window.

| Trisc | end FastChip: Module - Input (Input_B) |     | ×                                                                                                                                                                           |
|-------|----------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ••    | Component Name: Input_B                | 24  | Properties<br>Input Width<br>Width:<br>Bus Minder<br>O None<br>O Pull-Up Resistor<br>O Pull-Down Resistor<br>O Bus Follower<br>Power-Down Operation +<br>Input Hysteresis + |
|       | Apply VOK XCand                        | ;el | Synchronize Input       Help       Help   Export to VHDL                                                                                                                    |

Set up the last input by clicking on the lnput\_C icon. This is a one-bit carry input, so there is no need to adjust the width of the signal. Just type C into the <input> field as the signal name and click on OK to close the window.

| Trisc | end FastChip: Module - Input (Input_C) |    | ×                                                                           |
|-------|----------------------------------------|----|-----------------------------------------------------------------------------|
| ₽     | Component Name: Input_C -              |    | Properties Input Width Width: Bus Minder None Pull-Up Resistor Bus Follower |
|       |                                        |    | Power-Down Operation +<br>Input Hysteresis +<br>Synchronize Input +         |
|       | Apply VOK XCance                       | el | ? Help                                                                      |

Now you can customize the **Adder\_A** module for your design. Click on the Adder\_A icon and the following window appears. The adder is initially set up to add two eight-bit inputs and output a nine-bit result.



Click in the Width field and type 3 to adjust the adder to the appropriate size for this design. Then click on the checkbox to the left of Cin to enable the carry input to the **Adder\_A** module.



Click on the I next to the right of each signal name field and select the appropriate signal for each input and output from the list that appears.



The final assignment of signals to the inputs and outputs of the **Adder\_A** module is shown below. The four-bit sum is passed to the LED decoder over the **D[3:0]** signal bus. **Adder\_A** is set up so click on OK to close the window.



Once the modules are interconnected, the next step is to connect the I/O for your design to the pins of the CSoC. Click on the I/O Editor icon in the toolbar to display the **I/O Editor** window. The outputs for the **7seg\_E** module were already assigned to the correct pins for the CSoC Board in the **Chapter1.1** project, and those assignments were copied over to this project when it was created. The same goes for the three **Input\_A** inputs. So you only need to click-and-drag the **Input\_B** and **C** signals to the pins connected to the DIP switch on the CSoC Board. The pin assignments for the inputs are as follows:

| Signal    | Pin | CSoC Board Resource    |
|-----------|-----|------------------------|
| Input_A.0 | 53  | DIP switch position #1 |
| Input_A.1 | 54  | DIP switch position #2 |
| Input A.2 | 55  | DIP switch position #3 |
| Input B.0 | 58  | DIP switch position #4 |
| Input B.1 | 59  | DIP switch position #5 |
| Input B.2 | 60  | DIP switch position #6 |
|           | 62  | DIP switch position #7 |
| not used  | 63  | DIP switch position #8 |

| Table 2: Pin | assignments | for the i | inputs to the | three-bit | adder design. |
|--------------|-------------|-----------|---------------|-----------|---------------|
|              |             |           |               |           |               |



The **I/O Editor** window looks like this after the pin assignments are made:

Once the pin assignments are complete, you can map, place, and route your circuit to the CSL of the CSoC by clicking on the Bind icon on the toolbar. Note from the status bar that this design consumes ten cells in the CSL (seven for the LED decoder and three for the three-bit adder) and fourteen of the I/O pins (seven for the LED decoder outputs, six for the two 3-bit addends and one for the carry input).

| 📈 Triscend FastChip: Chapter1.2 (Target Device: TE505S16-25L)                       |                                                                       |  |  |  |  |
|-------------------------------------------------------------------------------------|-----------------------------------------------------------------------|--|--|--|--|
| 📈 File View Tools Help                                                              |                                                                       |  |  |  |  |
| Project Library Import EDIF I/O Editor Generate Bind, Download Debug Log Stop       |                                                                       |  |  |  |  |
| Triscend Library ? X                                                                | - Dedicated Resources ?                                               |  |  |  |  |
| Archive<br>Displays                                                                 | MCU Clocks MIU Timer_0 100 Timer_2 UART                               |  |  |  |  |
| Logic Modules                                                                       |                                                                       |  |  |  |  |
| Arithmetic                                                                          | Configurable System Interconnect (CSI) Bus                            |  |  |  |  |
| 🗆 🕂 Adder, Loadable                                                                 | 👔 🎃 Configurable System Logic 🙎 🧃 ——————————————————————————————————— |  |  |  |  |
| Miscellaneous     Counters     Registers                                            | Adder_A                                                               |  |  |  |  |
| FIFOs                                                                               | \$                                                                    |  |  |  |  |
| LUT                                                                                 | Add 1/0 - 🥡                                                           |  |  |  |  |
| Peripherals<br>  CSI Bus                                                            | 8     D→     D→       7seg_E     Input_A     Input_B                  |  |  |  |  |
|                                                                                     |                                                                       |  |  |  |  |
| Resource Estimate ?                                                                 |                                                                       |  |  |  |  |
| UCSL Cells: 10/512 2 2 № I/O Pins: 14/59 24 2 D CSI Selectors: 0/32 0 2 0 2 Perform |                                                                       |  |  |  |  |
| 🖾 Binding design to physical resources. 💦 🔲 13 %                                    |                                                                       |  |  |  |  |

You can download your design once the bind process completes. As always, make sure your CSoC Board is attached to the 9V DC power supply and it is connected to the parallel port of your PC with the downloading cable. Click on the Download icon on the toolbar and then click on OK in the **Download** window that appears. This initiates the downloading of the configuration file into your CSoC Board.

| Trisce | nd FastChip: Download                                                                                                                                                                                                                                                          | ×      |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|        | Application Object Code ?<br>Use Bank Switching<br>Intel HEX File Name:            Intel HEX File Name>                                                                                                                                                                        | JITAG  |
| \$     | Memory Device: Internal SRAM • +?<br>CSoC Operation Mode ?<br>• NOT Secured<br>• Disable CSoC JTAG access after download<br>(Disable reset triggered reconfiguration<br>• Secured Disable external access from NNU pins<br>Disable Triscend FastChip debug from the JTAG pins) | z CSoc |
|        | VOK XCancel ? Help                                                                                                                                                                                                                                                             |        |

With your design downloaded into the CSoC Board, you can try some test cases to see if various inputs are summed correctly. The first addend is driven by the first three DIP switches, the second addend is driven by the next set of three switches, and the carry input is set by the seventh switch. Figure 7 shows a few test examples.



Figure 7: Testing the three-bit adder.

Once you are done testing the adder, finish by clicking on File⇒Save Project and File⇒Exit.

## **Design 1.3: A Simple Timer**

Your previous designs were combinatorial in nature: the output was a function of only the current inputs. This design introduces a sequential component, a counter, whose output depends upon its previous state.

The counter is used to build a timer where the elapsed time is displayed on the sevensegment LED (Figure 8). A 25 MHz clock drives a 27-bit counter. The counter will roll-