KEMBAR78
Control Unit - Lec 2 | PDF | Central Processing Unit | Computer Engineering
0% found this document useful (0 votes)
95 views32 pages

Control Unit - Lec 2

The control unit of the CPU sends all the hardware signals required for proper instruction execution. There are two main approaches to designing the control unit (CU): the hardwired approach and microprogrammed approach. The hardwired approach can achieve faster speeds but has a fixed instruction set, while the microprogrammed approach uses microcode to allow for more flexible and complex instruction sets. The document then provides details on how each approach generates control signals through different methods such as AND/OR gates or microinstructions.

Uploaded by

Danu Nim
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
95 views32 pages

Control Unit - Lec 2

The control unit of the CPU sends all the hardware signals required for proper instruction execution. There are two main approaches to designing the control unit (CU): the hardwired approach and microprogrammed approach. The hardwired approach can achieve faster speeds but has a fixed instruction set, while the microprogrammed approach uses microcode to allow for more flexible and complex instruction sets. The document then provides details on how each approach generates control signals through different methods such as AND/OR gates or microinstructions.

Uploaded by

Danu Nim
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 32

Control Unit Implementation

The control unit of the CPU is responsible for


sending all the hardware signals required both by
internal and external units of the CPU for proper
execution of instructions.
There are two popular methods available to design
the CU.
• Hard wired control unit (Hardware approach)
• Micro program control unit (software
approach)
The hardwired approach has the
advantage that it is possible to devise
faster CPUs if typical CPU speeds are
faster than typical memory speeds (a
situation that has been true for quite some
time).
drawback of hardwired logic is that it is
difficult to design CPUs with large and
complex instruction sets using this
approach.
Hard wired control unit
8 bit
Instruction OPCODE OPERAND
Register (IR)

Instruction Decoder
Master
clock
0 1 2 3 64 255

T1
T2
T3
Timing
Generator
T4 Control Matrix
Tn

Sequenced
control
RESET signals
Condition codes
The timing generator generates pulses at corresponding time slots as
shown below
Master clock

T1 t

T2 t

t
T3

t
Similarly all the timing signals are generated up to Tn. Then start
again from T1. Same thing repeats in a cyclic manner.
Now consider the fetch cycle.
Control signals to activate are listed below according to the order

T1 (PC)outA
T2 (MAR)inA
T3 (MAR)out
T4 Read
T5 (MBR)in
T6 (MBR)outD
T7
(IR)inD
T8
(PC)inc
The above control signals are activated in the given order.
For that timing generator outputs are hard wired to an array of AND
gates.
Selected Line corresponding to the OPcode -64 line LOAD A
‘1’
(PC)outA
T1
(MAR)inA
T2
(MAR)out
T3
Read
T4
(MBR)in
T5
(MBR)outD
T6
(IR)inD
T7
(PC)inc
T8
• Instruction decoder select a line out of 255
according to the Opcode part (64th line for
LOAD A OPcode).

• Each and every line is connected to a set of


AND gates.

• Required control signals are activated at the


proper order as the timing pulses are applied to
gate inputs
• This continues for the execution cycle as well.

• Now consider the execution cycle of LOAD A


instruction
Selected Line corresponding to the OPcode -64 line LOAD A
‘1’
(IR)outA
T9
(MAR)inA
T10
(MAR)out
T11
Read
T12
(MBR)in
T13
(MBR)outD
T14
(ACC)inD
T15
RESET
T16
• The RESET control signal initializes the timing
generator.
• In the above execution cycle, the timing
generator is reset with T16 (with 16th clock
pulse).
• Therefore with the following clock pulse the
timing generator will activate T1 there by starting
the fetch cycle of the next instruction.
• Since the length of the execution cycle can vary
from instruction to instruction timing generator
will be initilized during different time slots(not
always with T16 )
Draw the AND gate band diagram for the FETCH &
EXECUTION cycles of the ADD A,(address) instruction
Draw the AND gate band diagram for the FETCH &
EXECUTION cycles of the STORE A,(address) instruction
Draw the AND gate band diagram for the FETCH &
EXECUTION cycles of the JUMP (address) instruction
Now it is clear that each machine code instruction (OPcode) requires
a separate AND gate band inside the control matrix in the CU.
As the number of instruction increases gate count also increases. This
limits the instruction set to a small number.
A particular control signal (e.g. (MAR)out) will have to be activated
during different intervals for different instructions. Therefore the
similer control signals from the AND gate bands must be combined
using a band of OR gates to derive a final control signal output.
STORE A, (address)

(MAR)out
T11
FETCH cycle T3
(MAR)in A
I t is possible to carry out some operations in parallel without affecting
the other. E.g. put ACC to Bus D & IR to Bus A.
So that the time taken to complete the execution of an instruction can
be reduced. Consider the execution cycle of STORE A,(address)
‘1’
(IR)outA / (ACC)outD
T9
(MAR)inA / (MBR)inD
T10
(MAR)out / (MBR)out
T11
Write

T12 RESET

T13
• Disadvantage of hard wired CU is that it
makes the instruction set fixed and no
modifications or enhancements to the
instruction set is possible after it is
manufactured.
• However hard wired control units can be
operated at high clock rates and more
suitable for high speed CPUs.
Micro Program Control Unit
(IR) OPCODE OPERAND

Starting Address Selection


(Instruction Counter Source CCR
Selector)

