

## CEG2136: Computer Architecture I CEG2536: Architecture des Ordinateurs I FINAL EXAMINATION

Profs. Voicu Z. Groza and Naim M. Rahmani

- Closed book exam. All electronic devices including calculators are not allowed.
- If in doubt how to interpret a question, make an assumption and elaborate your solution based on this hypothesis. Explain all your assumptions and well define the symbols used.
- If you finish 10 minutes or less before the due time, remain seated until the end of the exam.

### Question

Consider the following logic diagram:

- a) What is the  $C_4$ ,  $S_3$ ,  $S_2$ ,  $S_1$ ,  $S_0$  value if:  
 (1) Register A = 1101, Register B = 0110, and M=0  
 (2) Register A = 1101, Register B = 0110, and M=1

Write your calculations and results in the last two columns of the following table



- b) Given that registers A, B and S contain signed numbers in 2's complement representation, convert the binary numbers  $A_3 A_2 A_1 A_0$ ,  $B_3 B_2 B_1 B_0$  and  $S_3 S_2 S_1 S_0$  to decimal, and write your results and calculations in the following table:

| $A_3 A_2 A_1 A_0$<br>(binary/<br>decimal)                                        | $B_3 B_2 B_1 B_0$<br>(binary/<br>decimal) | M | $C_4$ | a)<br>$S_3 S_2 S_1 S_0$<br>(binary)                                                                                                                              | b)<br>$S_3 S_2 S_1 S_0$<br>(decimal)           | c) Are the results provided by the logic circuit correct?, i.e., are they in accord with the results you obtain if you do the same operations yourself |
|----------------------------------------------------------------------------------|-------------------------------------------|---|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| $A=1101 = - A $<br>$ A =-1101=$<br>2's compl(1101)<br>$ A =0011 = 3$<br>$A = -3$ | 0110<br>$= + 6$                           | 0 | 1     | Carry: $c_4 c_3 c_2 c_1 c_0$<br>$\underline{1} \underline{1} \underline{0} \underline{0} \underline{0}$<br>1101<br>$+ 0110$<br>$\underline{\underline{(1)0011}}$ | $S = A + B$<br>$S = -3 + 6$<br>$= 0011 = +3$   | CORRECT!                                                                                                                                               |
| 1101                                                                             | 0110<br>$= + 6$                           | 1 | 1     | Carry : $\underline{1} \underline{0} \underline{0} \underline{1} \underline{1}$<br>1101<br>$+ 1001$<br>$\underline{\underline{(1)0111}}$                         | $S = A - B$<br>$S = -3 - 6$<br>$= 0111 = +7 ?$ | $A - B = -3 - 6 = -9$<br>=> Overflow, since the result should be in the domain [-8, +7]                                                                |

- d) Expand your adder with a circuit that can signalize overflow



## Question

Consider the computer of Lab 4, the architecture of which is described in Figure 1 and Tables 1, 2, 3, 4, and 5. The instruction type is determined by the two most significant bits of the 8-bit register IR, as follows:

$X_0 = \text{IR}(7)' \text{ IR}(6)'$  denotes a memory-reference instruction (MRI) in direct addressing mode;  
 $X_1 = \text{IR}(7)' \text{ IR}(6)$  denotes a register-reference instruction (RRI); and  
 $X_2 = \text{IR}(7) \text{ IR}(6)'$  denotes a memory-reference instruction (MRI) in indirect addressing mode.  
 Assume that all registers are equipped with 3 control bits for loading the register (LD), increment by 1 (INC), and reset to zero (CLR).

Find the list of all micro-operations which change the value of register AC and derive the logic equations

