

## Addressing Modes:

It specifies a rule for interpreting or modifying the address field of the instruction.

Variety of addressing modes.

- to give programming flexibility to the user.
- to use the bits in the address field by the instruction efficiently.

## Types of Addressing Modes:

### 1. Implied Mode:

Address of the operands are specified implicitly in the instruction. No need to specify in the instruction.

Ex: CMA (Complement the accumulator)

### 2. Immediate Mode:

Instead of specifying the address of the operand, the instruction contain the operand itself.

### 3) Direct Address Mode:

Instruction specifies the memory address which can be used directly to get the operand.

### 4. Indirect Addressing mode:

The address field of an

Instruction specifies the address of a memory location that contains the address of the operand.

5. Register Mode:  
 Address specified in the instruction in the register address.

6. Register Indirect Mode:  
 Instruction specifies a register which contains the memory of the operand.

Auto - Increment:  
 Same as the register indirect but when the address in the register is used to access memory, the value in the register is incremented after the execution of the instruction.

Auto - Decrement:  
 Same as the register indirect but when the address in the register is used to access memory, the value in the register is decremented before the execution of the instruction.

7. Relative Addressing Model:

The Address field of an instruction specifies the part of the address which can be used along with a PC to calculate the address of operand.  
 $EA = PC + IR(\text{address})$

8. Indexed Addressing Mode:

XR: Index Register

$$EA = XR + IR \text{ (address)}$$

$\begin{matrix} C \\ \text{Effective} \\ \text{address} \end{matrix}$        $\begin{matrix} I \\ \text{Index} \\ \text{Register} \\ \text{Address} \end{matrix}$

9. Base Register Addressing Mode:

BAR: Base Address Register

$$EA = BAR + IR \text{ (address)}$$

Ques: 1

| Address | Memory           |            |
|---------|------------------|------------|
| 200     | Word to AC       | $PC = 200$ |
| 202     | Address = 500    | $R1 = 400$ |
| 202     | Next Instruction | $XR = 100$ |
| 399     | 450              |            |
| 400     | 700              |            |
| 500     | 000              | $AC$       |
| 600     | 900              |            |
| 702     | 325              |            |
| 800     | 300              |            |

| Addressing Modes  | Effective Address | Content of AC |
|-------------------|-------------------|---------------|
| Direct Address    | 500               | 800           |
| Immediate Operand | 202               | 500           |
| Indirect Address  | 800               | 300           |
| Relative Address  | 702               | 385           |
| Indexed Address   | 600               | 900           |
| Register          | -                 | 400           |
| Register indirect | 400               | 700           |
| Autoincrement     | 400               | 700           |
| Autodecrement     | 399               | 450           |

## Pipelining

Pipelining is a technique of decomposing a sequential process into sub-operation with each sub-process being executed in a segment that operates concurrently with all other segments.

Example:  $A_i * B_i + C_i$  for  $i = 1, 2, 3, \dots, n$ .





$R_1 \leftarrow A_i$ ,  $R_2 \leftarrow B_i$ ,  $R_4 \leftarrow C_i$  Input  $A_i, B_i, C_i$   
 $R_3 \leftarrow A_i * B_i$  Multiply  
 $R_5 \leftarrow R_3 + R_4$  Add.

Operations in each pipeline stage.

| clock pulse no. | Segment 1 |       | Segment 2   |       | Segment 3         |  |
|-----------------|-----------|-------|-------------|-------|-------------------|--|
|                 | $R_1$     | $R_2$ | $R_3$       | $R_4$ | $R_5$             |  |
| 1               | $A_1$     | $B_1$ | -           | -     | -                 |  |
| 2               | $A_2$     | $B_2$ | $A_1 * B_1$ | $C_1$ | -                 |  |
| 3.              | $A_3$     | $B_3$ | $A_2 * B_2$ | $C_2$ | $A_1 * B_1 + C_1$ |  |
| 4.              | $A_4$     | $B_4$ | $A_3 * B_3$ | $C_3$ | $A_2 * B_2 + C_2$ |  |
| 5.              | $A_5$     | $B_5$ | $A_4 * B_4$ | $C_4$ | $A_3 * B_3 + C_3$ |  |
| 6.              | $A_6$     | $B_6$ | $A_5 * B_5$ | $C_5$ | $A_4 * B_4 + C_4$ |  |
| 7               | $A_7$     | $B_7$ | $A_6 * B_6$ | $C_6$ | $A_5 * B_5 + C_5$ |  |
|                 | -         | -     | $A_7 * B_7$ | $C_7$ | $A_6 * B_6 + C_6$ |  |
|                 | -         | -     | -           | -     | $A_7 * B_7 + C_7$ |  |

