

# ECE 120: Introduction to Computing

## Fall 2023 – Final Exam

Friday, December 8<sup>th</sup>, 2023

### Answer KEY

- Ensure that your exam booklet has 19 pages.
- **Write your NAME and UIN** clearly in the boxes below.
- Do not tear the exam booklet apart. You can only detach the last page for scratch work if needed.
- This is a closed book/notes exam. You may use a calculator.
- You are allowed **one handwritten sheet** of notes (both sides). Write your name on the cheat sheet. The cheat sheet will be collected at the end of your exam.
- Absolutely no interaction between students is allowed.
- Indicate any assumptions that you make.
- **The questions are not weighted equally.** Budget your time accordingly.
- Show your work and write legibly. Solutions in **illegible handwriting will be graded as incorrect.**
- Write your **UIN (9-digit #)** in the provided space on each page.

NAME  
\_\_\_\_\_

UIN  
\_\_\_\_\_

Problem 1      10 points      \_\_\_\_\_

Problem 2      15 points      \_\_\_\_\_

Problem 3      15 points      \_\_\_\_\_

Problem 4      15 points      \_\_\_\_\_

Problem 5      26 points      \_\_\_\_\_

Problem 6      08 points      \_\_\_\_\_

Problem 7      11 points      \_\_\_\_\_

---

Total      100 points      \_\_\_\_\_

**Problem 1 (10 points): Binary Representation and Operations**

1. **(3 points) a)** What is the minimum number of bits required to encode a character set consisting of 129 symbols?

Answer: \_\_\_\_\_

- b)** How many additional symbols, if any, can be encoded with your answer to part (a)?

Answer: \_\_\_\_\_

2. **(4 points)** The **7-bit** pattern x74 represents what value in each of the following representations?

ASCII: \_\_\_\_\_

Unsigned (write answer in decimal): \_\_\_\_\_

2's complement (write answer in decimal): \_\_\_\_\_

3. **(3 points)** Prove that the set of Boolean functions {OR, NOT} is logically complete.

1. (3 points) a) What is the minimum number of bits required to encode a character set consisting of 129 symbols?

(+1) Answer: 8 bits

- b) How many additional symbols, if any, can be encoded with your answer to part (a)?

(+2) Answer: 127 symbols

2. (4 points) The 7-bit pattern x74 represents what value in each of the following representations?

(+1) ASCII: t (lower case)

(+1) Unsigned (write answer in decimal): 116

(+2) 2's complement (write answer in decimal): -12

3. (3 points) Prove that the set of Boolean functions {OR, NOT} is logically complete.

(+1) ① An n-bit NOR gate can be built with an n-bit OR gate followed by a NOT gate.

(+2) ② Since {NOR} is logically complete, {OR, NOT} is also logically complete.

Note: If statement in ② is not complete, (-1)

**Problem 2 (15 points): Combinational Logic**

1. Shown on the right is a combinational circuit that adds two 2-bit numbers,  $a_1a_0$  and  $b_1b_0$ , and outputs the sum bits  $s_1s_0$  and the carry bit  $c_2$ .



- a. (4 points) Fill in the K-map for  $c_2$  below.

| $c_2$    | $b_1b_0$ |    |    |    |
|----------|----------|----|----|----|
|          | 00       | 01 | 11 | 10 |
| $a_1a_0$ | 00       |    |    |    |
| 00       |          |    |    |    |
| 01       |          |    |    |    |
| 11       |          |    |    |    |
| 10       |          |    |    |    |

| $s_0$    | $b_1b_0$ |    |    |    |   |
|----------|----------|----|----|----|---|
|          | 00       | 01 | 11 | 10 |   |
| $a_1a_0$ | 00       | 0  | 1  | 1  | 0 |
| 00       | 0        | 1  | 0  | 1  |   |
| 01       | 1        | 0  | 0  | 1  |   |
| 11       | 1        | 0  | 0  | 1  |   |
| 10       | 0        | 1  | 1  | 0  |   |

- b. (3 points) Based on the K-map to the right above, write a Boolean expression for  $s_0$  in **POS** form. Show corresponding loops on the K-map.

$$s_0 = \underline{\hspace{10cm}}$$

