

**ECE 120 Third Midterm Exam  
Fall 2017**

Tuesday, November 28, 2017

Name:

**SOLUTIONS**

NetID:

Discussion Section and TA name:

|          |                  |                  |
|----------|------------------|------------------|
| 11:00 AM | [ ] AD1 Ruby     | [ ] AD8 Matt     |
| 12:00 PM | [ ] AD2 David    | [ ] AD9 Matt     |
| 1:00 PM  | [ ] AD3 David    | [ ] ADA Yu-Hsuan |
| 2:00 PM  | [ ] AD4 WanZheng | [ ] ADB ZhaoHeng |
| 3:00 PM  | [ ] AD5 WanZheng |                  |
| 4:00 PM  | [ ] AD6 Spencer  | [ ] ADC Ruby     |
| 5:00 PM  | [ ] AD7 Spencer  | [ ] ADD ZhaoHeng |

- Be sure that your exam booklet has 9 pages.
- Write your name, netid and check discussion section on the title page.
- Do not tear the exam booklet apart, except for the last two pages.
- Use backs of pages for scratch work if needed.
- This is a closed book exam. You may not use a calculator.
- You are allowed one handwritten 8.5 x 11" sheet of notes (both sides).
- Absolutely no interaction between students is allowed.
- Clearly indicate any assumptions that you make.
- The questions are not weighted equally. Budget your time accordingly.
- Show your work.

Problem 1    19 points \_\_\_\_\_

Problem 2    12 points \_\_\_\_\_

Problem 3    23 points \_\_\_\_\_

Problem 4    24 points \_\_\_\_\_

Problem 5    22 points \_\_\_\_\_

---

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

### Problem 1 (19 points): FSM Design

In this problem you will implement an FSM that recognizes a **01** sequence. The circuit has one input  $x$ , one output  $z$ , and the output is 1 if and only if the pattern **01** has been detected in the input stream.

Example:

*Input:  $x = 0 \ 0 \ 1 \ 1 \ 1 \ 0 \ 1 \ 0 \ 1 \ 1 \ 1 \ 0 \ 1 \ 1 \ 0 \ 1 \dots$*

*Output:  $z = 0 \ 0 \ 1 \ 0 \ 0 \ 0 \ 1 \ 0 \ 1 \ 0 \ 0 \ 0 \ 0 \ 1 \ 0 \ 0 \ 1 \dots$*

Note that the output sequence is delayed by 1 clock cycle compared to the input sequence because the output is a function of the flip-flop outputs.

1. (14 points) Draw the **Moore** state diagram and label the outputs and inputs. Give the meaning of each state. To get full credit, use the minimum number of states.



| State      | Meaning                |
|------------|------------------------|
| "Start" 00 | Pattern not yet seen   |
| 01         | 0 of pattern seen      |
| 10         | 01 <del>not</del> seen |
| 11         | Not used.              |



2. (5 points) Shown below is a 4-bit **shift register**, constructed with 4 positive-edge-triggered D flip-flops. Use this shift register and **only one gate** (NOT, AND, OR, NAND, NOR, XOR, or XNOR) to implement a circuit, which recognizes **01** just like the example at the top of the page. Be sure to label input  $x$  and output  $z$ .



**Problem 2 (XX points): FSM Analysis**

1. (4 points) Write the next state equation for  $S_1^+$  from the FSM circuit given below.

