| USN |  |  |  |  |  |
|-----|--|--|--|--|--|



# IAT 3 – Nov. 2019

|       |                                                                                                                                                  |                                                              |                                                                        | IAT 3 – Nov. 20                                                                                      | 19            |                |         |          |     |        |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------|---------------|----------------|---------|----------|-----|--------|
| Sub:  | Computer C                                                                                                                                       | Organization                                                 |                                                                        |                                                                                                      | Sub Code:     | 18CS34         | Branch: | CSE      |     |        |
| Date: | 18/11/2019                                                                                                                                       | Duration:                                                    | 90 mins                                                                | Max Marks: 50                                                                                        | Sem/Sec:      | 3 (A,B,C)      |         |          | OB  |        |
|       | Answer FOUR F                                                                                                                                    | FULL question                                                | s selecting A                                                          | Γ LEAST ONE question                                                                                 | on FROM EA    | CH PART        | MA      | ARKS     | СО  | RBT    |
| Date: | ii)  1. PCout, MA  I. PCout, MA  2. Zout, PCin, 3. MDRout, IF 4. PCout, MA  5. Zout, PCin, 6. MDRout, M 7. MDRout, M 8. R1out, Yin, 9. MDRout, A | Rin, Read, Se WMFC IARin, Read WMFC IARin, Read WMFC dd, Zin | trol steps rents of memore R1.  MAR  MDR  Lect4, Add, Lect4, Add, WMFC | PART A equired for single but ory location whose a lastraction decoder and control logic R(n-1) TEMP | s structure f | Or each if the | [       | ARKS 10] |     | BE RBT |
|       | -                                                                                                                                                | O. Zout, R1in,                                               |                                                                        |                                                                                                      |               |                |         |          |     |        |
| 2 (a) | Drief mete em                                                                                                                                    | Dambua Mass                                                  | NOWY.                                                                  | OR                                                                                                   |               |                |         | [4]      |     |        |
| 2 (a) | Brief note on                                                                                                                                    | Kamous Men                                                   | югу                                                                    |                                                                                                      |               |                |         | [4]      | CO3 | L2     |

- · Rambus developed the implementation of narrow bus.
- Rambus technology is a fast signaling method used to transfer information betw
- The signals consist of much smaller voltage swings around a reference voltage \
- The reference voltage is about 2V.
- $\bullet$  The two logical values are represented by 0.3V swings above and below  $V_{ref.}$
- This type of signaling is generally is known as Differential Signalling.
- · Rambus provides a complete specification for design of communication called as
- · Rambus memory has a clock frequency of 400 MHz.
- The data are transmitted on both the edges of clock so that effective data-trans
- Circuitry needed to interface to Rambus channel is included on chip. Such chips (RDRAM = Rambus DRAMs).
- · Rambus channel has:
  - 1) 9 Data-lines (1st-8th line -> Transfer the data, 9th line-> Parity checking).
  - 2) Control-Line &
  - 3) Power line.
- A two channel rambus has 18 data-lines which has no separate Address-Lines.
- Communication between processor and RDRAM modules is carried out b transmitted on the data-lines.
- There are 3 types of packets:
  - 1) Request
  - 2) Acknowledge &
  - 3) Data.
- (b) Explain Memory Hierarchy with respect to cost, speed and size.

# [6]

# , SIZE, and COST



Figure 8.14 Memory hierarchy.

CO3 L2

- Fastest access is to the data held in processor registers. Registers are at the top of the memory hierarchy.
- Relatively small amount of memory that can be implemented on the processor chip. This is processor cache. Usually implemented as SRAM.
- Two levels of cache. Level 1 (L1) cache is on the processor chip. Level 2 (L2) cache is in between main memory and processor.
- Next level is main memory, implemented as DRAM (SIMMs,RIMM,DIMM). Much larger, but much slower than cache memory.
- Next level is magnetic disks. Huge amount of inexepensive storage.
- Speed of memory access is critical, the idea is to bring instructions and data that will be used in the near future as close to the processor as possible.

# **PART B**

3 (a) With a figure, explain single bus organization of Datapath inside a processor.



Figure 7.1 Single-bus organization of the datapath inside a processor.

