Chapter 7 - Part 2 1 CPEN 315 - Digital System Design Chapter 7 – Registers and Register Transfers Part 2 – Counters, Register Cells, Buses, & Serial Operations.

Slides:



Advertisements
Similar presentations
CPEN Digital System Design
Advertisements

KU College of Engineering Elec 204: Digital Systems Design
Lecture 23: Registers and Counters (2)
Overview Part 2 – Combinational Logic Functions and functional blocks
Registers and Counters
Registers and Counters
Charles Kime & Thomas Kaminski © 2004 Pearson Education, Inc. Terms of Use (Hyperlinks are active in View Show mode) Terms of Use Chapter 7 – Registers.
CPEN Digital System Design Chapter 5 Sequential Circuits Storage Elements and Sequential Circuit Analysis C. Gerousis © Logic and Computer Design.
Chapter 7. Register Transfer and Computer Operations
11/16/2004EE 42 fall 2004 lecture 331 Lecture #33: Some example circuits Last lecture: –Edge triggers –Registers This lecture: –Example circuits –shift.
Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc. (Hyperlinks are active in View Show mode) Chapter 3 – Combinational Logic Design Part 2 –
Logic and Computer Design Fundamentals Registers and Counters
CPEN Digital System Design Chapter 9 – Computer Design
ENGIN112 L26: Shift Registers November 3, 2003 ENGIN 112 Intro to Electrical and Computer Engineering Lecture 26 Shift Registers.
Overview Part 1 - Storage Elements and Sequential Circuit Analysis
KU College of Engineering Elec 204: Digital Systems Design
A.Abhari CPS2131 Registers A register is a group of n flip-flops each of them capable of storing one bit of information There are two types of registers:
Registers and Counters
Unit 12 Registers and Counters Ku-Yaw Chang Assistant Professor, Department of Computer Science and Information Engineering Da-Yeh.
Registers and Counters
Chapter 1_4 Part II Counters
1 Sequential Circuits Registers and Counters. 2 Master Slave Flip Flops.
Registers & Register Transfers Digital Logic Design Instructor: Kasım Sinan YILDIRIM.
EE345: Introduction to Microcontrollers Register and Counters Prof. Ahmad Abu-El-Haija.
Sequential Circuits Chapter 4 S. Dandamudi To be used with S. Dandamudi, “Fundamentals of Computer Organization and Design,” Springer,  S.
Registers and Counters
ReVieW Combinational & Sequential Logic Circuit EKT 221 / 4 DIGITAL ELECTRONICS II.
1 Registers and Counters A register consists of a group of flip-flops and gates that affect their transition. An n-bit register consists of n-bit flip-flops.
Rabie A. Ramadan Lecture 3
P. 4.1 Digital Technology and Computer Fundamentals Chapter 4 Digital Components.
EKT 221/4 DIGITAL ELECTRONICS II  Registers, Micro-operations and Implementations - Part3.
SEQUENTIAL CIRCUITS Component Design and Use. Register with Parallel Load  Register: Group of Flip-Flops  Ex: D Flip-Flops  Holds a Word of Data 
Charles Kime & Thomas Kaminski © 2004 Pearson Education, Inc. Terms of Use (Hyperlinks are active in View Show mode) Terms of Use ECE/CS 352: Digital Systems.
Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc. (Hyperlinks are active in View Show mode) Chapter 7 – Registers and Register Transfers Part.
Charles Kime & Thomas Kaminski © 2004 Pearson Education, Inc. Terms of Use (Hyperlinks are active in View Show mode) Terms of Use Chapter 7 – Registers.
Chap 7. Register Transfers and Datapaths. 7.1 Datapaths and Operations Two types of modules of digital systems –Datapath perform data-processing operations.
7-6 단일 레지스터에서 Microoperation Multiplexer-Based Transfer  Register 가 서로 다른 시간에 둘 이상의 source 에서 data 를 받을 경우 If (K1=1) then (R0 ←R1) else if (K2=1) then.
 Counters are sequential circuits which "count" through a specific state sequence. They can count up, count down, or count through other fixed sequences.
1 Registers & Counters Logic and Digital System Design - CS 303 Erkay Savaş Sabancı University.
ENG241 Digital Design Week #8 Registers and Counters.
Chap 5. Registers and Counters. Chap Definition of Register and Counter l a clocked sequential circuit o consist of a group of flip-flops & combinational.
Register and Register Transfers
Chapter 1_4 Part III more on … Counters Chapter 1_4 Part III more on … Counters.
Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc. (Hyperlinks are active in View Show mode) Chapter 7 – Registers and Register Transfers Part.
Abdullah Said Alkalbani University of Buraimi
Charles Kime & Thomas Kaminski © 2004 Pearson Education, Inc. Terms of Use (Hyperlinks are active in View Show mode) Terms of Use ECE/CS 352: Digital Systems.
EKT 221 : Digital 2 Serial Transfers & Microoperations Date : Lecture : 2 hr.
Counters.
Digital System Design using VHDL
Chap 5. Registers and Counters
Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc. (Hyperlinks are active in View Show mode) Chapter 7 – Registers and Register Transfers Part.
ECEN 248: INTRODUCTION TO DIGITAL SYSTEMS DESIGN Dr. Shi Dept. of Electrical and Computer Engineering.
1 Registers A register is a group of n flip-flops each of them capable of storing one bit of information There are two types of registers: parallel and.
EKT 221 : Digital 2 Serial Transfers & Microoperations
6.
Chap 7. Register Transfers and Datapaths
EKT 221 : Digital 2 Serial Transfers & Microoperations
EKT 221 – Counters.
EKT 221 : Digital 2 COUNTERS.
SLIDES FOR CHAPTER 12 REGISTERS AND COUNTERS
KU College of Engineering Elec 204: Digital Systems Design
Chapter 7 – Registers and Register Transfers
DIGITAL 2 : EKT 221 RTL : Microoperations on a Single Register
Register Transfer and Microoperations
Registers and Counters
Registers and Counters Register : A Group of Flip-Flops. N-Bit Register has N flip-flops. Each flip-flop stores 1-Bit Information. So N-Bit Register Stores.
Computer Architecture and Organization: L02: Logic design Review
Chapter 1_5 register Cell Design
Overview Part 1 - Registers, Microoperations and Implementations
Computer Architecture
Presentation transcript:

Chapter 7 - Part 2 1 CPEN Digital System Design Chapter 7 – Registers and Register Transfers Part 2 – Counters, Register Cells, Buses, & Serial Operations C. Gerousis © Logic and Computer Design Fundamentals, 4 rd Ed., Mano Prentice Hall Charles Kime & Thomas Kaminski © 2008 Pearson Education, Inc.

Chapter 7 - Part 2 2 Overview  Part 1 - Registers, Microoperations and Implementations Registers and load enable Register transfer operations Microoperations - arithmetic, logic, and shift Microoperations on a single register  Multiplexer-based transfers  Shift registers  Part 2 - Counters, register cells, buses, & serial operations Counters Register cell design Multiplexer and bus-based transfers for multiple registers Serial transfers and microoperations

Chapter 7 - Part 2 3  Counters are sequential circuits which "count" through a specific state sequence. They can count up, count down, or count through other fixed sequences. Two distinct types are in common usage:  Ripple Counters Clock is connected to the flip-flop clock input on the LSB bit flip-flop For all other bits, a flip-flop output is connected to the clock input, thus circuit is not truly synchronous Output change is delayed more for each bit toward the MSB.  Synchronous Counters Clock is directly connected to the flip-flop clock inputs Logic is used to implement the desired state sequencing Counters

Chapter 7 - Part 2 4  How does it work? When there is a positive edge on the clock input of A, A complements The clock input for flip- flop B is the complemented output of flip-flop A When FF A changes from 1 to 0, there is a positive edge on the clock input of B causing B to complement Reset Clock D D CRCR CRCR B A Ripple Counter CP B A

Chapter 7 - Part 2 5 Synchronous Counters  To eliminate the "ripple" effects, use a common clock for each flip-flop and a combinational circuit to generate the next state.  For an up-counter, use an incrementer  D3Q3 D2 Q2 D1 Q1 D0Q0 Clock Incrementer A3 A2 A1 A0 S3 S2 S1 S0

Chapter 7 - Part 2 6  Add path for input data enabled for Load = 1  Add logic to: disable count logic for Load = 1 disable feedback from outputs for Load = 1 enable count logic for Load = 0 and Count = 1  The resulting function table: Counter with Parallel Load LoadCountAction 00Hold Stored Value 01Count Up Stored Value 1XLoad D