|                                        |
|----------------------------------------|
| T7 Y0 : AC $\leftarrow$ AC + DR ,      |
| T7 Y1 : AC $\leftarrow$ DR             |
| T7 Y5 : AC $\leftarrow$ AC $\wedge$ DR |
| T7 Y6 : AC $\leftarrow$ AC - DR        |
| T3 X1 IR(0) : AC $\leftarrow$ 0        |
| T3 X1 IR(1) : AC $\leftarrow$ AC       |
| T3 X1 IR(2) : AC $\leftarrow$ ashl AC  |
| T3 X1 IR(3) : AC $\leftarrow$ ashr AC  |
| T3 X1 IR(4) : AC $\leftarrow$ AC + 1   |

$$LD_{AC} = T7(Y0 + Y1 + Y5 + Y6) + \\ T3[(X1 IR(1) + X1 IR(2) + X1 IR(3))]$$

$$INC_{AC} = T3 X1 IR(0)$$

$$CLR_{AC} = T3 X1 IR(4)$$

**RRI**

| Symbol | Notation (RTL)                       |
|--------|--------------------------------------|
| CLA    | T3 X1 IR(0): AC $\leftarrow$ 0       |
| CMA    | T3 X1 IR(1): AC $\leftarrow$ AC      |
| ASL    | T3 X1 IR(2): AC $\leftarrow$ ashl AC |
| ASR    | T3 X1 IR(3): AC $\leftarrow$ ashr AC |
| INC    | T3 X1 IR(4): AC $\leftarrow$ AC + 1  |
| HLT    | T3 X1 IR(5) : S $\leftarrow$ 1       |

**MRI**

|                              | Notation (RTL)                                                                                                                                                                                                                           |
|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Y0 =<br>IR(6)' IR(1)' IR(0)' | T6 Y0:DR $\leftarrow$ M [AR]<br>T7 Y0:AC $\leftarrow$ AC + DR<br>SC $\leftarrow$ 0                                                                                                                                                       |
| Y1 = IR(6)' IR(2)            | T6 Y1:DR $\leftarrow$ M [AR]<br>T7 Y1:AC $\leftarrow$ DR, SC $\leftarrow$ 0                                                                                                                                                              |
| Y2 = IR(6)' IR(3)            | T6:<br>T7 Y2:M [AR] $\leftarrow$ AC,<br>SC $\leftarrow$ 0                                                                                                                                                                                |
| Y3 = IR(6)' IR(4)            | T6 Y3:PC $\leftarrow$ AR, SC $\leftarrow$ 0                                                                                                                                                                                              |
| Y4 = IR(6)' IR(5)            | T6 Y4:DR $\leftarrow$ M [AR]<br>T7 Y4:DR $\leftarrow$ DR + 1<br>T8 Y4:M [AR] $\leftarrow$ DR<br>T9 Y4:if (DR = 0)S' then<br>(PC $\leftarrow$ PC + 1)<br>T10 Y4:if (DR = 0)S'<br>then(PC $\leftarrow$ PC + 1)<br>T10 Y4:SC $\leftarrow$ 0 |
| Y5 =<br>IR(6)' IR(1)' IR(0)  | T6 Y5:DR $\leftarrow$ M [AR]<br>T7 Y5:AC $\leftarrow$ AC $\wedge$ DR<br>SC $\leftarrow$ 0                                                                                                                                                |
| Y6 =<br>IR(6)' IR(1)' IR(0)  | T6 Y6:DR $\leftarrow$ M [AR]<br>T7 Y6:AC $\leftarrow$ AC - DR<br>SC $\leftarrow$ 0                                                                                                                                                       |

## Question

Two memory-reference instructions in the Basic Computer are to be changed to the instructions specified in the following table.

| Symbol | Opcode | Symbolic designation                        | Description in words     |
|--------|--------|---------------------------------------------|--------------------------|
| ADM    | 001    | $M[EA] \leftarrow AC + M[EA]$               | Add AC to memory         |
| BNA    | 011    | If ( $AC < 0$ ) then ( $PC \leftarrow EA$ ) | Branch if AC is negative |