[10]

CO5

L2

|       | Data & address lines of the MAR respectively. (MDR-     MDR has 2 inputs and 2 decided in the market in the | are interconnected via a Single Che external memory-bus is connected with the external memory-bus is connected with the external memory-bus (external) or outputs. Data may be loaded from memory-bus (external) or us (internal). It is internal-bus; nected to external-bus.  Control Unit is responsible for oblesignals to all the units inside the external specified by the instructional access these registers for generical access these registers for generical access these 3 registers. The extensional access these 3 registers. The operand from the output detects the operand directly from the ded for 'A' input of the ALU. In of the 2 inputs.  (which is used to increment PC control and is a from a register into a given mediata from a register into a given mediata from a register into a given mediata word can be transferred over a internal-paths. Multiple paths allowed. | cted to the internal processor-bus via MD Memory Address Register).  e processor. on (loaded in the IR). al-purpose use. nporary storage during program-execution of the multiplexer (MUX). processor-bus.  ontent). following operations: or to the ALU. e result in a register. oad them into a register. mory-location. |        |     |     |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----|-----|
|       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | OR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                            |        |     |     |
| 4 (a) | diagram.  Attribute                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Hardwired Control                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | icro-programmed control with near                                                                                                                                                                                                                                                                                          | t [10] |     |     |
|       | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Hardwired control is a control mechanism to generate control-<br>signals by using gates, flip-<br>flops, decoders, and other digital circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | mechanism to generate control-signals<br>by using a memory called control store                                                                                                                                                                                                                                            |        |     |     |
|       | Speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Fast                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Slow                                                                                                                                                                                                                                                                                                                       |        |     |     |
|       | Control functions                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Implemented in hardware.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Implemented in software.                                                                                                                                                                                                                                                                                                   |        |     |     |
|       | Flexibility                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Not flexible to accommodate<br>new system specifications or<br>new instructions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | More flexible, to accommodate new system specification or new instructions redesign is required.                                                                                                                                                                                                                           |        |     |     |
|       | Ability to handle large                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Easier.                                                                                                                                                                                                                                                                                                                    |        | CO5 | L2  |
|       | Ability to Hallale large                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Difficulti                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Edding 1                                                                                                                                                                                                                                                                                                                   |        | 000 | 112 |

| Attribute               | Hardwired Control               | Microprogrammed Control                  |
|-------------------------|---------------------------------|------------------------------------------|
| Definition              | Hardwired control is a control  |                                          |
|                         | mechanism to generate control-  | mechanism to generate control-signals    |
|                         | signals by using gates, flip-   | by using a memory called control store   |
|                         | flops, decoders, and other      | (CS), which contains the control-        |
|                         | digital circuits.               | signals.                                 |
| Speed                   | Fast                            | Slow                                     |
| Control functions       | Implemented in hardware.        | Implemented in software.                 |
| Flexibility             | Not flexible to accommodate     | More flexible, to accommodate new        |
| -                       | new system specifications or    | system specification or new instructions |
|                         | new instructions.               | redesign is required.                    |
| Ability to handle large | Difficult.                      | Easier.                                  |
| or complex instruction  |                                 |                                          |
| sets                    |                                 |                                          |
| Ability to support      | Very difficult.                 | Easy.                                    |
| operating systems &     |                                 | ·                                        |
| diagnostic features     |                                 |                                          |
| Design process          | Complicated.                    | Orderly and systematic.                  |
| Applications            | Mostly RISC microprocessors.    | Mainframes, some microprocessors.        |
| Instructionset size     | Usually under 100 instructions. | Usually over 100 instructions.           |
| ROM size                | -                               | 2K to 10K by 20-400 bit                  |
|                         |                                 | microinstructions.                       |
| Chip area efficiency    | Uses least area.                | Uses more area.                          |

# PART C

5 (a) What is cache memory. Explain the following terms a) write through b) write back c) early restart d) Miss penalty e) average memory access time f) dirty bit g) valid bit h) Hit rate i) Write buffer

[10]

ie effectiveness of cache mechanism is based on the property of 'Locality of Reference'. ality of Reference