- c. (3 points) Implement the circuit to calculate  $s_0$  as a **two-level network** using only one type of gate. You can assume that inverted inputs are available.

**Problem 2, continued**

2. (5 points) Using two copies of the combinational circuit from Part 1 as building blocks and as few additional gates as possible, design a combinational circuit that subtracts two 2-bit 2's complement numbers,  $p_1p_0$  and  $q_1q_0$ . The circuit should output the difference bits  
 $d_1d_0 = p_1p_0 - q_1q_0$



a. (4 points) Fill in the K-map for  $c_2$  below.

| $c_2$ | $b_1b_0$ |    |    |    |
|-------|----------|----|----|----|
|       | 00       | 01 | 11 | 10 |
| 00    | 0        | 0  | 0  | 0  |
| 01    | 0        | 0  | 1  | 0  |
| 11    | 0        | 1  | 1  | 1  |
| 10    | 0        | 0  | 1  | 1  |

(-1) For each incorrect row  $a_1a_0 \rightarrow$

| $s_0$ | $b_1b_0$ |    |    |    |
|-------|----------|----|----|----|
|       | 00       | 01 | 11 | 10 |
| 00    | 0        | 1  | 1  | 0  |
| 01    | 1        | 0  | 0  | 1  |
| 11    | 1        | 0  | 0  | 1  |
| 10    | 0        | 1  | 1  | 0  |

| $s_0$ | $b_1b_0$ |    |    |    |
|-------|----------|----|----|----|
|       | 00       | 01 | 11 | 10 |
| 00    | 0        | 1  | 1  | 0  |
| 01    | 1        | 0  | 0  | 1  |
| 11    | 1        | 0  | 0  | 1  |
| 10    | 0        | 1  | 1  | 0  |

(+2) For expression      (+1) For k-map.

$$s_0 = \underline{(\bar{a}_0 + b_0)} \cdot \underline{(a_0 + b_0)}$$



NOR.

(+1) for NOR

(+1) for 2-level

(+1) for labels

xor Implementation  
is also correct.





(You should not need to write below this line.)

Rubric: (⊕2) For  $-(q_1, q_0)$

(⊕2) For  $(p_1, p_0) + (-q_1, q_0)$

(⊕1) For labels ( $d_1, d_0$ , etc)

NOTE:  $p_1, p_0$  and  $q_1', q_0'$   
could be switched  
but  $q_1, q_0$  has to go  
with  $\pm 1$

**Problem 3: FSM Design Problem (15 points)**

Your part-time employer Professor Zapper from Psychology asks you to design the logic for an experiment to study the memory of rats. The experimental setup is shown below. In each "cycle," the experimenter turns the alarm on or off. Your system receives a signal from the audio sensor A: when the alarm is on, A = 1. In the same "cycle" (long cycles), the rat responds by either depressing the lever L (in which case L = 1) or not depressing the lever (L = 0).

Professor Zapper wants the rats to follow a protocol. In the first and second cycles, the rat should not match the lever with the alarm. In other words, the rat should press the lever when the alarm is off, and not press the lever when the alarm is on. In the third cycle, the rat should match the alarm: press the lever when the alarm is on, and don't press the lever when the alarm is off.

If the rat succeeds in this endeavor, it should receive food (set F = 1 for a cycle). If it fails, it should immediately be zapped for a cycle (set Z = 1 for a cycle). After the penalty/reward cycle, start over.

**Designing the FSM:**

We can make one crucial observation to simplify the design. We can introduce a variable T such that when rat's action is in accordance with the alarm, T=1. This is the case when

| A | L | T |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 1 |

Thus,  $T = \text{NOT } (\text{A XOR L})$

1. (4 points) Based on this description, design a finite state machine to implement the desired experimental protocol. In particular, draw a complete state transition diagram labeled with input, internal state bits, and outputs. For your convenience, the partial state diagram is given to you. Complete the state diagram showing necessary transitions, inputs, and output. Hint: from every state, there will be two possible transitions.



A side effect of the above implementation is that when the experiment starts, the rat is zapped at first

1. **(6 points)** Find simple logical expressions (minimal SOP) for next-state variables as well as functions mapping your internal state values to the outputs F and Z.