In the following table, write down the necessary micro-operations (in RTL) to perform the execution phase of each instruction. Note that the execution phase of such type of instructions starts at  $T_4$ . See figures 2 and 3 from Annex. **Note** that the value in AC should not be changed by the execution of any instruction unless the instruction specifies a change in its content. To this extent you can use TR to store the content of AC temporary.

## Question

Column (3) of the following table shows the content of a memory segment of the Basic Computer that stores a machine language program and its operands.

- Convert from binary to hexadecimal both the address and the memory contents (columns (1) and (3)) and write your results in columns (2) and (4), respectively.
- Use Table 6 from Annex to convert the machine language program (stored in the first six memory locations) to symbolic operation codes (assembly language). Use Table 6 from Annex to convert the machine language program (stored in the first six memory locations) to symbolic operation codes (assembly language). Write the assembly language instructions in the corresponding cells of column (5) of the above table. Use hexadecimal representation for the address field of the instructions.
- Fill out the last column (6) of the table with the content of the accumulator after the execution of each instruction.

| Memory Address |         | Memory Content      |         | Assembly /operands in HEX | AC after execution of instr. |
|----------------|---------|---------------------|---------|---------------------------|------------------------------|
| Binary (1)     | Hex (2) | Binary (3)          | Hex (4) | (5)                       | (6)                          |
| 1000 0001 0111 | 817     | 0111 1000 0000 0000 | 7800    | CLA                       | 0000                         |
| 1000 0001 1000 | 818     | 0010 1000 0001 1101 | 281D    | LDA 81D                   | 0121                         |
| 1000 0001 1001 | 819     | 0001 1000 0001 1110 | 181E    | ADD 81E                   | 0130                         |
| 1000 0001 1010 | 81A     | 1000 1000 0001 1111 | 881F    | AND 81F I                 | 0100                         |
| 1000 0001 1011 | 81B     | 0011 1000 0001 1101 | 381D    | STA 81D                   | 0100                         |
| 1000 0001 1100 | 81C     | 0111 0000 0000 0001 | 7001    | HLT                       | 0100                         |
| 1000 0001 1101 | 81D     | 0000 0001 0010 0001 | 0121    |                           |                              |
| 1000 0001 1110 | 81E     | 0000 0000 0000 1111 | 000F    |                           |                              |
| 1000 0001 1111 | 81F     | 0000 1000 0010 0000 | 0820    |                           |                              |
| 1000 0010 0000 | 820     | 0000 0001 1100 0100 | 01C4    |                           |                              |

| Symbol | RTL                                                                                                                                                                                                          |
|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADM    | $D_1T_4: TR \leftarrow AC$<br>$D_1T_5: DR \leftarrow M[EA]$<br>$D_1T_6: AC \leftarrow AC + DR$<br>$D_1T_7: M[EA] \leftarrow AC$<br>$D_1T_8: DR \leftarrow TR$<br>$D_1T_9: AC \leftarrow DR, SC \leftarrow 0$ |
| BNA    | $D_3T_4: If (AC(15) = 1)$<br>$then (PC \leftarrow AR), SC \leftarrow 0$                                                                                                                                      |

| Symbol | Hex code | Symbol | Hex code |
|--------|----------|--------|----------|
| AND    | 0 or 8   | CIR    | 7080     |
| ADD    | 1 or 9   | CIL    | 7040     |
| LDA    | 2 or A   | INC    | 7020     |
| STA    | 3 or B   | SPA    | 7010     |
| BUN    | 4 or C   | SNA    | 7008     |
| BSA    | 5 or D   | SZA    | 7004     |
| ISZ    | 6 or B   | SZE    | 7002     |
| CLA    | 7800     | HLT    | 7001     |
| CLE    | 7400     | INP    | F800     |
| CMA    | 7200     | OUT    | F400     |
| CME    | 7100     | SKI    | F200     |

## **Question**