any instructions in the localized areas of program are executed repeatedly during some time pemainder of the program is accessed relatively infrequently (Figure 8.15).

Here are 2 types:

### ) Temporal

The recently executed instructions are likely to be executed again very soon.

### ) Spatial

• Instructions in close proximity to recently executed instruction are also likely to be executed active segment of program is placed in cache-memory, then total execution time can be reduced refers to the set of contiguous address locations of some size.

The cache-line is used to refer to the cache-block.



Figure 8.15 Use of a cache memory.

e Cache-memory stores a reasonable number of blocks at a given time. is number of blocks is small compared to the total number of blocks available in main rrespondence b/w main-memory-block & cache-memory-block is specified by mappin iche control hardware decides which block should be removed to create space for the e collection of rule for making this decision is called the **Replacement Algorithm**. In e cache control-circuit determines whether the requested-word currently exists in the

# HIT

- If the data is in the cache it is called a Read or Write hit.
- Read hit:
  - The data is obtained from the cache.
- Write hit:
  - Cache has a replica of the contents of the main memory.
  - Contents of the cache and the main memory may be updated simultaneously. This is the write-through protocol.
  - Update the contents of the cache, and mark it as updated by setting a bit known as the <u>dirty bit or modified</u> bit. The contents of the main memory are updated when this block is replaced. This is <u>write-back or copy-back</u> protocol.

# **MISS**

CO3 L2

When the addressed word in a Read operation is not in the cache, a *read miss* occurs. The block of words that contains the requested word is copied from the main memory into the cache. After the entire block is loaded into the cache, the particular word requested is forwarded to the processor. Alternatively, this word may be sent to the processor as soon as it is read from the main memory. The latter approach, which is called *load-through*, or *early restart*, reduces the processor's waiting period somewhat, but at the expense of more complex circuitry.

During a Write operation, if the addressed word is not in the cache, a write miss occurs. Then, if the write-through protocol is used, the information is written directly into the main memory. In the case of the write-back protocol, the block containing the addressed word is first brought into the cache, and then the desired word in the cache is overwritten with the new information.

# MAPPING FUNCTION

OR

6(a) Explain basic concepts of pipeling in details . Also explain the hazards

# **PIPELING**

# BASIC CONCEPTS

The speed of execution of programs is influenced by many factors. One way to improve performance is to use faster circuit technology to build the processor and the main memory. Another possibility is to arrange the hardware so that more than one operation can be performed at the same time. In this way, the number of operations performed per second is increased even though the elapsed time needed to perform any one operation is not changed.





(b) Hardware organization

[10]

CO5 L2



Figure 8.1 Basic idea of instruction pipelining.

The computer is controlled by a clock whose period is such that the fetch and execute steps of any instruction can each be completed in one clock cycle. Operation of the computer proceeds as in Figure 8.1c. In the first clock cycle, the fetch unit fetches an instruction  $I_1$  (step  $F_1$ ) and stores it in buffer B1 at the end of the clock cycle. In the second clock cycle, the instruction fetch unit proceeds with the fetch operation for instruction  $I_2$  (step  $F_2$ ). Meanwhile, the execution unit performs the operation specified by instruction  $I_1$ , which is available to it in buffer B1 (step  $E_1$ ). By the end of the

second clock cycle, the execution of instruction  $I_1$  is completed and instruction  $I_2$  is available. Instruction  $I_2$  is stored in B1, replacing  $I_1$ , which is no longer needed. Step  $E_2$  is performed by the execution unit during the third clock cycle, while instruction  $I_3$  is being fetched by the fetch unit. In this manner, both the fetch and execute units are kept busy all the time. If the pattern in Figure 8.1c can be sustained for a long time, the completion rate of instruction execution will be twice that achievable by the sequential operation depicted in Figure 8.1a.

In summary, the fetch and execute units in Figure 8.1b constitute a two-stage pipeline in which each stage performs one step in processing an instruction. An interstage storage buffer, B1, is needed to hold the information being passed from one stage to the next. New information is loaded into this buffer at the end of each clock cycle.

The processing of an instruction need not be divided into only two steps. For example, a pipelined processor may process each instruction in four steps, as follows:

- F Fetch: read the instruction from the memory.
- D Decode: decode the instruction and fetch the source operand(s).
- E Execute: perform the operation specified by the instruction.
- W Write: store the result in the destination location.

# ROLE OF CACHE MEMORY

Each stage in a pipeline is expected to complete its operation in one clock cycle. Hence, the clock period should be sufficiently long to complete the task being performed in any stage. If different units require different amounts of time, the clock period must allow the longest task to be completed. A unit that completes its task early is idle for the remainder of the clock period. Hence, pipelining is most effective in improving

performance if the tasks being performed in different stages require about the same amount of time.

This consideration is particularly important for the instruction fetch step, which is assigned one clock period in Figure 8.2a. The clock cycle has to be equal to or greater than the time needed to complete a fetch operation. However, the access time of the main memory may be as much as ten times greater than the time needed to perform basic pipeline stage operations inside the processor, such as adding two numbers. Thus, if each instruction fetch required access to the main memory, pipelining would be of little value.



(a) Instruction execution divided into four steps



For a variety of reasons, one of the pipeline stages may not be able to complete its processing task for a given instruction in the time allotted. For example, stage E in the four-stage pipeline of Figure 8.2b is responsible for arithmetic and logic operations, and one clock cycle is assigned for this task. Although this may be sufficient for most operations, some operations, such as divide, may require more time to complete. Figure 8.3 shows an example in which the operation specified in instruction I<sub>2</sub> requires three cycles to complete, from cycle 4 through cycle 6. Thus, in cycles 5 and 6, the Write stage must be told to do nothing, because it has no data to work with. Meanwhile, the information in buffer B2 must remain intact until the Execute stage has completed its operation. This means that stage 2 and, in turn, stage 1 are blocked from accepting new instructions because the information in B1 cannot be overwritten. Thus, steps D<sub>4</sub> and F<sub>5</sub> must be postponed as shown.



Figure 8.3 Effect of an execution operation taking more than one clock cycle.

Pipelined operation in Figure 8.3 is said to have been *stalled* for two clock cycles Normal pipelined operation resumes in cycle 7. Any condition that causes the pipeline to stall is called a *hazard*. We have just seen an example of a *data hazard*. A data hazard is any condition in which either the source or the destination operands of an instruction are not available at the time expected in the pipeline. As a result some operation has to be delayed, and the pipeline stalls.

The pipeline may also be stalled because of a delay in the availability of an instruction. For example, this may be a result of a miss in the cache, requiring the instruction to be fetched from the main memory. Such hazards are often called *control hazards* or *instruction hazards*. The effect of a cache miss on pipelined operation is illustrated in Figure 8.4. Instruction  $I_1$  is fetched from the cache in cycle 1, and its execution proceeds normally. However, the fetch operation for instruction  $I_2$ , which is started in cycle 2 results in a cache miss. The instruction fetch unit must now suspend any further fetch requests and wait for  $I_2$  to arrive. We assume that instruction  $I_2$  is received and loaded into buffer  $I_2$  to arrive  $I_3$ . The pipeline resumes its normal operation at that point



Figure 8.4 Pipeline stall caused by a cache miss in F2.

[15]

7(a) Explain three types of mapping functions for cache memory.

(Direct mapping-5M, Associative Mapping-5M, Set-associative mapping-5M)



# **DIRECT MAPPING**

This technique is easy to implement but not very flexible.

Block j of the main memory maps onto j modulo 128 of the cache. For example, whenever **one of** the main memory blocks 0, 128, 256, .... Is loaded in the cache, it is stored in cache block 0. Main memory blocks 1, 129, 257, ..... are stored in cache block 1 (one at a time), and so on. Contention may occur for a single cache block required by multiple memory blocks. E.g when for program execution both memory block 1 and 129 are required but cache block 1 can only store one memory block. To resolve this, new blocks are allowed to overwrite the currently resident block.

From example,

4096 memory blocks need to be mapped to 128 cache blocks. i.e, each cache block identified 32 memory blocks (4096/128).

# Main memory address is divided into three parts:

Tag (5 bits): identify which memory block (out of 32 in this case) is currently resident in the cache

Block (7 bits): cache block position where the new memory block must be stored