Space - Time Diagram.

| segment | 1     | 2     | 3     | 4     | 5     | 6     | 7     | 8     | 9     |
|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| 1       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |       |       |
| 2       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |       |
| 3       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |       |
| 4       |       |       |       | $T_1$ | $T_2$ | $T_3$ | $T_4$ | $T_5$ | $T_6$ |

## Pipeline Speedup

Let  $n$ : number of tasks to be performed  
Pipelined machine ( $k$  segments)

$k$  segments pipeline with a clock time of  $T_p$   
is used to execute  $n$  tasks.

The first task  $T_1$  required time =  $k \times T_p$

The remaining  $(n-1)$  task emerge from the pipe at  
the rate of one task per cycle =  $(n-1) \times T_p$

To complete  $n$  task with  $k$ -segment pipeline  
=  $k + (n-1)$  clock cycle.

### Non-Pipelined (Conventional)

Time required to complete each task =  $T_n$

Time required to complete  $n$  task =  $n \times T_n$

### Speed up:

$$\begin{aligned} S_k &= \frac{\text{non-pipelined time}}{\text{Pipelined Time}} \\ &= \frac{n \times T_n}{k + (n-1) \times T_p} \end{aligned}$$

A non-pipelined system takes 50 ns to process  
a task. The same task can be processed in  
a six segment pipeline with a clock cycle  
of 10 ns. Determine the speed up ratio of  
the pipeline for 100 task.



Sol<sup>n</sup>. Given,

$$t_n = 50 \text{ ns}$$

$$k = 6$$

$$t_p = 10 \text{ ns}$$

$$n = 100$$

we know that

$$S = \frac{n \times T_n}{k + (n-1) \times T_p}$$

$$\frac{100 \times 50}{6 + (99) \times 10} = 4.76$$

$$= 5000 \text{ ns} = 5 \text{ ms}$$

~~1050~~

$$S_{\max} = \frac{T_n}{T_p} = \frac{50}{10} = 5 \text{ ns.}$$

Ques.2 Draw a space time diagram for a six segment pipeline showing the time it takes to process eight task.

Sol<sup>n</sup>.

$$k = 6$$

$$n = 8$$

$$[k + (n-1)] T_p = 6 + 7 = 13 \text{ cycle.}$$

Clock.

1 2 3 4 5 6 7 8 9 10 11 12 13

↑ 1

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

↓ 2

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

3

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

4

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

5

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

6

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

7

$T_1 T_2 T_3 T_4 T_5 T_6 T_7 T_8$

Ques:3 In certain Scientific Calculation it is necessary to perform the arithmetic operation  $(A_i + B_i) * (C_i + D_i)$

- a) Specify the pipeline configuration to carry out this task.



- b) List the content of all register of all the register in the pipeline for  $i=1$  to 2.



OR

$$\begin{aligned}
 \text{no. of cycle} &= k + (n-1) \\
 &= 3 + (6-1) \\
 &= 8.
 \end{aligned}$$