a) Write a subroutine (MUL) in assembly language that multiplies two positive numbers by a repeated addition method. For example, to multiply 6 x 4, the subroutine evaluates the product by adding the multiplicand (6) four times (multiplier), i.e., 6+6+6+6.

Write your program using instructions of the Basic Computer given in the Table 6 from the Annex. Your subroutine should be stored in the memory of your Basic Computer beginning with address **A00**.

Before invoking your subroutine MUL, the calling program places:

- the multiplicand (6 in the above example) in memory location at address **9FF**;
- the multiplier (4 in the above example) in the accumulator.

The result (the product of the two numbers) is passed by subroutine to the calling program through the accumulator.

**NOTE:** You are allowed to use different ways to pass parameters, but full explanations should be provided.

## **Solution:**

|                                |
|--------------------------------|
| ORG HEX 9FF                    |
| MLP, 0000                      |
| MUL, 0000                      |
| CMA                            |
| INC /initialize CTR to         |
| STA CTR /"negative multiplier" |
| CLA                            |
| LOP, ADD MLP                   |
| ISZ CTR                        |
| BUN LOP                        |
| BUN MUL I                      |
| CTR, 0000                      |

b) This part is independent of part (a).

The coordinates of two 2-dimensional vectors ( $a_x, a_y, b_x, b_y$ ) are stored at consecutive addresses starting at F01. Write an assembly language program that calculates the scalar (dot) product of two 2-dimensional vectors, assuming that all their coordinates are positive numbers:

$$p = a_x b_x + a_y b_y$$

Your program is stored in memory beginning with location at address **100**, and it has to place the product "p" at address **F00**.

To calculate partial products ( $a_x b_x$  and  $a_y b_y$ ), you should call subroutine MUL. Parameters have to be passed as follows:

- memory location **9FF** is used to pass a factor, say  $a_x$ ;
- the other factor (i.e.,  $b_x$ ) is passed to the subroutine through the accumulator;
- the product  $a_x b_x$  is passed back to your program by subroutine MUL through the accumulator.

## **Solution:**

|                                                |
|------------------------------------------------|
| ORG HEX 100                                    |
| CLA /to initialise P = 0                       |
| STA P                                          |
| LDA AX /prepare $a_x$ in MLP                   |
| STA MLP                                        |
| LDA BX /prepare $b_x$ in AC                    |
| BSA MUL / call MUL to get $a_x b_x$            |
| ADD P / P <- P + $a_x b_x = 0 + a_x b_x$       |
| STA P                                          |
| LDA AY /prepare $a_y$ in MLP                   |
| STA MUL                                        |
| LDA BY /prepare $b_y$ in AC                    |
| BSA MUL / call MUL to get $a_y b_y$            |
| ADD P / P <- P + $a_y b_y = a_x b_x + a_y b_y$ |
| STA P                                          |
| HLT                                            |
| ORG HEX F00                                    |
| P                                              |
| AX                                             |
| AY                                             |
| BX                                             |
| BY                                             |



Table 1: Starting micro-operations in the instruction cycle of the 8-bit mini computer