**Word** (4 bits): selects one of the words of the memory block (out of 16 words per block in this case)

CO3

L2



Figure 8.17 Associative-mapped cache.

- It is more flexible than direct mapping technique but more expensive. Main memory block can be placed into any cache block position.
- · Memory address is divided into two fields:
  - Low order 4 bits identify the memory word within a block.
  - High order 12 bits or tag bits identify a memory block when residing in the cache.
- · Flexible, and uses cache space efficiently.
- Replacement algorithms can be used to replace an existing block in the cache when the cache is full.
- Cost is higher than direct-mapped cache because of the need to search all 128
  patterns to determine whether a given block is in the cache.



# roprogrammed Control



# P.7.16 Basic organization of a microprogrammed control unit.

roprogramming is a method of control unit design (Figure 7.16).

ntrol-signals are generated by a program similar to machine language programs.

ntrol Word(CW) is a word whose individual bits represent various control-signals (like Add, PC th of the control-steps in control sequence of an instruction defines a unique combination of 1 CW.

ividual control-words in microroutine are referred to as **microinstructions** (Figure 7.15). sequence of CWs corresponding to control-sequence of a machine instruction constitutes **oroutine.** 

a microroutines for all instructions in the instruction-set of a computer are stored in a spe ory called the **Control Store (CS)**.

ontrol-unit generates control-signals for any instruction by sequentially reading CWs sponding microroutine from CS.

C is used to read CWs sequentially from CS. ( $\mu PC \rightarrow$  Microprogram Counter).

ery time new instruction is loaded into IR, o/p of **Starting Address Generator** is loaded into µlen, µPC is automatically incremented by clock;

causing successive microinstructions to be read from CS.

Hence, control-signals are delivered to various parts of processor in correct sequence.

### antages

simplifies the design of control unit. Thus it is both, cheaper and less error prone implement. ntrol functions are implemented in software rather than hardware.

e design process is orderly and systematic.

ore flexible, can be changed to accommodate new system specifications or to correct the desired quickly and cheaply.

mplex function such as floating point arithmetic can be realized efficiently.

## idvantages

nicroprogrammed control unit is somewhat slower than the hardwired control unit, because tim ired to access the microinstructions from CM.

e flexibility is achieved at some extra hardware cost due to the control memory and its accultry.

# PCout, MARin, Read, Select4, Add, Zin Zout, PCin, Yin, WMFC MDRout, IRin R3out, MARin, Read R1out, Yin, WMFC MDRout, SelectY, Add, Zin Zout, R1in, End P7.6 Control sequence for execution of the instruction Add (R3),R1

CO5 L2

| ro -<br>ruction | <br>PCin | PCour | MARin | Read | MDRour | IRin | Y <sub>in</sub> | Select | Add | Zin | Zour | Rlour | R1in | R3out | WMFC | End |  |
|-----------------|----------|-------|-------|------|--------|------|-----------------|--------|-----|-----|------|-------|------|-------|------|-----|--|
| 1               | 0        | 1     | 1     | 1    | 0      | 0    | 0               | 1      | 1   | 1   | 0    | 0     | 0    | 0     | 0    | 0   |  |
| 2               | 1        | 0     | 0     | 0    | 0      | 0    | 1               | 0      | 0   | 0   | 1    | 0     | 0    | 0     | 1    | 0   |  |
| 3               | 0        | 0     | 0     | 0    | 1      | 1    | 0               | 0      | 0   | 0   | 0    | 0     | 0    | 0     | 0    | 0   |  |
| 4               | 0        | 0     | 1     | 1    | 0      | 0    | 0               | 0      | 0   | 0   | 0    | 0     | 0    | 1     | 0    | 0   |  |
| 5               | 0        | 0     | 0     | 0    | 0      | 0    | 1               | 0      | 0   | 0   | 0    | 1     | 0    | 0     | 1    | 0   |  |
| 6               | 0        | 0     | 0     | 0    | 1      | 0    | 0               | 0      | 1   | 1   | 0    | 0     | 0    | 0     | 0    | 0   |  |
| 7               | 0        | 0     | 0     | 0    | 0      | 0    | 0               | 0      | 0   | 0   | 1    | 0     | 1    | 0     | 0    | 1   |  |

are 7.15 An example of microinstructions for Figure 7.6.

# ORGANIZATION OF MICROPROGRAMMED CONTROL UNIT TO SUPPORT CONDIBRANCHING

- Drawback of previous Microprogram control:
  - > It cannot handle the situation when the control unit is required to check the status of condition codes or external inputs to choose between alternative courses of action.

### Solution:

- > Use conditional branch microinstruction.
- In case of conditional branching, microinstructions specify which of the external inputs, c codes should be checked as a condition for branching to take place.
- Starting and Branch Address Generator Block loads a new address into  $\mu$ PC microinstruction instructs it to do so (Figure 7.18).
- To allow implementation of a conditional branch, inputs to this block consist of
  - → external inputs and condition-codes &
  - → contents of IR.
- $\bullet$   $\mu PC$  is incremented every time a new microinstruction is fetched from microprogram memor in following situations:
  - 1) When a new instruction is loaded into IR,  $\mu PC$  is loaded with starting-address of mici for that instruction.
  - 2) When a Branch microinstruction is encountered and branch condition is satisfied loaded with branch-address.
  - 3) When an End microinstruction is encountered,  $\mu PC$  is loaded with address of first microroutine for instruction fetch cycle.



