# **Computer System Architectures**

# BASIC COMPUTER ORGANIZATION AND DESIGN

#### System Buses:

- The major computer system components (processor, main memory, I/O modules) need to be interconnected in order to exchange data and control signals
- A bus is a communication pathway connecting two or more devices
- A bus that connects major computer components (processor, memory, I/O) is called a system bus.
- Bus = a shared transmission medium. Only one device at a time can successfully transmit.
  - shared system bus consisting of multiple lines
  - A hierarchy of buses to improve performance.
- Key design elements for buses include: Arbitration, Timing, width

## Multiple Bus Hierarchies:

- In general, the more devices attached to the bus, the greater the bus length and hence the greater the propagation delay.
- The bus may become a bottleneck as the aggregate data transfer demand approaches the capacity of the bus.

#### **Synchronous Buses:**

- Synchronous buses include a clock line between the control lines, line that is controlled by a clock quartz oscillator, usually between 5 133 MHz
- All the transfers on the system bus have a fixed protocol related to the clock signal, and it is developed along an integer number of cycles, called bus cycles.
- The advantages of a synchronous bus are a high speed of transfer, the very simple implied logic
- The disadvantage comes from transfers that can be shorter than the time corresponding to the integer number of bus cycles.

## **Introduction of Basic Computer:**

- Every different processor type has its own design (different registers, buses, Microoperations, machine instructions, etc)
- Modern processor is a very complex device
- It contains
  - Many registers
  - Multiple arithmetic units, for both integer and floating point calculations
  - The ability to pipeline several consecutive instructions to speed execution etc.
  - However, to understand how processors work, we will start with a simplified processor model
  - This is similar to what real processors were like ~25 years ago
  - M. Morris Mano introduces a simple processor model he calls the *Basic Computer*
  - We will use this to introduce processor organization and the relationship of the RTL model to the higher level computer processor.

- The Basic Computer has two components, a processor and memory
- The memory has 4096 words in it
  - $4096 = 2^{12}$ , so it takes 12 bits to select a word in memory
- Each word is 16 bits long.



## **Instructions:**

- Program
  - A sequence of (machine) instructions
- (Machine) Instruction
  - A group of bits that tell the computer to *perform a specific operation* (a sequence of micro-operation)
- The instructions of a program, along with any needed data are stored in memory
- The CPU reads the next instruction from memory
- It is placed in an *Instruction Register* (IR)
- Control circuitry in control unit then translates the instruction into the sequence of Microoperations necessary to implement it.

## Stored program organization



#### **Instruction Format:**

- A computer instruction is often divided into two parts
  - An *opcode* (Operation Code) that specifies the operation for that instruction
  - An *address* that specifies the registers and/or locations in memory to use for that operation
- In the Basic Computer, since the memory contains  $4096 (= 2^{12})$  words, we needs 12 bit to specify which memory address this instruction will use
- In the Basic Computer, bit 15 of the instruction specifies the *addressing mode* (0: direct addressing, 1: indirect addressing)
- Since the memory words, and hence the instructions, are 16 bits long, that leaves 3 bits for the instruction's opcode.

| 15 14 12 1      | 11 0    | _ |
|-----------------|---------|---|
| I Opcode        | Address |   |
| Addressing mode |         | - |

Instruction Format

#### **Addressing Modes:**

The address field of an instruction can represent either

- Direct address: the address in memory of the data to use (the address of the operand), or
- Indirect address: the address in memory of the address in memory of the data to use.



#### **Effective Address (EA)**

• The address, which can be directly used without modification to access an operand for a computation-type instruction, or as the target address for a branch-type instruction.

#### **Processor Registers:**

- A processor has many registers to hold instructions, addresses, data, etc
- The processor has a register, the *Program Counter* (PC) that holds the memory address of the next instruction to get

#### College of Engineering

- Since the memory in the Basic Computer only has 4096 locations, the PC only needs 12 bits,
- In a direct or indirect addressing, the processor needs to keep track of what locations in memory it is addressing: The *Address Register* (AR) is used for this
  - The AR is a 12 bit register in the Basic Computer,