| Instant                      | Description                                                                                                                                                                | Notation (RTL)                                                                                                 |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| T <sub>0</sub>               | Load the program counter PC in AR, and increment PC                                                                                                                        | T <sub>0</sub> : AR ← PC<br>T <sub>0</sub> S' : PC ← PC + 1                                                    |
| T <sub>1</sub>               | Read instruction from memory and put it in the instruction register IR                                                                                                     | T <sub>1</sub> : IR ← M [AR]                                                                                   |
| T <sub>2</sub>               | This cycle is not used to allow for the new value of the instruction to propagate in the controller                                                                        | (nothing)                                                                                                      |
| T <sub>3</sub>               | If X <sub>1</sub> => it is a <i>register - reference instruction</i> that will be executed now                                                                             | T <sub>3</sub> X <sub>1</sub> : execute an RRI instruction (Table 4)<br>T <sub>3</sub> X <sub>1</sub> : SC ← 0 |
|                              | If X <sub>0</sub> or X <sub>2</sub> , read the memory address of the operand and place it in AR, and increment PC. Recall that (X <sub>0</sub> + X <sub>2</sub> ) = IR(6)' | T <sub>3</sub> IR(6)' : AR ← PC<br>T <sub>3</sub> IR(6)'S' : PC ← PC + 1                                       |
| T <sub>4</sub>               | Read memory address into AR                                                                                                                                                | T <sub>4</sub> IR(6)' : AR ← M [AR]                                                                            |
| T <sub>5</sub>               | If <i>indirect addressing</i> , read the <i>operand address</i> from memory location pointed to by AR                                                                      | T <sub>5</sub> X <sub>2</sub> : AR ← M [AR]                                                                    |
| T <sub>5</sub>               | If <i>direct addressing</i> , don't do anything, as the operand address is already in AR since T <sub>6</sub>                                                              | T <sub>5</sub> X <sub>0</sub> : (nothing)                                                                      |
| starting from T <sub>6</sub> | Execute the memory-reference instructions (MRI) described in Table 2                                                                                                       | (see Table 2)                                                                                                  |

Table 2: Execution of a memory-reference instruction (MRI) in the 8-bit mini computer

| Symbol                                                                                                                |                                     | Notation (RTL)                                                                                                                                                                                                                                                                                                                |
|-----------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ADD                                                                                                                   | Y <sub>0</sub> =IR(6)' IR(1) IR(0)' | T <sub>6</sub> Y <sub>0</sub> : DR ← M [AR]<br>T <sub>7</sub> Y <sub>0</sub> : AC ← AC + DR , SC ← 0                                                                                                                                                                                                                          |
| LDA                                                                                                                   | Y <sub>1</sub> =IR(6)' IR(2)        | T <sub>6</sub> Y <sub>1</sub> : DR ← M [AR]<br>T <sub>7</sub> Y <sub>1</sub> : AC ← DR , SC ← 0                                                                                                                                                                                                                               |
| STA                                                                                                                   | Y <sub>2</sub> =IR(6)' IR(3)        | T <sub>6</sub> : (cycle not used to allow for the address bus to stabilize)<br>T <sub>7</sub> Y <sub>2</sub> : M [AR] ← AC , SC ← 0                                                                                                                                                                                           |
| BUN                                                                                                                   | Y <sub>3</sub> =IR(6)' IR(4)        | T <sub>6</sub> Y <sub>3</sub> : PC ← AR , SC ← 0                                                                                                                                                                                                                                                                              |
| ISZ (assuming that the next instruction is a memory-reference instruction, stored at 2 memory locations further down) | Y <sub>4</sub> =IR(6)' IR(5)        | T <sub>6</sub> Y <sub>4</sub> : DR ← M [AR]<br>T <sub>7</sub> Y <sub>4</sub> : DR ← DR + 1<br>T <sub>8</sub> Y <sub>4</sub> : M [AR] ← DR<br>T <sub>9</sub> Y <sub>4</sub> : if (DR = 0)S' then (PC ← PC + 1)<br>T <sub>10</sub> Y <sub>4</sub> : if (DR = 0)S' then (PC ← PC + 1)<br>T <sub>10</sub> Y <sub>4</sub> : SC ← 0 |
| AND                                                                                                                   | Y <sub>5</sub> =IR(6)' IR(1)' IR(0) | T <sub>6</sub> Y <sub>5</sub> : DR ← M [AR]<br>T <sub>7</sub> Y <sub>5</sub> : AC ← AC ∧ DR , SC ← 0                                                                                                                                                                                                                          |
| SUB                                                                                                                   | Y <sub>6</sub> =IR(6)' IR(1)' IR(0) | T <sub>6</sub> Y <sub>6</sub> : DR ← M [AR]<br>T <sub>7</sub> Y <sub>6</sub> : AC ← AC − DR , SC ← 0                                                                                                                                                                                                                          |

