# Computer Organization

## SYSTEM BUS

The CPU, memory and I/O are normally connected by three groups of connections, each called a bus: data bus, address bus and control bus.

<u>Data Bus</u>: These are lines used by the information that is being moved.
 When communicating with memory this information may either instruction or data.

In I/O devices this information may be data, device status or commands or interrupt information.

- □ Data can be transferred in both directions on the data bus (bidirectional).
- ☐ Internal data bus: within the CPU itself.
- □ External data bus: Between CPU and other components (as RAM, I/O devices, etc.).
- ☐ The number of data lines in a bus determines the number of bits that can be transferred simultaneously.
- $\square$  A microcomputer with n data lines is normally called an <u>n-bit microcomputer</u>.
- ex: 8-bits microcomputer can transfer one byte in each bus cycle.
  - 16-bits microcomputer can transfer 2 byte (word) in each bus cycle. (8086 mp).

### SYSTEM BUS

EX1: How many bus cycle need to transfer data of size 64bits, if data bus size 16 line?

sol: no of cycle = 
$$\frac{\text{no. of bits (data)}}{\text{no. of lines in dada bus}} = \frac{64}{16} = 4 \text{ bus cycle}$$

EX2: How many bus cycle need to transfer 128 byte of data in 32-bits microcomputer?

 $\therefore$  data bus size = 32 bits = 4 byte can be transfer in each cycle

no of cycle = 
$$\frac{\text{size of data}}{\text{size of data bus}} = \frac{128 \, \text{byte}}{4 \, \text{byte}} = 32 \, \text{bus cycle}$$

