Department of Electrical and Computer Engineering The University of Texas at Austin

EE 306, Fall 2015

Yale Patt, Instructor

Stephen Pruett, Siavash Zangeneh, Kamyar Mirzazad, Esha Choukse, Ali Fakhrzadegan, Zheng Zhao, Steven Flolid, Nico Garofano, Sabee Grewal, William Hoenig, Adeesh Jain, Matthew Normyle Exam 2, November 11, 2015

Name: Solution

Problem 1 (20 points):

Problem 2 (15 points):

Problem 3 (15 points):\_\_\_\_\_

Problem 4 (25 points):\_\_\_\_

Problem 5 (25 points):\_\_\_\_\_

Total (100 points):

Note: Please be sure that your answers to all questions (and all supporting work that is required) are contained in the space provided.

Note: Please be sure your name is recorded on each sheet of the exam.

I will not cheat on this exam.

Signature

**GOOD LUCK!** 

Problem 1. (20 points):

Part a. (5 points): Part of the state of the computer is as follows:

| R3: x3000 | Mem[x4000]: x1234 |
|-----------|-------------------|
| R4: x4000 | Mem[x4001]: x2345 |
| R5: x5000 | Mem[x4002]: x3456 |
|           | Mem[x4003]: x4567 |

Then, LDR R5, R4, #2 is executed.

After this instruction is executed, R5 contains  $\times 3456$ 

Solution

**Part b.** (5 points): The program below adds the absolute value of the integer in A to the absolute value of the integer in B, and stores the sum in C. We decide to use the subroutine ABS to take as input the contents of R0, and return its absolute value in R0.



Why will the above program not work correctly? Please answer in 20 words or fewer.

The subroutine modifies R4 without saving/restoring it R4 is used by the callee.

Solution Name:

Part c. (5 points): The following program is assembled, loaded into LC-3 memory, and executed.

.ORIG \*3000 LD RO, A  $RO \leftarrow xF000$ LD RI, B  $RI \leftarrow x0025$ ADD RO, RI, RO  $RO \leftarrow xF025$ ADD RO, RI, RO  $RO \leftarrow xF025$   $RO \leftarrow xF02$ .STRINGZ "%" .FILL xF000 x25 Α В END

Does the program halt? If yes, explain what causes the program to halt. If no, explain why the program doesn't halt. Please answer in 20 words or fewer.

Halt instruction xF025 gets stored at label B which is executed since characters in A are "not taken" branches.

Part d. (5 points): Create the Symbol Table for this piece of code that an Aggie wrote one night when he was drunk.

string length = 12+1 = 13

.ORIG x4000 LEA R1, X R2, R1, R1 AGAIN ADD ST R2, X ADD R2, R1, R1 ST R2, Y BRz AGAIN HALT PROMPT .STRINGZ "EE306 ROCKS!" X .BLKW 10 Y .BLKW 1 Z .FILL XAE00

. END

| Symbol | Address |
|--------|---------|
| AGAIN  | x4001   |
| PROMPT | x4007   |
| ×      | ×4014   |
| У      | ×401E   |
| Z      | ×401F   |

**Problem 2.** (15 points): We want to add a new instruction to the LC-3, using the unused opcode 1101. It will have the following format:



To implement this instruction we add four new states, shown below.

Solution



We show in each state the control signals that are needed to implement the processing for that clock cycle. All control signals not shown in a state are assumed to be 0.

Note that from state 61, we branch either to state 18 or state 22.

What does this new instruction do? Be concise, but complete in your answer.

It branches to the instruction at PC (meremented) + & 9-bit afford if the content of the memory location pointed by the base register is zero.

Solution

**Problem 3.** (15 points): We want to support 8 input keyboards instead of 1. To do this we need 8 ready bits in KBSR, and 8 separate KBDRs. We will use the 8 odd-numbered bits in the KBSR as ready bits for the 8 keyboards, as shown below. We will set the other 8 bits in the KBSR to 0.



The 8 memory-mapped keyboard data registers and their corresponding ready bits are as follows:

| FE04: | KBSR   |                       |
|-------|--------|-----------------------|
| FE06: | KBDR1, | Ready bit is KBSR[1]  |
| FE08: | KBDR2, | Ready bit is KBSR[3]  |
| FE0A: | KBDR3, | Ready bit is KBSR[5]  |
| FE0C: | KBDR4, | Ready bit is KBSR[7]  |
| FE0E: | KBDR5, | Ready bit is KBSR[9]  |
| FE10: | KBDR6, | Ready bit is KBSR[11] |
| FE12: | KBDR7, | Ready bit is KBSR[13] |
| FE14: | KBDR8. | Ready bit is KBSR[15] |