- When an operand is found, using either direct or indirect addressing, it is placed in the *Data Register* (DR). The processor then uses this value as data for its operation
- The Basic Computer has a single general purpose register the Accumulator (AC).
- The significance of a general purpose register is that it can be referred to in instructions
  - e.g. load AC with the contents of a specific memory location; store the contents of AC into a specified memory location
- Often a processor will need a scratch register to store intermediate results or other temporary data; in the Basic Computer this is the *Temporary Register* (TR)
- The Basic Computer uses a very simple model of input/output (I/O) operations
  - Input devices are considered to send 8 bits of character data to the processor
  - The processor can send 8 bits of character data to output devices
  - The Input Register (INPR) holds an 8 bit character gotten from an input device
- The Output Register (OUTR) holds an 8 bit character to be sent to an output device.

## Basic computer registers and memory



| List of | f Register | for the | e basic | computer |
|---------|------------|---------|---------|----------|
|---------|------------|---------|---------|----------|

| Register<br>symbol | Number<br>of bits | Register name        | Function                     |
|--------------------|-------------------|----------------------|------------------------------|
| DR                 | 16                | Data register        | Holds memory operand         |
| AR                 | 12                | Address register     | Holds address for memory     |
| AC                 | 16                | Accumulator          | Processor register           |
| IR                 | 16                | Instruction register | Holds instruction code       |
| PC                 | 12                | Program counter      | Holds address of instruction |
| TR                 | 16                | Temporary register   | Holds temporary data         |
| INPR               | 8                 | Input register       | Holds input character        |
| OUTR               | 8                 | Output register      | Holds output character       |

#### **Common Bus System:**

- The registers in the Basic Computer are connected using a bus.
- This gives a savings in circuitry over complete connections between registers.





• Three control lines,  $S_2$ ,  $S_1$ , and  $S_0$  control which register the bus selects as its input:

| •        |
|----------|
| Register |
| x        |
| AR       |
| PC       |
| DR       |
| AC       |
| IR       |
| TR       |
| Memory   |
|          |

- Either one of the registers will have its load signal activated, or the memory will have its read signal activated
  - Will determine where the data from the bus gets loaded
- The 12-bit registers, AR and PC, have 0's loaded onto the bus in the high order 4 bit positions

When the 8-bit register OUTR is loaded from the bus, the data comes from the low order 8 bits on the bus.

## **Basic Computer Instruction Format:**



A computer should have a set of instructions so that the user can construct machine language programs to evaluate any function that is known to be computable.

## **Instruction Types:**

- Functional Instructions
  - Arithmetic, logic, and shift instructions
  - ADD, CMA, INC, CIR, CIL, AND, CLA
- Transfer Instructions
  - Data transfers between the main memory and the processor registers
  - LDA, STA
- Control Instructions
  - Program sequencing and control
  - BUN, BSA, ISZ
- Input/output Instructions
  - Input and output
  - INP, OUT.

|        | Hexadec | imal code |                                      |
|--------|---------|-----------|--------------------------------------|
| Symbol | I = 0   | I = 1     | Description                          |
| AND    | 0xxx    | 8xxx      | AND memory word to AC                |
| ADD    | 1xxx    | 9xxx      | Add memory word to AC                |
| LDA    | 2xxx    | Axxx      | Load memory word to AC               |
| STA    | 3xxx    | Bxxx      | Store content of AC in memory        |
| BUN    | 4xxx    | Cxxx      | Branch unconditionally               |
| BSA    | 5xxx    | Dxxx      | Branch and save return address       |
| ISZ    | 6xxx    | Exxx      | Increment and skip if zero           |
| CLA    | 78      | :00       | Clear AC                             |
| CLE    | 74      | -00       | Clear E                              |
| CMA    | 72      | .00       | Complement AC                        |
| CME    | 71      | .00       | Complement E                         |
| CIR    | 70      | 80        | Circulate right $AC$ and $E$         |
| CIL    | 70      | 40        | Circulate left $AC$ and $E$          |
| INC    | 70      | 20        | Increment AC                         |
| SPA    | 70      | 10        | Skip next instruction if AC positive |
| SNA    | 70      | 08        | Skip next instruction if AC negative |
| SZA    | 70      | 04        | Skip next instruction if AC zero     |
| SZE    | 70      | 02        | Skip next instruction if $E$ is 0    |
| HLT    | 70      | 01        | Halt computer                        |
| INP    | F       | 300       | Input character to AC                |
| OUT    | F4      | 400       | Output character from AC             |
| SKI    | F       | 200       | Skip on input flag                   |
| SKO    | F       | 100       | Skip on output flag                  |
| ION    | F       | 080       | Interrupt on                         |
| IOF    | F       | 040       | Interrupt off                        |

