# Design

**Computer Architecture** 

#### 1-<u>CPU</u>



CPU

Figure 1: CPU Diagram



Figure 2: CPU Circuit

# 2- ALSU Functions

|         | S <sub>3</sub> | S <sub>2</sub> | <b>S</b> <sub>1</sub> | S <sub>0</sub> | Cin =0                      | Cin = 1    |
|---------|----------------|----------------|-----------------------|----------------|-----------------------------|------------|
| Part A  | 0              | 0              | 0                     | 0              | F = A                       | F = A+1    |
|         | 0              | 0              | 0                     | 1              | F = A + B                   | F = A+ B+1 |
| PallA   | 0              | 0              | 1                     | 0              | F = A-B-1                   | F = A-B    |
|         | 0              | 0              | 1                     | 1              | F= A- 1                     | F = 0      |
| Part B  | 0              | 1              | 0                     | 0              | F = A and B                 |            |
|         | 0              | 1              | 0                     | 1              | F = A or B                  |            |
|         | 0              | 1              | 1                     | 0              | F = A xor B                 |            |
|         | 0              | 1              | 1                     | 1              | F = Not A                   |            |
|         | 1              | 0              | 0                     | 0              | F=Logic shift right A       |            |
| Don't C | 1              | 0              | 0                     | 1              | F=Rotate right A            |            |
| Part C  | 1              | 0              | 1                     | 0              | F=Rotate right A with Carry |            |
|         | 1              | 0              | 1                     | 1              | F=Arithmatic shift          | right A    |
| Part D  | 1              | 1              | 0                     | 0              | F=Logic shift left A        |            |
|         | 1              | 1              | 0                     | 1              | F=Rotate left A             |            |
|         | 1              | 1              | 1                     | 0              | F=Rotate left A with Carry  |            |
|         | 1              | 1              | 1                     | 1              | F = Arithmatic shift        | left A     |

Figure 3: ALSU Functions

### 3-<u>CU</u>



# 4-CW functions

| F0                                                                                             | F1                                                                                                                                                                                                                                                                                   | F7                                                                                                                                                                       | 2 F                                                                       |
|------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| F0 (8 bits)                                                                                    | F1 (4 bits)                                                                                                                                                                                                                                                                          | F2 (3 bits)                                                                                                                                                              | F3 (2 bits)                                                               |
| Address of next<br>microinstruction                                                            | 0000: No transfe<br>0001: PC <sub>out</sub><br>0010: MDR <sub>out</sub><br>0011: Z <sub>out</sub><br>0100: Rsrc <sub>out</sub><br>0101: Rdst <sub>out</sub><br>0110: SPout<br>1000: SOURCE <sub>o</sub><br>1001: DESTIN <sub>ou</sub><br>1010: TEMP <sub>out</sub><br>1011: Addresse | 001: PC <sub>in</sub><br>010: IR <sub>in</sub><br>011: Z <sub>in</sub><br>100: Rsrc <sub>in</sub><br>101: Rdst <sub>in</sub><br>110: SPin                                | 00: No trer<br>01: MAR <sub>in</sub><br>10: MDR <sub>in</sub><br>11: TEMP |
| F4                                                                                             | F5                                                                                                                                                                                                                                                                                   | F6                                                                                                                                                                       | F7                                                                        |
| F4 (2 bits)                                                                                    | F5 (4 bits)                                                                                                                                                                                                                                                                          | F6 (2 bits)                                                                                                                                                              | F7 (1 bit)                                                                |
| 00: No transfer<br>01: Y <sub>in</sub><br>10: SOURCE <sub>in</sub><br>11: DESTIN <sub>in</sub> | in ALSU file                                                                                                                                                                                                                                                                         | 00: No action<br>01: Read<br>10: Write<br>11: HLT                                                                                                                        | 0: No action<br>1: Clear Y                                                |
| F8                                                                                             | . F9                                                                                                                                                                                                                                                                                 | F10                                                                                                                                                                      | F11                                                                       |
| F8 (1 bit)                                                                                     | F9 (1 bit)                                                                                                                                                                                                                                                                           | F10 (3 bits)                                                                                                                                                             | F11 (1 bit)                                                               |
| 0: Carry-in = 0<br>1: Carry-in = 1                                                             | 0: No action<br>1: FLAGS_E                                                                                                                                                                                                                                                           | 000: No action<br>001: OR <sub>dst</sub><br>010: OR <sub>inddec</sub><br>011: OR <sub>inddet</sub><br>100: OR <sub>result</sub><br>101: OR2op<br>110: OR0p<br>111: OR1op | 0: No action 1: PLA <sub>cut</sub>                                        |

Figure 5: CW Functions

#### 5-BitOring Circuit



#### 6-ROM instructions



Figure 7: fetching Source & Branch operations & RTS



Figure 8: fetching Destination



Figure 9: Operation ORing & JSR



Figure 10: 2-Operand operations



Figure 11: 1-Operand operations