

# ASSIGNMENT-0

ડાયલોગ સ્ક્રીન  
 ડાયલોગ સ્ક્રીન

|                   |          |         |
|-------------------|----------|---------|
| જ્યા સ્વામીનારાયણ | Dt.: / / | Pg.no.: |
|-------------------|----------|---------|

1. Convert the following binary numbers to decimal.

$$\begin{aligned}
 (a) (101110)_2 &= (1 \times 2^5) + (0 \times 2^4) + (1 \times 2^3) + (1 \times 2^2) \\
 &\quad + (1 \times 2^1) + (0 \times 2^0) \\
 &= 32 + 0 + 8 + 4 + 2 + 0 \\
 &= (46)_{10}
 \end{aligned}$$

$$\begin{aligned}
 (b) (1110101)_2 &= (1 \times 2^6) + (1 \times 2^5) + (1 \times 2^4) + (0 \times 2^3) \\
 &\quad + (1 \times 2^2) + (0 \times 2^1) + (1 \times 2^0) \\
 &= 64 + 32 + 16 + 0 + 4 + 0 + 1 \\
 &= (117)_{10}
 \end{aligned}$$

$$\begin{aligned}
 (c) (110110100)_2 &= (1 \times 2^8) + (1 \times 2^7) + (0 \times 2^6) + \\
 &\quad (1 \times 2^5) + (1 \times 2^4) + (0 \times 2^3) + \\
 &\quad (1 \times 2^2) + (0 \times 2^1) + (0 \times 2^0) \\
 &= 256 + 128 + 0 + 32 + 16 + 0 + 4 \\
 &\quad + 0 + 0 \\
 &= (436)_{10}
 \end{aligned}$$

2. Convert the following numbers with the indicated bases to decimal.

$$\begin{aligned}
 (a) (22121)_3 &= (2 \times 3^4) + (2 \times 3^3) + (1 \times 3^2) + (2 \times 3^1) \\
 &\quad + (1 \times 3^0) \\
 &= 82 + 54 + 9 + 6 + 1 \\
 &= (151)_{10}
 \end{aligned}$$

(b)  $(4310)_5 = (4 \times 5^3) + (3 \times 5^2) + (1 \times 5^1) + (0 \times 5^0)$   
 $= 500 + 75 + 5 + 0$   
 $= (580)_{10}$

(c)  $(50)_7 = (5 \times 7^1) + (0 \times 7^0)$   
 $= 35 + 0$   
 $= (35)_{10}$

(d)  $(198)_{12} = (1 \times 12^2) + (9 \times 12^1) + (8 \times 12^0)$   
 $= 144 + 108 + 8$   
 $= (260)_{10}$

3. Convert the following decimal numbers to the bases indicated.

(a) 7562 to octal

|        | Quotient | Remainder | Coefficient |
|--------|----------|-----------|-------------|
| 7562/8 | 945      | 2         | $a_0 = 2$   |
| 945/8  | 118      | 1         | $a_1 = 1$   |
| 118/8  | 14       | 6         | $a_2 = 6$   |
| 14/8   | 1        | 6         | $a_3 = 6$   |
| 1/8    | 0        | 1         | $a_4 = 1$   |

$$(7562)_{10} = (16612)_8$$

(b) 1938 to hexadecimal

|           | Quotient | Remainder | Coefficient |
|-----------|----------|-----------|-------------|
| 1938 / 16 | 121      | 2         | $a_0 = 2$   |
| 121 / 16  | 7        | 9         | $a_1 = 9$   |
| 7 / 16    | 0        | 7         | $a_2 = 7$   |

$$(1938)_{10} = (792)_{16}$$

(c) 175 to binary

|         | Quotient | Remainder | Coefficient |
|---------|----------|-----------|-------------|
| 175 / 2 | 87       | 1         | $a_0 = 1$   |
| 87 / 2  | 43       | 1         | $a_1 = 1$   |
| 43 / 2  | 21       | 1         | $a_2 = 1$   |
| 21 / 2  | 10       | 1         | $a_3 = 1$   |
| 10 / 2  | 5        | 0         | $a_4 = 0$   |
| 5 / 2   | 2        | 1         | $a_5 = 1$   |
| 2 / 2   | 1        | 0         | $a_6 = 0$   |
| 1 / 2   | 0        | 1         | $a_7 = 1$   |

$$(175)_{10} = (10101111)_2$$

4. Show the value of all bits of a 12 bit register that hold the number equivalent to decimal 215 in (a) Binary (b) Binary coded octal (c) Binary coded hexadecimal (d) Binary coded decimal.

Ans: (a) Binary :

|         | Quotient | Remainder | Coefficient |
|---------|----------|-----------|-------------|
| $215/2$ | 107      | 1         | $a_0 = 1$   |
| $107/2$ | 53       | 1         | $a_1 = 1$   |
| $53/2$  | 26       | 1         | $a_2 = 1$   |
| $26/2$  | 13       | 0         | $a_3 = 0$   |
| $13/2$  | 6        | 1         | $a_4 = 1$   |
| $6/2$   | 3        | 0         | $a_5 = 0$   |
| $3/2$   | 1        | 1         | $a_6 = 1$   |
| $1/2$   | 0        | 1         | $a_7 = 1$   |

$$(215)_{10} = (11010111)_2$$

In 12-bit register, it is stored as  
"0000 1101 0111"

(b) Binary coded Octal :

|         | Quotient | Remainder | Coefficient |
|---------|----------|-----------|-------------|
| $215/8$ | 26       | 7         | $a_0 = 7$   |
| $26/8$  | 3        | 2         | $a_1 = 2$   |
| $3/8$   | 0        | 3         | $a_2 = 3$   |