#### **Basic Computer Instructions**

- Control unit (CU) of a processor translates from machine instructions to the control signals for the Microoperations that implement them
- Control units are implemented in one of two ways
- *Hardwired* Control
  - CU is made up of sequential and combinational circuits to generate the control signals
- Microprogrammed Control
  - A control memory on the processor contains Micro-programs that activate the necessary control signals
  - We will consider a hardwired implementation of the control unit for the Basic Computer

#### Hardwired/Microprogrammed:



#### **Timing and Control:**

Control unit of basic computer



#### **Timing Signals:**

Generated by 4-bit sequence counter and 4×16 decoder

- The SC can be incremented or cleared.
- Example: T0, T1, T2, T3, T4, T0, T1, . . . Assume: At time T4, SC is cleared to 0 if decoder output D3 is active.



#### **Instruction Cycle:**

- In Basic Computer, a machine instruction is executed in the following cycle:
  - Fetch an instruction from memory.
  - Decode the instruction.
  - Read the effective address from memory if the instruction has an indirect address.
  - Execute the instruction.
  - After an instruction is executed, the cycle starts again at step 1, for the next instruction.
- Note: Every different processor has its own (different) instruction cycle

## **Fetch and Decode:**

- $T_0: AR \leftarrow PC$
- $T_1: IR \leftarrow M[AR], PC \leftarrow PC + 1$
- $T_2$ :  $D_0, \ldots, D_7 \leftarrow$  Decode  $IR(12-14), AR \leftarrow IR(0-11), I \leftarrow IR(15)$



## **Determine the Type Of Instruction:**



- $D'_7 IT_3$ :  $AR \leftarrow M[AR]$
- $D'_7 I'T_3$ : Nothing
- $D_7 I'T_3$ : Execute a register-reference instruction
- D<sub>7</sub>IT<sub>3</sub>: Execute an input-output instruction

#### **Register Reference Instructions:**

Register Reference Instructions are identified when

-  $D_7 = 1$ , I = 0

- Register Ref. Instr. is specified in b<sub>0</sub> ~ b<sub>11</sub> of IR
- Execution starts with timing signal T<sub>3</sub>

r = D<sub>7</sub> I'T<sub>3</sub> => Register Reference Instruction B<sub>i</sub> = IR(i) , i=0,1,2,...,11

|     |                           | mmon to all register-reference instructions)<br>it in $IR(0-11)$ that specifies the operation] |                  |
|-----|---------------------------|------------------------------------------------------------------------------------------------|------------------|
|     | <i>r</i> :                | <i>SC</i> ← 0                                                                                  | Clear SC         |
| CLA | <i>rB</i> <sub>11</sub> : | $AC \leftarrow 0$                                                                              | Clear AC         |
| CLE | $rB_{10}$ :               | $E \leftarrow 0$                                                                               | Clear E          |
| CMA | <b>rB</b> 9:              | $AC \leftarrow \overline{AC}$                                                                  | Complement AC    |
| CME | <i>rB</i> <sub>8</sub> :  | $E \leftarrow \overline{E}$                                                                    | Complement E     |
| CIR | <b>rB</b> <sub>7</sub> :  | $AC \leftarrow \text{shr } AC, AC(15) \leftarrow E, E \leftarrow AC(0)$                        | Circulate right  |
| CIL | $rB_6$ :                  | $AC \leftarrow \text{shl } AC, AC(0) \leftarrow E, E \leftarrow AC(15)$                        | Circulate left   |
| INC | <b>rB</b> <sub>5</sub> :  | $AC \leftarrow AC + 1$                                                                         | Increment AC     |
| SPA | $rB_4$ :                  | If $(AC(15) = 0)$ then $(PC \leftarrow PC + 1)$                                                | Skip if positive |
| SNA | <i>rB</i> <sub>3</sub> :  | If $(AC(15) = 1)$ then $(PC \leftarrow PC + 1)$                                                | Skip if negative |
| SZA | $rB_2$ :                  | If $(AC = 0)$ then $PC \leftarrow PC + 1$                                                      | Skip if AC zero  |
| SZE | $rB_1$ :                  | If $(E = 0)$ then $(PC \leftarrow PC + 1)$                                                     | Skip if E zero   |
| HLT | $rB_0$ :                  | $S \leftarrow 0$ (S is a start-stop flip-flop)                                                 | Halt computer    |