| <del>clock seq.</del> | R <sub>1</sub> | R <sub>2</sub> | R <sub>3</sub> | R <sub>4</sub> | R <sub>5</sub>                 | R <sub>6</sub>                 | R <sub>7</sub>                                                      |
|-----------------------|----------------|----------------|----------------|----------------|--------------------------------|--------------------------------|---------------------------------------------------------------------|
| 1                     | A <sub>1</sub> | B <sub>1</sub> | C <sub>1</sub> | D <sub>1</sub> | -                              | -                              | -                                                                   |
| 2                     | A <sub>2</sub> | B <sub>2</sub> | C <sub>2</sub> | D <sub>2</sub> | A <sub>1</sub> +B <sub>1</sub> | A <sub>1</sub> *B <sub>1</sub> | -                                                                   |
| 3                     | A <sub>3</sub> | B <sub>3</sub> | C <sub>3</sub> | D <sub>3</sub> | A <sub>2</sub> +B <sub>2</sub> | C <sub>2</sub> *D <sub>2</sub> | (A <sub>1</sub> +B <sub>1</sub> )+(C <sub>1</sub> *D <sub>1</sub> ) |
| 4                     | A <sub>4</sub> | B <sub>4</sub> | C <sub>4</sub> | D <sub>4</sub> | A <sub>3</sub> +B <sub>3</sub> | C <sub>3</sub> *D <sub>3</sub> | (A <sub>2</sub> +B <sub>2</sub> )+(C <sub>2</sub> *D <sub>2</sub> ) |
| 5                     | A <sub>5</sub> | B <sub>5</sub> | C <sub>5</sub> | D <sub>5</sub> | A <sub>4</sub> +B <sub>4</sub> | C <sub>4</sub> *D <sub>4</sub> | (A <sub>3</sub> +B <sub>3</sub> )+(C <sub>3</sub> *D <sub>3</sub> ) |
| 6                     | A <sub>6</sub> | B <sub>6</sub> | C <sub>6</sub> | D <sub>6</sub> | A <sub>5</sub> +B <sub>5</sub> | C <sub>5</sub> *D <sub>5</sub> | (A <sub>4</sub> +B <sub>4</sub> )+(C <sub>4</sub> *D <sub>4</sub> ) |
| 7                     | -              | -              | -              | -              | A <sub>6</sub> +B <sub>6</sub> | C <sub>6</sub> *D <sub>6</sub> | (A <sub>5</sub> +B <sub>5</sub> )+(C <sub>5</sub> *D <sub>5</sub> ) |
| 8                     | -              | -              | -              | -              | -                              | -                              | (A <sub>6</sub> +B <sub>6</sub> )+(C <sub>6</sub> *D <sub>6</sub> ) |

## Basic Computer Organization & Design

**Program:** It is a set of instruction that specify the operations, operands and the sequence by which processing has to occur.

**Instruction:** A binary code that specifies a sequence of micro-operation for the computer.

**Instruction Cycle:** The control then interpret the binary code of the instruction and proceeds to execute it by issuing a sequence of micro-operation. The time required to execute one instruction known as instruction cycle.

**Instruction code:** It is a group of bits that instruct the computer to perform specific operation.

**Operation code (Opcode):** It is a group of bits that defines the operation. Number of bits required for opcode depends on number of operations available in computer.

**Address (Operand):** It specifies the location of operands (register or memory words). Memory words are specified by their address. Registers are specified by their k-bit binary code.

1. **Memory reference instruction:** In memory reference instruction mode field = 1, and opcode = 000 - - 110 ( $0 \rightarrow 6$ ),  $i=0$  (direct address)



2. **Register Reference Instruction:** Mode field ( $I$ ) = 0  
Opcode = 111 (7).

|   |              |                    |
|---|--------------|--------------------|
| 0 | Opcode field | Addressing.        |
| 0 | 111          | Register operation |



### 3. Input - Output Instruction:

Mode field ( $I$ ) = 1

Opcode = IEE(7).



### List of Register for the Basic Computer

| Register<br>Symbol | Number of<br>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       |

### Timing and control.

- \* The timing for all register in the basic computer is controlled by a master clock generator.
- \* The clock pulses are applied to all flip-flop and registers in the system in the system including the flip-flop and register in the control unit.

## Hardwired Control

1. The control logic is implemented with gates, flip-flop, decoders and other digital circuit.
2. The advantage that it can be optimized to produce a fast mode of operation.
3. Requires changes in the wiring among the various components if the design has to be modified or changed.

## Microprogrammed Control