Table 3:  
Function table of the 8-bit ALU

| $S_2$ | $S_1$ | $S_0$ | Operation           |
|-------|-------|-------|---------------------|
| 0     | 0     | 0     | $F = AC + DR$       |
| 0     | 0     | 1     | $F = AC - DR$       |
| 0     | 1     | 0     | $F = ash\ll AC$     |
| 0     | 1     | 1     | $F = ash\gg AC$     |
| 1     | 0     | 0     | $F = AC \wedge DR$  |
| 1     | 0     | 1     | $F = AC \vee DR$    |
| 1     | 1     | 0     | $F = DR$ (transfer) |
| 1     | 1     | 1     | $F = AC'$           |

Table 4:  
Execution of a register-reference instruction (RRI) of the 8-bit mini computer

| Symbol | Notation (RTL)                         |
|--------|----------------------------------------|
| CLA    | $T_3 X_1 IR(0) : AC \leftarrow 0$      |
| CMA    | $T_3 X_1 IR(1) : AC \leftarrow AC$     |
| ASL    | $T_3 X_1 IR(2) : AC \leftarrow ash\ll$ |
| ASR    | $T_3 X_1 IR(3) : AC \leftarrow ash\gg$ |
| INC    | $T_3 X_1 IR(4) : AC \leftarrow AC$     |
| HLT    | $T_3 X_1 IR(5) : S \leftarrow 1$       |

Table 5:  
Function table of the 8-bit bus

| $S_2$ | $S_1$ | $S_0$ | Register placed on the bus |
|-------|-------|-------|----------------------------|
| 0     | 0     | 0     | Memory                     |
| 0     | 0     | 1     | AR                         |
| 0     | 1     | 0     | PC                         |
| 0     | 1     | 1     | DR                         |
| 1     | 0     | 0     | IR                         |
| 1     | 0     | 1     | AC                         |
| 1     | 1     | 0     | OUTA                       |
| 1     | 1     | 1     | None                       |

Table 6:  
Instructions list of the 16-bit Basic Computer of the textbook

| Symbol | Hex code | Description                                      |
|--------|----------|--------------------------------------------------|
| AND    | 0 or 8   | AND $M$ to $AC$                                  |
| ADD    | 1 or 9   | Add $M$ to $AC$ , carry to $E$                   |
| LDA    | 2 or A   | Load $AC$ from $M$                               |
| STA    | 3 or B   | Store $AC$ in $M$                                |
| BUN    | 4 or C   | Branch unconditionally to $m$                    |
| BSA    | 5 or D   | Save return address in $m$ and branch to $m + 1$ |
| ISZ    | 6 or B   | Increment $M$ and skip if zero                   |
| CLA    | 7800     | Clear $AC$                                       |
| CLE    | 7400     | Clear $E$                                        |
| CMA    | 7200     | Complement $AC$                                  |
| CME    | 7100     | Complement $E$                                   |
| CIR    | 7080     | Circulate right $E$ and $AC$                     |
| CIL    | 7040     | Circulate left $E$ and $AC$                      |
| INC    | 7020     | Increment $AC$ ,                                 |
| SPA    | 7010     | Skip if $AC$ is positive                         |
| SNA    | 7008     | Skip if $AC$ is negative                         |
| SZA    | 7004     | Skip if $AC$ is zero                             |
| SZE    | 7002     | Skip if $E$ is zero                              |
| HLT    | 7001     | Halt computer                                    |
| INP    | F800     | Input information and clear flag                 |
| OUT    | F400     | Output information and clear flag                |
| SKI    | F200     | Skip if input flag is on                         |
| SKO    | F100     | Skip if output flag is on                        |
| ION    | F080     | Turn interrupt on                                |
| IOF    | F040     | Turn interrupt off                               |



Fig. 3. Basic Computer registers connected to a common bus