LOAD
RESET
-PC

- Program memory - IR
Control
(Control memory) signals
Instruction
Decoder
The control memory is -ins1
divided in to number of -ins2
micro instruction segments. Fragment
Each segment contains 1
number of micro -insN
instructions.
Fragment
There is a micro instruction
2
fragment corresponding to
fetch cycle. usually the first
one, fragnent1. Similarly Fragment
there is a micro instruction 3
fragment corresponding for
each execution cycle , of
the machine code
instruction cycle.
ICSS Load with fragment 1(fetch cycle) starting address

ICSS -PC
- Program memory - IR
Increment -PC
- Program memory - IR
Increment -PC
- Program memory - IR
Increment -PC

………..
Until the end of the fetch cycle.
Activate LOAD signal
ICSS load with starting address of the execution fragment

ICSS -PC
- Program memory - IR
Increment -PC
- Program memory - IR
Increment -PC
- Program memory - IR
Increment -PC
…………………………..
Until the end of the Execution Cycle.
Activate RESET signal
Continue the Same cycle again for the
next instruction
…………………….
The instruction counter source selector (ICSS) provides
the starting address of the micro instruction fragment
corresponding with the current machine code instruction.
The micro program counter starts counting from this
starting address.
The micro instruction currently being executed, is held
in the micro instruction register,and is decoded by the
instruction decoder for final control outputs.
• At he end of each fetch cycle micro
instruction program counter is loaded by
the output of the ICSS at the end of each
execution cycle the -PC is reset, initiating
the next fetch cycle.
• Micro program CU can be implemented in
three different ways.
1. Horizontal microprogramming
2. Vertical microprogramming
3. Combined microprogramming
Horizontal microprogramming

(MAR)in Micro instruction LOAD RESET


(MBR)in
(MAR)out format
(MBR)out
(PC)outA
In horizontal micro programming a unique bit (MAR)inA
position in the micro instruction format is (MAR)out
reserved for each control
Read
Each micro instruction is responsible for the (MBR)in
activation of a single control signal.
(MBR)outD
Let us consider the fetch cycle. The control
(IR)inD
sequence for the fetch cycle is given here
(PC)inc
Clock
cycle

1 0 0 0 0 0 0 0 0 0 1 0 0 0
2 1 0 0 0 0 0 0 0 0 0 0 0 0
3 0 1 0 0 0 0 0 0 0 0 0 0 0
4 0 0 0 0 0 0 1 0 0 0 0 0 0
5 0 0 0 1 0 0 0 0 0 0 0 0 0
6 0 0 0 0 1 0 0 0 0 0 0 0 0
7 0 0 0 0 0 0 0 0 0 0 1 0 0
8 0 0 0 0 0 0 0 0 1 0 0 0 0
9 0 0 0 0 0 0 0 0 0 0 0 1 0
In horizontal micro programming an instruction decoder is not
necessary inside the control unit. Control signals are straight away
derived from the micro instruction register.
Each out put of micro instruction register correspond to a control
signal output.
In horizontal microprogramming the length of the micro
instruction is relatively large.(If there are 200 control signals to be
generated, each micro instruction will be 200 bit long). This is
considered to be a disadvantage of the horizontal
microprogramming.
However this technique supports the parallel operation of
controls. If parallel operation of controls are provided a micro
instruction can contain more than a single one ‘1’.
Further advantage of this technique is that it does not require an
instruction decoder
Draw the control memory for the execution cycle of
ADD A,(address) instruction
Draw the control memory for the execution cycle of
STORE A,(address) instruction
Vertical microprogramming
This technique is an effort to reduce the micro instruction length.
There by reducing the complexity of micro IR and the control
memory.
Ex assume that there are 256 controls 7 each micro instruction
activates a single control out of the 256 controls.
Since 256 = 28 an 8 bit coded micro instruction can be used this
technique is known as Vertical micro programming and an instruction
decoder is required to get the final control outputs.
The advantages of vertical micro programming are the
reduced micro instruction length & control memory size.
The disadvantages are Parallel operation of controls is not
possible. Additional instruction decoder is required. Due to the
additional instruction decoder the speed of the control unit can be
slower compared to horizontal micro programming.
Combined microprogramming
This is a hybrid version of horizontal and vertical micro programming.
This technique tries to reduce the micro instruction length, while
allowing parallel operation of controls.
In this technique the control signals are grouped in such a way so that
parallel operation of controls is not required within a group.
e.g. group1 Bus D controls (ACC)out D (R0)out D (TEMP)out D)…
group2 Bus D out put controls (ACC)in D (R0)in D …
group3 ALU controls.

Group1 Group2 Group3

Fully encoded bit pattern


Each group require separate decoder unit.

Group1 Group2 Group3

Decoder 1 Decoder 2 Decoder 3 Decoder


4

Control signals Control signals Control signals


Within each group a fully encoded bit pattern can be used so that
only a single control within a group can be activated at a time.
However control signals from different groups can be activated at
the same time.
An additional bit pattern within each group is required to keep all
the control signals disabled, each other pattern would corresponds
to the activation of a single control within the group.
A micro program control unit can be slower than a hardwired
control unit however the advantage of a micro programmed control
unit over a hard wired one is the flexibility to change the available
instruction set and EPROM (Erasable Programmable Read Only
Memory) can be used for the control memory of micro program
CU, allowing the micro instruction fragments to be re-programmed

You might also like