- The control information is stored in a control memory. The control memory is programmed to initiate the required sequence of micro-operations.
- Compared with the hardwired control operation is slow.
2. Compared with the hardwired control operation is slow.
  - Required changes or modification can be done by updating the micro-program in control memory.

### Block Diagram of Hardwired Control Unit:

- \* It consists of 2 decoders, a sequence counter and a number of control logic gates.
- \* The operation code on bits 12 through 14 are decoded with a  $3 \times 8$  decoder. The eight output of the decoder are designated by the symbol  $D_0$  through  $D_7$ .
- \* Bit 0 through 11 are applied to the control logic gates.



### Instruction Cycle:

- \* A program residing in the memory unit of the computer consists of a sequence of instruction.
- \* The program is executed in the computer by going through a cycle for each instruction.
- \* Each instruction cycle in turn is sub-divided into a sequence of sub cycle or phases.

## Flowchart for instruction cycle.



$D7' IT_3 : AR \leftarrow m[AR]$

$D7' I' T_3 : \text{Nothing}$

$D7 I' T_3 : \text{Execute a register - reference instruction}$

$D7 I T_3 : \text{Execute an Input - Output instruction.}$

## Memory Reference Instruction.

| Symbol | Operation Decoder | Symbolic Description      |
|--------|-------------------|---------------------------|
| AND    | D <sub>0</sub>    | AC ← AC ∧ M[AR]           |
| ADD    | D <sub>1</sub>    | AC ← AC + M[AR], E ← Cout |
| LDA    | D <sub>2</sub>    | AC ← M[AR]                |
| STA    | D <sub>3</sub>    | M[AR] ← AC                |

**AND to AC:** This is an instruction that performs the AND logic operation on pairs of bits in AC and the memory word specified by the effective address. The result of the operation is transferred to AC. The microoperations that execute this instruction are:

$$D_0 T_4 : DR \leftarrow m[AR]$$

$$D_0 T_5 : AC \leftarrow AC \wedge DR, SC \leftarrow 0$$

**ADD to AC:** This instruction adds the content of the memory word specified by the effective address to the value of AC. The sum is transferred into AC and the output carry Cout is transferred to the E (Extended accumulator) flip flop. The microoperations needed to execute this instruction are:

$$D_1 T_4 : DR \leftarrow m[AR]$$

$$D_1 T_5 : AC \leftarrow AC + DR, E \leftarrow Cout, SC \leftarrow 0$$

LDA: load to AC. This instruction transfer the memory word specified by the effective address to AC. The microoperations needed to execute this instruction are.

$$D_2 T_4 : DR \leftarrow m[AR]$$

$$D_2 T_5 : AC \leftarrow DR, SC \leftarrow 0$$

STA: store to AC. This instruction stores the content of AC into the memory word specified by the effective address. Since the output of AC is applied to the bus and the data input of memory is connected to the bus, we can execute this instruction with one micro-operation.

$$D_3 T_4 : m[AR] \leftarrow AC, SC \leftarrow 0$$

### Memory Organization

#### \* Memory Hierarchy

1. Main memory: Memory unit that communicates directly with the CPU. (RAM)
2. Auxiliary Memory: Device that provide backup storage (Disk Drives)
3. Cache Memory: Special very high speed memory to increase the processing speed (Cache RAM)
4. Multiprogramming! Enable the CPU to process a number

of independent program concurrently.

**Memory Management System:** Supervise the flow of information between auxiliary memory and main memory.



Memory Hierarchy is to obtain the highest possible access speed while minimizing the total cost of the memory system.



Difference between Static & Dynamic RAM.

### Static RAM

1. It uses transistors to store a single bit of data.
2. It does not need periodic refreshment to maintain data.
3. Its structure is complex than dynamic RAM.
4. They are expensive.
5. It is faster than dynamic RAM.

### Dynamic RAM.

- It uses a separate capacitor to store each bit of data.
- It needs periodic refreshment to maintain data.
- Its structure is simpler than static RAM.
- It is less expensive.
- It is slower than static RAM.

### RAM and ROM Chips.

#### Typical RAM chip.