$$(215)_{10} = (327)_8$$

In 2-bit register, it is stored as  
"000 011 010 111"

(c) Binary coded hexadecimal :

|        | Quotient | Remainder | Coefficient    |
|--------|----------|-----------|----------------|
| 215/16 | 13       | 7         | $a_0 = 7$      |
| 13/16  | 0        | 13        | $a_1 = 13 = D$ |

$$(215)_{10} = (D7)_{16}$$

In 12-bit register, it is stored as  
" 0000 1101 0111 "

#### (d) Binary Coded decimal

|       | Quotient | Remainder | Coefficient |
|-------|----------|-----------|-------------|
| 215/2 | 107      | 1         | $a_0 = 1$   |
| 107/2 | 53       | 1         | $a_1 = 1$   |
| 53/2  | 26       | 1         | $a_2 = 1$   |
| 26/2  | 13       | 0         | $a_3 = 0$   |
| 13/2  | 6        | 1         | $a_4 = 1$   |
| 6/2   | 3        | 0         | $a_5 = 0$   |
| 3/2   | 1        | 1         | $a_6 = 1$   |
| 1/2   | 0        | 1         | $a_7 = 1$   |

$$(215)_{10} = (11010111)_2$$

In 12-bit register, it is stored as  
" 0000 1101 0111 ".

5. Perform the arithmetic operation  $(+42) + (-13)$  and  $(-42) - (-13)$  in binary using signed 2's complement representation for negative numbers.

| Quotient | Remainder | Coefficient |
|----------|-----------|-------------|
| 42/2     | 21        | $a_0 = 0$   |
| 21/2     | 10        | $a_1 = 1$   |
| 10/2     | 5         | $a_2 = 0$   |
| 5/2      | 2         | $a_3 = 1$   |
| 2/2      | 1         | $a_4 = 0$   |
| 1/2      | 0         | $a_5 = 1$   |

$$(42)_{10} = (101010)_2$$

| Quotient | Remainder | Coefficient |
|----------|-----------|-------------|
| 13/2     | 6         | $a_0 = 1$   |
| 6/2      | 3         | $a_1 = 0$   |
| 3/2      | 1         | $a_2 = 1$   |
| 1/2      | 0         | $a_3 = 1$   |

$$(13)_{10} = (1101)_2$$

$$\rightarrow (+42) + (-13)$$

2's complement of 001101 is;

