#### CS 240 Arch

#### ID Number:

About how many hours did you spend actively working on this assignment?

#### 1. Flop-Flip-Flopping

| <b>1a.</b> Cycles<br>Completed | Q <sub>2</sub> | Q <sub>1</sub> | Q <sub>0</sub> | <b>1b. Explanation</b> (You need not fill this entire space.) |
|--------------------------------|----------------|----------------|----------------|---------------------------------------------------------------|
| 0 (initial)                    | 0              | 0              | 0              |                                                               |
| 1                              |                |                |                |                                                               |
| 2                              |                |                |                |                                                               |
| 3                              |                |                |                |                                                               |
| 4                              |                |                |                |                                                               |
| 5                              |                |                |                |                                                               |
| 6                              |                |                |                |                                                               |
| 7                              |                |                |                |                                                               |
| 8                              |                |                |                |                                                               |
| 9                              |                |                |                |                                                               |
| 10                             |                |                |                |                                                               |

#### 2. Reconstructing Memories

2a. Draw a 256×8 RAM based on two 256×4 RAMs. Your logic will go inside the box.



**2b.** Draw a 64K×8 RAM based on one 16K×32 RAM.



## 3. A Loopy Program

# 3a. Execution Table for P1 (should have 18 rows)

| PC | Instruction | State Changes |
|----|-------------|---------------|
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |
|    |             |               |

| 3b. Final Register Contents | R2: | R3: | R4: |
|-----------------------------|-----|-----|-----|
|                             |     |     |     |

| 3c Python, Java, or Javascript statements equivalent to P1: |  |  |  |  |  |
|-------------------------------------------------------------|--|--|--|--|--|
|                                                             |  |  |  |  |  |
|                                                             |  |  |  |  |  |
|                                                             |  |  |  |  |  |
|                                                             |  |  |  |  |  |
|                                                             |  |  |  |  |  |

## 4. Taking Control

## **Control Unit Truth Table**

| Instruction<br>Name   | Opcode <sub>[3:0]</sub><br>(4 bits) | Reg Write<br>(1 bit) | ALU Op <sub>[3:0]</sub><br>(4 bits) | Mem Store<br>(1 bit) | Mem<br>(1 bit) | Branch<br>(1 bit) | Jump <b>(5a(ii))</b><br>(1 bit) |
|-----------------------|-------------------------------------|----------------------|-------------------------------------|----------------------|----------------|-------------------|---------------------------------|
| LW                    |                                     |                      |                                     |                      |                |                   |                                 |
| SW                    |                                     |                      |                                     |                      |                |                   |                                 |
| ADD                   |                                     |                      |                                     |                      |                |                   |                                 |
| SUB                   |                                     |                      |                                     |                      |                |                   |                                 |
| AND                   |                                     |                      |                                     |                      |                |                   |                                 |
| OR                    |                                     |                      |                                     |                      |                |                   |                                 |
| BEQ                   |                                     |                      |                                     |                      |                |                   |                                 |
| JMP <b>(5a(iii)</b> ) |                                     |                      |                                     |                      |                |                   |                                 |
| NAND (6b(ii))         |                                     |                      |                                     |                      |                |                   |                                 |

### 5. Jumping into the Unknown

5a(i). Below, add Jump output from Control Unit and modify logic to use it to implement JMP instruction.



| <b>5b(i).</b> Execute this code, assuming <b>R2</b> holds 5 and <b>R3</b> holds 2. Indicate the final register | <b>5b(ii).</b> Single line of C code equivalent to this code.                                                       |
|----------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| values when the code reaches HALT.                                                                             | R4 = ;                                                                                                              |
| 0: AND R2, R2, R4<br>2: AND R3, R3, R5                                                                         | 6. Instruction Not Missing                                                                                          |
| 4: BEQ R5, R0, 3<br>6: SUB R5, R1, R5                                                                          | <b>6a.</b> The instruction <b>NOT Rs</b> , <b>Rd</b> can be emulated by running the following instructions instead: |
| 8: ADD R4, R4, R4<br>A: JMP 2<br>C: HALT # Stops execution.                                                    |                                                                                                                     |
| c. Indi # Stops execution.                                                                                     |                                                                                                                     |
| R2: R3: R4: R5:                                                                                                |                                                                                                                     |

# 6b-c. NAND/NOT encoding and definition ------ 16-bit encoding ------

| Assembly               | Meaning                       | Opcode<br>[15:12] | Rs<br>[11:8] | Rt<br>[7:4] | Rd<br>[3:0] |
|------------------------|-------------------------------|-------------------|--------------|-------------|-------------|
| 6b(i). NAND Rs, Rt, Rd | $R[d] \leftarrow ~(Rs \& Rt)$ |                   |              |             |             |
| 6C.NOT Rs,Rd           | R[d] ← ~Rs                    |                   |              |             |             |

## 7. Points Affixed and Afloat in a C of Numbers (OPTIONAL PROBLEM!)

| 7a. Fixed point numbers Sea Type     | Minimum<br>(base ten) | Maximum<br>(base ten) | iii. Adder (It fits! Reuse provided parts.) |
|--------------------------------------|-----------------------|-----------------------|---------------------------------------------|
| i.<br>signed fixed8ths char          |                       |                       |                                             |
| <b>ii.</b><br>signed fixed32nds char |                       |                       |                                             |

### **7b.** Floating point conversion.

| 6-bit floating-point encoding | 110101 | 100001 | 011100 | 000011 | 010010 | 111101 |
|-------------------------------|--------|--------|--------|--------|--------|--------|
| Decimal number represented    |        |        |        |        |        |        |