Micro Operation. MICROOPERATIONS Computer system microoperations are of four types: - Register transfer microoperations - Arithmetic microoperations -

Slides:



Advertisements
Similar presentations
Register Transfer and Microoperations Part2
Advertisements

Princess Sumaya University
Combinational Circuits
REGISTER TRANSFER LANGUAGE (RTL)
Chapter 4 Register Transfer and Microoperations
Princess Sumaya Univ. Computer Engineering Dept. د. بســام كحـالــه Dr. Bassam Kahhaleh.
Chapter 7 Henry Hexmoor Registers and RTL
Princess Sumaya University
7-5 Microoperation An elementary operations performed on data stored in registers or in memory. Transfer Arithmetic Logic: perform bit manipulation on.
ARITHMETIC LOGIC SHIFT UNIT
1 Register Transfer &  -operations Computer Organization Computer Architectures Lab REGISTER TRANSFER AND MICROOPERATIONS Register Transfer Language Register.
8085 processor. Bus system in microprocessor.
Charles Kime & Thomas Kaminski © 2004 Pearson Education, Inc. Terms of Use (Hyperlinks are active in View Show mode) Terms of Use Chapter 7 – Registers.
Chapter 7. Register Transfer and Computer Operations
Cpe 252: Computer Organization1 Lo’ai Tawalbeh Lecture #4 Register Transfer and Microoperations 23/2/2006 Chapter 4:
Combinational Comparators
Logic and Computer Design Dr. Sanjay P. Ahuja, Ph.D. FIS Distinguished Professor of CIS ( ) School of Computing, UNF.
Part 2: DESIGN CIRCUIT. LOGIC CIRCUIT DESIGN x y z F F = x + y’z x y z F Truth Table Boolean Function.
Chapter 4 Register Transfer and Microoperations
Shift Micro operations
Operations on data CHAPTER 4.
4 Operations On Data Foundations of Computer Science ã Cengage Learning.
Dr. Bernard Chen Ph.D. University of Central Arkansas
Computer System Configuration and Function Computer Architecture and Design Lecture 6.
Review We have introduced registers previously.
MICRO OPERATIONS Department of Computer Engineering, M.S.P.V.L. Polytechnic College, Pavoorchatram.
Chapter 4 – Arithmetic Functions and HDLs Logic and Computer Design Fundamentals.
CSC321 Where We’ve Been Binary representations Boolean logic Logic gates – combinational circuits Flip-flops – sequential circuits Complex gates – modules.
Chapter 4 Register Transfer and Micro -operations
REGISTER TRANSFER AND MICROOPERATIONS
Computer System Architecture © Korea Univ. of Tech. & Edu. Dept. of Info. & Comm. Chap. 4 Register Transfer and Microoperations 4-1 Chap. 4 Register Transfer.
Exam2 Review Dr. Bernard Chen Ph.D. University of Central Arkansas Spring 2009.
Chap 7. Register Transfers and Datapaths. 7.1 Datapaths and Operations Two types of modules of digital systems –Datapath perform data-processing operations.
REGISTER TRANSFER LANGUAGE MICROOPERATIONS. TODAY OUTLINES Logic Microoperations Shift Microoperations.
REGISTER TRANSFER & MICROOPERATIONS By Sohaib. Digital System Overview  Each module is built from digital components  Registers  Decoders  Arithmetic.
1 Chapter Four Register Transfer and Micro operations.
Exam1 Review Dr. Bernard Chen Ph.D. University of Central Arkansas Spring 2010.
Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc. (Hyperlinks are active in View Show mode) Chapter 7 – Registers and Register Transfers Part.
ARITHMETIC MICRO OPERATIONS
1 Outline Bus Transfer Memory Transfer Microoperations.
1 Chapter 7 Henry Hexmoor Registers and RTL. REGISTER TRANSFER AND MICROOPERATIONS Register Transfer Language Register Transfer Bus and Memory Transfers.
CS 151: Digital Design Chapter 4: Arithmetic Functions and Circuits
Register Transfer Languages (RTL)
CSC321 Homework Due Due Tuesday after spring break Turn in –Design information State diagram State table K-map simplifications and expressions for flip-flop.
Chapter 4 Register Transfer and Microoperations Dr. Bernard Chen Ph.D. University of Central Arkansas Spring 2010.
Exam1 Review Dr. Bernard Chen Ph.D. University of Central Arkansas.
REGISTER TRANSFER & MICROOPERATIONS By Sohaib. Digital System Overview  Each module is built from digital components  Registers  Decoders  Arithmetic.
ECEG-3202: Computer Architecture and Organization, Dept of ECE, AAU 1 Register Transfer & Microoperations.
LOGIC CIRCUITLOGIC CIRCUIT. Goal To understand how digital a computer can work, at the lowest level. To understand what is possible and the limitations.
1 Register Transfer and Microoperations Acknowledgment: Most of the slides are adapted from Prof. Hyunsoo Yoon’s slides.
1 REGISTER TRANSFER & MICROOPERATIONS. 2 OUTLINES Register Transfer Language Register Transfer Bus and Memory Transfers Arithmetic Microoperations Logic.
REGISTER TRANSFER AND MICROOPERATIONS
UNIT 2 REGISTER TRANSFER AND MICROOPERATIONS
Chapter 4 Operations on Bits.
REGISTER TRANSFER AND MICROOPERATIONS
Chapter 4 Register Transfer and Microoperations
Chap 7. Register Transfers and Datapaths
Overview Register Transfer Language Register Transfer
Register Transfer and Microoperations
REGISTER TRANSFER LANGUAGE AND DESIGN OF CONTROL UNIT
Computer Organization and Design
به نام یگانه مهندس هستی معماری کامپیوتر مهدی قدیری
REGISTER TRANSFER LANGUAGE
Computer Organization and Design
By: A. H. Abdul Hafez CAO, by Dr. A.H. Abdul Hafez, CE Dept. HKU
13 Digital Logic Circuits.
Overview Part 1 – Design Procedure Part 2 – Combinational Logic
Combinational Circuits
CHAPTER-3 REGISTER TRANSFER LANGUAGE AND MICROOPERATIONS
Instruction execution and ALU
Presentation transcript:

Micro Operation

MICROOPERATIONS Computer system microoperations are of four types: - Register transfer microoperations - Arithmetic microoperations - Logic microoperations - Shift microoperations Arithmetic Microoperations Transfer - move data from one set of registers to another Arithmetic - perform arithmetic on data in registers Logic - manipulate data or use bitwise logical operations Shift - shift data in registers

REGISTER TRANSFER MICROOPERATIONS Bus and Memory Transfers A  B Transfer content of reg. B into reg. A AR  DR(AD)Transfer content of AD portion of reg. DR into reg. AR A  constantTransfer a binary constant into reg. A ABUS  R1, Transfer content of R1 into bus A and, at the same time, R2  ABUS transfer content of bus A into R2 AR Address register DR Data register M[R] Memory word specified by reg. R M Equivalent to M[AR] DR  M Memory read operation: transfers content of memory word specified by AR into DR M  DR Memory write operation: transfers content of DR into memory word specified by AR

ARITHMETIC MICROOPERATIONS The basic arithmetic microoperations are –Addition –Subtraction –Increment –Decrement The additional arithmetic microoperations are –Add with carry –Subtract with borrow –Transfer/Load –etc. … Summary of Typical Arithmetic Micro-Operations Arithmetic Microoperations R3  R1 + R2 Contents of R1 plus R2 transferred to R3 R3  R1 - R2Contents of R1 minus R2 transferred to R3 R2  R2’Complement the contents of R2 R2  R2’+ 12's complement the contents of R2 (negate) R3  R1 + R2’+ 1subtraction R1  R1 + 1Increment R1  R1 - 1Decrement

BINARY ADDER / SUBTRACTOR / INCREMENTER Binary Adder-Subtractor Binary Incrementer Binary Adder Arithmetic Microoperations

ARITHMETIC CIRCUIT S1 S x1 MUX X0 Y0 C0 C1 D0 FA S1 S x1 MUX X1 Y1 C1 C2 D1 FA S1 S x1 MUX X2 Y2 C2 C3 D2 FA S1 S x1 MUX X3 Y3 C3 C4 D3 FA Cout A0 B0 A1 B1 A2 B2 A3 B3 01 S0 S1 Cin S1S0CinYOutputMicrooperation 0 00BD = A + BAdd 0 01BD = A + B + 1Add with carry 0 10B’D = A + B’Subtract with borrow 0 11B’D = A + B’+ 1Subtract 1 000D = ATransfer A 1 010D = A + 1Increment A 1 101D = A - 1Decrement A 1 111D = ATransfer A Arithmetic Microoperations

LOGIC MICROOPERATIONS Specify binary operations on the strings of bits in registers –Logic microoperations are bit-wise operations, i.e., they work on the individual bits of data –useful for bit manipulations on binary data –useful for making logical decisions based on the bit value There are, in principle, 16 different logic functions that can be defined over two binary input variables However, most systems only implement four of these –AND (  ), OR (  ), XOR (  ), Complement/NOT The others can be created from combination of these Logic Microoperations … … … … A B F 0 F 1 F 2 … F 13 F 14 F 15

LIST OF LOGIC MICROOPERATIONS List of Logic Microoperations - 16 different logic operations with 2 binary vars. - n binary vars → functions 2 2 n Truth tables for 16 functions of 2 variables and the corresponding 16 logic micro-operations Boolean Function Micro- Operations Name x y Logic Microoperations 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 F5 = y F  B Transfer B F6 = x  y F  A  B Exclusive-OR F7 = x + y F  A  B OR F8 = (x + y)' F   A  B)’ NOR F9 = (x  y)' F  (A  B)’ Exclusive-NOR F10 = y' F  B’ Complement B F11 = x + y' F  A  B F12 = x' F  A’ Complement A F13 = x' + y F  A’  B F14 = (xy)' F  (A  B)’ NAND F15 = 1 F  all 1's Set to all 1's