| CS1 | CS2 | RD | WR | Memory function | State of Data-bus    |
|-----|-----|----|----|-----------------|----------------------|
| 0   | 0   | X  | X  | Inhibit         | High Impedance       |
| 0   | 1   | X  | X  | Inhibit         | High Impedance       |
| 1   | 0   | 0  | 0  | Inhibit         | High Impedance       |
| 1   | 0   | 0  | 1  | Write           | Input data to RAM    |
| 1   | 0   | 1  | X  | Read            | Output data from RAM |
| 1   | 1   | X  | X  | Inhibit         | High Impedance       |

## Typical ROM Chips



Example: 512 bytes RAM and 512 bytes ROM.

$$\begin{aligned}
 \text{No of RAM} &= \frac{\text{Total capacity of RAM}}{\text{Single RAM capacity}} \\
 &= \frac{512}{128} = 4 \text{ bytes.}
 \end{aligned}$$

$$\text{No of Rom} = \frac{512}{512} = 1 \text{ byte.}$$

| Component | Hexadecimal address | Address bus               |
|-----------|---------------------|---------------------------|
| RAM 1     | 0000-007F           | 10 0 9 8 7 6 5 4 3 2 1    |
| RAM 2     | 0080-00FF           | 0 1 0 0 1 X X X X X X X X |
| RAM 3     | 0100-017F           | 0 1 1 0 X X X X X X X X   |
| RAM 4     | 0180-01FF           | 0 1 1 1 X X X X X X X X   |
| ROM       | 0200-03FF           | 1 X X X X X X X X X X     |

## Memory Connection to CPU

- RAM and ROM chips are connected to a CPU through the data and address buses.
- The low-order line in the address bus select the byte within the chips and other lines in the

address bus select a particular chip through its chip select inputs.

### Connection of Memory to CPU:



- Ques: 1(a) How many 128x8 RAM chips are needed to provide a memory capacity of 2048 bytes.
- b) How many lines of the address bus must be

used to access 2048 bytes of memory. How many of these lines will be common to all chips.

- c) How many lines must be decoded for chip select? Specify the size of decoder.

Sol<sup>n=9</sup>) No of RAM chips =  $\frac{\text{Capacity of RAM}}{\text{Single RAM capacity}}$

$$= \frac{2048 \times 8}{128 \times 8}$$

$$= 16 \text{ chips.}$$

b)  $2048 = 2^{11}$ , 11 lines to address 2048 bytes.

$128 = 2^7$ , 7 lines to address each chip

c) 4 lines to decoder for selecting 16 chips =  $2^4 = 16$ .  
 $4 \times 16$  decoder size.

Ques: 2 Extend the memory system of Q-L to 4096 bytes of RAM and 4096 bytes of ROM. List the memory address map and indicate what size decoders are needed.

Sol<sup>n=7</sup>) No of RAM chips =  $\frac{4096 \times 8}{128 \times 8} = 32 \text{ chips.}$

No of ROM chips =  $\frac{4096 \times 8}{512 \times 8} = 8 \text{ chips.}$

$4096 = 2^{12} \rightarrow$  There are 12 common address lines + 1 line to select between RAM & ROM

| Component | Address   | 16 15 14 13 12 11 10 9 8, 7 6 5 4 3 2 1                        |
|-----------|-----------|----------------------------------------------------------------|
| RAM       | 0000-0FFF | 0 0 0 0 $\xleftarrow{5 \times 32 \text{ decoder}}$ X X X X X X |
| ROM       | 1000-1FFF | 0 0 0 1 $\xleftarrow{3 \times 8 \text{ decoder}}$ X X X X X X  |

Ques 3 A computer employs RAM chips of  $256 \times 8$  and ROM chips of  $1024 \times 8$ . The computer system needs 2K bytes of RAM, 4K bytes of ROM, and four interface units each with four registers. A memory mapped I/O configuration is used. The two highest order bits of the address bus are assigned 00 for RAM, 01 for ROM, and 10 for interface registers.

- How many RAM & ROM chips are needed.
- Draw a memory address map for the system.
- Give the address range in hexadecimal for RAM, ROM & Interface.