**Memory Reference Instructions:** 

| Symbol | Operation<br>decoder | Symbolic description                             |
|--------|----------------------|--------------------------------------------------|
| AND    | $D_0$                | $AC \leftarrow AC \land M[AR]$                   |
| ADD    | $D_1$                | $AC \leftarrow AC + M[AR], E \leftarrow C_{out}$ |
| LDA    | $D_2$                | $AC \leftarrow M[AR]$                            |
| STA    | $D_3$                | $M[AR] \leftarrow AC$                            |
| BUN    | $D_4$                | $PC \leftarrow AR$                               |
| BSA    | D₅                   | $M[AR] \leftarrow PC, PC \leftarrow AR + 1$      |
| ISZ    | $D_6$                | $M[AR] \leftarrow M[AR] + 1,$                    |
|        |                      | If $M[AR] + 1 = 0$ then $PC \leftarrow PC + 1$   |

-The effective address of the instruction is in AR and was placed there during timing signal  $T_2$  when I = 0, or during timing signal  $T_3$  when I = 1

- Memory cycle is assumed to be short enough to complete in a CPU cycle

- The execution of MR instruction starts with T<sub>4.</sub>



D<sub>6</sub>T<sub>4</sub>: DR  $\leftarrow$  M[AR] D<sub>6</sub>T<sub>5</sub>: DR  $\leftarrow$  DR + 1 D<sub>6</sub>T<sub>4</sub>: M[AR]  $\leftarrow$  DR, if (DR = 0) then (PC  $\leftarrow$  PC + 1), SC  $\leftarrow$  0

12

#### Flowchart for Memory Reference Instructions:



## **Input-Output and Interrupt:**



- The terminal sends and receives serial information

- The serial information from the keyboard is shifted into INPR

- The serial info. for the printer is stored in the OUTR

- INPR and OUTR communicate with the terminal serially and with the AC in parallel.

- The flags are needed to *synchronize* the timing difference between I/O device and the computer

#### **Program Controlled Data Transfer:**



#### **Input-Output Instructions:**

 $D_7IT_3 = p$  (common to all input-output instructions)  $IR(i) = B_i$  [bit in IR(6-11) that specifies the instruction]  $SC \leftarrow 0$ Clear SC **p**: INP  $AC(0-7) \leftarrow INPR, FGI \leftarrow 0$ Input character *pB*<sub>11</sub>:  $OUTR \leftarrow AC(0-7), FGO \leftarrow 0$ Output character OUT  $pB_{10}$ : If (FGI = 1) then  $(PC \leftarrow PC + 1)$ Skip on input flag SKI  $pB_9$ : If (FGO = 1) then  $(PC \leftarrow PC + 1)$ Skip on output flag  $pB_8$ : SKO  $IEN \leftarrow 1$ Interrupt enable on ION  $pB_7$ : IOF *pB*<sub>6</sub>:  $IEN \leftarrow 0$ Interrupt enable off

Program-Controlled Input/output:

- Continuous CPU involvement

I/O takes valuable CPU time

- CPU slowed down to I/O speed
- Simple
- Least hardware

| Input  |     |      |
|--------|-----|------|
| LOOP,  | SKI | DEV  |
|        | BUN | LOOP |
|        | INP | DEV  |
| Output |     |      |
| LOOP,  | LDA | DATA |
| LOP,   | SKO | DEV  |
|        | BUN | LOP  |
|        | OUT | DEV  |

• •

. . .