Next State Table

| $S_1$ | $S_0$ | T | $S_1^+$ | $S_0^+$ | F | Z |
|-------|-------|---|---------|---------|---|---|
| 0     | 0     | 0 | 0       | 1       | 0 | 1 |
|       |       |   |         |         |   |   |
|       |       |   |         |         |   |   |
| 0     | 1     |   |         |         | 0 | 0 |
|       |       |   |         |         |   |   |
|       |       |   |         |         |   |   |
| 1     | 1     | 1 | 1       | 0       |   |   |

2. **(5 points)** Implement the FSM by drawing a logic schematic circuit diagram for your system.



(-1) For every  
incorrect  
transition/label

Next State Table

|   | $S_1$ | $S_0$ | T | $S_1^+$ | $S_0^+$ | F | Z |
|---|-------|-------|---|---------|---------|---|---|
| 0 | 0     | 0     | 0 | 0       | 1       | 0 | 1 |
| 1 | 0     | 0     | 1 | 0       | 0       | 0 | 1 |
| 2 | 0     | 1     | 0 | 1       | 1       | 0 | 0 |
| 3 | 0     | 1     | 1 | 0       | 0       | 0 | 0 |
| 4 | 1     | 0     | 0 | 0       | 1       | 1 | 0 |
| 5 | 1     | 0     | 1 | 0       | 0       | 1 | 0 |
| 6 | 1     | 1     | 0 | 0       | 0       | 0 | 0 |
| 7 | 1     | 1     | 1 | 1       | 0       | 0 | 0 |

$$F = S_1 \bar{S}_0$$

$$Z = \bar{S}_1 \bar{S}_0$$

|   | $S_1$ | $S_0 T$ | 00 | 01 | 11 | 10 |
|---|-------|---------|----|----|----|----|
| 0 | 0     |         |    |    |    |    |
| 1 | 1     |         |    |    |    |    |

$$S_1^+ = \bar{S}_1 S_0 \bar{T} + S_1 S_0 T$$

|   | $S_1$ | $S_0 T$ | 00 | 01 | 11 | 10 |
|---|-------|---------|----|----|----|----|
| 0 | 0     |         | 1  |    |    | 1  |
| 1 | 1     |         | 1  |    |    |    |

$$S_0^+ = \bar{S}_0 \bar{T} + \bar{S}_1 \bar{T}$$

Truth Table : (-0.5) every incorrect row

(-1) every incorrect  $S_1^+$ ,  $S_0^+$

(-0.75) every incorrect F, Z

\* Note:  $S_1^+$ ,  $S_0^+$ , F, Z should be based on student's table, which could be wrong / incorrect.



$$A \oplus L \rightarrow D \rightarrow T$$

$$T = \text{NOT} (A \oplus L)$$

Rubric:

(-1) For every incorrect implementation of  $S_1^+$ ,  $S_0^+$ ,  $F$ ,  $Z$ ,  $T$

**Problem 4 (15 points): LC-3 Interpretation and Assembly**

1. The program below consists of LC-3 instructions and data.

x3000 0010 0110 0000 1011 LD R3, #11

x3001 0101 1011 0110 0000 \_\_\_\_\_

x3002 0110 1100 1100 0000 \_\_\_\_\_

x3003 0000 0110 0000 0011 \_\_\_\_\_

x3004 1001 1001 1011 1111 \_\_\_\_\_

x3005 0001 1101 0010 0001 \_\_\_\_\_

x3006 0111 1100 1100 0000 \_\_\_\_\_

x3007 0001 0110 1110 0001 \_\_\_\_\_

x3008 0001 1011 0110 0001 ADD R5, R5, #1

x3009 0001 1101 0111 1000 \_\_\_\_\_

x300A 0000 1001 1111 0111 \_\_\_\_\_

x300B 1111 0000 0010 0101 \_\_\_\_\_

x300C 1111 0000 0000 0000 FILL .xF000

- a. **(9 points)** Decode the remaining instructions in the program above into LC-3 assembly language using the format shown in those already done for you. Note that all blanks correspond to instructions, not data.
- b. **(4 points)** In twenty words or less, explain what the program does.