$$S_1^+ = \underline{S_1 S_0 + S_0' M}$$



2. (8 points) Complete the state transition diagram (shown below) so that it corresponds to the FSM circuit above.



### Problem 3 (23 points): Serialized Design

The circuit below will be a serialized n-bit 2's complement adder/subtractor circuit. The inputs  $a_{n-1}a_{n-2}\dots a_1a_0$  and  $b_{n-1}b_{n-2}\dots b_1b_0$  are fed in serially (from LSB to MSB) and the output  $s_{n-1}s_{n-2}\dots s_1s_0$  comes out serially (also from LSB to MSB). The control bit  $K$  determines whether addition or subtraction happens. Also available is a signal  $F$  that is 1 when  $a_0$  and  $b_0$  are input, and 0 otherwise. ( $F$  is not shown in the diagram, but you can use it.)

The output  $V$  will indicate that overflow has occurred, and is usually calculated as the XOR of the carry-in and the carry-out of the  $(a_{n-1}, b_{n-1})$  calculation in the Full Adder. However, in this serialized design  $V$  must depend only on the current state of the FSM.



1. (12 points) Complete the circuit above by writing the missing signals in the 5 boxes using 0, 1, F or any other signal labeled in the diagram. Complemented signals are not available, unless they are already shown in the diagram. You may not use additional wires or gates. Remember, the output  $V$  must depend only on the current state of the FSM.
2. (4 points) When does  $V$  indicate whether overflow has occurred compared to when  $s_{n-1}$  comes out of its flip-flop? Circle the correct answer.

2 cycles earlier    1 cycle earlier    same cycle    1 cycle later    2 cycles later

3. (7 points) Setting  $n=10$ , calculate the costs of the following circuits using the component prices shown on the right.

Cost of the **serialized** 10-bit 2's complement adder/subtractor circuit with overflow detection (shown above):

81 cents

Cost of the corresponding **bit-sliced** 10-bit 2's complement adder/subtractor circuit with overflow detection:

104 cents

| Component    | Price (cents) |
|--------------|---------------|
| NOT          | 1             |
| 2-input NAND | 2             |
| 2-input XOR  | 4             |
| Full adder   | 6             |
| Flip-flop    | 20            |

### Problem 4 (24 points): Memory

The ECE 120 instructors invited Doctor Strange to assist with the exam, and he obliged with the memory design presented below. Unfortunately for students, the instructors realized too late that he did not learn ECE 120 in this dimension, but in some other alternate dimension.

Doctor Strange designed a **24x4 RAM**. His design, even though it works fine, is a bit... *strange!*



(The questions you need to answer are on the next page.)

**Problem 4 (24 points): Memory (continued)**

1. (12 points) A student attempts to write (CS=1 and R/W'=0) into the 24x4 RAM with data  $D_3D_2D_1D_0 = 1011$  at address  $A_4A_3A_2A_1A_0 = 01110$ . Indicate in the table below which of the 8x2 RAMs are accessed by circling YES or NO for each RAM. If an 8x2 RAM is accessed, also write down the 2-bit Data-In and the 3-bit address ADDR[2:0] for that 8x2 RAM.

|                                                                                 |                                                                                 |
|---------------------------------------------------------------------------------|---------------------------------------------------------------------------------|
| RAM #1<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____           | RAM #2<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____           |
| RAM #3<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____           | RAM #4<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____           |
| RAM #5<br>Accessed? <b>YES</b> / NO<br>Data-In= <b>10</b> ADDR[2:0]= <b>011</b> | RAM #6<br>Accessed? <b>YES</b> / NO<br>Data-In= <b>11</b> ADDR[2:0]= <b>011</b> |

2. (12 points) Another student now attempts to write (CS=1 and R/W'=0) into the 24x4 RAM with data  $D_3D_2D_1D_0 = 0100$  at address  $A_4A_3A_2A_1A_0 = 01011$ . Indicate in the table below which of the 8x2 RAMs are accessed by circling YES or NO for each RAM. If an 8x2 RAM is accessed, also write down the 2-bit Data-In and the 3-bit address ADDR[2:0] for that 8x2 RAM.

|                                                                       |                                                                       |
|-----------------------------------------------------------------------|-----------------------------------------------------------------------|
| RAM #1<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ | RAM #2<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ |
| RAM #3<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ | RAM #4<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ |
| RAM #5<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ | RAM #6<br>Accessed? YES / <b>NO</b><br>Data-In= ____ ADDR[2:0]= _____ |

### Problem 5 (22 points): LC-3 Interpretation and Assembly

The registers of an LC-3 processor currently have the values shown in the table to the right.

|           |         |           |       |            |       |
|-----------|---------|-----------|-------|------------|-------|
| <b>R0</b> | x8888   | <b>R4</b> | xCCCC | <b>PC</b>  | x3710 |
| <b>R1</b> | x9999   | <b>R5</b> | xDDDD | <b>IR</b>  | x993F |
| <b>R2</b> | xA AAAA | <b>R6</b> | xEEEE | <b>MAR</b> | x370F |
| <b>R3</b> | xB BBBB | <b>R7</b> | xFFFF | <b>MDR</b> | x993F |

The table to the right shows some of the contents of the LC-3 processor's memory.

When the bits represent instructions, an interpretation has been provided for you in RTL.

Here is the question:

| Address      | Contents             | RTL Interpretation             |
|--------------|----------------------|--------------------------------|
| <b>x370F</b> | 1001 100 100 111111  | R4 $\leftarrow$ NOT(R4)        |
| <b>x3710</b> | 0101 101 000 000 001 | R5 $\leftarrow$ AND(R0, R1)    |
| <b>x3711</b> | 0000 100 000000001   | BRn #1                         |
| <b>x3712</b> | 0001 110 010 1 00001 | R6 $\leftarrow$ R2+#1          |
| <b>x3713</b> | 1010 111 0 1000 0001 | R7 $\leftarrow$ M[M[PC+x0081]] |
| ...          |                      | ...                            |
| <b>x3793</b> | 0011 0111 1001 0100  | (data: x3794)                  |
| <b>x3794</b> | 0011 0111 1001 0110  | (data: x3796)                  |
| <b>x3795</b> | 0011 0111 1001 0011  | (data: x3793)                  |
| <b>x3796</b> | 0011 0111 1001 0101  | (data: x3795)                  |

The LC-3 FSM PROCESSES THREE INSTRUCTIONS, starting with the fetch phase.

1. (7 points) Write a complete list of the sequence of values taken by the MAR register as the LC-3 processes these instructions. Use only as many lines as are necessary.

#1: x370F (initial value)

#5: x3795

#2: x3710

#6: x3793

#3: x3711

#7: \_\_\_\_\_

#4: x3713

#8: \_\_\_\_\_

2. (15 points) Complete the tables below with the FINAL values of each register and memory location (after processing the three instructions). To receive credit, you must write your answers in hexadecimal.

|           |       |
|-----------|-------|
| <b>R4</b> | xCCCC |
| <b>R5</b> | x8888 |
| <b>R6</b> | xEEEE |
| <b>R7</b> | x3794 |

|            |       |
|------------|-------|
| <b>PC</b>  | x3714 |
| <b>IR</b>  | xAE81 |
| <b>MDR</b> | x3794 |

## LC-3 Instructions

|      |                                                                                                              |           |            |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|------|--------------------------------------------------------------------------------------------------------------|-----------|------------|---------------------------------------------------|------------|------|-----------|-------------------|-----|-------------------------------------------------------------------------------------------|------|----|-------|-----------|------------------------|
| ADD  | <table border="1"><tr><td>0001</td><td>DR</td><td>SR1</td><td>0</td><td>00</td><td>SR2</td></tr></table>     | 0001      | DR         | SR1                                               | 0          | 00   | SR2       | ADD DR, SR1, SR2  | LD  | <table border="1"><tr><td>0010</td><td>DR</td><td></td><td>PCoffset9</td></tr></table>    | 0010 | DR |       | PCoffset9 | LD DR, PCoffset9       |
| 0001 | DR                                                                                                           | SR1       | 0          | 00                                                | SR2        |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 0010 | DR                                                                                                           |           | PCoffset9  |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | DR $\leftarrow$ SR1 + SR2, Setcc                                                                             |           |            | DR $\leftarrow$ M[PC + SEXT(PCoffset9)], Setcc    |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| ADD  | <table border="1"><tr><td>0001</td><td>DR</td><td>SR1</td><td>1</td><td>imm5</td><td></td></tr></table>      | 0001      | DR         | SR1                                               | 1          | imm5 |           | ADD DR, SR1, imm5 | LDI | <table border="1"><tr><td>1010</td><td>DR</td><td></td><td>PCoffset9</td></tr></table>    | 1010 | DR |       | PCoffset9 | LDI DR, PCoffset9      |
| 0001 | DR                                                                                                           | SR1       | 1          | imm5                                              |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 1010 | DR                                                                                                           |           | PCoffset9  |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | DR $\leftarrow$ SR1 + SEXT(imm5), Setcc                                                                      |           |            | DR $\leftarrow$ M[M[PC + SEXT(PCoffset9)]], Setcc |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| AND  | <table border="1"><tr><td>0101</td><td>DR</td><td>SR1</td><td>0</td><td>00</td><td>SR2</td></tr></table>     | 0101      | DR         | SR1                                               | 0          | 00   | SR2       | AND DR, SR1, SR2  | LDR | <table border="1"><tr><td>0110</td><td>DR</td><td>BaseR</td><td>offset6</td></tr></table> | 0110 | DR | BaseR | offset6   | LDR DR, BaseR, offset6 |
| 0101 | DR                                                                                                           | SR1       | 0          | 00                                                | SR2        |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 0110 | DR                                                                                                           | BaseR     | offset6    |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | DR $\leftarrow$ SR1 AND SR2, Setcc                                                                           |           |            | DR $\leftarrow$ M[BaseR + SEXT(offset6)], Setcc   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| AND  | <table border="1"><tr><td>0101</td><td>DR</td><td>SR1</td><td>1</td><td>imm5</td><td></td></tr></table>      | 0101      | DR         | SR1                                               | 1          | imm5 |           | AND DR, SR1, imm5 | LEA | <table border="1"><tr><td>1110</td><td>DR</td><td></td><td>PCoffset9</td></tr></table>    | 1110 | DR |       | PCoffset9 | LEA DR, PCoffset9      |
| 0101 | DR                                                                                                           | SR1       | 1          | imm5                                              |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 1110 | DR                                                                                                           |           | PCoffset9  |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | DR $\leftarrow$ SR1 AND SEXT(imm5), Setcc                                                                    |           |            | DR $\leftarrow$ PC + SEXT(PCoffset9), Setcc       |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| BR   | <table border="1"><tr><td>0000</td><td>n</td><td>z</td><td>p</td><td></td><td>PCoffset9</td></tr></table>    | 0000      | n          | z                                                 | p          |      | PCoffset9 | BR{nzp} PCoffset9 | NOT | <table border="1"><tr><td>1001</td><td>DR</td><td>SR</td><td>111111</td></tr></table>     | 1001 | DR | SR    | 111111    | NOT DR, SR             |
| 0000 | n                                                                                                            | z         | p          |                                                   | PCoffset9  |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 1001 | DR                                                                                                           | SR        | 111111     |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | ((n AND N) OR (z AND Z) OR (p AND P)):<br>PC $\leftarrow$ PC + SEXT(PCoffset9)                               |           |            | DR $\leftarrow$ NOT SR, Setcc                     |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| JMP  | <table border="1"><tr><td>1100</td><td>000</td><td>BaseR</td><td>0000000</td><td></td><td></td></tr></table> | 1100      | 000        | BaseR                                             | 0000000    |      |           | JMP BaseR         | ST  | <table border="1"><tr><td>0011</td><td>SR</td><td></td><td>PCoffset9</td></tr></table>    | 0011 | SR |       | PCoffset9 | ST SR, PCoffset9       |
| 1100 | 000                                                                                                          | BaseR     | 0000000    |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 0011 | SR                                                                                                           |           | PCoffset9  |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | PC $\leftarrow$ BaseR                                                                                        |           |            | M[PC + SEXT(PCoffset9)] $\leftarrow$ SR           |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| JSR  | <table border="1"><tr><td>0100</td><td>1</td><td></td><td>PCoffset11</td><td></td><td></td></tr></table>     | 0100      | 1          |                                                   | PCoffset11 |      |           | JSR PCoffset11    | STI | <table border="1"><tr><td>1011</td><td>SR</td><td></td><td>PCoffset9</td></tr></table>    | 1011 | SR |       | PCoffset9 | STI SR, PCoffset9      |
| 0100 | 1                                                                                                            |           | PCoffset11 |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 1011 | SR                                                                                                           |           | PCoffset9  |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | R7 $\leftarrow$ PC, PC $\leftarrow$ PC + SEXT(PCoffset11)                                                    |           |            | M[M[PC + SEXT(PCoffset9)]] $\leftarrow$ SR        |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| TRAP | <table border="1"><tr><td>1111</td><td>0000</td><td>trapvect8</td><td></td><td></td><td></td></tr></table>   | 1111      | 0000       | trapvect8                                         |            |      |           | TRAP trapvect8    | STR | <table border="1"><tr><td>0111</td><td>SR</td><td>BaseR</td><td>offset6</td></tr></table> | 0111 | SR | BaseR | offset6   | STR SR, BaseR, offset6 |
| 1111 | 0000                                                                                                         | trapvect8 |            |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
| 0111 | SR                                                                                                           | BaseR     | offset6    |                                                   |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |
|      | R7 $\leftarrow$ PC, PC $\leftarrow$ M[ZEXT(trapvect8)]                                                       |           |            | M[BaseR + SEXT(offset6)] $\leftarrow$ SR          |            |      |           |                   |     |                                                                                           |      |    |       |           |                        |



| Signal   | Description                                                                                                                                                                   | Signal                                               | Description                                                                                                                                                      |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| LD.MAR   | = 1, MAR is loaded                                                                                                                                                            | LD.CC = 1, updates status bits from system bus       |                                                                                                                                                                  |  |
| LD.MDR   | = 1, MDR is loaded                                                                                                                                                            | GateMARMUX = 1, MARMUX output is put onto system bus |                                                                                                                                                                  |  |
| LD.IR    | = 1, IR is loaded                                                                                                                                                             | GateMDR = 1, MDR contents are put onto system bus    |                                                                                                                                                                  |  |
| LD.PC    | = 1, PC is loaded                                                                                                                                                             | GateALU = 1, ALU output is put onto system bus       |                                                                                                                                                                  |  |
| LD.REG   | = 1, register file is loaded                                                                                                                                                  | GatePC = 1, PC contents are put onto system bus      |                                                                                                                                                                  |  |
| LD.BEN   | = 1, updates Branch Enable (BEN) bit                                                                                                                                          |                                                      |                                                                                                                                                                  |  |
| MARMUX   | $\begin{cases} = 0, \text{ chooses ZEXT IR[7:0]} \\ = 1, \text{ chooses address adder output} \end{cases}$                                                                    | MIO.EN                                               | $\begin{cases} = 1, \text{ Enables memory, chooses memory output for MDR input} \\ = 0, \text{ Disables memory, chooses system bus for MDR input} \end{cases}$   |  |
| ADDR1MUX | $\begin{cases} = 0, \text{ chooses PC} \\ = 1, \text{ chooses reg file SR1 OUT} \end{cases}$                                                                                  | R.W                                                  | $\begin{cases} = 1, M[\text{MAR}] \leftarrow \text{MDR} \text{ when MIO.EN} = 1 \\ = 0, \text{MDR} \leftarrow M[\text{MAR}] \text{ when MIO.EN} = 1 \end{cases}$ |  |
| ADDR2MUX | $\begin{cases} = 00, \text{ chooses "0...00"} \\ = 01, \text{ chooses SEXT IR[5:0]} \\ = 10, \text{ chooses SEXT IR[8:0]} \\ = 11, \text{ chooses SEXT IR[10:0]} \end{cases}$ | ALUK                                                 | $\begin{cases} = 00, \text{ADD} \\ = 01, \text{AND} \\ = 10, \text{NOT A} \\ = 11, \text{PASS A} \end{cases}$                                                    |  |
| PCMUX    | $\begin{cases} = 00, \text{ chooses PC + 1} \\ = 01, \text{ chooses system bus} \\ = 10, \text{ chooses address adder output} \end{cases}$                                    | DRMUX                                                | $\begin{cases} = 00, \text{ chooses IR[11:9]} \\ = 01, \text{ chooses "111"} \\ = 10, \text{ chooses "110"} \end{cases}$                                         |  |
| SR1MUX   | $\begin{cases} = 00, \text{ chooses IR[11:9]} \\ = 01, \text{ chooses IR[8:6]} \\ = 10, \text{ chooses "110"} \end{cases}$                                                    |                                                      |                                                                                                                                                                  |  |