| Fetch                     | R'T <sub>0</sub> :                            | $AR \leftarrow PC$                                                                      |
|---------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------|
|                           | $R'T_1$ :                                     | $IR \leftarrow M[AR], PC \leftarrow PC + 1$                                             |
| Decode                    | $R'T_2$ :                                     | $D_0, \ldots, D_7 \leftarrow \text{Decode } IR(12-14),$                                 |
|                           |                                               | $AR \leftarrow IR(0-11), I \leftarrow IR(15)$                                           |
| Indirect                  | $D'_{7}IT_{3}$ :                              | $AR \leftarrow M[AR]$                                                                   |
| Interrupt:                |                                               |                                                                                         |
| $T_0^i T_1^i T_2^i (IEN)$ | (FGI + FGO):                                  | <i>R</i> ←1                                                                             |
|                           | $RT_0$ :                                      | $AR \leftarrow 0, TR \leftarrow PC$                                                     |
|                           |                                               | $M[AR] \leftarrow TR, PC \leftarrow 0$                                                  |
|                           | $RT_2$ :                                      | $PC \leftarrow PC + 1$ , $IEN \leftarrow 0$ , $R \leftarrow 0$ , $SC \leftarrow 0$      |
| Memory-reference          |                                               |                                                                                         |
| AND                       | $D_0T_4$ :                                    |                                                                                         |
|                           |                                               | $AC \leftarrow AC \land DR, SC \leftarrow 0$                                            |
| ADD                       |                                               | $DR \leftarrow M[AR]$                                                                   |
|                           | $D_1T_5$ :                                    |                                                                                         |
| LDA                       |                                               | $DR \leftarrow M[AR]$                                                                   |
|                           | $D_2T_3$ :                                    |                                                                                         |
| STA                       |                                               | $M[AR] \leftarrow AC, SC \leftarrow 0$                                                  |
| BUN                       |                                               | $PC \leftarrow AR, SC \leftarrow 0$                                                     |
| BSA                       |                                               | $M[AR] \leftarrow PC, AR \leftarrow AR + 1$                                             |
| 107                       |                                               | $PC \leftarrow AR, SC \leftarrow 0$                                                     |
| ISZ                       |                                               | $DR \leftarrow M[AR]$                                                                   |
|                           |                                               | $DR \leftarrow DR + 1$<br>M(AR) = DR = M(AR) = 0 then $(RC + RC + 1) = SC + 1$          |
| Register-reference        | <i>D</i> <sub>6</sub> <i>T</i> <sub>6</sub> : | $M[AR] \leftarrow DR$ , if $(DR = 0)$ then $(PC \leftarrow PC + 1)$ , $SC \leftarrow 0$ |
| Register-reference        |                                               | = $r$ (common to all register-reference instructions)                                   |
|                           |                                               | $= B_i (i = 0, 1, 2,, 11)$                                                              |
|                           | r:                                            | $SC \leftarrow 0$                                                                       |
| CLA                       |                                               | <i>AC</i> ← 0                                                                           |
| CLE                       |                                               | $E \leftarrow 0$                                                                        |
| CMA                       |                                               | $AC \leftarrow \overline{AC}$                                                           |
| CME                       | rBa:                                          | $E \leftarrow \overline{E}$                                                             |
| CIR                       | rB <sub>2</sub> :                             | $AC \leftarrow \text{shr } AC,  AC(15) \leftarrow E,  E \leftarrow AC(0)$               |
| CIL                       | rB6:                                          |                                                                                         |
| INC                       | rB <sub>5</sub> :                             | $AC \leftarrow AC + 1$                                                                  |
| SPA                       | rB4:                                          | If $(AC(15) = 0)$ then $(PC \leftarrow PC + 1)$                                         |
| SNA                       | rB <sub>3</sub> :                             | If $(AC(15) = 1)$ then $(PC \leftarrow PC + 1)$                                         |
| SZA                       | rB <sub>2</sub> :                             | If $(AC = 0)$ then $PC \leftarrow PC + 1$                                               |
| SZE                       | <i>rB</i> <sub>1</sub> :                      | If $(E = 0)$ then $(PC \leftarrow PC + 1)$                                              |
| HLT                       | rB <sub>0</sub> :                             | <i>S</i> ← 0                                                                            |
| Input-output:             |                                               |                                                                                         |
|                           |                                               | = p (common to all input-output instructions)                                           |
|                           |                                               | $B_i (i = 6, 7, 8, 9, 10, 11)$                                                          |
| D.I.S.                    | <i>p</i> :                                    | $SC \leftarrow 0$                                                                       |
| INP                       | <i>pB</i> <sub>11</sub> :                     | $AC(0-7) \leftarrow INPR, FGI \leftarrow 0$                                             |
| OUT                       | <i>pB</i> <sub>10</sub> :                     | $OUTR \leftarrow AC(0-7), FGO \leftarrow 0$                                             |
| SKI                       | <i>pB</i> <sub>9</sub> :                      | If $(FGI = 1)$ then $(PC \leftarrow PC + 1)$                                            |
| SKO                       | pB <sub>8</sub> :                             | If $(FGO = 1)$ then $(PC \leftarrow PC + 1)$                                            |
| ION                       | <i>pB</i> <sub>7</sub> :                      | $IEN \leftarrow 1$                                                                      |
| IOF                       | pB6:                                          | <i>IEN</i> ←0                                                                           |