| 2. Address Bus:                                                        | Ho             | ardware - BUS St                          | ructure |  |  |  |  |  |  |  |  |  |  |
|------------------------------------------------------------------------|----------------|-------------------------------------------|---------|--|--|--|--|--|--|--|--|--|--|
| unidirectional group of wires which carrie                             | s address info | rmation bits f                            | orm     |  |  |  |  |  |  |  |  |  |  |
| processor to peripherals                                               |                |                                           |         |  |  |  |  |  |  |  |  |  |  |
| □ Each memory locations or interface reg                               | ociated with i | it a                                      |         |  |  |  |  |  |  |  |  |  |  |
| unique bit combination called an address.                              |                |                                           |         |  |  |  |  |  |  |  |  |  |  |
| □ The number of bits used to specify an address clearly determines the |                |                                           |         |  |  |  |  |  |  |  |  |  |  |
| set of all possible addresses.                                         |                | content of                                | memorv  |  |  |  |  |  |  |  |  |  |  |
| ■ Memory address is put on address bus.                                | location (     |                                           |         |  |  |  |  |  |  |  |  |  |  |
| Address                                                                | → 0000000000   | 01001101                                  |         |  |  |  |  |  |  |  |  |  |  |
| Memory                                                                 |                |                                           |         |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Ordered sequence of bytes</li> </ul>                          | 000000001      | 175 Pro 1866 Pro 1861 Pro 1867 August 240 |         |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>The sequence number is called the</li> </ul>                  | 000000010      | 11101000                                  |         |  |  |  |  |  |  |  |  |  |  |
| memory address                                                         |                | •                                         |         |  |  |  |  |  |  |  |  |  |  |
| Byte addressable memory                                                |                | •                                         |         |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Each byte has a unique address</li> </ul>                     |                | •                                         |         |  |  |  |  |  |  |  |  |  |  |
| <ul> <li>Supported by almost all processors</li> </ul>                 |                | •                                         |         |  |  |  |  |  |  |  |  |  |  |
| Physical address space                                                 | •              |                                           |         |  |  |  |  |  |  |  |  |  |  |
| Determined by the address bus width                                    | •              |                                           |         |  |  |  |  |  |  |  |  |  |  |
| Determined by the dadress bus width                                    |                | •                                         |         |  |  |  |  |  |  |  |  |  |  |
|                                                                        | 1111111111     | 00001110                                  |         |  |  |  |  |  |  |  |  |  |  |
|                                                                        |                |                                           |         |  |  |  |  |  |  |  |  |  |  |

#### The size of address bus determine:

Let n = the number of lines in address bus

1. The size of memory connected with processor (capcity).

size of memory 
$$= 2^{n}$$

2. Size of memory address (physical address).

size of memory 
$$address = n$$

3. The address space of main memory (set of all possible addresses).

address space = 
$$0 \rightarrow [2^{n} - 1]$$
 (in decimal)

#### EX: Processor has a 8 lines address bus

Size of memory =  $2^n$  =  $2^8$  = 256 byte

Size of address for each memory location = 8 bits

Address space (decimal) =  $0 \longrightarrow 2^8-1 = 0 \longrightarrow 255$  different memory location

Address space in hexadecimal



Address Space is the set of memory locations (bytes) that can be addressed 00 -- FF

## EX: Processor has a 16 lines address bus

Size of memory =  $2^n$  =  $2^{16}$  = 64 K.Byte Size of address for each memory location = 16 bits Address space (decimal) =  $0 \longrightarrow 2^{16}$ -1 =  $0 \longrightarrow 65536$  different memory location Address space in hexadecimal 0000 - FFFF

| b <sub>15</sub> | b <sub>14</sub> | B <sub>12</sub> | b <sub>12</sub> | b <sub>11</sub> | b <sub>10</sub> | b <sub>9</sub> | b <sub>8</sub> | <b>b</b> <sub>7</sub> | b <sub>6</sub> | b <sub>5</sub> | b <sub>4</sub> | p <sup>3</sup> | b <sub>2</sub> | b <sub>1</sub> | bo |          | in Hex  |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|-----------------------|----------------|----------------|----------------|----------------|----------------|----------------|----|----------|---------|
| 0               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 0                     | 0              | 0              | 0              | 0              | 0              | 0              | 0  | 01001101 | 0 0 0 0 |
| 0               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 0                     | 0              | 0              | 0              | 0              | 0              | 0              | 1  | 10011100 | 0 0 0 1 |
| 0               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 0                     | 0              | 0              | 0              | 0              | 0              | 1              | 0  | 11101000 | 0 0 0 2 |
|                 | ***             | •••             | •••             | •••             |                 | •••            | •••            | •••                   |                |                | ***            |                | ***            |                |    | •        |         |
|                 | •••             | ***             | •••             |                 |                 | •••            | •••            | •••                   |                |                | ***            | ***            | •••            |                |    | :        |         |
| 0               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 0                     | 0              | 0              | 0              | 1              | 1              | 1              | 1  | 00001110 | 0 0 0 F |
|                 |                 |                 |                 |                 | •••             | •••            |                | •••                   |                |                | •••            | •••            |                |                |    |          |         |
|                 |                 |                 |                 | ***             | ***             | ***            | •••            | •••                   | ***            |                | •••            |                | ***            |                |    | •        |         |
| 0               | 0               | 0               | 0               | 0               | 0               | 0              | 0              | 1                     | 1              | 1              | 1              | 0              | 0              | 0              | 0  | •        | 0 0 F F |
|                 |                 |                 |                 |                 |                 |                |                |                       |                |                |                |                |                |                |    |          |         |
|                 | ***             | ***             | ***             | ***             |                 | •••            |                |                       |                |                | ***            | ***            |                |                |    |          |         |
|                 | •••             |                 |                 |                 |                 |                | •••            | •••                   |                |                | •••            | •••            | •••            |                |    |          |         |
| 1               |                 |                 | 1               | 1               | 1               | 1              | 1              | 1                     | 1              | 1              | 1              | 1              | 1              | 1              | 1  |          | FFFF    |

<u>Control Bus</u>: Regardless of the bus arrangement being used, a certain amount of control information must be passed back and forth among the CPU, the memory modules, and the device interfaces.



## Fetch and Execute

The following pages illustrate the operations performed within a computer during a fetch and execute cycle.

## The control bus performs a read operation:



The control unit in the CPU prompts memory to put the instruction onto the data bus enabling the CPU to read the instruction onto its instruction decoder which is part of the control unit:



The next step involves the CPU decoding the instruction. This instruction is then executed. For example, if the instruction is for the Control Unit to load the contents of the memory location 112 into the accumulator:





Performing a write operation

The control unit sets the address bus to location 112 and puts the value of the accumulator onto the data bus.

Finally the control bus performs a memory write operation:

