2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved.
This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4.
CONTENTS
PREFACE 1
xv 1
INTRODUCTION
1.1 About Digital Design 1 1.2 Analog versus Digital 3 1.3 Digital Devices 6 1.4 Electronic Aspects of Digital Design 1.5 Software Aspects of Digital Design 1.6 Integrated Circuits 11 1.7 Programmable Logic Devices 14 1.8 Application-Specific ICs 16 1.9 Printed-Circuit Boards 17 1.10 Digital-Design Levels 18 1.11 The Name of the Game 22 1.12 Going Forward 23 Drill Problems 23
7 8
NUMBER SYSTEMS AND CODES
2.1 2.2 2.3 2.4 2.5
25
Positional Number Systems 26 Octal and Hexadecimal Numbers 27 General Positional-Number-System Conversions Addition and Subtraction of Nondecimal Numbers Representation of Negative Numbers 34
29 32
2.5.1 2.5.3 2.5.4 2.5.5 2.5.6
2.6
Signed-Magnitude Representation 2.5.2 Complement Number Systems Radix-Complement Representation Twos-Complement Representation Diminished Radix-Complement Representation Ones-Complement Representation 2.5.7 Excess Representations
39
Twos-Complement Addition and Subtraction
2.6.1 Addition Rules 2.6.2 A Graphical View 2.6.3 Overflow 2.6.4 Subtraction Rules 2.6.5 Twos-Complement and Unsigned Binary Numbers
2.7 2.8 Ones-Complement Addition and Subtraction Binary Multiplication 45 44
vii
viii
Contents
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4. 2.9 Binary Division 47 2.10 Binary Codes for Decimal Numbers 48 2.11 Gray Code 51 2.12 Character Codes 53 2.13 Codes for Actions, Conditions, and States 53 2.14 n-Cubes and Distance 57 2.15 Codes for Detecting and Correcting Errors 58
2.15.1 2.15.2 2.15.3 2.15.5 2.15.7
Error-Detecting Codes Error-Correcting and Multiple-Error-Detecting Codes Hamming Codes 2.15.4 CRC Codes Two-Dimensional Codes 2.15.6 Checksum Codes m-out-of-n Codes
69
2.16 Codes for Serial Data Transmission and Storage
2.16.1 Parallel and Serial Data
References 73 Drill Problems 74 Exercises 76
2.16.2 Serial Line Codes
DIGITAL CIRCUITS
3.1 3.2 3.3
79
80
Logic Signals and Gates Logic Families 84 CMOS Logic 86
3.3.1 3.3.3 3.3.4 3.3.6 3.3.7
3.4 3.5
CMOS Logic Levels 3.3.2 MOS Transistors Basic CMOS Inverter Circuit CMOS NAND and NOR Gates 3.3.5 Fan-In Noninverting Gates CMOS AND-OR-INVERT and OR-AND-INVERT Gates
96
Electrical Behavior of CMOS Circuits
3.4.1 Overview 3.5.1 3.5.2 3.5.3 3.5.5 3.5.7
3.6
3.4.2 Data Sheets and Specifications
101
CMOS Static Electrical Behavior
Logic Levels and Noise Margins Circuit Behavior with Resistive Loads Circuit Behavior with Nonideal Inputs 3.5.4 Fanout Effects of Loading 3.5.6 Unused Inputs How to Destroy a CMOS Device
114
CMOS Dynamic Electrical Behavior
3.6.1 3.6.3 3.6.4 3.6.5 3.6.6
3.7
Transition Time 3.6.2 Propagation Delay Power Consumption Current Spikes and Decoupling Capacitors Inductive Effects Simultaneous Switching and Ground Bounce
129
Other CMOS Input and Output Structures
3.7.1 3.7.3 3.7.5 3.7.8
Transmission Gates 3.7.2 Schmitt-Trigger Inputs Three-State Outputs 3.7.4 Open-Drain Outputs Driving LEDs 3.7.6 Multisource Buses 3.7.7 Wired Logic Pull-Up Resistors
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4. 3.8 CMOS Logic Families 141
Contents
ix
3.8.1 3.8.3 3.8.4 3.8.6
3.9
HC and HCT 3.8.2 AHC and AHCT HC, HCT, AHC, and AHCT Electrical Characteristics AC and ACT 3.8.5 FCT and FCT-T FCT-T Electrical Characteristics
151
Low-Voltage CMOS Logic and Interfacing
3.9.1 3.3-V LVTTL and LVCMOS Logic 3.9.2 5-V Tolerant Inputs 3.9.3 5-V Tolerant Outputs 3.9.4 TTL/LVTTL Interfacing Summary 3.9.5 Logic Levels Less Than 3.3 V
3.10 Bipolar Logic 155
3.10.1 3.10.3 3.10.4 3.10.6 3.10.8
Diode Logic 3.10.2 Bipolar Junction Transistors Transistor-Transistor Logic TTL Logic Levels and Noise Margins 3.10.5 TTL Fanout TTL Families 3.10.7 A TTL Data Sheet CMOS/TTL Interfacing 3.10.9 Emitter-Coupled Logic
References 174 Drill Problems 175 Exercises 179
COMBINATIONAL LOGIC DESIGN PRINCIPLES
4.1 Switching Algebra 184
183
4.1.1 4.1.3 4.1.4 4.1.6
4.2 4.3
Axioms 4.1.2 Single-Variable Theorems Two- and Three-Variable Theorems n-Variable Theorems 4.1.5 Duality Standard Representations of Logic Functions
Combinational-Circuit Analysis 199 Combinational-Circuit Synthesis 205
4.3.1 4.3.3 4.3.5 4.3.7
4.4
Circuit Descriptions and Designs 4.3.2 Circuit Manipulations Combinational-Circuit Minimization 4.3.4 Karnaugh Maps Minimizing Sums of Products 4.3.6 Other Minimization Topics Programmed Minimization Methods
224
Timing Hazards
4.4.1 Static Hazards 4.4.2 Finding Static Hazards Using Maps 4.4.3 Dynamic Hazards 4.4.4 Designing Hazard-Free Circuits
References 229 Drill Problems 230 Exercises 232
HARDWARE DESCRIPTION LANGUAGES
5.1 HDL-Based Digital Design 238
237
5.1.1 Why HDLs? 5.1.2 HDL Tool Suites 5.1.3 HDL-Based Design Flow
5.2 The ABEL Hardware Description Language 243
5.2.1 5.2.3 5.2.5 5.2.7
ABEL Program Structure 5.2.2 ABEL Compiler Operation WHEN Statements and Equation Blocks 5.2.4 Truth Tables Ranges, Sets, and Relations 5.2.6 Test Vectors Additional ABEL Features
Contents
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4. 5.3 The VHDL Hardware Description Language 256
5.3.1 Program Structure 5.3.2 Types, Constants, and Arrays 5.3.3 Functions and Procedures 5.3.4 Libraries and Packages 5.3.5 Structural Design Elements 5.3.6 Dataflow Design Elements 5.3.7 Behavioral Design Elements 5.3.8 The Time Dimension 5.3.9 Simulation 5.3.10 Test Benches 5.3.11 VHDL Features for Sequential Logic Design 5.3.12 Synthesis
5.4 The Verilog Hardware Description Language 290
5.4.1 Program Structure 5.4.2 Logic System, Nets, Variables, and Constants 5.4.3 Vectors and Operators 5.4.4 Arrays 5.4.5 Logical Operators and Expressions 5.4.6 Compiler Directives 5.4.7 Structural Design Elements 5.4.8 Dataflow Design Elements 5.4.9 Behavioral Design Elements (Procedural Code) 5.4.10 Functions and Tasks 5.4.11 The Time Dimension 5.4.12 Simulation 5.4.13 Test Benches 5.4.14 Verilog Features for Sequential Logic Design 5.4.15 Synthesis
References 335 Drill Problems 337 Exercises 338
COMBINATIONAL LOGIC DESIGN PRACTICES
6.1 Documentation Standards 342
341
6.1.1 6.1.3 6.1.5 6.1.6 6.1.8
6.2
Block Diagrams 6.1.2 Gate Symbols Signal Names and Active Levels 6.1.4 Active Levels for Pins Bubble-to-Bubble Logic Design Signal Naming in HDL Programs 6.1.7 Drawing Layout Buses 6.1.9 Additional Schematic Information
362
Circuit Timing
6.2.1 Timing Diagrams 6.2.2 Propagation Delay 6.2.3 Timing Specifications 6.2.4 Timing Analysis 6.2.5 Timing Analysis Tools
6.3 Combinational PLDs 370
6.3.1 6.3.2 6.3.3 6.3.4 6.3.5
6.4
Programmable Logic Arrays Programmable Array Logic Devices Generic Array Logic Devices Complex Programmable Logic Devices (CPLDs) CMOS PLD Circuits 6.3.6 Device Programming and Testing
384
Decoders
6.4.1 6.4.2 6.4.3 6.4.5 6.4.7
6.5
Binary Decoders Logic Symbols for Larger-Scale Elements The 74x138 3-to-8 Decoder 6.4.4 Cascading Binary Decoders Decoders in ABEL and PLDs 6.4.6 Decoders in VHDL Decoders in Verilog 6.4.8 Seven-Segment Decoders
408
Encoders
6.5.1 Priority Encoders 6.5.2 The 74x148 Priority Encoder 6.5.3 Encoders in ABEL and PLDs 6.5.4 Encoders in VHDL 6.5.5 Encoders in Verilog
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4. 6.6 Three-State Devices 418
Contents
xi
6.6.1 6.6.3 6.6.4 6.6.5
6.7
Three-State Buffers 6.6.2 Standard MSI Three-State Buffers Three-State Outputs in ABEL and PLDs Three-State Outputs in VHDL Three-State Outputs in Verilog
432
Multiplexers
6.7.1 6.7.3 6.7.4 6.7.6
6.8
Standard MSI Multiplexers 6.7.2 Expanding Multiplexers Multiplexers, Demultiplexers, and Buses Multiplexers in ABEL and PLDs 6.7.5 Multiplexers in VHDL Multiplexers in Verilog
447
Exclusive-OR and Exclusive-NOR Gates
Exclusive-OR Gates and Parity Circuits
6.8.1 6.8.3 6.8.4 6.8.5 6.8.6 6.8.7
6.9
6.8.2 Parity Circuits The 74x280 9-Bit Parity Generator Parity-Checking Applications Exclusive-OR Gates and Parity Circuits in ABEL and PLDs Exclusive-OR Gates and Parity Circuits in VHDL Exclusive-OR Gates and Parity Circuits in Verilog
458
Comparators
6.9.1 6.9.3 6.9.4 6.9.5 6.9.7 6.10.1 6.10.3 6.10.5 6.10.7 6.10.9
Comparator Structure 6.9.2 Iterative Circuits An Iterative Comparator Circuit Standard MSI Magnitude Comparators Comparators in HDLs 6.9.6 Comparators in ABEL and PLDs Comparators in VHDL 6.9.8 Comparators in Verilog
474
6.10 Adders, Subtractors, and ALUs
Half Adders and Full Adders 6.10.2 Ripple Adders Subtractors 6.10.4 Carry-Lookahead Adders MSI Adders 6.10.6 MSI Arithmetic and Logic Units Group-Carry Lookahead 6.10.8 Adders in ABEL and PLDs Adders in VHDL 6.10.10 Adders in Verilog
494
6.11 Combinational Multipliers
6.11.1 Combinational Multiplier Structures 6.11.2 Multiplication in ABEL and PLDs 6.11.4 Multiplication in Verilog
References 508 Drill Problems 509 Exercises 511
6.11.3 Multiplication in VHDL
SEQUENTIAL LOGIC DESIGN PRINCIPLES
7.1 Bistable Elements 523
521
7.1.1 Digital Analysis 7.1.2 Analog Analysis 7.1.3 Metastable Behavior
7.2 Latches and Flip-Flops 526
7.2.1 S-R Latch 7.2.2 S-R Latch 7.2.3 S-R Latch with Enable 7.2.5 Edge-Triggered D Flip-Flop 7.2.4 D Latch 7.2.6 Edge-Triggered D Flip-Flop with Enable 7.2.7 Scan Flip-Flop 7.2.8 Master/Slave S-R Flip-Flop 7.2.9 Master/Slave J-K Flip-Flop 7.2.11 T Flip-Flop 7.2.10 Edge-Triggered J-K Flip-Flop
xii
Contents
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4. 7.3 Clocked Synchronous State-Machine Analysis 542
7.3.1 State-Machine Structure 7.3.2 Output Logic 7.3.3 Characteristic Equations 7.3.4 Analysis of State Machines with D Flip-Flops
7.4 Clocked Synchronous State-Machine Design 553
7.4.1 7.4.3 7.4.5 7.4.6
7.5 7.6
State-Table Design Example 7.4.2 State Minimization State Assignment 7.4.4 Synthesis Using D Flip-Flops Synthesis Using J-K Flip-Flops More Design Examples Using D Flip-Flops
Designing State Machines Using State Diagrams 570 State-Machine Synthesis Using Transition Lists 577
7.6.1 Transition Equations 7.6.2 Excitation Equations 7.6.3 Variations on the Scheme 7.6.4 Realizing the State Machine
7.7 Another State-Machine Design Example 580
7.7.1 The Guessing Game 7.7.2 Unused States 7.7.3 Output-Coded State Assignment 7.7.4 Dont-Care State Codings
7.8 7.9 Decomposing State Machines 587 Feedback Sequential-Circuit Analysis 590
7.9.1 7.9.2 7.9.3 7.9.5 7.10.1 7.10.3 7.10.5 7.10.7 7.11.1 7.11.3 7.11.5 7.11.6
Basic Analysis Analyzing Circuits with Multiple Feedback Loops Races 7.9.4 State Tables and Flow Tables CMOS D Flip-Flop Analysis
601
7.10 Feedback Sequential-Circuit Design
Latches 7.10.2 Designing Fundamental-Mode Flow Table Flow-Table Minimization 7.10.4 Race-Free State Assignment Excitation Equations 7.10.6 Essential Hazards Summary
612
7.11 ABEL Sequential-Circuit Design Features
Registered Outputs 7.11.2 State Diagrams External State Memory 7.11.4 Specifying Moore Outputs Specifying Mealy and Pipelined Outputs with WITH Test Vectors
625
7.12 Sequential-Circuit Design with VHDL
7.12.1 Clocked Circuits 7.12.2 State-Machine Design with VHDL 7.12.3 A VHDL State-Machine Example 7.12.4 State Assignment in VHDL 7.12.5 Pipelined Outputs in VHDL 7.12.6 Direct VHDL Coding Without a State Table 7.12.7 More VHDL State-Machine Examples 7.12.8 Specifying Flip-Flops in VHDL 7.12.9 VHDL State-Machine Test Benches 7.12.10 Feedback Sequential Circuits
7.13 Sequential-Circuit Design with Verilog 646
7.13.1 7.13.3 7.13.4 7.13.5 7.13.6
Clocked Circuits 7.13.2 State-Machine Design with Verilog A Verilog State-Machine Example Pipelined Outputs in Verilog Direct Verilog Coding Without a State Table More Verilog State-Machine Examples
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4.
Contents
xiii
7.13.7 Specifying Flip-Flops in Verilog 7.13.8 Verilog State-Machine Test Benches 7.13.9 Feedback Sequential Circuits
References 663 Drill Problems 664 Exercises 669
SEQUENTIAL LOGIC DESIGN PRACTICES
8.1 Sequential-Circuit Documentation Standards
679
680
8.1.1 General Requirements 8.1.2 Logic Symbols 8.1.3 State-Machine Descriptions 8.1.4 Timing Diagrams and Specifications
8.2 Latches and Flip-Flops 686
8.2.1 8.2.3 8.2.5 8.2.6 8.2.7 8.2.8
8.3 8.4
SSI Latches and Flip-Flops 8.2.2 Switch Debouncing The Simplest Switch Debouncer 8.2.4 Bus Holder Circuit Multibit Registers and Latches Registers and Latches in ABEL and PLDs Registers and Latches in VHDL Registers and Latches in Verilog
703
Sequential PLDs Counters 710
8.3.1 Sequential GAL Devices 8.4.1 8.4.3 8.4.4 8.4.5 8.4.7
8.5
8.3.2 PLD Timing Specifications
Ripple Counters 8.4.2 Synchronous Counters MSI Counters and Applications Decoding Binary-Counter States Counters in ABEL and PLDs 8.4.6 Counters in VHDL Counters in Verilog
727
Shift Registers
8.5.1 8.5.3 8.5.5 8.5.7 8.5.9
8.6 8.7 8.8
Shift-Register Structure 8.5.2 MSI Shift Registers Shift-Register Counters 8.5.4 Ring Counters Johnson Counters 8.5.6 Linear Feedback Shift-Register Counters Shift Registers in ABEL and PLDs 8.5.8 Shift Registers in VHDL Shift Registers in Verilog 752
756 758 762
Iterative versus Sequential Circuits Synchronous Design Methodology
8.7.1 Synchronous System Structure
Impediments to Synchronous Design
8.8.1 Clock Skew 8.8.2 Gating the Clock 8.8.3 Asynchronous Inputs
8.9 Synchronizer Failure and Metastability 769
8.9.1 8.9.3 8.9.4 8.9.6 8.9.7
Synchronizer Failure 8.9.2 Metastability Resolution Time Reliable Synchronizer Design Analysis of Metastable Timing 8.9.5 Better Synchronizers Other Synchronizer Designs Synchronizing High-Speed Data Transfers
References 788 Drill Problems 790 Exercises 792
xiv
Contents
2006 Pearson Education, Inc., Upper Saddle River, NJ. All rights reserved. This material is protected under all copyright laws as they currently exist. No portion of this material may be reproduced, in any form or by any means, without permission in writing by the publisher. For exclusive use of adopters of the book Digital Design Principles and Practices, Fourth Edition, by John F. Wakerly, ISBN 0-13-186389-4.
MEMORY, CPLDS, AND FPGAS
9.1 Read-Only Memory 800
799
9.1.1 9.1.2 9.1.4 9.1.5
9.2 9.3
Using ROMs for Random Combinational Logic Functions Internal ROM Structure 9.1.3 Two-Dimensional Decoding Commercial ROM Types ROM Control Inputs and Timing 9.1.6 ROM Applications
821
Read/Write Memory Static RAM 822
9.3.1 9.3.2 9.3.3 9.3.5
9.4
Static-RAM Inputs and Outputs Static-RAM Internal Structure Static-RAM Timing 9.3.4 Standard Static RAMs Synchronous SRAM
833
Dynamic RAM
9.4.1 Dynamic-RAM Structure 9.4.3 DDR SDRAMs
9.5
9.4.2 SDRAM Timing
840
Complex Programmable Logic Devices
9.5.1 Xilinx XC9500 CPLD Family 9.5.2 Function-Block Architecture 9.5.3 Input/Output-Block Architecture
9.6 Field-Programmable Gate Arrays 850
9.5.4 Switch Matrix
9.6.1 Xilinx XC4000 FPGA Family 9.6.2 Configurable Logic Block 9.6.3 Input/Output Block 9.6.4 Programmable Interconnect
References 859 Drill Problems 859 Exercises 860
INDEX
863