**Problem 4, continued:**

2. (2 points) The following program has exactly one error. State the nature of the error, in which pass the assembler identifies the error (first or second), and suggest how the program can be corrected.

```
.ORIG x3000
LEA R0, STRING
FIND
    LDR R1, R0, #0
    BRn DONE
    ADD R0, R0, #1
    BRnzp FIND
STRING .BLKW x1000
EOS     .FILL xFFFF
DONE   HALT
.END
```

**Answer** (use no more than 20 words):

(-1) For every incorrect decoding  
\* Max (-9)

1. The program below consists of LC-3 instructions and data.

```

x3000 0010 0110 0000 1011 LD R3, #11
x3001 0101 1011 0110 0000 AND R5, R5, #10
x3002 0110 1100 1100 0000 LD R6, R3, #10
x3003 0000 0110 0000 0011 BRzp #3
x3004 1001 1001 1011 1111 NOT R4, R6
x3005 0001 1101 0010 0001 ADD R6, R4, #1
x3006 0111 1100 1100 0000 STR R6, R3, #10
x3007 0001 0110 1110 0001 ADD R3, R3, #1
x3008 0001 1011 0110 0001 ADD R5, R5, #1
x3009 0001 1101 0111 1000 ADD R5, R5, #-8
x300A 0000 1001 1111 0111 BRz #-9
x300B 1111 0000 0010 0101 HALT
x300C 1111 0000 0000 0000 FILL .xF000

```

- b. (4 points) In twenty words or less, explain what the program does.

Read an array of eight memory locations from xF000 ; invert the negative values and store them in their corresponding - location

**Problem 4, continued:**

2. (2 points) The following program has exactly one error. State the nature of the error, in which pass the assembler identifies the error (first or second), and suggest how the program can be corrected.

```

.ORIG x3000
LEA R0, STRING
FIND
    LDR R1, R0, #0
    BRn DONE
    ADD R0, R0, #1
    BRnzp FIND
STRING .BLKW x1000
EOS .FILL xFFFF
DONE HALT
.END

```

**Answer** (use no more than 20 words):

out of range eos08.

"If someone claims that this is the source of error", is also correct

→ PC offset  
out of range

The assembler identifies the error in the second pass

**Problem 5 (26 points)**

In this problem we introduce a new instruction to the LC3 instruction set, called ADDM: Add to Memory.

**ADDM DR, SR1, SR2**

ADDM adds the content of the source register **SR2** and the content of the memory location whose address is in register **SR1**, and puts the result in register **DR**. ADDM has opcode 1101 and the RTL is:

$$\text{DR} \leftarrow M[\text{SR1}] + \text{SR2}, \text{ set CC}$$

1. (4 points) Give the binary encoding of the instruction **ADDM R3, R4, R5** by filling in the missing bits.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
|    |    |    |    |    |    |   |   |   |   | 0 | 0 | 0 |   |   |   |

2. (2 points) Statement: "If we set the 5<sup>th</sup> bit to 1 (IR[5]=1) when encoding the ADDM instruction, it won't work as expected."

Is this statement True or False? Justify your choice with reference to SR2MUX.

True, because \_\_\_\_\_

False, because \_\_\_\_\_

3. (8 points) Give the sequence of 4 microinstructions that implement the ADDM instruction **after the decode state**. If needed, you may use R6 as a temporary register.

Answer: \_\_\_\_\_

\_\_\_\_\_

\_\_\_\_\_

\_\_\_\_\_

4. (8 points) Determine the control ROM microinstructions that implement the RTL statements from part (a). Complete the table below by filling in **0**, **1**, or **x** as appropriate. Specify ROM addresses in **decimal**. Note that your first state number is implied by the decode strategy used in the LC-3 microarchitecture. State numbers 51, 52, 53, and 54 are available as additional states for your use.