We wish to write a program that polls the keyboards and loads the ASCII code typed by the highest priority keyboard into R0. That is, if someone had previously typed a key on keyboard 1, we want to load the ASCII code in KBDR1 into R0. If no key was typed on keyboard 1, but a key had been typed on keyboard 2, we want to load the ASCII code in KBDR2 into R0. ...and so on. That is, KB1 has higher priority than KB2, which has higher priority than KB3, which has higher priority than KB4, etc. KB8 has the lowest priority.

The following program will do the job AFTER you fill in the missing instructions:



Your job: fill in the missing instructions.

Problem 4. (25 points):

You are given a linked list, consisting of at most 20 elements, as shown below.



Note the listhead is at location x4000.

Solution

We want to reverse the nodes of the linked list. For the above linked list, the result would be:



The program on the following page (with missing instructions filled in) does the job, using subroutines PUSH and POP. Your job: fill in the missing instructions.

Solution

Solution Name:

Problem 5. (25 points): Consider the following program:



The program uses only R0 and R1. Note the boxes to indicate two missing instructions. Note also that one of the instructions in the program must be labeled AGAIN and that label is missing.

After execution of the program, the contents of A is x1800.

## **PROBLEM IS CONTINUED ON THE NEXT PAGE!!!**

During execution, we examined the computer during each clock cycle, and recorded some information for certain clock cycles, producing the table shown below. The table is ordered by the cycle number in which the information was collected. -Note that each memory access takes 5 clock cycles.

| number of cucles to                 | Note that eac                           | ch memory a                                   | iccess takes                        | BR opco                                              | de => must                                                      | orresp                                    | oond to                     | BRZ                    | instruction  |
|-------------------------------------|-----------------------------------------|-----------------------------------------------|-------------------------------------|------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------|-----------------------------|------------------------|--------------|
| execute<br>two IDE                  | Cycle<br>Number                         | State<br>Number                               | er Control Signals                  |                                                      |                                                                 |                                           |                             |                        |              |
| 1                                   | 1                                       | 18                                            | LD.MAR<br>LD.PC:                    | : 1                                                  | LD.REG:                                                         | Q<br>PC+I                                 | GateMDR:<br>GatePC:         |                        |              |
| 30+9=39                             | 39                                      | 0                                             | LD.MAR<br>LD.PC:                    | : 0<br>0                                             | LD.REG:                                                         | Q<br>0                                    | BEN                         | Q                      |              |
| $= 2 \times 9$ Each blank           | 48                                      | 1                                             | LD.REG:<br>GateALU                  |                                                      | DR:                                                             | 000<br>X: O                               | GateMDR                     | Q                      |              |
| instruction<br>takes q<br>Cycles to | 57                                      |                                               | LD.MAR<br>LD.REG:                   | : 0                                                  | ALUK:                                                           | ADD<br>001                                | GateALU:<br>GatePC:         | 0                      |              |
| execude                             | 577                                     | 22                                            | ADDR1N<br>LD.PC:                    | IUX: PC                                              | ADDR2                                                           | MUX: PC                                   | <del>Aset q</del><br>PCMUX: | Apr                    | DER          |
| ADDopard                            | 101<br>¢                                | 15                                            |                                     |                                                      |                                                                 | - P. 1                                    |                             |                        |              |
| ~                                   | Part a: Fill<br>AGAIN. Als              | lonle inst<br>in the missi<br>so, fill in the | ng instruction<br>missing info      | must be<br>ons in the program<br>ormation in the tab | ADD, and complete the pole.                                     | ISFanck<br>program by Ial                 | beling the app              | propriate in           | struction    |
|                                     | Part b: Give                            | en values for<br>FSG                          | r A and B, w<br>FFs F               | A, $B$ +                                             | ram do?<br>me s                                                 |                                           |                             |                        |              |
| J Ex<br>Sin<br>Co<br>ar             | nce ano<br>nce ano<br>nrrespo<br>re set | of "<br>ther but<br>nd to<br>by th            | BRnzy<br>ranch in<br>BRz<br>he seco | p AGAIN"<br>s taken at<br>: DONE".<br>ind blank      | Starts at<br>starts at<br>cycle 77<br>The condit<br>instruction | te<br>58 and<br>, label<br>ion code<br>n. | ends<br>AGAIN<br>s for th   | at C<br>mus<br>ese bro | ycle 67<br>f |
|                                     |                                         |                                               |                                     |                                                      |                                                                 |                                           |                             |                        |              |