Figure 7.18 Organization of the control unit to allow conditional branching in the microprogram.

| Address     | Microinstruction                                              |
|-------------|---------------------------------------------------------------|
| 0           | PCout, MARin, Read, Select4, Add, Zin                         |
| 1           | Zout, PCin, Yin, WMFC                                         |
| 2           | MDR <sub>out</sub> , IR <sub>in</sub>                         |
| 3           | Branch to starting address of appropriate microroutine        |
| 25          | If N=0, then branch to microinstruction 0                     |
| 26          | Offset-field-of-IR $_{out}$ , SelectY, Add, $\mathbf{Z}_{in}$ |
| 27          | $\mathbf{Z}_{out}$ , $\mathbf{PC}_{in}$ , $\mathbf{End}$      |
| Figure 7.17 | Microroutine for the instruction Branch < 0.                  |

### MICROINSTRUCTIONS

- A simple way to structure microinstructions is to assign one bit position to each con required in the CPU.
- There are 42 signals and hence each microinstruction will have 42 bits.
- Drawbacks of microprogrammed control:
  - Assigning individual bits to each control-signal results in long microinstructions bec the number of required signals is usually large.
  - 2) Available bit-space is poorly used because
    - only a few bits are set to 1 in any given microinstruction.
- Solution: Signals can be grouped because
  - 1) Most signals are not needed simultaneously.
  - 2) Many signals are mutually exclusive. E.g. only 1 function of ALU can be activated at For ex: Gating signals: IN and OUT signals (Figure 7.19).

Control-signals: Read, Write.

ALU signals: Add, Sub, Mul, Div, Mod.

- Grouping control-signals into fields requires a little more hardware because decoding-circuits must be used to decode bit patterns of each field into individual control
- Advantage: This method results in a smaller control-store (only 20 bits are needed to patterns for the 42 signals).

### **MICROINSTRUCTIONS**

- A simple way to structure microinstructions is to assign one bit position to each cont required in the CPU.
- There are 42 signals and hence each microinstruction will have 42 bits.
- Drawbacks of microprogrammed control:
  - Assigning individual bits to each control-signal results in long microinstructions becathe number of required signals is usually large.
  - 2) Available bit-space is poorly used because

only a few bits are set to 1 in any given microinstruction.

- Solution: Signals can be grouped because
  - 1) Most signals are not needed simultaneously.
  - 2) Many signals are mutually exclusive. E.g. only 1 function of ALU can be activated at For ex: Gating signals: IN and OUT signals (Figure 7.19).

Control-signals: Read, Write.

ALU signals: Add, Sub, Mul, Div, Mod.

- Grouping control-signals into fields requires a little more hardware because
  - decoding-circuits must be used to decode bit patterns of each field into individual control-
- Advantage: This method results in a smaller control-store (only 20 bits are needed to patterns for the 42 signals).