|                                                                                                                        |     |                          |                     |  |                                                                 |                                            |                                                                                   |               |
|------------------------------------------------------------------------------------------------------------------------|-----|--------------------------|---------------------|--|-----------------------------------------------------------------|--------------------------------------------|-----------------------------------------------------------------------------------|---------------|
| ROM address in decimal                                                                                                 | IRD | COND(3),<br>COND0 is LSB | J(6), J0 is the LSB |  | LD.BEN<br>LD.MAR<br>LD.MDR<br>LD.IR<br>LD.PC<br>LD.REG<br>LC.CC | GateMARMUX<br>GateMDR<br>GateALU<br>GatePC | MARMUX<br>PCMUX(2)<br>ADDR1MUX<br>ADDR2MUX(2)<br>DRMUX(2)<br>SR1MUX(2)<br>ALUK(2) | MIO.EN<br>R.W |
|                                                                                                                        |     |                          |                     |  |                                                                 |                                            |                                                                                   |               |
| Do not fill in datapath control word fields for these two microinstructions. But be sure to fill in the remaining two. |     |                          |                     |  |                                                                 |                                            |                                                                                   |               |

5. (4 points) Draw the state diagram for ADDM after the decode state with the arc labels as needed, the RTLs mentioned in the states, and include the state numbers in the boxes provided. State numbers 51, 52, 53 and 54 are available as additional states for your use. Hint: your answer should be consistent with the simplified Patt and Patel microsequencer circuit attached to this booklet.

Note:  $51_{10} = 110011_2, 52_{10} = 110100_2, 53_{10} = 110101_2, 54_{10} = 110110_2$



missing bits.

|    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| 1  | 1  | 0  | 1  | 0  | 1  | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 1 |

opcode  $\rightarrow +1$  $R_3 \rightarrow +1$  $R_4 \rightarrow +1$  $R_5 \rightarrow +1$ 

If the operands are <sup>10</sup> correct,  
but misplaced (-1)

Is this statement True or False? Justify your choice with reference to SR2MUX.

True, because SR[5] must be zero such that SR2 (i.e. R5) is selected by the SR2MUX

False, because \_\_\_\_\_

3. (8 points) Give the sequence of 4 microinstructions that implement the ADDM instruction after the decode state. If needed, you may use R6 as a temporary register.

Answer: MAR  $\leftarrow R[IR[8\text{-}6]]$  ; MAR  $\leftarrow R_4$

MDR  $\leftarrow M[MAR]$

$R_6 \leftarrow MDR$

$R[IR[11\text{-}9]] \leftarrow R_6 + R[IR[2\text{-}0]]$  ;  $R_3 \leftarrow R_6 + R_5$

| ROM address in decimal | IRD | COND(3), CONDO is LSB | J(6..10) is the LSB | LD.BEN | LD.MAR | LD.MDR | LD.IR | LD.PC | LD.REG | LC.CC | GateMARMUX | GateMDR | GateALU | GatePC | MARMUX | PCMUX(2) | ADDR1MUX | ADDR2MUX(2) | DRMUX(2) | SRIMUX(2) | ALUK(2) | MIO.EN | R.W |  |
|------------------------|-----|-----------------------|---------------------|--------|--------|--------|-------|-------|--------|-------|------------|---------|---------|--------|--------|----------|----------|-------------|----------|-----------|---------|--------|-----|--|
| 13                     | 0   | 000                   | 110100              | 0      | 1      | 0      | 0     | 0     | 0      | 0     | 0          | 1       | 0       | x      | xx     | x        | xx       | xx          | 0        | 1         | 1       | 0      | x   |  |
| 52                     | 0   | 001                   | 110100              | 0      | 0      | 1      | 0     | 0     | 0      | 0     | 0          | 0       | 0       | x      | xx     | x        | xx       | xx          | xx       | xx        | xx      | 1      | 0   |  |
| 54                     | 0   | 000                   | 110011              |        |        |        |       |       |        |       |            |         |         |        |        |          |          |             |          |           |         |        |     |  |
| 51                     | 0   | 000                   | 010010              |        |        |        |       |       |        |       |            |         |         |        |        |          |          |             |          |           |         |        |     |  |

110101 (also correct)