Chapter 7 - Part 2 7  The following techniques use an n-bit binary counter with asynchronous or synchronous clear and/or parallel load: Detect a terminal count of N in a Modulo-N count sequence to asynchronously Clear the count to 0 or asynchronously Load in value 0 (These lead to counts which are present for only a very short time and can fail to work for some timing conditions!) Detect a terminal count of N - 1 in a Modulo-N count sequence to Clear the count synchronously to 0 Detect a terminal count of N - 1 in a Modulo-N count sequence to synchronously Load in value 0 Detect a terminal count and use Load to preset a count of the terminal count value minus (N - 1)  Alternatively, custom design a modulo N counter as done for BCD Counting Modulo N

Chapter 7 - Part 2 8  A synchronous 4-bit binary counter with an asynchronous Clear is used to make a Modulo 7 counter.  Use the Clear feature to detect the count 7 and clear the count to 0. This gives a count of 0, 1, 2, 3, 4, 5, 6, 7(short)0, 1, 2, 3, 4, 5, 6, 7(short)0, etc. Counting Modulo 7: Detect 7 and Asynchronously Clear Clock 0 D3 Q3 D2 Q2 D1 Q1 D0 Q0 CLEAR CP LOAD

Chapter 7 - Part 2 9  A synchronous 4-bit binary counter with a synchronous load and an asynchronous clear is used to make a Modulo 7 counter  Use the Load feature to detect the count "6" and load in "zero". This gives a count of 0, 1, 2, 3, 4, 5, 6, 0, 1, 2, 3, 4, 5, 6, 0,... Counting Modulo 7: Synchronously Load on Terminal Count of 6 D3 Q3 D2 Q2 D1 Q1 D0 Q0 CLEAR CP LOAD Clock Reset

Chapter 7 - Part 2 10  A synchronous, 4-bit binary counter with a synchronous Load is to be used to make a Modulo 6 counter.  Use the Load feature to preset the count to 9 on Reset or detection of count 14.  This gives a count of 9, 10, 11, 12, 13, 14, 9, 10, 11, 12, 13, 14, 9, …  If the terminal count is 15 detection is usually built in as Carry Out (CO) Counting Modulo 6: Synchronously Preset 9 on Reset and Load 9 on Terminal Count 14 Clock D3 Q3 D2 Q2 D1 Q1 D0 Q0 CLEAR CP LOAD Reset 1

Chapter 7 - Part 2 11 Register Cell Design  Assume that a register consists of identical cells  Then register design can be approached as follows: Design representative cell for the register Connect copies of the cell together to form the register Applying appropriate “boundary conditions” to cells that need to be different and contract if appropriate  Register cell design is the first step of the above process

Chapter 7 - Part 2 12  A register  Data inputs to the register  Control input combinations to the register Example 1: Not encoded  Control inputs: Load, Shift, Add,...  At most, one of Load, Shift, Add is 1 for any clock cycle (0,0,0), (1,0,0), (0,1,0), (0,0,1) Example 2: Encoded  Control inputs: S1, S0  All possible binary combinations on S1, S0 (0,0), (0,1), (1,0), (1,1) Register Cell Specifications

Chapter 7 - Part 2 13  A set of register functions (typically specified as register transfers) Example: Load: A ← B Shift: A ← sr B Add: A ← A + B  A hold state specification Example:  Control inputs: Load, Shift, Add  If all control inputs are 0, hold the current register state Register Cell Specifications

Chapter 7 - Part 2 14 Register Cell Exmaple

Chapter 7 - Part 2 15  Register A (m-bits) Specification: Data input: B Control inputs (CX, CY) Control input combinations (0,0), (0,1) (1,0) Register transfers: CX: A ← B v A CY :A ← B + A Hold state: (0,0) Example 1: Register Cell Design

Chapter 7 - Part 2 16  Load Control Load = CX + CY  Since all control combinations appear as if encoded (0,0), (0,1), (1,0) can use multiplexer without encoder: S1 = CX S0 = CY D0 = A i Hold A D1 = A i ← B i + A i CY = 1 D2 = A i ← B i v A i CX = 1  Note that the decoder part of the 3-input multiplexer can be shared between bits if desired Example 1: Register Cell Design (continued)

Chapter 7 - Part 2 17 Sequential Circuit Design Approach  Find a state diagram or state table Note that there are only two states with the state assignment equal to the register cell output value  Use the design procedure in Chapter 5 to complete the cell design  For optimization: Use K-maps for up to 4 to 6 variables Otherwise, use computer-aided or manual optimization