TABLE 5-6 Control Functions and Microoperations for the Basic Computer

Hardware Components of BC A memory unit: 4096 x 16. Registers: AR, PC, DR, AC, IR, TR, OUTR, INPR, and SC Flip-Flops(Status): I, S, E, R, IEN, FGI, and FGO Decoders: a 3x8 Opcode decoder a 4x16 timing decoder Common bus: 16 bits Control logic gates: Adder and Logic circuit: Connected to AC

**Control Logic Gates** 

- Input Controls of the nine registers

- Read and Write Controls of memory

- Set, Clear, or Complement Controls of the flip-flops

- S<sub>2</sub>, S<sub>1</sub>, S<sub>0</sub> Controls to select a register for the bus

- AC, and Adder and Logic circuit

Address Register; AR

Scan all of the register transfer statements that change the content of AR:

| 4 | $\begin{array}{l} AR \leftarrow PC \\ AR \leftarrow IR(0\text{-}11) \\ AR \leftarrow M[AR] \\ AR \leftarrow 0 \end{array}$ | LD(AR)<br>LD(AR)<br>LD(AR)<br>CLR(AR) |  |
|---|----------------------------------------------------------------------------------------------------------------------------|---------------------------------------|--|
| U | $AR \leftarrow 0$<br>$AR \leftarrow AR + 1$                                                                                | INR(AR)                               |  |

| LD(AR) = R'T <sub>0</sub> + | $R'T_2 + D'_7 IT_3$ |
|-----------------------------|---------------------|
| $CLR(AR) = RT_0$            | 2,0                 |
| $INR(AR) = D_5 T_4$         |                     |

#### Read = R'Ti + D7ZT3 + (D0 + D1 + D2 + D6)T4



Figure 5-16 Control gates associated with AR.

**Control of Common Bus** 

**IEN: Interrupt Enable Flag** 

 $pB_7$ :IEN  $\neg$  1 (I/O Instruction) $pB_6$ :IEN  $\neg$  0 (I/O Instruction) $RT_2$ :IEN  $\neg$  0 (Interrupt) $p = D_7 IT_3$  (Input/Output Instruction)





## **Design of Accumulator Logic**

| $D_0T_5$ :                | $AC \leftarrow AC \land DR$                          | AND with DR        |
|---------------------------|------------------------------------------------------|--------------------|
| $D_1T_5$ :                | $AC \leftarrow AC + DR$                              | Add with DR        |
| $D_2T_5$ :                | $AC \leftarrow DR$                                   | Transfer from DR   |
| pB <sub>11</sub> :        | $AC(0-7) \leftarrow INPR$                            | Transfer from INPR |
| $rB_9$ :                  | $AC \leftarrow \overline{AC}$                        | Complement         |
| rB7:                      | $AC \leftarrow \text{shr } AC,  AC(15) \leftarrow E$ | Shift right        |
| $rB_6$ :                  | $AC \leftarrow \text{shl } AC, AC(0) \leftarrow E$   | Shift left         |
| <i>rB</i> <sub>11</sub> : | <i>AC</i> ← 0                                        | Clear              |
| <i>rB</i> ₅:              | $AC \leftarrow AC + 1$                               | Increment          |

# Figure 5-19 Circuits associated with AC.



J

# **Control of AC Register**

·····



Figure 5-20 Gate structure for controlling the LD, INR, and CLR of AC.

υ