Professional Documents
Culture Documents
Unit-1 Notes
By
Dr. Lalit Saraswat
1
2
3
4
5
System bus
13
a) Daisy chaining
• It is simple and cheaper method. All masters make use of the
same line for bus request.
• In response to the bus request the controller sends a bus
grant if the bus is free.
• The bus grant signal serially propagates through each master
until it encounters the first one that is requesting access to
the bus. This master blocks the propagation of the bus grant
signal, activities the busy line and gains control of the bus.
• Therefore any other requesting module will not receive the
grant signal and hence cannot get the bus access
14
a) Daisy chaining
• Advantages –
• Simplicity and Scalability.
• The user can add more devices anywhere along the chain, up
to a certain maximum value.
• Disadvantages –
• The value of priority assigned to a device is depends on the
position of master bus.
• Propagation delay is arises in this method.
• If one device fails then entire system will stop working.
15
a) Daisy chaining
16
b) Polling method
17
Advantages –
•This method does not favor any particular device and
processor.
•The method is also quite simple.
•If one device fails then entire system will not stop
working.
Disadvantages –
•Adding bus masters is different as increases the
number of address lines of the circuit.
18
19
c) Independent request
• In this scheme each master has a separate pair of bus request
and bus grant lines and each pair has a priority assigned to it.
• The built in priority decoder within the controller selects the
highest priority request and asserts the corresponding bus
grant signal.
20
2. Distributed Arbitration
• In distributed arbitration, all devices
participate in the selection of the next bus
master.
• In this scheme each device on the bus is
assigned a4-bit identification number.
• The decentralized arbitration offers high
reliability because operation of the bus is not
dependent on any single device.
21
Register Transfer Language:
22
Register Transfer Language:
❖ The internal hardware organization of a digital computer is defined by specifying:
➢ The set of registers it contains and their function.
➢ The sequence of microoperations performed on the binary information stored in
the registers.
➢ The control that initiates the sequence of microoperations.
❖ The symbolic notation used to describe the microoperation transfers among registers is
called a register transfer language.
❖ The term register transfer implies the availability of hardware logic circuit that can
transfer the result of the operation to the same or another register.
❖ A register transfer language (RTL) is a system for expressing in symbolic form the
microoperation sequences among the register of a digital module.
❖ Computer registers are designated by capital letters (sometimes followed by numerals)
to denote the function of the register
➢ R1: processor register (general purpose register)
➢ MAR: Memory Address Register (holds an address for a memory unit)
➢ PC: Program Counter
➢ IR: Instruction Register
➢ SR: Status Register
23
Register Transfer:
❖ The individual flip-flops in an n-bit register are numbered in sequence from 0 to n-
1 (from the right position toward the left position).
R1 7 6 5 4 3 2 1 0
25
Register Transfer:
Control P Load
R2 Clock
Circuit
R1
Block Diagram:
t t+1
Clock
Synchronized
Load
with the clock
Transfer occurs here
Timing Diagram:
26
Register Transfer:
❖ The statement
❖ T: R2 ← R1, R1 ← R2
denotes an operation that exchanges the contents of two registers during one
common clock pulse provided that T = 1.
This simultaneous operation is possible with registers that have edge-triggered flip-
flops.
27
Bus and Memory Transfers:
❖ A typical digital computer has many registers, and paths must be provided to
transfer information from one register to another.
❖ The number of wires will be excessive if separate lines are used between each
register and all other registers in the system.
❖ The more efficient scheme for transferring information between registers in a
multiple-register system is a common bus system.
❖ A bus structure consists of a set of common lines, one for each bit of a register,
through which binary information is transferred one at a time.
❖ Control signals determine which register is selected by the bus during each
particular register transfer.
❖ Common bus system can be constructed either by using multiplexers or by using
three-state buffers.
28
Bus System for Four Registers using Multiplexers:
4-line
S1
common
S0
bus
4*1 4*1 4*1 4*1 S1 S0 Register selected
MUX 3 MUX 2 MUX 1 MUX 0
0 0 A
3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0 0 1 B
1 0 C
1 1 D
•BUS ← C
•R1 ← BUS
3 2 1 0 3 2 1 0 3 2 1 0 3 2 1 0
Register D Register C Register B Register A
• R1 ← C
30
Memory Transfer:
31
Microoperations:
❖ A microoperation is an elementary operation performed with the data
stored in registers.
❖ The microoperations performed in digital systems are classified into four
categories:
❖ Register transfer microoperations --- transfer binary information one
register to another.
❖ Arithmetic microoperations --- perform arithmetic operation on
numeric data stored in registers.
❖ Logic microoperations --- perform bit manipulation operations on
numeric data stored in registers.
❖ Shift microoperations --- perform shift operations on data stored in
registers.
32
Arithmetic Microoperations:
33
4-bit Binary Adder:
1 1 1 1 0 C4 C3 C2 C1 C0
0 1 1 1
A3 A2 A1 A0
1 1 0 1 B3 B2 B1 B 0
1 0 1 0 0 S3 S2 S1 S0
C3 1 C2 1 C1 1 C0 0
1
FA FA FA FA
C4 S3 0 S2 1 S1 0 S0 0
34
4-bit Binary Adder-Subtractor: 0 1 0 0 A 0 1 0 0 A
0 0 0 1 0 1 1 1
C3 C2 C1 C0
FA FA FA FA
C4 S3 S2 S1 S0
35
4-bit Binary Adder-Subtractor:
M=0 M=1
C4 C3 C2 C1 C0 C4 C3 C2 C1 C0
A3 A2 A1 A0 A3 A2 A1 A0
B3 B2 B1 B0 B3’ B2’ B1’ B0’
S3 S2 S1 S0 S3 S2 S1 S0
A+B A-B
36
4-bit Binary Incrementer:
C4 C3 C2 C1
1
+
1 0 1
1
A A3 A2 A1 A0
1 1 1 0 1
S3 S2 S1 S0
A3 1 A2 1
A1 0 A0 1 1
x y x y x y x y
HA HA HA HA
C S C S C S C S
C4 S3 S2 S1 S0
37
Logic Microoperations:
❖ Logic microoperations specify binary operations for strings of bits stored
in registers.
❖ These operations consider each bit of the register separately and treat
them as binary variables.
❖ Example: P : R1 R1 R2
1010 Content of R1
+ 1100 Content of R2
0110 Content of R1 after P=1
❖ Special Symbols
Special symbols will be adopted for the logic microoperations OR(V),
AND(Ʌ), and complement (a bar on top), to distinguish them from the
corresponding symbols used to express Boolean functions.
38
Logic Microoperations:
S 1
E i
1
S1 S0 Output Operation
0 0 E=AɅB AND
0 1 E=AVB OR 2
1 0 E = A B XOR
1 1 E = A’ Compliment
3
NOT
39
Boolean Function Microoperation Name
F0 = 0 F←0 Clear
F1 = xy F←AɅB AND
F2 = xy’ F←AɅB
F3 = x F←A Transfer A
F4 = x’y F←AɅB
Table #
F5 = y F←B Transfer B
F6 = x y F←AB Exclusive-OR
F7 = x + y F←AVB OR
F8 = (x + y)’ F←AVB NOR
F9 = (x y)’ F←AB Exclusive-NOR
F10 = y’ F←B Compliment B
F11 = x + y’ F←AVB
F12 = x’ F←A Compliment A
F13 = x’ + y F←AVB
F14 = (xy)’ F←AɅB NAND
40
F15 = 1 F ← all 1’s Set to all 1’s
Logic Microoperations --- Applications:
❖ Logic microoperations are very useful for manipulating individual bits or a
portion of a word stored in a register
❖ Used to change bit values, delete a group of bits, or insert new bit values
❖ Selective-set
❖ The selective-set operation sets to 1 the bits in register A where there
are corresponding 1’s in register B. It does not effect bit positions that
have 0’s in B.
A AVB 1010 A before
1100 B(Logic Operand)
1110 A After
❖ Selective-complement
❖The selective-complement operation complements bits in A where there
are corresponding 1’s in B. It does not effect bit positions that have 0’s in B.
❖The clear operation compares the words in A and B and produces an all
0’s result if the two numbers are equal
A AB 0110 A
0110 B
0000 A after clear 42
Shift Microoperations:
❖ Used for serial transfer of data.
❖ Three types of shift: Logical, Circular, and Arithmetic.
Symbolic Description
Designation
R ← shl R Shift left register R
R ← shr R Shift right register R
R ← cil R Circular shift left register R
R ← cir R Circular shift right register R
R ← ashl R Arithmetic shift left register R
R ← ashr R Arithmetic shift right register R
43
Logical Shift:
❖ Transfers 0 through the serial input.
Logical Shift Left:
? Rn-1 R3 R2 R1 R0 0
0 Rn-1 R3 R2 R1 R0 ?
Rn-1 R3 R2 R1 R0
Rn-1 R3 R2 R1 R0
45
Circular Shift Examples:
Register Contents Before Shift Operation
1 0 1 1 0 1 0 1
46
Arithmetic Shift Right:
Rn-1 R3 R2 R1 R0
?
Sign
Bit Arithmetic Shift Right
? Rn-1 R3 R2 R1 R0 0
Sign Bit Arithmetic Shift Left
Register Contents Before
Arithmetic Shift Left Operation
0 0 1 1 0 1 0 1
Register Contents After
Arithmetic Shift Left Operation
0 1 1 0 1 0 1 0
Register Contents Before
Arithmetic Shift Left Operation
1 0 1 1 0 1 0 1
Register Contents After
Arithmetic Shift Left Operation
48
0 1 1 0 1 0 1 0
Arithmetic Shift Left:
❖ A sign reversal occurs if the bit in Rn-1 changes in value after the shift.
❖ This happens if the multiplication by 2 causes an overflow.
❖ An overflow flip-flop VS can be used to detect an arithmetic shift-left
overflow.
❖ VS = Rn-1 Rn-2
Rn-1
1 → overflow
VS=
Rn-2 0 → no overflow
49
Types of CPU Organizations:
• Single accumulator organization
• General register organization
• Stack organization
50
General Register Organization:
Clock Input
R1
R2
R3
R4
R5
R6
R7
Load
(7 lines) SELA MUX MUX SELB
3X8
A bus B bus
Decoder
Output
51
General Register Organization:
52
General Register Organization:
53
General Register Organization:
54
General Register Organization:
• Example: R1 R2 + R3
• MUX A selector (SELA - 010) : to place the content of R2 into
BUS A.
• MUX B selector (SELB - 011) : to place the content of R3 into
BUS B.
• ALU operation selector (OPR - 00010) : to provide the
arithmetic addition R2 + R3.
• Decoder selector (SELD - 001) : to transfer the content of the
output bus into R1.
Field SELA SELB SELD OPR
Symbol R2 R3 R1 ADD
Control Word: 010 011 001 00010
55
Stack Organization:
56
Register Stack: • A register stack is organized as a
Address collection of a finite number of registers.
• In a 64-word stack, the stack pointer
64
contains 6 bits.
• The one-bit register FULL is set to 1
FULL EMTY
when the stack is full; EMTY register is 1
when the stack is empty.
• The data register DR holds the data to
4
SP C 3 be written into or read from the stack.
B 2
A
• Initially, SP is cleared to 0, EMTY is set
1
0 to 1, and FULL is cleared to 0, so that SP
points to the word at address 0.
• If the stack is not full (if FULL = 0), a
DR
new item is inserted with a push
operation.
• A new item is deleted from the stack if
the stack is not empty (if EMTY = 0) with
a pop operation. 57
Register Stack:
• push operation:
• SP SP + 1 Increment stack pointer
• M[SP] DR Write item on top of the stack
• If (SP = 0) then (FULL 1) Check if stack is full
• EMTY 0 Mark the stack not empty
• pop operation:
• DR M[SP] Read item from top of stack
• SP SP - 1 Decrement stack pointer
• If (SP = 0) then (EMTY 1) Check if stack is empty
•FULL 0 Mark the stack not full
58
Memory Stack:
• A memory stack is implemented by
Address assigning a portion of memory to a stack
Memory unit
1000
operation and using a processor register
PC
Program as a stack pointer.
(instructions)
• The program counter PC points at the
AR
2000 address of the next instruction in the
Data program.
(operands)
• The address register AR points at an
3000 array of data.
Stack
• The stack pointer SP points at the top of
3997 the stack.
SP 3998
3999
• The three registers are connected to a
4000 common address bus, and either one can
4001 provide address for memory.
• Once the stack is initialized by loading
DR
address of stack top in SP, the stack
grows with decreasing address.
59
Memory Stack:
• push operation:
• SP SP - 1 Decrement stack pointer
• M[SP] DR Write item on top of the stack
•pop operation:
• DR M[SP] Read item from top of stack
• SP SP +1 Increment stack pointer
Arithmetic Expressions - Notation:
• A+B Infix notation
• +AB Prefix or Polish notation
• AB+ Postfix or reverse Polish notation (RPN)
•A*B+C*D → AB*CD*+
• This expression is evaluated from left to right as follows:
• (A* B)CD*+
• (A* B)(C*D)+
• (A* B) + (C*D) 60
Conversion to RPN:
• The conversion from infix to reverse Polish notation must follow
the operational hierarchy adopted for infix notation.
• First perform all arithmetic inside inner parenthesis, then inside
outer parenthesis, and do multiplication and division operations
before addition and subtraction operations.
• Consider the expression (A + B) * [C * (D + E) + F]
• First we evaluate the arithmetic inside the inner parenthesis (A + B)
and (D +E).
• Next calculate the expression inside the square brackets.
• The multiplication of C * (D + E) must be done prior to the addition
of F since multiplication has precedence over addition.
• The last operation is the multiplication of the two terms between
the parenthesis and brackets.
• The converted expression is AB + DE + C * F + *
61
Evaluation of Arithmetic Expression:
• Consider the example
(3*4)+(5*6) → 34 * 56 * +
4 5 5 30
3 3 12 12 12 12 42
3 4 * 5 6 * +
Instruction Formats:
• The bits of an instruction are divided into three fields.
❖ Operation Code Field : specify the operation to be performed.
❖ Address Field : designate a memory address or a processor
register.
❖ Mode Field : specify the operand or the effective address
(Addressing Mode). 62
Instruction Codes:
•An instruction code is a group of bits that instruct
that the computer to perform a specific
operation.
• An instruction code is usually divided into two
parts, operation code (opcode) and operand.
• The operation code is a group of bits that define
such operations as add, subtract, multiply, shift,
and compliment.
• An operation code is sometimes called a
macrooperation because it specifies a set of
micro-operations.
63
Instruction Formats:
• Three types of CPU organizations.
• The influence of the number of addresses on computer instructions
❖ Consider the example X = (A + B)*(C + D)
• Three Address Instruction:
ADD R1, A, B R1 M[A] + M[B]
ADD R2, C, D R2 M[C] + M[D]
MUL X, R1, R2 M[X] R1 * R2
• Two Address Instruction:
MOV R1, A R1 M[A]
ADD R1, B R1 R1 + M[B]
MOV R2, C R2 M[C]
ADD R2, D R2 R2 + M[D]
MUL R1, R2 R1 R1 * R2
MOV X R1 M[X] R1
64
• One Address Instructions:
LOAD A AC M[A]
ADD B AC AC + M[B]
STORE T M[T] AC
LOAD C AC M[C]
ADD D AC AC + M[D]
MUL T AC AC * M[T]
STORE X M[X] AC
• Zero Address Instructions:
PUSH A TOS A
PUSH B TOS B
ADD TOS (A + B)
PUSH C TOS C
PUSH D TOS D
ADD TOS (C + D)
MUL TOS (C + D) * (A + B)
POP X M[T] TOS 65
Addressing Modes:
• The way the operands are chose during program execution is dependent
on the addressing mode of the instruction.
• The addressing mode specifies a rule for interpreting or modifying the
address field of the instruction before the operand is actually referenced.
•Immediate Mode: In this mode the operand is specified in the instruction
itself i.e., an immediate-mode instruction has an operand field rather than
an address field.
• Immediate mode instructions are useful for initializing registers to a
constant value.
69
Indirect Address Mode:
70
Addressing Modes:
•Indexed Addressing Mode: In this mode the content of an index register is
added to the address part of the instruction to obtain the effective address.
• The index register is a special CPU register that contains an index value.
• The address field of the instruction defines the beginning address of a data
array in memory.
effective address = address part of instruction + content of CPU
register
71
Addressing Modes:
•Relative address Mode: In this mode the content of the program counter
is added to the address part of the instruction in order to obtain the
effective address.
•Base Register Addressing Mode: In this mode the content of a base
register is added to the address part of the instruction to obtain the
effective address.
• The base register holds a base address and the address field of the
instruction gives a displacement relative to the base address.
•Implied Mode: In this mode the operands are specified implicitly in the
definition of the instruction.
• Examples: Compliment Accumulator
• All register-reference instructions that use an accumulator are implied-
mode instructions.
• Zero address instructions in a stack-organized computer are implied-
mode instructions since the operands are implied to be on top of the stack.
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90