# Lab 10: Build a Computer

November 18, 2008

## Contents

| 1        | Prelab                                | 3             |
|----------|---------------------------------------|---------------|
| <b>2</b> | Lab                                   | 3             |
| 3        | Supplementary Material    3.1 Quartus | <b>4</b><br>4 |

A conceptual block diagram of a simple computer is shown in Figure 1. In previous labs you have already designed the Addr\_Mux, the ALU, the control unit and the required registers. In this lab you will put all the components together to build a computer. The only missing block is the memory block which you can find here. You will also need the mem\_init.v in which you are going to insert your program code. You are going to use graphical design to implement the computer as shown in Figure 1. Instructions on how to do that is provided in the prelab section 1.



Figure 1: Simple Computer

# 1 Prelab

1. Using the instruction set provided in the Appendix 3.1.1, write a computer program to generate running lights. One way to accomplish this is to start with an 8-bit number 0000 0001 (where the one represents the LED that would be off). Then left shift that number once you have reached the end, jump back to the beginning of the program. Figure 2 shows the expected output at different time steps.



Figure 2: The sequence at which the LEDs turn on or off. The empty rectangles with black boarder represent and LED in the off state.

2. Using the graphical method as shown in Section 3, design and build the entire computer.

### 2 Lab

- 1. Enter your running light program in to the mem\_init.v file.
- 2. Simulate the computer you have created in the prelab.
- 3. Run your code on the Altera board.

## 3 Supplementary Material

#### 3.1 Quartus

#### 3.1.1 Graphical Design

- 1. Start a new project and include the mem\_block.v.
- Open the mem\_block.v file and select File > Create/Update > Create Symbol Files for Current File. This creates a memory block as shown below.



Figure 3: Memory block symbol

3. Open a block diagram file by

File > New > Design Files > Block Diagram/Schematic file Input and output pins are located under primitives/pin. That creates a \*.bdf file.

- 4. Right click in the main window and select Insert > Symbol.
- 5. Under you project directory select the mem\_block you just created.
- 6. Keep adding the files that you have created in previous lab for remaining components of the computer. Each time create a Symbol file and added it to the your main \*.bdf file.
- 7. For the address mux and the reset constant you can use already existing block in Quartus. You can do that by Insert > Symbol, select ../quartus/libraries/, then select lpm\_mux and/or lpm\_constant which are located under megafunctions/gates. Input and output pins are located under primitives/pin.

8. Once you are done start connecting the blocks as shown in Figure 1.

# Appendix

|   | Mnemonic                                                  | Operation                                                                                                                                     |
|---|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | nop<br>(no operation)                                     | Do nothing                                                                                                                                    |
| 1 | LDAA addr<br>(load ACCA from mem-<br>ory)                 | Loads ACCA with the value in memory at address addr. C stays the same, Z changes                                                              |
| 2 | LDAA_IMM #num<br>(load ACCA with an im-<br>mediate)       | Loads ACCA with num, the value in memory at<br>the address immediately following the LDAA #num<br>command. C stays the same, Z changes        |
| 3 | STAA addr<br>(store ACCA in memory)                       | Stores the value in ACCA at memory address addr. C stays the same, Z changes                                                                  |
| 4 | ADDA addr<br>(add ACCA and value in<br>memory)            | Adds the value in memory location addr to the value in ACCA and saves the result inACCA. C and Z change                                       |
| 5 | SUBA addr<br>(subtract value in mem-<br>ory from ACCA)    | Subtracts the value in memory location addr<br>from the value in ACCA and saves the result in<br>ACCA. C and Z change                         |
| 6 | ANDA addr<br>(logical AND of ACCA and<br>value in memory) | Perform a logical AND of the value in memory<br>location addr with the value in ACCA. Save the<br>result in ACCA. C stays the same, Z changes |
| 7 | ORAA addr<br>(logical OR of ACCA and<br>value in memory)  | Perform a logical OR of the value in memory<br>location addr with the value in ACCA. Save the<br>result in ACCA. C stays the same, Z changes  |
| 8 | CMPA addr<br>(Compares ACCA to the<br>value in addr)      | Compare ACCA to value in addr. This is done by<br>subtracting the value in addr from ACCA. ACCA<br>does not change. C and Z change            |
| 9 | COMA<br>(Complement ACCA)                                 | Replace the value in ACCA with its one's complement. C is set to 1 and Z changes                                                              |
| Α | INCA<br>(INCA ACCA)                                       | Increment value in ACCA. ${\tt C}$ stays the same and ${\tt Z}$ changes                                                                       |
| В | LSLA<br>(logical shift left ACCA)                         | Logical shift left of ACCA. ${\tt C}$ and ${\tt Z}$ change                                                                                    |
| С | LSRA<br>(logical shift right ACCA)                        | Logical shift right of ACCA. ${\tt C}$ and ${\tt Z}$ change                                                                                   |
| D | ASRA<br>(Arithmetic shift right<br>ACCA)                  | Arithmetic shift right of ACCA. C and Z change                                                                                                |

### Table 1: Computer Instructions

| Е  | JMP addr                | Jumps to the instruction stored in address addr.          |
|----|-------------------------|-----------------------------------------------------------|
|    | (jump)                  | The PC is replaced with $addr$ . C and Z stay the         |
|    |                         | same                                                      |
| F  | JCS addr                | Jumps to the instruction stored in address addr           |
|    | (jump if carry set)     | if $C=1$ . If C is not set, continue with next            |
|    |                         | instruction. ${\tt C}$ and ${\tt Z}$ stay the same        |
| 10 | JCC addr                | Jumps to the instruction stored in address addr           |
|    | (jump if carry not set) | if $C=0$ . If $C$ is set, continue with next instruction. |
|    |                         | ${\tt C}$ and ${\tt Z}$ stay the same                     |
| 11 | JEQ addr                | Jumps to the instruction stored in address addr           |
|    | (jump if Z set)         | if $Z=1$ . If Z is not set, continue with next            |
|    |                         | instruction. $C$ and $Z$ stay the same                    |