$$\begin{array}{r}
 110010 \\
 + \quad 1 \\
 \hline
 110011
 \end{array}
 \quad \text{1's complement of } 001101$$

Add 1

$$\begin{array}{r}
 & 1 & \text{carry} \\
 101010 & + 110011 & 2\text{' complement of } (-13)_{10} \\
 \hline
 101101
 \end{array}$$

Here, carry generated on MSB is ignored.

$$\begin{aligned}
 \therefore (42)_{10} + (-13)_{10} &= (101010)_2 + (-001101)_2 \\
 &= (011101)_2 \\
 &= (29)_{10}
 \end{aligned}$$

$$\rightarrow (-42) - (-13)$$

$$= 13 - 42$$

$$= (001101)_2 - (101010)_2$$

2's complement of 101010 is,

$$\begin{array}{r}
 & 1 & \text{carry} \\
 010101 & + 1 & 1\text{'s complement of } 101010 \\
 \hline
 010110 & & \text{Add 1}
 \end{array}$$

$$\begin{array}{r}
 111 \\
 001101 \\
 + 010110 \\
 \hline
 100011
 \end{array}
 \quad \begin{array}{l}
 \text{Carry} \\
 (-13)_{10} \\
 2\text{'s complement of } (42)_{10}
 \end{array}$$

2's complement of 100011;

$$\begin{array}{r}
 011100 \\
 + 1 \\
 \hline
 011101
 \end{array}
 \quad \begin{array}{l}
 1\text{'s complement of } 100011 \\
 \text{Add 1}
 \end{array}$$

$$-(011101)_2 = (-29)_{10}$$

$$(-42)_{10} - (-13)_{10} = (-29)_{10}$$

6. Perform the arithmetic operations

$(+70) + (+80)$  and  $(-70) + (-80)$  with binary number in signed 2's complement representation. Use eight bits to accommodate each number together with its sign. Show that overflow occurs in both cases, that the last two carries are unequal and that there is a sign reversal.

Sol<sup>n</sup>:

|        | Quotient | Remainder | Coefficient |
|--------|----------|-----------|-------------|
| $70/2$ | 35       | 0         | $a_0 = 0$   |
| $35/2$ | 17       | 1         | $a_1 = 1$   |
| $17/2$ | 8        | 1         | $a_2 = 1$   |
| $8/2$  | 4        | 0         | $a_3 = 0$   |
| $4/2$  | 2        | 0         | $a_4 = 0$   |
| $2/2$  | 1        | 0         | $a_5 = 0$   |
| $1/2$  | 0        | 1         | $a_6 = 1$   |

$$(70)_{10} = (1000110)_2$$

|        | Quotient | Remainder | Coefficient |
|--------|----------|-----------|-------------|
| $80/2$ | 40       | 0         | $a_0 = 0$   |
| $40/2$ | 20       | 0         | $a_1 = 0$   |
| $20/2$ | 10       | 0         | $a_2 = 0$   |
| $10/2$ | 5        | 0         | $a_3 = 0$   |

|     |   |   |
|-----|---|---|
| 5/2 | 2 | 1 |
| 2/2 | 1 | 0 |
| 1/2 | 0 | 1 |

$$a_4 = 1$$

$$a_5 = 0$$

$$a_6 = 1$$

$$(80)_{10} = (1010000)_2$$

$$\rightarrow (+70) + (+80)$$

$$\begin{array}{r}
 & 1 & \\
 & \text{carry} & \\
 \begin{array}{r} 01000110 \\ + 01010000 \\ \hline 10010110 \end{array} & 
 \end{array}$$

Here, overflow occurs as the sign bit of two nos  $(+70)$  and  $(+80)$  is '0' in 8-bit representation. But, the sign bit of the ans is '1'.

$$\rightarrow (-70) + (-80)$$

$$\begin{array}{r}
 1 \\
 \text{2's complement of } 01000110 \text{ is } 10111001 \\
 + \quad \quad \quad 1 \\
 \hline 10111010
 \end{array}$$

$$\text{2's complement of } 01010000 \text{ is } 10110111$$

$$\begin{array}{r}
 + \quad \quad \quad 1 \\
 \hline 10110000
 \end{array}$$

$$\begin{array}{r}
 10111010 \\
 + 10110000 \\
 \hline
 101101010 \quad \text{Carry generated}
 \end{array}$$

If carry is ignored, it means  $(-80) + (-70) = -150$  which is wrong. So, overflow occurs.

In case I,  $C_{in} = 1$  but  $C_{out} = 0$

In case II,  $C_{in} = 0$  but  $C_{out} = 1$

In both cases, the two carries are not equal so am overflow occurred.

7. Represent  $(8620)_{10}$  in (a) binary (b) Excess-3 code and (c) 2421 code

Sol<sup>n</sup>: (a) Binary

|          | Quotient | Remainder | Coefficient |
|----------|----------|-----------|-------------|
| $8620/2$ | 4310     | 0         | $a_0 = 0$   |
| $4310/2$ | 2155     | 0         | $a_1 = 0$   |
| $2155/2$ | 1077     | 1         | $a_2 = 1$   |
| $1077/2$ | 538      | 1         | $a_3 = 1$   |
| $538/2$  | 269      | 0         | $a_4 = 0$   |
| $269/2$  | 134      | 1         | $a_5 = 1$   |
| $134/2$  | 67       | 0         | $a_6 = 0$   |
| $67/2$   | 33       | 1         | $a_7 = 1$   |
| $33/2$   | 16       | 1         | $a_8 = 1$   |

|      |   |   |              |
|------|---|---|--------------|
| 1612 | 8 | 0 | $a_9 = 0$    |
| 812  | 4 | 0 | $a_{10} = 0$ |
| 412  | 2 | 0 | $a_{11} = 0$ |
| 212  | 1 | 0 | $a_{12} = 0$ |
| 112  | 0 | 1 | $a_{13} = 1$ |

Q)  
Ans.

$$(8620)_10 = (10000110101100)_2$$

(b) Excess - 3 code

$$\begin{aligned}(8620)_10 &= (1000 \ 0210 \ 0010 \ 0000)_{BCD} \\ &= (1011 \ 1001 \ 0101 \ 0011)_{\text{Ex-3}}\end{aligned}$$

(c) 2421 code :

$$(8620)_10 = (1110 \ 1100 \ 0010 \ 0000)_{2421-\text{code}}$$

8. Convert the hexadecimal number F3A7C2 to binary and Octal.

Soln:

$$\begin{aligned}&\text{F } 3 \ A \ 7 \ C \ 2 \\ &= (1111 \ 0011 \ 1010 \ 0111 \ 1100 \ 0010)_2\end{aligned}$$

$$\begin{array}{cccccccccc} \underline{111} & \underline{100} & \underline{111} & \underline{010} & \underline{011} & \underline{111} & \underline{000} & \underline{010} \\ \downarrow & \downarrow \\ 7 & 4 & 7 & 2 & 3 & 7 & 0 & 2 \end{array}$$

$$(F3A7C2)_{16} = (1111 \ 0011 \ 1010 \ 0111 \ 1100 \ 0010)_2$$

$$(F3A7C2)_{16} = (74728702)_8$$

9. Perform the arithmetic operation  $(+42) + (-13)$  and  $(-42) - (-13)$  in binary using signed 2's complement representation for negative numbers.

Sol<sup>n</sup>:  $(+42)_{10} = (101010)_2$

$(-13)_{10} = (1001101)_2$

$\rightarrow (+42) + (-13)$

2's complement of  $1001101$  is  $110010$

$$\begin{array}{r} & & 1 \\ & + & & 1 \\ 110010 & + & 1 & \\ \hline 110011 \end{array}$$

$$\begin{array}{r} & & 1 & \text{carry} \\ 101010 & + & 110011 & \\ \hline 11011101 & & \text{carry generated} & \end{array}$$

$$\begin{aligned} (+42)_{10} + (-13)_{10} &= (+101010)_2 + (-001101)_2 \\ &= (+111101)_2 \\ &= (29)_{10} \end{aligned}$$

$\rightarrow (-42) - (-13)$

2's complement of  $101010$  is  $010101$

$$\begin{array}{r} & & 1 \\ & + & & 1 \\ 010110 & + & 1 & \\ \hline 010111 \end{array}$$

$$\begin{array}{r} & & 1 \\ 001101 & + & 1 \\ \hline 110011 \end{array}$$

2's complement of  $110011$  is  $001100$

$$+ \underline{1}$$

$$001101$$

$$\begin{array}{r} 111 \\ 010110 \\ + \underline{001101} \\ \hline 1000\ 11 \end{array}$$

2's complement of  $100011$  is  $011100$

$$+ \underline{1}$$

$$011101$$

$$\begin{aligned} (-42)_{10} - (-33)_{10} &= (-101010)_2 - (-001101)_2 \\ &= -(011101)_2 \\ &= -29 \\ &= +(29)_{10} \end{aligned}$$

10. Perform the subtraction with the following unsigned numbers by taking the 2's complement of the subtrahend.

(a)  $11010 - 10000$

2's complement of  $10000$  is;

$1111$  carry

$01111$  2's complement

$$\begin{array}{r} + \underline{1} \\ \hline 10000 \end{array}$$

$$\begin{array}{r}
 11010 \\
 + 10000 \\
 \hline
 \boxed{1}01010
 \end{array}$$

$$(11010)_2 - (10000)_2 = (01010)_2$$

$$(b) 11010 - 01101$$

2's complement of 01101 is 10010

$$\begin{array}{r}
 + 1 \\
 \hline
 10011
 \end{array}$$

1                  carry

$$\begin{array}{r}
 11010 \\
 + 10011 \\
 \hline
 \boxed{1}01101
 \end{array}$$

$$(11010)_2 - (01101)_2 = (01101)_2$$

# ASSIGNMENT-1

15/10/2015

Page No. 1 / 10

જ્યોતિસ્વામિનારાયણ

Dt.: / / Pg no.:

1. A digital computer has a common bus system for 16 registers of 32 bit each. The bus is constructed with multiplexers.

(a) How many selection inputs are there in each multiplexer?

→ 4 selection inputs are there in each multiplexer.

(b) What size of multiplexers are needed?

→  $16 \times 1$  sized multiplexers is needed.

(c) How many multiplexers are there in the bus?

→ 32 multiplexers are there in the bus.

2. The following transfer statements specify a memory. Explain the memory operation in each case.

(a)  $R_2 \leftarrow M [AR]$

→ Read memory word specified by the address in AR into register  $R_2$ .

i.e. It would transfer the contents of Memory word that has the address specified by AR into register  $R_2$ .

$$(b) M[AR] \leftarrow R_3$$

→ Write content of register  $R_3$  into the memory word specified by the address in AR.

$$(c) R_5 \leftarrow M[R_5]$$

→ Read memory word specified by the address in  $R_5$  and transfer context to the same register  $R_5$  (over writing the previous value)

3. Draw the Binary adder - subtractor circuit which has the following values for input mode M and data inputs A and B. In each case, determine the values of the output:  $S_3, S_2, S_1, S_0$  and  $C_4$ .



|     | M | A    | B    | Operation |
|-----|---|------|------|-----------|
| (a) | 0 | 0111 | 0110 | 7 + 6     |
| (b) | 0 | 1000 | 1001 | 8 + 9     |
| (c) | 1 | 1100 | 1000 | 12 - 8    |
| (d) | 1 | 0101 | 1010 | 5 - 10    |
| (e) | 1 | 0000 | 0001 | 0 - 1     |

(a)  $C_0 = 0$

$$\begin{array}{r}
 11 \\
 0111 \\
 + \underline{0120} \\
 \hline S = 1101 \Rightarrow C_4 = 0
 \end{array}
 \quad \text{carry}$$

(b)  $C_0 = 0$

$$\begin{array}{r}
 1000 \\
 + \underline{1001} \\
 \hline S = 0001, C_4 = 1
 \end{array}$$

(c)  $C_0 = 1$

$$\begin{array}{r}
 1100 \\
 + \underline{1000} \\
 \hline S = 0100, C_4 = 1
 \end{array}$$

(d)  $C_0 = 1$

$$\begin{array}{r}
 0101 \\
 + \underline{0110} \\
 \hline S = 1011, C_4 = 0
 \end{array}$$

$$\text{ce) } C_0 = 1$$

$$\begin{array}{r}
 0000 \\
 + \underline{1111} \\
 \hline
 1111
 \end{array}
 \quad S = 1111, C_4 = 0$$

|   | $S_3$ | $S_2$ | $S_1$ | $S_0$ | $C_4$ |
|---|-------|-------|-------|-------|-------|
| a | 1     | 1     | 0     | 1     | 0     |
| b | 0     | 0     | 0     | 1     | 1     |
| c | 0     | 1     | 0     | 0     | 1     |
| d | 1     | 0     | 1     | 1     | 0     |
| e | 1     | 1     | 1     | 1     | 0     |

4. Design a 4-bit combinational circuit

decremented using four-full adder circuits

Soln:

$$\begin{aligned}
 A-1 &= A + 2^4 \text{ complement of } 1 \\
 &= A + 1111
 \end{aligned}$$



5. Design a digital circuit that performs the four logic operations of exclusive-OR, exclusive-NOR, NOR and NAND. use two selection variables. Show the logic diagram of one typical stage.

$A_i$     $B_i$



| $S_1$ | $S_0$ | $Y$                | Operation |
|-------|-------|--------------------|-----------|
| 0     | 0     | $A \oplus B$       | X-OR      |
| 0     | 1     | $A \odot B$        | X-NOR     |
| 1     | 0     | $\overline{A + B}$ | NOR       |
| 1     | 1     | $\overline{AB}$    | NAND      |

→ Logic diagram of one typical stage

Let  $A_i = 1$

$B_i = 0$

and  $S_1 = 0$ ,  $S_0 = 1 \Rightarrow x\text{-NOR gate is selected.}$

$$\begin{aligned} Y &= A_i \odot B_i \\ &= 1 \odot 0 \\ \therefore Y &= 0 \end{aligned}$$

$$A=1 \quad B_i=0$$



6. Register A holds the 8 bit binary 11011001. Determine the B operand and the logic microoperation to be performed in order to change the value in A to :

(a) 01101101      (b) 11111101

Sol<sup>n</sup>:

(a)

$$A \rightarrow 11011001$$

$$B \rightarrow \underline{10110000}$$

$$A^+ \rightarrow 01102101$$

$$A^+ = A \oplus B \quad [x\text{-OR}] \quad \text{selective complement}$$

$$(b) \quad A \rightarrow 11011001$$

$$B \rightarrow \underline{11111101}$$

$$A^+ \rightarrow \underline{11111101}$$

$A^+ = A + B$  [OR]  $\rightarrow$  Selective set

7. The 8-bit registers AR, BR, CR and DR initially have the following values

$$AR = 11110010 \quad CR = 10111001$$

$$BR = 11111111 \quad DR = 11101010$$

Determine the 8-bit values in each register after the execution of the following sequence of microoperations.

$$AR \leftarrow AR + BR$$

$$CR \leftarrow CR \wedge DR, \quad BR \leftarrow BR + 1$$

$$AR \leftarrow AR - CR$$

Sol:

$$\begin{array}{r} 11111111 \\ + 11101010 \\ \hline \end{array}$$

$$AR + BR \Rightarrow \underline{11110010}$$

$$+ \underline{11111111}$$

$$\boxed{111100001}$$

$$AR = 11110001$$

$$CR \wedge DR \Rightarrow \underline{10111001}$$

$$11101010$$

$$\hline 10101000$$

$$CR = 10101000$$

$$\begin{array}{r}
 1111111 \\
 BR + 1 \Rightarrow 1111111 \\
 + \underline{\quad \quad \quad 1} \\
 \boxed{0000000} \\
 BR = 0000000
 \end{array}$$

$$\begin{array}{r}
 \cdot 1 \cdot 11 \\
 AR - CR \Rightarrow 1110010 \\
 + \underline{01000111} \\
 \boxed{00111001} \\
 AR = 00111001
 \end{array}$$

| Micro operation         | AR       | BR       | CR       | DR       |
|-------------------------|----------|----------|----------|----------|
| Initially               | 1110010  | 1111111  | 10111001 | 11101010 |
| $AR \leftarrow AR + BR$ | 1110001  | 1111111  | 10111001 | 11101010 |
| $CR \leftarrow CR ^ DR$ | 1110001  | 1111111  | 10101000 | 11101010 |
| $BR \leftarrow BR + 1$  | 1110001  | 00000000 | 10101000 | 11101010 |
| $AR \leftarrow AR - CR$ | 01001001 | 00000000 | 10101000 | 11101010 |

8. An 8 bit register contains the binary value 10011100. What is the register value after

an arithmetic shift right 2. Starting from the initial number 10011100. determine the register value after an arithmetic shift left, and state whether there is an overflow.

Sol<sup>n</sup>:  $R = 10011100$

→ Register value after right shift,

$$R = 11001110$$

→ Register value after left shift.

$$R = 00111000$$

There is an overflow condition because a negative no. changes to positive no.

9. Represent the following conditional control statement by two register transfer statements with control functions.

if  $(P=1)$  then  $R_1 \leftarrow R_2$  else if  $(Q=1)$  then  $R_1 \leftarrow R_3$

Sol<sup>n</sup>:

$$P : R_1 \leftarrow R_2$$

$$P'Q : R_1 \leftarrow R_3$$

10. What is wrong with the following register transfer statements?

(a)  $xT : AR \leftarrow AR', AR \leftarrow 0$

→ We cannot perform two microoperations 'complement' and 'clear' at same time on same register.

(b) y T :  $R_1 \leftarrow R_2, R_2 \leftarrow R_3$

→ We cannot transfer two different values ( $R_2$  and  $R_3$ ) to the same register ( $R_1$ ) at same time.

(c) z T :  $PC \leftarrow AR, PC \leftarrow PC + 1$

→ We cannot transfer a new value into register (PC) and increment the original value by one at the same time. Both are conflicting microoperations.

## ASSIGNMENT - 2

જ્યે સ્વામિનારાચારા  
Date: / / Pg no.:

1. A computer uses a memory unit with 256 K words of 32 bit each. A binary instruction code is stored in one word of memory. The instruction has four parts: an indirect bit, an operation code, a register code part to specify one of 64 registers and an address part.
- (a) How many bits are there in the operation code, the register code part, and the address part?

→ Indirect = 1 bit

$$\begin{aligned} \text{Address} &= 2^8 (\text{256 KB}) * 2^{10} (\text{1024 byte/1KB}) \\ &= 2^{18} \Rightarrow 18 \text{ bits} \end{aligned}$$

$$\text{Register (64 registers)} = 2^6 \Rightarrow 6 \text{ bits}$$

$$\text{Opcode } 32 - 1 - 18 - 6 = 7 \text{ bits}$$

- (b) Draw the instruction word format and indicate the number of bits in each part.

→ Instruction word Format

| Indirect | Op-code | Register | Address |
|----------|---------|----------|---------|
| 1        | 7       | 6        | 18      |
| 32 bit   |         |          |         |

2. What is the difference between a direct and indirect address instruction? How many references to memory are needed for each type of instruction to bring an operand into a processor register?

### Direct Address Instruction

1. Address field contains the effective address of operand.
2. Requires only one memory reference.
3. Fast addressing.
4. No further classification.
5. No further calculation is required to perform the operation.

### Indirect Address Instruction

Address field contains reference of effective address.

Requires two memory references.

Slower than direct addressing mode.

Further classified into two categories.

Require further calculation to find the effective address.

→ A direct address instruction needs two references to memory. (J) Read instruction

(2) Read operand

→ An indirect address instruction needs three references to memory (1) Read instruction

(2) Read effective address (3) Read operand.

3. What are the two instruction needed in the basic computer in order to set the E flip flop to 1?

Soln: CLE clear E

CME complement E

4. An output program resides in memory starting from address 2300. It is executed after the computer recognizes an interrupt when FGO becomes a 1 (while IEN = 1)

5. Explain following terms :

(a) Instruction code

→ An instruction code is a group of bits that instruct the computer to perform a specific operation.

(b) Operation code

→ The operation code of an instruction is a group of bits that define operations such group of bits that as addition, subtraction, shift, complement etc.

(c) Effective Address

→ The effective address is a term that describes the address of an operand that is stored in memory.

6. Draw and Explain the common bus system for a basic computer registers.

Ans: The computer uses a common bus system for transferring information from register to register or between registers and memory instead of one to one connections to avoid excessive connections.

→ The control inputs LD (Load) and EN (Enable) are used to load data into register from



common bus and to send data from register on to the common bus, respectively. The 3:8 decoder is used to select the specific register whose data to be sent on the common bus.

- The register AR, PC, DR and AC have a CLR (Clear) and INP inputs along with LD and OE inputs. There is register IR is used only to hold instruction read from memory so it does not have INR and CLR as control signals.
- Registers DR, AC, IR and TR are 16-bit registers. On the other hand, AR and PC are 22-bit registers, thus they hold a 22-bit memory address.
- INPR and OUTR are the 8-bit registers and they communicate with the eight least significant bits in the bus. INPR receives a character from an input device which is then transferred to AC register, thus it serves as an information provider. OUTR receives a character from AC and delivers it to an output device.
- AR register provides address to the memory and

data input and data output of memory is connected to the common bus. The ALU has three 16-bit input sources and 16-bit destination, i.e. AC register. The three 16-bit input source are AC, DR and INPR registers. The ALU performs arithmetic and logic micro-operations and result is transferred to the AC register. Thus AC gets input from ALU.

→ In this configuration, the contents of any register can be applied onto the bus and an operation can be performed in the ALU during the same clock cycle.

7. Draw and explain the control unit of basic computer.

Ans: Control unit (CU) of a processor translates from machine instructions to the control signal for the micro-operations that implement them.

→ Control units are implemented in one of two ways:

(1) Hard wired Control

CU is made up of sequential and combinational circuits to generate the control signals.



## (2) Microprogrammed Control

A control memory on the processor contains microoperations, microprograms that activate the necessary control signals.

→ We will consider a hardwired implementation of the control unit for the basic computer.

8. Explain Instruction cycle with the help of flow chart.

Ans:

A program residing in the memory unit of the computer consists of a sequence of instructions. In the basic computer each instruction cycle consists of following phases.

- (a) Fetch an instruction from memory
- (b) Decode the Instruction
- (c) Read the effective address from memory if the instruction has an indirect address.
- (d) Execute the instruction.

→ After step 4, control goes back to step 1 to fetch, decode and execute the next instruction. This process continues unless a HALT instruction is encountered.



Control signals

IS  
e



- IF  $D_f = 1$ , the instruction must be register-reference or input-output type. IF  $D_f = 0$ , the operation code must be one of the other seven values 110, specifying a memory-reference instruction.
- IF  $D_f = 0$  and  $I = 1$ , we have a memory-reference instruction with an indirect address. It is then necessary to read the effective address from memory.
- The selected operation is activated with the clock transition associated with timing signal  $T_3$ . This can be symbolized as :

$D' \neq I$   $T_3$  :  $AR \leftarrow M[AR]$

$D' = I$   $T_3$  : Nothing

$D' \neq I$   $T_3$  : Execute register reference inst.

$D' = I$   $T_3$  : Execute input output instruction

- When a memory - reference instruction with  $I=0$  is encountered it is not necessary to do anything since the effective address is already in AR.
- However, the sequence counter SC must be incremented when  $D' \neq I$   $T_3 = 1$ . So that the execution of the memory reference instruction can be continued with timing variable  $T_4$ .
- A register reference or input-output instruction can be executed with the click associated with timing signal  $T_3$ . After the instruction is executed, SC is cleared to 0 and control I returns to fetch phase with  $T_0 = 1$ . SC is either incremented or cleared to 0 with every positive clock transition.

#### 9. Explain interrupt cycle with the flowchart.

Ans: The interrupt cycle is a hardware implementation of a branch and save return address operation.

- An interrupt flip-flop R is included in the computer.



→ When  $R=0$ , the computer goes through an instruction cycle. During the execute phase of the instruction cycle IEN is checked by the control.

→ If it is 0, it indicates that the programmer doesn't want to use the interrupt, so control continues with the next instruction cycle. If IEN is 1, control checks the Flag bits.

If both flags are 0, it indicates that neither the input nor the output register are ready for transfer of information.

- In this case, control continues with the next instruction cycle. If either flag is set to 1 while  $IEN=1$ , flip-flop R is set to 1. At the end of the execute phase, control checks the value of R, and if it is equal to 1, it goes to an interrupt cycle instead of an instruction cycle.
- The flip-flop is set to 1 if  $IEN=1$  and either FGI or FGO are equal to 1. This can happen with any clock transition except when timing signals  $T_0$ ,  $T_1$  or  $T_2$  are active.
- The condition for setting Flip-Flop  $R=1$  can be expressed with the following register transfer statement:  
 $T_0' T_1' T_2' (IEN) (FGI + FGO) : R \leftarrow 1$
- The symbol + between FGI and FGO in the control function designates a logic OR operation. This is AND with IEN and  $T_0' T_1' T_2'$ . The fetch and decode phases of the instruction cycle must be modified and replace

$T_0, T_1, T_2$  with  $R'T_0, R'T_1, R'T_2$ .

Therefore the interrupt cycle statements are:

$RT_0 : AR \leftarrow 0, TR \leftarrow PC$

$RT_1 : M[AR] \leftarrow TR, PC \leftarrow 0$

$RT_2 : PC \leftarrow PC + 1, IEN \leftarrow 0, R \leftarrow 0, SC \leftarrow 0$



→ During the first timing signal AR is cleared to 0, and the content of PC is transferred to the temporary register TR. With the second timing signal, the return address is stored in memory at location 0 and PC is cleared to 0.

→ The third timing signal increments PC by 1, clears IEN and R, and control goes back to  $T_0$ .

are:

-o

by clearing SC to 0. The beginning of the next instruction cycle has the condition R To and the content of PC is equal to 1. The control then goes through an instruction cycle that fetches and executes the BUN instruction in location 1.

- Draw and Explain the design of Accumulator Logic.

Ans!



→ The adder and logic circuit has three sets of inputs. One set of 16 inputs comes from the output AC. Another set of 16 input comes from the data register DR. A third set of eight inputs comes from the input register INPR. The output of the adder and logic circuit provide the data inputs for register.

→ In addition, it is necessary to include logic gates for controlling the LD, INP and CLR in registers and for controlling the operation of the adder and logic circuit. In order to design the logic associated with AC, it is necessary to extract all the statements that change the content of AC.



$$D_0 T_5 : AC \leftarrow AC \wedge DR$$

AND with DR

$$D_1 T_5 : AC \leftarrow AC + DR$$

Add with DR

$$D_2 T_5 : AC \leftarrow DR$$

Transfer from DR

$$P B_{11} : AC (0-7) \leftarrow INPR$$

Transfer from INPR

$$\gamma B_9 : AC \leftarrow AC'$$

Complement

$$\gamma B_7 : AC \leftarrow Shr AC, ACC(15) \leftarrow E$$

Shift right

$\gamma B_6 : AC \leftarrow \text{shl} AC, ACC0) \leftarrow E$

Shift left

$\gamma B_{11} : AC \leftarrow 0$

clear

$\gamma B_5 : AC \leftarrow AC + 1$

Increment

- The control function for the clear microoperation is  $\gamma B_{11}$ , where  $\gamma = D_7 I' T_2$  and  $B_{11} = IR(11)$ . The output of the AND gate that generates this control function is connected to the CLR input of the register.
- Similarly, the output of the gate that implements the increment microoperation is connected to the INR input of register.
- The other seven microoperations are generated in the adder and logic circuit and are loaded into AC at the proper time.
- The output of the gates for each control function are marked with a symbolic name and used in the design of the adder and logic circuit.

# ASSIGNMENT-3

જ્યે સ્વામિનારાયણ

Dt.: / / Pg.no.:

1. Write an assembly level program for the following pseudocode.

$$\text{SUM} = 0$$

$$\text{SUM} = \text{SUM} + A + B$$

$$\text{DIF} = \text{DIF} - C$$

$$\text{SUM} = \text{SUM} + \text{DIF}$$

Ans:

|         |                         |
|---------|-------------------------|
| CLA     | / SUM = 0               |
| STA SUM |                         |
| LDA SUM | / Load current sum      |
| ADD A   | / Add A to sum          |
| ADD B   | / Add B to sum          |
| STA SUM | / Save sum              |
| LDA C   | / Load C to AC          |
| CMA     | / Create 2's complement |
| JNC     |                         |
| ADD DIF | / Subtract C from DIF   |
| STA DIF | / Save DIF              |
| ADD SUM | / Add SUM to DIF        |
| STA SUM | / Save SUM              |
| HLT     | / Halt                  |

2. Write a program loop using a pointer and a counter to clear the contents of hex locations 500 to 5FF with 0.

Ans:

|              |                             |
|--------------|-----------------------------|
| LDA NBR      | ; Initialize counter        |
| CMA          | ; 2's complement of NBR INC |
| STA CTR      | ; save- NBR to counter      |
| LDA ADR      | ; Save start address        |
| STA PTR      | ; Initialize pointer PTR    |
| LOP , CLA    | ; Clear AC                  |
| STA PTR1     | ; Reset memory word         |
| ISZ PTR      | ; Increment pointer         |
| ISZ CTR      | ; Increment counter         |
| BUN LOP      | ; Branch to LOP (CTR < 0)   |
| HLT          | ; Halt when CTR=0           |
| NBR, HEX FF  | ; NBR of cleared words      |
| CTR, -       | ; Counter                   |
| ADR, HEX 500 | ; Start Address             |
| PTR, -       | ; Pointer                   |

3. What is an assembler? Explain the first pass of an assembler with a flowchart.

Ans: An assembler is a program that accepts a symbolic language program and produces its binary machine language equivalent.

- The input symbolic program is called the source program and the resulting binary program is called the logic object program.
- The assembler is a program that operates on character strings and produces an equivalent binary interpretation.



→ First Pass of an Assembler :

- During the First pass, it generates a table that correlates all user-defined address symbols with their binary equivalent value.
- The binary translation is done during the second pass.
- To keep track of the location of instructions, the assembler uses a memory word called a location counter.

- The content of LC stores the values of the memory location assigned to the instruction or operand presently being processed.
- The ORG pseudo instruction initializes the location counter to the value of first location.
- Since instruction are stored in sequential locations, the content of LC is incremented by 1 after processing each line of code.
- To avoid ambiguity in case ORG is missing, the assembler sets the location counter to 0 initially.
- The task performed by the assembler during the first pass are described in the flowchart.
- LC is initially set to 0.
- A line of symbolic code is analyzed to determine if it has a label.
- If the line of code has no label, the assembler checks the symbol in the instruction field.
- If it contains an ORG pseudo instruction, the assembler sets LC to number that follows ORG and goes back to process the next line.
- If the line has an END pseudo instruction, the assembler terminates the first pass and goes to the second pass.
- If the line of code contains a label, it is stored in the address symbol table.

together with its binary equivalent number specified by the content of LC. Nothing is stored in the table if no label is encountered.

- LC is then incremented by 1 and a new line of code is processed.
4. Explain the working of second pass Assembly with its flowchart.

Ans: Machine instructions are translated during the second pass by means of table-look up procedure.

- During the second pass, the assembler examines the operands for symbolic references to storage locations and resolves these symbolic references using information in the symbol table.
- On the second pass, the assembler:
  - Examines the operands for symbolic reference to storage locations and resolves these symbolic reference using information in the symbol table.
  - Ensure that no instructions contain an invalid instruction form
  - Translates source statements into machine code and constants, thus filling the allocated space with object code.

Second Pass

 $LC \leftarrow 0$ 

Scan next line of code

Done

Pseudo  
Instruction

Set LC

ORG

yes

END

no

yes

MRI

no

Decompose

Convert  
operand to  
binary and  
store in  
location given  
by LC.Get operation code  
and set bit 2-4Valid  
non-MRI  
Instruction

yes

no

Store binary  
equivalent of  
instruction in  
location given  
by LCError in  
line of  
code

I

Set first  
bit to 1Set first  
bit to 0Assemble all parts of  
binary instruction and  
store in location by LC

Increment LC

- Produces a file containing error message, if any have occurred.
  - At the beginning of the second pass, the assembler scans each source statements a second time. As the assembler translates each instruction, it increments the value contained in the location counter.
5. Write the program to multiply two positive numbers by a repeated addition method. For ex. to multiply  $5 \times 4$ , the program evaluates the product by adding 5 four times, or  $5 + 5 + 5 + 5$ .

Ans:

```

ORG 100 ; Origin of program is HEX 100
LDA X ; Load first add. of operand
STA PTR ; Store in pointer
LDA NBR ; load minus second operand
STA Y ; Store in counter
CLA ; Clear accumulator
LOP ADD PTR I ; Add an operand to AC
ISZ Y ; increment counter
BUN LOP ; Repeat loop again
STA MUL ; Store sum
HLT ; Halt
X, DEC 5 ; First operand
PTR, HEX 0 ; This loc. reserved for a pointer.

```

NBR, DEC - 4 ; second operand  
 CTR, HEX 0 ; This loc. reserved for a pointer  
 MUL, HEX 0 ; Sum is stored here  
 END ; End of symbolic program

6. Write a program that evaluates the logic ex-or of two logic operands.

Ans:  $Z = X \oplus Y = XY' + X'Y = [C(XY')]'.C(X'Y)']'$

LDA y  
 CMA  
 AND X  
 CMA  
 STA TMP  
 LDA X  
 CMA  
 AND Y  
 CMA  
 AND TMP  
 CMA  
 STA Z  
 HLT

X, ...

Y, ...

Z, ...

TMP, ...

7. Write a program for the arithmetic shift-left operation. Branch to OVF if an overflow occurs.

Ans:

```

LDA X
CLE
CIL ; Zero to low order bit
SIZE
BUN ONE
SPA
BUN OVF
BUN EXT
ONE, SNA
BUN OVF
EXT, HLT
    
```



9. Write an assembly language program to multiply two positive numbers.

ORG 200  
 LOP, CLE ; Clear E  
 LDA Y ; Load multiplier  
 CIR ; Transfer multiplier bit to E  
 STA Y ; Store shifted multiplier  
 SZE ; check if bit is zero  
 BUN ONE ; Bit is one, go to ONE  
 BUN ZRO ; Bit is zero, go to ZERO  
 ONE, LDA X ; Load Multiplicand  
 ADD P ; Add to partial product  
 STA P ; store partial product  
 CLE ; Clear E  
 ZRO, LDA X ; load multiplicand  
 CIL ; Shift left  
 STA X ; store shifted multiplicand  
 ISZ CTR ; Increment counter  
 BUN LOP ; Counter not zero; repeat loop  
 HLT ; Counter is zero halt  
 CTR, DEC = 8 ; This location serves as a counter  
 X, HEX 000F ; Multiplicand stored here  
 Y, HEX 000B ; Multiplier stored here  
 P, HEX 0 ; Product formed here  
 END ; END of symbolic program.

20. Write an assembly language program to Add two double precision numbers.

Ans:

|         |                                   |
|---------|-----------------------------------|
| LDA AL  | ; Load A low                      |
| ADD BL  | ; Add B low, Carry in E           |
| STA CL  | ; Store in C Low                  |
| CLA     | ; clear AC                        |
| CIL     | ; Circulate to bring into AC (16) |
| ADD AH  | ; Add A high and carry            |
| ADD BH  | ; Add B high                      |
| STA CH  | ; Store C high                    |
| HLT     | ; Increment counter C             |
| AL, ... | ; Locations of operand            |
| AH, ... |                                   |
| BL, ... |                                   |
| BH, ... |                                   |
| CL, ... |                                   |
| CH, ... |                                   |
| END     | ; End of symbolic program.        |

8. For the given program below :

- (a) Explain in words what the program accomplishes when it is executed. What is the value of location CTR when the computer halts?
- (b) List the address symbol table obtained during the first pass of the assembler.

ORG 100

CLE

CLA

STA CTR

LDA WRD  
SZA  
BUN ROT  
BUN STP  
ROT. CIL  
SZE  
BUN AGN  
BUN ROT  
AGN, CLE  
ISZ CTR  
SZA  
BUN ROT  
STP, HLT  
CTR, HEX O  
WRD, HEX  
END