| ROM address in decimal | IRD | COND(3), CONDO is LSB | J(6..10) is the LSB | LD.BEN | LD.MAR | LD.MDR | LD.IR | LD.PC | LD.REG | LC.CC | GateMARMUX | GateMDR | GateALU | GatePC | MARMUX | PCMUX(2) | ADDR1MUX | ADDR2MUX(2) | DRMUX(2) | SRIMUX(2) | ALUK(2) | MIO.EN | R.W |  |
|------------------------|-----|-----------------------|---------------------|--------|--------|--------|-------|-------|--------|-------|------------|---------|---------|--------|--------|----------|----------|-------------|----------|-----------|---------|--------|-----|--|
| 13                     | 0   | 000                   | 110100              | 0      | 1      | 0      | 0     | 0     | 0      | 0     | 0          | 1       | 0       | x      | xx     | 1        | 0        | xx          | 0        | 1         | 1       | 0      | x   |  |
| 52                     | 0   | 001                   | 110100              | 0      | 1      | 0      | 0     | 0     | 0      | 0     | 0          | 0       | 0       | x      | xx     | x        | xx       | xx          | xx       | xx        | xx      | 1      | 0   |  |
| 54                     | 0   | 000                   | 110011              |        |        |        |       |       |        |       |            |         |         |        |        |          |          |             |          |           |         |        |     |  |
| 51                     | 0   | 000                   | 010010              |        |        |        |       |       |        |       |            |         |         |        |        |          |          |             |          |           |         |        |     |  |

Do not fill in datapath control word fields for these two microinstructions. But be sure to fill in the remaining two.

110101

(-1) For every incorrect group  
(i.e ROM address, IRD .. COND(3), J(6), and control signal groups)

Also correct



(-1) point  
for every  
incorrect  
state no.

**Problem 6 (8 points): LC-3 Assembly Programming**

Shown below is an incomplete LC-3 assembly program that computes the sum of the squares of a list of positive integers, stored in consecutive memory locations starting at address **x5000**. A zero or a negative number indicates the end of the list of integers. The result is saved to memory address **x6000**. **Write the missing lines of code.** You must **write only one instruction per missing line.** To receive credit, **you can only use registers R0, R1, R2, R3, R4, and no other register.**

| LINE | PROGRAM                                            |
|------|----------------------------------------------------|
| 1    | ; Store program in location x3000                  |
| 2    | _____                                              |
| 3    | ; R0 stores the address of the list, 0x5000        |
| 4    | LD R0, NUM_LIST                                    |
| 5    | ; Initialize the sum in R1 to zero                 |
| 6    | _____                                              |
| 7    | SUM_LOOP ; Load current number from the list to R2 |
| 8    | _____                                              |
| 9    | ; Exit if the number is negative or zero           |
| 10   | BR _____ END_LOOP                                  |
| 11   | ; Clear R3 to store the square result              |
| 12   | AND R3, R3, #0                                     |
| 13   | ; Copy the current number to R4                    |
| 14   | ADD R4, R2, #0                                     |
| 15   | MULT_LOOP ; The loop calculates the square of R4   |
| 16   | _____                                              |
| 17   | ADD R2, R2, #-1                                    |
| 18   | ; Repeat inner loop to calculate the square        |
| 19   | BR _____                                           |
| 20   | ; Add the calculated square R3 to the sum          |
| 21   | ADD R1, R1, R3                                     |
| 22   | ; Move to the next number in the list              |
| 23   | ADD R0, R0, #1                                     |
| 24   | BR SUM_LOOP                                        |
| 25   | END_LOOP ; Store the sum at x6000                  |
| 26   | _____                                              |
| 27   | HALT                                               |
| 28   | ; Memory address of the number list                |
| 29   | NUM_LIST _____                                     |
| 30   | ; Memory address to store the result               |
| 31   | RESULT .FILL x6000                                 |

|  |      |
|--|------|
|  | .END |
|--|------|

(-1) For every incorrect instruction

