

## Problem 1

Consider a processor with the following instructions

| instruction         | format                                              |                                        |
|---------------------|-----------------------------------------------------|----------------------------------------|
| mnemonic            | meaning                                             |                                        |
|                     |                                                     | XXXX : not used                        |
| AD1 <i>rs, rf</i>   | $rs \leftarrow ADD(rs, rf)$                         | 00   <i>rs</i>   <i>rf</i>   XXXX   00 |
| AD2 <i>rs, #cte</i> | $rs \leftarrow ADD(rs, cte)$                        | 00   <i>rs</i>   <i>cte</i>   01       |
| AD3 <i>rs, (rf)</i> | $rs \leftarrow ADD(rs, M[rf])$                      | 00   <i>rs</i>   <i>rf</i>   XXXX   10 |
| AD4 <i>rs, dir</i>  | $rs \leftarrow ADD(rs, M[PC+1+dir])$                | 00   <i>rs</i>   <i>dir</i>   11       |
| JZ <i>offset</i>    | <i>if Z==1</i><br>$PC \leftarrow ADD(PC+1, offset)$ | 10   <i>offset</i>                     |

Words of 16 bits; register file with 16 registers;  
2 last bits of ADj represent the addressing mode of  
the second operand; PC increases by 1

- a. Draw the design of the datapath.
- b. Design the control unit.
- c. Add to the design the instruction

LAC *rd, rd*  $\leftarrow M[AC]$ , 11 | *xxxxxx* | *rd*

where AC is a specific use register

## Problem 2

Suppose we have a working processor of Problem 1.

Given the memory content shown in the table having the PC content  $0045_{\text{hex}}$  and assuming the registers are clean, i.e. they have a content of 0.

Let the binary *cte*, *dir* and *offset* represent two's complement numbers; e.g. see Section 2.4 of HP.

Determine now for the empty table the development of the memory and register content when we step through the corresponding program.

| pos               | content             |
|-------------------|---------------------|
| ...               | ...                 |
| $29_{\text{hex}}$ | $0033_{\text{hex}}$ |
| $2a_{\text{hex}}$ | $0042_{\text{hex}}$ |
| $2b_{\text{hex}}$ | $0008_{\text{hex}}$ |
| ...               | ...                 |
| $41_{\text{hex}}$ | $0023_{\text{hex}}$ |
| $42_{\text{hex}}$ | $000a_{\text{hex}}$ |
| $43_{\text{hex}}$ | $0c01_{\text{hex}}$ |
| $44_{\text{hex}}$ | $0001_{\text{hex}}$ |
| $45_{\text{hex}}$ | $1793_{\text{hex}}$ |
| $46_{\text{hex}}$ | $0542_{\text{hex}}$ |
| $47_{\text{hex}}$ | $0bd5_{\text{hex}}$ |
| $48_{\text{hex}}$ | $0480_{\text{hex}}$ |
| $49_{\text{hex}}$ | $0405_{\text{hex}}$ |
| $4a_{\text{hex}}$ | $8002_{\text{hex}}$ |
| $4b_{\text{hex}}$ | $0801_{\text{hex}}$ |
| $4c_{\text{hex}}$ | $0c01_{\text{hex}}$ |
| $4d_{\text{hex}}$ | $1001_{\text{hex}}$ |
| $4e_{\text{hex}}$ | $1401_{\text{hex}}$ |

| Instruction address | mnemonic | Operands source | Operand destination | Value to write |
|---------------------|----------|-----------------|---------------------|----------------|
|                     |          |                 |                     |                |
|                     |          |                 |                     |                |
|                     |          |                 |                     |                |