| F1                                                                                                                                                                                                                                                               | F2                                                                                                                                                                                             | F3                                                                                                                      | F4                                                                   | F5                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|----------------------------------------|
| 1 (4 bits)                                                                                                                                                                                                                                                       | F2 (3 bits)                                                                                                                                                                                    | F3 (3 bits)                                                                                                             | F4 (4 bits)                                                          | F5 (2 bits)                            |
| 000: No transfer<br>001: PC <sub>out</sub><br>010: MDR <sub>out</sub><br>011: Z <sub>out</sub><br>100: R0 <sub>out</sub><br>101: R1 <sub>out</sub><br>110: R2 <sub>out</sub><br>111: R3 <sub>out</sub><br>010: TEMP <sub>out</sub><br>011: Offset <sub>out</sub> | 000: No transfer<br>001: PC <sub>in</sub><br>010: IR <sub>in</sub><br>011: Z <sub>in</sub><br>100: RO <sub>in</sub><br>101: R1 <sub>in</sub><br>110: R2 <sub>in</sub><br>111: R3 <sub>in</sub> | 000: No transfer<br>001: MAR <sub>in</sub><br>010: MDR <sub>in</sub><br>011: TEMP <sub>in</sub><br>100: Y <sub>in</sub> | 0000: Add<br>0001: Sub<br>:<br>:<br>!!!!: XOR<br>!! ALU<br>functions | 00: No action<br>01: Read<br>10: Write |
| F6                                                                                                                                                                                                                                                               | F7                                                                                                                                                                                             | F8 ·                                                                                                                    |                                                                      |                                        |
| F6 (1 bit)                                                                                                                                                                                                                                                       | F7 (1 bit)                                                                                                                                                                                     | F8 (1 bit)                                                                                                              | _                                                                    |                                        |
| 0: SelectY<br>1: Select4                                                                                                                                                                                                                                         | 0: No action<br>1: WMFC                                                                                                                                                                        | 0: Continue<br>1: End                                                                                                   | _                                                                    |                                        |

Figure 7.19 An example of a partial format for field encoded microinstructions.

(b) Explain with a neat diagram hardwired control.

CO5 L2

[8]

# Hardwired Control



Figure 7.11 Separation of the decoding and encoding functions.



- Hardwired control is a method of control unit design (Figure 7.11).
- The control-signals are generated by using logic circuits such as gates, flip-flops, decoders etc.
- **Decoder/Encoder Block** is a combinational-circuit that generates required control-outputs depending on state of all its inputs.

### • Instruction Decoder

- > It decodes the instruction loaded in the IR.
- $\succ$  If IR is an 8 bit register, then instruction decoder generates  $2^8(256 \text{ lines})$ ; one for each instruction.
- > It consists of a separate output-lines INS<sub>1</sub> through INS<sub>m</sub> for each machine instruction.
- $\succ$  According to code in the IR, one of the output-lines INS<sub>1</sub> through INS<sub>m</sub> is set to 1, and all other lines are set to 0.
- Step-Decoder provides a separate signal line for each step in the control sequence.

### Encoder

- > It gets the input from instruction decoder, step decoder, external inputs and condition codes.
- $\succ$  It uses all these inputs to generate individual control-signals:  $Y_{in}$ ,  $PC_{out}$ , Add, End and so on.
- $\triangleright$  For example (Figure 7.12),  $Z_{in}=T_1+T_6.ADD+T_4.BR$

;This signal is asserted during time-slot  $T_1$  for all instructions.

during T<sub>6</sub> for an Add instruction.

during T<sub>4</sub> for unconditional branch instruction

- When RUN=1, counter is incremented by 1 at the end of every clock cycle.
   When RUN=0, counter stops counting.
- After execution of each instruction, end signal is generated. End signal resets step counter.
- Sequence of operations carried out by this machine is determined by wiring of logic circuits, hence the name "hardwired".
- Advantage: Can operate at high speed.

# • Disadvantages:

- 1) Since no. of instructions/control-lines is often in hundreds, the complexity of control unit is very high.
- 2) It is costly and difficult to design.
- 3) The control unit is inflexible because it is difficult to change the design.