| LINE | PROGRAM                                             |
|------|-----------------------------------------------------|
| 1    | ; Store program in location x3000                   |
| 2    | .ORIG x3000                                         |
| 3    | ; R0 stores the address of the list, 0x5000         |
| 4    | LD R0, NUM_LIST                                     |
| 5    | ; Initialize the sum in R1 to zero                  |
| 6    | AND R1, R1, #0                                      |
| 7    | SUM_LOOP  ; Load current number from the list to R2 |
| 8    | LDR R2, R0, #0                                      |
| 9    | ; Exit if the number is negative or zero            |
| 10   | BRnz END_LOOP                                       |
| 11   | ; Clear R3 to store the square result               |
| 12   | AND R3, R3, #0                                      |
| 13   | ; Copy the current number to R4                     |
| 14   | ADD R4, R2, #0                                      |
| 15   | MULT_LOOP ; The loop calculates the square of R4    |
| 16   | ADD R3, R3, R4                                      |
| 17   | ADD R2, R2, #-1                                     |
| 18   | ; Repeat inner loop to calculate the square         |
| 19   | BRp MULT_LOOP                                       |
| 20   | ; Add the calculated square to the sum              |
| 21   | ADD R1, R1, R3                                      |
| 22   | ; Move to the next number in the list               |
| 23   | ADD R0, R0, #1                                      |
| 24   | BR SUM_LOOP                                         |
| 25   | END_LOOP ; Store the sum at x6000                   |
| 26   | STI R1, RESULT                                      |
| 27   | HALT                                                |
| 28   | ; Memory address of the number list                 |
| 29   | NUM_LIST .FILL x5000                                |
| 30   | ; Memory address to store the result                |
| 31   | RESULT .FILL x6000                                  |
|      | .END                                                |

**Problem 7 (11 points): LC-3 Assembly Analysis**

You are given the following program written in LC-3 assembly language.

```

.ORIG x3000
    LEA    R1, INPUT
    LEA    R2, MASK
    LDR    R3, R2, #0
    NOT    R2, R2
    ADD    R2, R2, #1
    AND    R4, R4, #0
    LDR    R0, R1, #0
    AND    R5, R5, #0
    ADD    R5, R5, #15
    AND    R6, R0, R3
    BRz   SKIP_ADD
    ADD    R4, R4, #1
    ADD    R0, R0, R0
    ADD    R5, R5, #-1
    BRzp  INNER_LOOP
    ADD    R1, R1, #1
    ADD    R6, R1, R2
    BRn   OUTER_LOOP
ST      R4, RESULT
        HALT
INPUT   .FILL x1248
        .FILL x2814
        .FILL x4821
MASK    .FILL x8000
RESULT  .BLKW #1
        .END

```

- (5 points)** For each label in the table below, fill in its memory address and the number of times the LC-3 reads from that memory address during the execution of the entire program. **Count only memory reads, not writes.**

| Label      | Memory Address<br>(4-digit hexadecimal value) | Number of Memory Reads<br>(decimal number) |
|------------|-----------------------------------------------|--------------------------------------------|
| OUTER_LOOP |                                               |                                            |
| INNER_LOOP |                                               |                                            |
| SKIP_ADD   |                                               |                                            |
| INPUT      |                                               |                                            |
| MASK       |                                               |                                            |

- (6 points)** Write the **4-digit hexadecimal values** held in the following registers/memory when the program halts. Assume that HALT does not modify any registers.

R1 = \_\_\_\_\_ R2 = \_\_\_\_\_ R4 = \_\_\_\_\_

**(5 points)** For each label in the table below, fill in its memory address and the number of times the LC-3 reads from that memory address during the execution of the entire program. **Count only memory reads, not writes.**

| Label      | Memory Address<br>(4-digit hexadecimal value) | Number of Memory Reads<br>(decimal number) |
|------------|-----------------------------------------------|--------------------------------------------|
| OUTER_LOOP | x3006                                         | 3                                          |
| INNER_LOOP | x3009                                         | 48                                         |
| SKIP_ADD   | x300c                                         | 48                                         |
| INPUT      | x3014                                         | 1                                          |
| MASK       | x3017                                         | 1                                          |

(-0.5) For every incorrect memory address

(-0.5) For every incorrect no. of memory read.

M[x300C] = \_\_\_\_\_ M[x300E] = \_\_\_\_\_ M[x3018] = \_\_\_\_\_

**(6 points)** Write the **4-digit hexadecimal values** held in the following registers/memory when the program halts. Assume that HALT does not modify any registers.

R1 = x3017 R2 = xCFE9 R4 = x000CM[x300C] = x1000 M[x300E] = x07FA M[x3018] = x000C

(-1) For every incorrect answer