## 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:

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

**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.

|      | .ORIG x3000    |
|------|----------------|
|      | LD RO, A       |
|      | JSR ABS        |
|      | ADD R4, R0, #0 |
|      | LD R0, B       |
|      | JSR ABS        |
|      | ADD R0, R4, R0 |
|      | ST R0, C       |
|      | HALT           |
| A    | .BLKW 1        |
| В    | .BLKW 1        |
| С    | .BLKW 1        |
|      |                |
| ABS  | ADD R4, R0, #0 |
|      | BRzp DONE      |
| SKIP | NOT R4, R4     |
|      | ADD R0, R4, #1 |
| DONE | RET            |
|      | .END           |

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

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

```
.ORIG x3000
LD R0, A
LD R1, B
ADD R0, R1, R0
ST R0, B
A .STRINGZ "%"
B .FILL xF000
.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.

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



.END

| Symbol | Address |
|--------|---------|
|        |         |
|        |         |
|        |         |
|        |         |
|        |         |

**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:

| 15   | 12 | 11 |     | 9 | 8 |  |   |      |   |  | 0 |
|------|----|----|-----|---|---|--|---|------|---|--|---|
| 1101 |    | В  | ase | R |   |  | o | ffse | t |  |   |

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



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.

**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.

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.

|                | .ORIG<br>LEA<br>LD       | X3000<br>R6, BASE<br>R0, START |
|----------------|--------------------------|--------------------------------|
| PHASE1         | LDR                      | R0, R0, #0                     |
|                |                          |                                |
|                | JSR<br>BRnzp             | PUSH<br>PHASE1                 |
| PHASE2         | LD                       | R1, START                      |
| AGAIN          | JSR                      | POP                            |
|                |                          |                                |
|                | BRnp                     | DONE                           |
|                |                          |                                |
|                |                          |                                |
| _              | BRnzp                    | AGAIN                          |
| DONE           | AND                      | R0, R0, #0                     |
|                |                          |                                |
|                | HALT                     |                                |
| START<br>STACK | .FILL<br>.BLKW           | x4000<br>#20                   |
| BASE .F        | ILL                      |                                |
| PUSH           |                          |                                |
|                | STR<br>RET               | R0, R6, #0                     |
| POP            | AND                      | R5, R5, #0<br>R0 RASE          |
|                | ADD<br>BRz               | RO, RO, RG<br>EMPTY            |
|                | LDR                      | R0, R6, #0                     |
| EMPTY          | ADD<br>RET<br>ADD<br>RET | R5, R5, #1                     |
|                | .END                     |                                |

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.

| Cycle<br>Number | State<br>Number | Control Signals            |
|-----------------|-----------------|----------------------------|
| 1               | 10              | LD.MAR: LD.REG: GateMDR:   |
|                 | 18              | LD.PC: PCMUX: GatePC:      |
|                 | 0               | LD.MAR: LD.REG: BEN        |
|                 | U               | LD.PC: LD.CC:              |
|                 |                 | LD.REG: 1 DR: 000 GateMDR: |
|                 |                 | GateALU: GateMARMUX:       |
| 57              | 1               | LD.MAR: ALUK: GateALU:     |
| 57              | 1               | LD.REG: DR: GatePC:        |
|                 |                 | ADDR1MUX: ADDR2MUX:        |
|                 | 22              | LD.PC: LD.MAR PCMUX:       |
| 101             | 15              |                            |

**Part a:** Fill in the missing instructions in the program, and complete the program by labeling the appropriate instruction AGAIN. Also, fill in the missing information in the table.

Part b: Given values for A and B, what does the program do?















(c)

| Table C.1                                                                                                                                 | )ata Path Contro                                                                                                                                                                                                                                                                                                                               | l Signals                                                                                                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Signal Name                                                                                                                               | Signal Values                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                  |
| LD.MAR/1:<br>LD.MDR/1:<br>LD.IR/1:<br>LD.REG/1:<br>LD.CC/1:<br>LD.PC/1:<br>LD.Priv/1:<br>LD.SavedSSP/1:<br>LD.SavedUSP/1:<br>LD.Vector/1: | <ul> <li>NO, LOAD</li> </ul> |                                                                                                                                  |
| GatePC/1:<br>GateMDR/1<br>GateALU/1:<br>GateMARMUX/1:<br>GateVector/1:<br>GatePC-1/1:<br>GatePSR/1:<br>GateSP/1:                          | <ul> <li>NO, YES</li> </ul>                                                                                                                                                           |                                                                                                                                  |
| PCMUX/2:                                                                                                                                  | : PC+1<br>BUS<br>ADDER                                                                                                                                                                                                                                                                                                                         | ;select pc+1<br>;select value from bus<br>;select output of address adder                                                        |
| DRMUX/2:                                                                                                                                  | : 11.9<br>R7<br>SP                                                                                                                                                                                                                                                                                                                             | ;destination IR[11:9]<br>;destination R7<br>;destination R6                                                                      |
| SR1MUX/2:                                                                                                                                 | : 11.9<br>8.6<br>SP                                                                                                                                                                                                                                                                                                                            | ;source IR[11:9]<br>;source IR[8:6]<br>;source R6                                                                                |
| ADDR1MUX/1:                                                                                                                               | : PC, BaseR                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                  |
| ADDR2MUX/2:                                                                                                                               | ZERO<br>offset6<br>PCoffset9<br>PCoffset11                                                                                                                                                                                                                                                                                                     | ;select the value zero<br>;select SEXTEIRE5:0]]<br>;select SEXTEIRE8:0]]<br>;select SEXTEIRE10:0]]                               |
| SPMUX/2:                                                                                                                                  | : SP+1<br>SP-1<br>Saved SSP<br>Saved USP                                                                                                                                                                                                                                                                                                       | ;select stack pointer+1<br>;select stack pointer-1<br>;select saved Supervisor Stack Pointer<br>;select saved User Stack Pointer |
| MARMUX/1:                                                                                                                                 | : 7.0<br>ADDER                                                                                                                                                                                                                                                                                                                                 | ;select ZEXT[IR[7:0]]<br>;select output of address adder                                                                         |
| VectorMUX/2:                                                                                                                              | : INTV<br>Priv.exception<br>Opc.exception                                                                                                                                                                                                                                                                                                      |                                                                                                                                  |
| PSRMUX/1:                                                                                                                                 | individual setting                                                                                                                                                                                                                                                                                                                             | gs, BUS                                                                                                                          |
| ALUK/2:                                                                                                                                   | ADD, AND, NOT                                                                                                                                                                                                                                                                                                                                  | Γ, PASSA                                                                                                                         |
| MIO.EN/1:<br>R.W/1:                                                                                                                       | NO, YES<br>RD, WR                                                                                                                                                                                                                                                                                                                              |                                                                                                                                  |
| Set.Priv/1:                                                                                                                               | : 0<br>1                                                                                                                                                                                                                                                                                                                                       | ;Supervisor mode<br>;User mode                                                                                                   |

"app-c" — 2004/5/21 — page 572 — #8

|          | 15 | 14      | 13            | 12     | 11 | 10  | 9           | 8 | 7         | 6      | 5     | 4          | 3          | 2           | 1      | 0 |
|----------|----|---------|---------------|--------|----|-----|-------------|---|-----------|--------|-------|------------|------------|-------------|--------|---|
| $ADD^+$  |    | 00      | 01            |        |    | DR  |             |   | SR1       |        | 0     | 0          | 0          |             | SR2    |   |
| $ADD^+$  |    | 00      | 01            | l<br>I |    | DR  | 1           |   | SR1       |        | 1     |            | i<br>i     | mm5         | 5<br>1 |   |
| $AND^+$  |    | 01      | 01            |        |    | DR  | 1           |   | SR1       | ,      | 0     | 0          | 0          | -           | SR2    |   |
|          |    | 01      | 01            |        |    | DR  | I           |   | SR1       |        | 1     |            | <br>       | ៣៣5<br>រ    | 5      |   |
| BR       |    | 00      | 00            | 1      | n  | z   | р           |   | I         |        | PC    | offs       | et9        | I           |        |   |
| JMP      |    | 11      | 00            | [      |    | 000 | L           | E | i<br>Base | R      |       | 1          | 000        | 000         | l      |   |
| JSR      |    | 01      | 00            | l -    | 1  |     | 1           | 1 | 1         | PC     | offse | ∙<br>∋t11  | Г — П      | ı<br>I      | <br>   |   |
| JSRR     |    | 01      | 00            | 1      | 0  | 0   | ו<br>0<br>ו | E | Base      | R      |       | 1          | 000        | 000         |        |   |
| $LD^+$   |    | 00      | 10            | I      |    | DR  | 1           |   | 1<br>1    | l      | PC    | ı<br>Coffs | et9        | I           | I      |   |
|          |    | 10      | 10<br>1       | I      |    | DR  | ι           |   | 1         | 1      | PC    | Coffs      | et9        | I<br>I      |        |   |
| $LDR^+$  |    | 01      | 10            | r      |    | DR  | I<br>I      | E | i<br>Base | R      |       | 1          | offs       | set6        |        |   |
| $LEA^+$  |    | 11<br>1 | 10            | 1      |    |     | T           |   | I         | l      | PC    | T<br>Coffs | et9        | !<br>  ·    | r 1    |   |
| NOT      |    | 10      | 1<br>101      | I      |    |     | r           |   | SR        | I      |       | I          | 111<br>111 | 111<br>111  |        |   |
| RET      |    | '<br>11 | 00            | 1      |    | 000 | í<br> <br>  |   | 111       | 1      |       | ı<br>I     | 000        | 0000        |        |   |
| RTI      |    | 10<br>1 | T<br>000      | 1      |    | 1   | I           | 1 | 000       | 0000   | 000   | 000        | T          | I<br>I      |        |   |
| ST       |    | 00      | 1<br>)11      | 1      |    | SR  |             |   | 1         | 1      | PC    | r<br>Coffs | et9        | 1           | I      |   |
| STI      |    | 10<br>  | 1<br>)11<br>1 | T .    |    | SR  |             |   | I         | !      | PC    | T<br>Coffs | et9        | ı —         | I      |   |
| STR      |    | 01      | 1<br>11       | 1      |    | SR  |             | E | i<br>Base | R<br>I |       | 1          | offs       | set6        | I      |   |
| TRAP     |    | 11      | 11            | r      |    | 00  | 000         | т |           |        | r     | trap       | /ect8      | 1<br>3<br>1 | I      |   |
| reserved |    | 11      | 01            | 1      |    | ,   | T           | , | T · ·     | ı      | 1     | 1          | 1          | T           |        | 1 |

Figure A.2 Format of the entire LC-3 instruction set. Note: + indicates instructions that modify condition codes

| AS        | SCII |      | AS        | ASCII |     |           | ASCII |      |           | ASCII        |     |  |
|-----------|------|------|-----------|-------|-----|-----------|-------|------|-----------|--------------|-----|--|
| Character | Dec  | Hex  | Character | Dec   | Hex | Character | Dec   | Hex  | Character | Dec          | Hex |  |
| nul       | 0    | 00   | sp        | 32    | 20  | @         | 64    | 40   | 1         | 96           | 60  |  |
| soh       | 1    | 01   | 1         | 33    | 21  | A         | 65    | 41   | a         | 97           | 61  |  |
| stx       | 2    | 02   | в         | 34    | 22  | В         | 66    | 42   | b         | 98           | 62  |  |
| etx       | 3    | 03   | #         | 35    | 23  | C         | 67    | 43   | с         | 99           | 63  |  |
| eot       | 4    | 04   | \$ .      | 36    | 24  | D         | 68    | 44   | d         | 100          | 64  |  |
| enq       | 5    | 05   | 8         | 37    | 25  | E         | 69    | 45   | е         | 101          | 65  |  |
| ack       | 6    | 06   | δe        | 38    | 26  | E.        | 70    | . 46 | f         | 102          | 66  |  |
| bel       | 7    | 07   | 1         | 39    | 27  | G.        | 71    | 47   | g         | 103          | 67  |  |
| bs        | 8    | 08   | (         | 40    | 28  | H·        | 72    | 48   | h         | 104          | 68  |  |
| ht        | 9    | 09   | ).        | 41    | 29  | I.        | 73    | 49   | i         | 105          | 69  |  |
| lf        | 10   | 0A   | *         | 42    | 2A  | J         | 74    | 4A   | t         | 106          | 6A  |  |
| vt        | 11   | 0B   | +         | 43    | 2B  | K         | 75    | 4B   | k         | 107          | 6B  |  |
| ff        | 12   | 0C   | i         | 44    | 2Ċ  | L         | 76    | 4C   | 1         | 108          | 6C  |  |
| cr        | 13   | 0 D  |           | 45    | 2 D | М         | 77    | 4D   | m         | 109          | 6D  |  |
| so        | 14   | 0E   | -         | 46    | 2E  | N         | 78    | 4E   | n         | 110          | 6E  |  |
| si        | 15   | 0F   | 1.        | 47    | 2F  | 0         | 79    | 4F   | 0         | 111          | 6F  |  |
| dle       | 16   | 10   | 0         | 48    | 30  | P         | 80    | 50   | р         | 112          | 70  |  |
| dcl       | 17   | 11   | 1         | 49    | 31  | Q         | 81    | 51   | q         | 113          | 71  |  |
| dc2       | 18   | 12   | 2         | 50    | 32  | R         | 82    | 52   | r         | 114          | 72  |  |
| dc3       | 19   | 13   | 3         | 51    | 33  | S         | 83    | 53   | s         | 1 <b>1</b> 5 | 73  |  |
| dc4       | 20   | 14   | 4         | 52    | 34  | Т         | 84    | 54   | ť         | 116          | 74  |  |
| nak       | 21   | 15   | 5         | 53    | 35  | υ         | 85    | 55   | u         | 117          | 75  |  |
| syn       | 22   | 16   | 6         | 54    | 36  | v         | 86    | 56   | v         | 118          | 76  |  |
| etb       | 23   | 17   | 7         | 55    | 37  | W         | 87    | 57   | W         | 119          | 77  |  |
| can       | 24   | 18   | 8         | 56    | 38  | х         | 88    | 58   | x         | 120          | 78  |  |
| em        | 25   | 19   | 9         | 57    | 39  | Y         | 89    | 59   | У         | 121          | 79  |  |
| sub       | 26   | 1A   | :         | 58    | 3A  | Z         | 90    | 5A   | z         | 122          | 7A  |  |
| esc       | 27   | 1B - | ;         | 59    | 3B  | [         | 91    | 5B   | . {       | 123          | 7B  |  |
| fs        | 28   | 10   | <         | 60    | 3C  | 1         | 92    | 5C   |           | 124          | 7C  |  |
| gs        | 29   | 1D   | = .       | 61    | 3D  | ]         | 93    | 5D   | }         | 125          | 7 D |  |
| rs        | 30   | 1E   | >         | 62    | 3E  | ^         | 94    | 5 E  | ~         | 126          | 7E  |  |
| us        | 31   | 1F   | 2         | 63    | 3F  | -         | 95    | 5F   | del       | 127          | 7F  |  |

# The Standard ASCII Table

.

| Table A.2 Trap Service Routines |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|---------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Trap Vector                     | Assembler Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
| x20                             | GETC           | Read a single character from the keyboard. The character is not echoed onto the console. Its ASCII code is copied into R0. The high eight bits of R0 are cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
| x21                             | OUT            | Write a character in R0[7:0] to the console display.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
| x22                             | PUTS           | Write a string of ASCII characters to the console display. The characters are contained<br>in consecutive memory locations, one character per memory location, starting with<br>the address specified in R0. Writing terminates with the occurrence of x0000 in a<br>memory location.                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
| x23                             | IN             | Print a prompt on the screen and read a single character from the keyboard. The<br>character is echoed onto the console monitor, and its ASCII code is copied into R0.<br>The high eight bits of R0 are cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| x24                             | PUTSP          | Write a string of ASCII characters to the console. The characters are contained in consecutive memory locations, two characters per memory location, starting with the address specified in R0. The ASCII code contained in bits [7:0] of a memory location is written to the console first. Then the ASCII code contained in bits [15:8] of that memory location is written to the console. (A character string consisting of an odd number of characters to be written will have x00 in bits [15:8] of the memory location containing the last character to be written.) Writing terminates with the occurrence of x0000 in a memory location. |  |  |  |  |  |
| x25                             | HALT           | Halt execution and print a message on the console.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |

| Table A.3 Device Register Assignments |                                           |                                                                                                                                                 |  |  |  |  |  |
|---------------------------------------|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Address                               | I/O Register Name                         | I/O Register Function                                                                                                                           |  |  |  |  |  |
| xFE00                                 | Keyboard status register                  | Also known as KBSR. The ready bit (bit [15]) indicates if the keyboard has received a new character.                                            |  |  |  |  |  |
| xFE02                                 | Keyboard data register                    | Also known as KBDR. Bits [7:0] contain the last character typed on the keyboard.                                                                |  |  |  |  |  |
| xFE04                                 | Display status register                   | Also known as DSR. The ready bit (bit [15]) indicates if<br>the display device is ready to receive another character<br>to print on the screen. |  |  |  |  |  |
| xFE06                                 | <ul> <li>Display data register</li> </ul> | Also known as DDR. A character written in the low byte of this register will be displayed on the screen.                                        |  |  |  |  |  |
| xFFFE                                 | Machine control register                  | Also known as MCR. Bit [15] is the clock enable bit.<br>When cleared, instruction processing stops.                                             |  |  |  |  |  |