Chapter 7 - Part 2 18  State Table: Four variables give a total of 16 state table entries By using:  Combinations of variable names and values  Don’t care conditions (for CX = CY = 1) only 8 entries are required to represent the 16 entries Example 1 Again Hold Ai v Bi Ai + Bi AiAi CX = 0 CY = 0 CX = 1 B i = 0 CX = 1 B i = 1 CY = 1 B i = 0 CY = 1 B i =

Chapter 7 - Part 2 19  K-map - Use variable ordering CX, CY, A i B i and assume a D flip-flop Example 1 Again (continued) 1 CY CX AiAi X BiBi X X X DiDi

Chapter 7 - Part 2 20  The resulting SOP equation: D i = CX B i + CY A i B i + A i B i + CY A i  Using factoring and DeMorgan’s law: D i = CX B i + A i (CY B i ) + A i (CY B i ) D i = CX B i + A i + (CY B i ) The gate input cost per cell = = 14  The gate input cost per cell for the previous version is: Per cell: 19 Shared decoder logic: 8  Cost gain by sequential design > 5 per cell  Also, no Enable on the flip-flop makes it cost less Example 1 Again (continued)

Chapter 7 - Part 2 21 Multiplexer and Bus-Based Transfers for Multiple Registers  Multiplexer dedicated to each register  Shared transfer paths for registers A shared transfer object is a called a bus  Bus implementation using: multiplexers three-state nodes and drivers  In most cases, the number of bits is the length of the receiving register

Chapter 7 - Part 2 22 Dedicated MUX-Based Transfers  Multiplexer connected to each register input produces a very flexible transfer structure.  Characterize the simultaneous transfers possible with this structure. Try: S0=1, S1=1, L0=L1=1 R0  R2, R1  R2

Chapter 7 - Part 2 23 Multiplexer Bus  A single bus driven by a multiplexer lowers cost, but limits the available transfers  Characterize the simultaneous transfers possible with this structure.  Characterize the cost savings compared to dedicated multiplexers L0 n n MUX S1 S0 0 1 n 2 S0S1 L1 L2 n R0 Load n R1 Load n R2 Load n

Chapter 7 - Part 2 24 Single Bus-Based Transfers - Example S1 = 1, S0 = 0, L0 = 1, L1=L2=0 R0  R2 S1 = 0, S0 = 1, L0 = 1, L1=0, L2=1 R0  R1, R2  R1

Chapter 7 - Part 2 25 Three-State Bus  The 3-input MUX can be replaced by a 3-state node (bus) and 3-state buffers.  Cost is further reduced, but transfers are limited  Characterize the simultaneous transfers possible with this structure.  Characterize the cost savings and compare  Compare tri-state and MUX-based bus transfer. n L0 L1 L2 n R0 Load n R1 Load n R2 Load n n E2 E1 E0

Chapter 7 - Part 2 26 Serial Transfers and Microoperations  Serial Transfers Used for “narrow” transfer paths Example 1: Telephone or cable line  Parallel-to-Serial conversion at source  Serial-to-Parallel conversion at destination Example 2: Initialization and Capture of the contents of many flip-flops for test purposes  Add shift function to all flip-flops and form large shift register  Use shifting for simultaneous Initialization and Capture operations  Serial microoperations Example 1: Addition Example 2: Error-Correction for CDs

Chapter 7 - Part 2 27 Serial Transfer Example

Chapter 7 - Part 2 28  By using two shift registers for operands, a full adder, and a flip flop (for the carry), we can add two numbers serially, starting at the least significant bit.  Serial addition is a low cost way to add large numbers of operands, since a “tree” of full adder cells can be made to any depth, and each new level doubles the number of operands.  Other operations can be performed serially as well, such as parity generation/checking or more complex error-check codes.  Shifting a binary number left is equivalent to multiplying by 2. Give an example.  Shifting a binary number right is equivalent to dividing by 2. Serial Microoperations

Chapter 7 - Part 2 29  The circuit shown uses two shift registers for operands A(3:0) and B(3:0).  A full adder, and one more flip flop (for the carry) is used to compute the sum.  The result is stored in the A register and the final carry in the flip-flop  With the operands and the result in shift registers, a tree of full adders can be used to add a large number of operands. Used as a common digital signal processing technique. A3 A2 A1 A0 B3 B2 B1 B0 A B Cin Sum Cout DQ CP FA Load/Right Shift Registers Serial In Serial In Parallel Load (Clock and Load/Shift Control not shown) Serial Adder

Chapter 7 - Part 2 30 Serial Adder