HARDWARE IMPLEMENTATION OF LOGIC MICROOPERATIONS 0 0 F = A  B AND 0 1 F = A  B OR 1 0 F = A  B XOR 1 1 F = A’ Complement S 1 S 0 Output  -operation Function table Logic Microoperations B A S S F 1 0 i i i X 1 MUX Select

APPLICATIONS OF LOGIC MICROOPERATIONS Logic microoperations can be used to manipulate individual bits or a portions of a word in a register They can be used to change bit values, delete a group of bits or insert new bit value in the register Consider the data in a register A. In another register, B, is bit data that will be used to modify the contents of A –Selective-set A  A + B –Selective-complement A  A  B –Selective-clear A  A B’ –Mask (Delete) A  A B –Clear A  A  B –Insert A  (A B) + C –Compare A  A  B –... Logic Microoperations

SELECTIVE SET In a selective set operation, the bit pattern in B is used to set certain bits in A i.e. set to 1,the bits in register A where there are corresponding 1’s in the register B. It does not affect bit position that have 0’s in register B A t B A t+1 (A  A + B) If a bit in B is set to 1, that same position in A gets set to 1, otherwise that bit in A keeps its previous value Logic Microoperations

SELECTIVE COMPLEMENT In a selective complement operation, the bit pattern in B is used to complement certain bits in A A t B A t+1 (A  A  B) If a bit in B is set to 1, that same position in A gets complemented from its original value, otherwise it is unchanged Logic Microoperations

SELECTIVE CLEAR In a selective clear operation, the bit pattern in B is used to clear certain bits in A A t B A t+1 (A  A  B’) If a bit in B is set to 1, that same position in A gets set to 0, otherwise it is unchanged i.e. this operation clears to 0 the bits in A only where there are corresponding 1’s in B. Logic Microoperations

MASK OPERATION In a mask operation, the bit pattern in B is used to clear certain bits in A It is similar to selective clear operation except that the bits of A are cleared only where there are corresponding 0’s in B A t B A t+1 (A  A  B) If a bit in B is set to 0, that same position in A gets set to 0, otherwise it is unchanged Logic Microoperations

CLEAR OPERATION In a clear operation, if the bits in the same position in A and B are the same, they are cleared in A, otherwise they are set in A Compare the word in A & B register and produces all 0’s result if two number are equal A t B A t+1 (A  A  B) Logic Microoperations

INSERT OPERATION An insert operation is used to introduce a specific bit pattern into A register, leaving the other bit positions unchanged This is done as –A mask operation to clear the desired bit positions, followed by –An OR operation to introduce the new bits into the desired positions –Example »Suppose you wanted to introduce 1010 into the low order four bits of A: A (Original) A (Desired) » A (Original) Mask A (Intermediate) Added bits A (Desired) Logic Microoperations

Micro-Operation Types Shift Operations –Logical Shift shl A shr A –Arithmetic Shift ashl A ashr A –Circular Shift cil A cir A

LOGICAL SHIFT In a logical shift the serial input to the shift is a 0. A right logical shift operation: A left logical shift operation: In a Register Transfer Language, the following notation is used –shl for a logical shift left –shrfor a logical shift right –Examples: »R2  shr R2 »R3  shl R3 Shift Microoperations

CIRCULAR SHIFT In a circular shift the serial input is the bit that is shifted out of the other end of the register. A right circular shift operation: A left circular shift operation: In a RTL, the following notation is used –cil for a circular shift left –cirfor a circular shift right –Examples: »R2  cir R2 »R3  cil R3 Shift Microoperations

Logical versus Arithmetic Shift A logical shift fills the newly created bit position with zero: An arithmetic shift fills the newly created bit position with a copy of the number’s sign bit:

ARITHMETIC SHIFT An left arithmetic shift operation must be checked for the overflow Shift Microoperations 0 V Before the shift, if the leftmost two bits differ, the shift will result in an overflow In a RTL, the following notation is used –ashl for an arithmetic shift left –ashrfor an arithmetic shift right –Examples: »R2  ashr R2 »R3  ashl R3 sign bit

HARDWARE IMPLEMENTATION OF SHIFT MICROOPERATIONS Shift Microoperations S 0 1 H0 MUX S 0 1 H1 MUX S 0 1 H2 MUX S 0 1 H3 MUX Select 0 for shift right (down) 1 for shift left (up) Serial input (I R ) A0 A1 A2 A3 Serial input (I L )

ARITHMETIC LOGIC SHIFT UNIT S3 S2 S1 S0CinOperation Function F = A Transfer A F = A + 1 Increment A F = A + B Addition F = A + B + 1 Add with carry F = A + B’ Subtract with borrow F = A + B’+ 1 Subtraction F = A - 1 Decrement A F = A TransferA XF = A  B AND XF = A  B OR XF = A  B XOR XF = A’ Complement A 1 0 X XXF = shr A Shift right A into F 1 1 X XXF = shl A Shift left A into F Shift Microoperations Arithmetic Circuit Logic Circuit C C 4 x 1 MUX Select F S3 S2 S1 S0 B A i A D A E shr shl i+1 i i i i-1 i i