$$\text{Sol/Ans} \quad \text{No of RAM chips} = \frac{2 \times 1024 \times 8}{256 \times 8} = 8 \text{ chips} \\ = 2^3 \\ \text{No of ROM chips} = \frac{4 \times 1024 \times 8}{1024 \times 8} = 4 \text{ chips} \\ = 2^2 \\ = 2 \times 2 \text{ decoder.}$$

$$\text{No of RAM chips} = \frac{2 \times 1024 \times 8}{256 \times 8} = 8 \text{ chips} \\ = 2^3 \\ = 2 \times 2 \text{ decoder.}$$

#### Hexadecimal

| b) Component | Address   | 16 | 15 | 14 | 13 | 12 | 11 | 10-9           | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 |
|--------------|-----------|----|----|----|----|----|----|----------------|---|---|---|---|---|---|---|---|
| RAM          | 0000-0FFF | 0  | 0  | 0  | 0  | 0  | 0  | 3x8<br>decoder | X | X | X | X | X | X | X | X |
| ROM          | 4000-9FFF | 0  | 1  | 0  | 0  | 0  | 0  | 9x4<br>decoder | X | X | X | X | X | X | X | X |
| Interface    | 8000-B00F | 1  | 0  | 0  | 0  | 0  | 0  | 0              | 0 | 0 | 0 | 0 | 0 | 0 | X | X |

#### Cache Memory

Locality of Reference: The references to memory tend to be confined within a few localized areas in the memory.

**Cache Memory:** A fast small memory. It keeps the most frequently accessed instruction and data in the fast cache memory.

**Hit Ratio:** The ratio of the number of hits divided by the total CPU reference (hit+miss) to memory.

**hit:** The CPU finds the words in the cache.

**miss:** The word is not found in cache (CPU must read main memory).



**Mapping:** The transformation of data from main memory to cache memory.

i) **Associative Memory:** Main memory: ~~32K~~

↳ 32K x 12 bit word (15 bit address)

Cache memory: 512 x 12 bit word.

CPU sends a 15-bit address to cache.

**Hit:** CPU accepts the 12-bit data from cache.

**Miss:** CPU reads the data from main memory (then data is written to cache).



MON TUE WED THU FRI SAT SUN

CPU address (15 bits)

Argument Register

| Address | Data  |             |
|---------|-------|-------------|
| 01000   | 3450  | 010E FFF000 |
| 09777   | 67A10 | 020E 00010  |
| 29345   | 1234  | 032N F6510  |
|         |       | 062E 000F0  |
|         |       | 0A1E2 F6680 |

2) Direct Mapping: n bit memory address

 Tag field ( $n-K$ ) : Index field ( $K$ )

 $2^K$  words Cache memory +  $2^N$  words main memory

Tag = 6 bit (15-0), Index = 9 bit



\* Direct mapping Cache with block size of 8 words.

$$64 \text{ blocks} \times 8 \text{ words} = 512 \text{ cache words size.}$$

|          | Index | Tag | Data |
|----------|-------|-----|------|
| Block 0  | 000   | 01  | 3450 |
|          | 001   | 01  | 6570 |
| Block 1  | 010   |     |      |
|          | 011   |     |      |
| Block 63 | 770   | 02  | !    |
|          | 771   | 02  | 6710 |



MON TUE WED THU FRI SAT SUN

| Memory address | memory data | Index address | Tag | Data |
|----------------|-------------|---------------|-----|------|
| 00000          | 1220        | 000           | 00  | 1220 |
| 00777          | 9340        | 0248          |     |      |
| 01000          | 3450        | 01777         | 02  | 6710 |
| 01777          | 4560        | 0248          |     |      |
| 02000          | 5670        | 01777         |     |      |
| 02777          | 6710        |               |     |      |

b) Main memory.

a) Main memory

### 3) Set - Associative Mapping.

Set - associative mapping : (two-way).

| Index | Tag | Data | Tag | Data |
|-------|-----|------|-----|------|
| 000   | 01  | 3450 | 02  | 5670 |
| 077   | 02  | 6710 | 00  | 9340 |