## 清华版双语教学用书 # 数字逻辑与Verilog设计 (第3版) Fundamentals of Digital Logic with Verilog Design Third Edition Stephen Brown Zvonko Vranesic 著 罗 嵘 选译 清华大学出版社 清华版双语教学用书 Fundamentals of Digital Logic with Verilog Design Third Edition # 数字逻辑 与Verilog设计 (第3版) Stephen Brown Zvonko Vranesic 著 罗 嵘 选译 清华大学出版社 北京 #### Stephen Brown, Zvonko Vranesic #### Fundamentals of Digital Logic with Verilog Design, Third Edition ISBN: 9780073380544 Copyright © 2014 by McGraw-Hill Education. All Rights reserved. No part of this publication may be reproduced or transmitted in any form or by any means, electronic or mechanical, including without limitation photocopying, recording, taping, or any database, information or retrieval system, without the prior written permission of the publisher. This authorized Bilingual edition is jointly published by McGraw-Hill Education and Tsinghua University Press Limited. This edition is authorized for sale in the People's Republic of China only, excluding Hong Kong, Macao SAR and Taiwan. Copyright © 2014 by McGraw-Hill Education and Tsinghua University Press Limited. 版权所有。未经出版人事先书面许可,对本出版物的任何部分不得以任何方式或途径复制或传播,包括但不限于复印、录制、录音,或通过任何数据库、信息或可检索的系统。 本授权双语版由麦格劳-希尔(亚洲)教育出版公司和清华大学出版社有限公司合作出版。此版本经授权仅限于中华人民共和国境内(不包括中国香港、澳门特别行政区及中国台湾地区)销售发行。 版权 ②2014 由麦格劳-希尔(亚洲)教育出版公司与清华大学出版社有限公司所有。 北京市版权局著作权合同登记号 图字: 01-2013-8360 #### 本书封面贴有 McGraw-Hill Education 公司防伪标签,无标签者不得销售。 版权所有,侵权必究。侵权举报电话: 010-62782989 13701121933 #### 图书在版编目(CIP)数据 数字逻辑与 Verilog 设计: 第 3 版: 英、汉/(美)布朗(Brown,S.),(美)弗兰民斯克(Vranesic,Z.)著; 罗嵘选译.--北京: 清华大学出版社,2014 书名原文: Fundamentals of Digital Logic with Verilog Design, Third Edition 清华版双语教学用书 ISBN 978-7-302-36685-0 I. ①数··· Ⅱ. ①布··· ②弗··· ③罗··· Ⅲ. ①数字逻辑 - 双语教学 - 教材 - 英、汉 ②硬件描述语言 - 程序设计 - 双语教学 - 教材 - 英、汉 Ⅳ. ①TP302.2 ②TP312 中国版本图书馆 CIP 数据核字(2014)第 117283 号 责任编辑: 盛东亮 封面设计:常雪影 责任校对:时翠兰 责任印制:沈 露 出版发行:清华大学出版社 网 址: http://www.tup.com.cn, http://www.wgbook.com 地 址:北京清华大学学研大厦 A 座 耶 编:10008 社 总 机: 010-62770175 邮 购:010-627 投稿与读者服务: 010-62776969, c-service@tup. tsinghua. edu. cn 质量反馈: 010-62772015, zhiliang@tup. tsinghua. edu. cn 印刷者:清华大学印刷厂 装 订 者:三河市溧源装订厂 经 销:全国新华书店 开 本: 185mm×230mm 印 张: 54.75 字 数: 1206 千字 版 次: 2014 年 8 月第 1 版 印 次: 2014 年 8 月第1 次印刷 印 数:1~2000 定 **价:** 99.00 元 To Susan and Anne ### 序 本书英文原著的作者是多伦多大学的 Stephen Brown 和 Zvonko Vranesic 教授。他们长期从事相关教学和研究工作,具有丰富的经验。Stephen Brown 教授还是 Altera 公司全球大学计划的总负责人。 译者曾多次和 Stephen Brown 教授交流,并在 2010 年通过 Altera 公司大学培训计划,由 Stephen Brown 教授授予该公司的工程师培训资格。 此次有幸接受清华大学出版社盛东亮编辑邀请选译本书,给出书中每节的导读和相关术语, 又重温了一遍这本在国内外大学本科教育以及工程师培训中广泛使用的经典教科书。 本书共包括 11 章正文和两篇附录。为了让读者了解传统的人工进行数字设计的基本理论,前六章主要还是介绍数字逻辑的基础,且此部分内容可以作为一个学期的数字逻辑设计导论课程。由于数字系统的规模越来越大,采用计算机辅助设计工具来完成数字电路的设计势在必行,因此本书从第 2 章开始就将相关知识融入到基础理论中,让读者能在阅读和学习过程中潜移默化地掌握 Verilog 代码编写风格,达到事半功倍的效果。 此外,本书基本上每章正文最后都有问题求解案例,让读者了解如何求解典型的习题。因此,该书作为高等院校的本科数字逻辑设计课程的参考教材或者从事数字设计的工程师的参考书籍,是非常有效的。 该书第 2 版由夏宇闻等进行了全文翻译(2008年),本版书中的术语和定义的翻译参考了第 2 版。 罗 嵘 2014年4月于清华大学 ## **ABOUT THE AUTHORS** **Stephen Brown** received his B.A.Sc. degree in Electrical Engineering from the University of New Brunswick, Canada, and the M.A.Sc. and Ph.D. degrees in Electrical Engineering from the University of Toronto. He joined the University of Toronto faculty in 1992, where he is now a Professor in the Department of Electrical & Computer Engineering. He is also the Director of the worldwide University Program at Altera Corporation. His research interests include field-programmable VLSI technology and computer architecture. He won the Canadian Natural Sciences and Engineering Research Council's 1992 Doctoral Prize for the best Ph.D. thesis in Canada and has published more than 100 scientific research papers. He has won five awards for excellence in teaching electrical engineering, computer engineering, and computer science courses. He is a coauthor of two other books: *Fundamentals of Digital Logic with VHDL Design*, 3rd ed. and *Field-Programmable Gate Arrays*. **Zvonko Vranesic** received his B.A.Sc., M.A.Sc., and Ph.D. degrees, all in Electrical Engineering, from the University of Toronto. From 1963–1965 he worked as a design engineer with the Northern Electric Co. Ltd. in Bramalea, Ontario. In 1968 he joined the University of Toronto, where he is now a Professor Emeritus in the Departments of Electrical & Computer Engineering and Computer Science. During the 1978–1979 academic year, he was a Senior Visitor at the University of Cambridge, England, and during 1984–1985 he was at the University of Paris, 6. From 1995 to 2000 he served as Chair of the Division of Engineering Science at the University of Toronto. He is also involved in research and development at the Altera Toronto Technology Center. His current research interests include computer architecture and field-programmable VLSI technology. He is a coauthor of four other books: *Computer Organization and Embedded Systems*, 6th ed.; *Fundamentals of Digital Logic with VHDL Design*, 3rd ed.; *Microcomputer Structures*; and *Field-Programmable Gate Arrays*. In 1990, he received the Wighton Fellowship for "innovative and distinctive contributions to undergraduate laboratory instruction." In 2004, he received the Faculty Teaching Award from the Faculty of Applied Science and Engineering at the University of Toronto. He has represented Canada in numerous chess competitions. He holds the title of International Master. ### **PREFACE** This book is intended for an introductory course in digital logic design, which is a basic course in most electrical and computer engineering programs. A successful designer of digital logic circuits needs a good understanding of basic concepts and a firm grasp of the modern design approach that relies on computer-aided design (CAD) tools. The main goals of the book are (1) to teach students the fundamental concepts in classical manual digital design and (2) illustrate clearly the way in which digital circuits are designed today, using CAD tools. Even though modern designers no longer use manual techniques, except in rare circumstances, our motivation for teaching such techniques is to give students an intuitive feeling for how digital circuits operate. Also, the manual techniques provide an illustration of the types of manipulations performed by CAD tools, giving students an appreciation of the benefits provided by design automation. Throughout the book, basic concepts are introduced by way of examples that involve simple circuit designs, which we perform using both manual techniques and modern CAD-tool-based methods. Having established the basic concepts, more complex examples are then provided, using the CAD tools. Thus our emphasis is on modern design methodology to illustrate how digital design is carried out in practice today. #### TECHNOLOGY The book discusses modern digital circuit implementation technologies. The emphasis is on programmable logic devices (PLDs), which is the most appropriate technology for use in a textbook for two reasons. First, PLDs are widely used in practice and are suitable for almost all types of digital circuit designs. In fact, students are more likely to be involved in PLD-based designs at some point in their careers than in any other technology. Second, circuits are implemented in PLDs by end-user programming. Therefore, students can be provided with an opportunity, in a laboratory setting, to implement the book's design examples in actual chips. Students can also simulate the behavior of their designed circuits on their own computers. We use the two most popular types of PLDs for targeting of designs: complex programmable logic devices (CPLDs) and field-programmable gate arrays (FPGAs). We emphasize the use of a hardware description language in specifying the logic circuits, because the HDL-based approach is the most efficient design method to use in practice. We describe in detail the IEEE Standard Verilog HDL language and use it extensively in examples. #### SCOPE OF THE BOOK This edition of the book has been extensively restructured. All of the material that should be covered in a one-semester course is now included in Chapters 1 to 6. More advanced material is presented in Chapters 7 to 11. Chapter 1 provides a general introduction to the process of designing digital systems. It discusses the key steps in the design process and explains how CAD tools can be used to automate many of the required tasks. It also introduces the representation of digital information. Chapter 2 introduces the logic circuits. It shows how Boolean algebra is used to represent such circuits. It introduces the concepts of logic circuit synthesis and optimization, and shows how logic gates are used to implement simple circuits. It also gives the reader a first glimpse at Verilog, as an example of a hardware description language that may be used to specify the logic circuits. Chapter 3 concentrates on circuits that perform arithmetic operations. It discusses numbers and shows how they can be manipulated using logic circuits. This chapter illustrates how Verilog can be used to specify the desired functionality and how CAD tools provide a mechanism for developing the required circuits. Chapter 4 presents combinational circuits that are used as building blocks. It includes the encoder, decoder, and multiplexer circuits. These circuits are very convenient for illustrating the application of many Verilog constructs, giving the reader an opportunity to discover more advanced features of Verilog. Storage elements are introduced in Chapter 5. The use of flip-flops to realize regular structures, such as shift registers and counters, is discussed. Verilog-specified designs of these structures are included. Chapter 6 gives a detailed presentation of synchronous sequential circuits (finite state machines). It explains the behavior of these circuits and develops practical design techniques for both manual and automated design. Chapter 7 is a discussion of a number of practical issues that arise in the design of real systems. It highlights problems often encountered in practice and indicates how they can be overcome. Examples of larger circuits illustrate a hierarchical approach in designing digital systems. Complete Verilog code for these circuits is presented. Chapter 8 deals with more advanced techniques for optimized implementation of logic functions. It presents algorithmic techniques for optimization. It also explains how logic functions can be specified using a cubical representation as well as using binary decision diagrams. Asynchronous sequential circuits are discussed in Chapter 9. While this treatment is not exhaustive, it provides a good indication of the main characteristics of such circuits. Even though the asynchronous circuits are not used extensively in practice, they provide an excellent vehicle for gaining a deeper understanding of the operation of digital circuits in general. They illustrate the consequences of propagation delays and race conditions that may be inherent in the structure of a circuit. Chapter 10 presents a complete CAD flow that the designer experiences when designing, implementing, and testing a digital circuit. Chapter 11 introduces the topic of testing. A designer of logic circuits has to be aware of the need to test circuits and should be conversant with at least the most basic aspects of testing. Appendix A provides a complete summary of Verilog features. Although use of Verilog is integrated throughout the book, this appendix provides a convenient reference that the reader can consult from time to time when writing Verilog code. The electronic aspects of digital circuits are presented in Appendix B. This appendix shows how the basic gates are built using transistors and presents various factors that affect circuit performance. The emphasis is on the latest technologies, with particular focus on CMOS technology and programmable logic devices. #### WHAT CAN BE COVERED IN A COURSE Much of the material in the book can be covered in 2 one-quarter courses. A good coverage of the most important material can be achieved in a single one-semester, or even a one-quarter course. This is possible only if the instructor does not spend too much time teaching the intricacies of Verilog and CAD tools. To make this approach possible, we organized the Verilog material in a modular style that is conductive to self-study. Our experience in teaching different classes of students at the University of Toronto shows that the instructor may spend only three to four lecture hours on Verilog, describing how the code should be structured, including the use of design hierarchy, using scalar and vector variables, and on the style of code needed to specify sequential circuits. The Verilog examples given in the book are largely self-explanatory, and students can understand them easily. The book is also suitable for a course in logic design that does not include exposure to Verilog. However, some knowledge of Verilog, even at a rudimentary level, is beneficial to the students, and it is a great preparation for a job as a design engineer. #### **One-Semester Course** The following material should be covered in lectures: - Chapter 1—all sections. - Chapter 2—all sections. - Chapter 3—Sections 3.1 to 3.5. - Chapter 4—all sections. - Chapter 5—all sections. - Chapter 6—all sections. #### **One-Quarter Course** In a one-quarter course the following material can be covered: - Chapter 1—all sections. - Chapter 2—all sections. - Chapter 3—Sections 3.1 to 3.3 and Section 3.5. - Chapter 4—all sections. - Chapter 5—all sections. - Chapter 6—Sections 6.1 to 6.4. #### VERILOG Verilog is a complex language, which some instructors feel is too hard for beginning students to grasp. We fully appreciate this issue and have attempted to solve it. It is not necessary to introduce the entire Verilog language. In the book we present the important Verilog constructs that are useful for the design and synthesis of logic circuits. Many other language constructs, such as those that have meaning only when using the language for simulation purposes, are omitted. The Verilog material is introduced gradually, with more advanced features being presented only at points where their use can be demonstrated in the design of relevant circuits. The book includes more than 120 examples of Verilog code. These examples illustrate how Verilog is used to describe a wide range of logic circuits, from those that contain only a few gates to those that represent digital systems such as a simple processor. All of the examples of Verilog code presented in the book are provided on the Authors' website at www.eecg.toronto.edu/~brown/Verilog\_3e #### SOLVED PROBLEMS The chapters include examples of solved problems. They show how typical homework problems may be solved. #### HOMEWORK PROBLEMS More than 400 homework problems are provided in the book. Answers to selected problems are given at the back of the book. Solutions to all problems are available to instructors in the *Solutions Manual* that accompanies the book. #### POWERPOINT SLIDES AND SOLUTIONS MANUAL PowerPoint slides that contain all of the figures in the book are available on the Authors' website. Instructors can request access to these slides, as well as access to the Solutions Manual for the book, at: www.mhhe.com/brownvranesic #### **CAD Tools** Modern digital systems are quite large. They contain complex logic circuits that would be difficult to design without using good CAD tools. Our treatment of Verilog should enable the reader to develop Verilog code that specifies logic circuits of varying degrees of complexity. To gain proper appreciation of the design process, it is highly beneficial to implement the designs using commercially-available CAD tools. Some excellent CAD tools are available free of charge. For example, the Altera Corporation has its Quartus II CAD software, which is widely used for implementing designs in programmable logic devices such as FPGAs. The Web Edition of the Quartus II software can be downloaded from Altera's website and used free of charge, without the need to obtain a license. In previous editions of this book a set of tutorials for using the Quartus II software was provided in the appendices. Those tutorials can now be found on the Authors' website. Another set of useful tutorials about Quartus II can be found on Altera's University Program website, which is located at www.altera.com/education/univ. #### ACKNOWLEDGMENTS We wish to express our thanks to the people who have helped during the preparation of the book. Dan Vranesic produced a substantial amount of artwork. He and Deshanand Singh also helped with the preparation of the solutions manual. Tom Czajkowski helped in checking the answers to some problems. The reviewers, William Barnes, New Jersey Institute of Technology; Thomas Bradicich, North Carolina State University; James Clark, McGill University; Stephen DeWeerth, Georgia Institute of Technology; Sander Eller, Cal Poly Pomona; Clay Gloster, Jr., North Carolina State University (Raleigh); Carl Hamacher, Queen's University; Vincent Heuring, University of Colorado; Yu Hen Hu, University of Wisconsin; Wei-Ming Lin, University of Texas (San Antonio); Wayne Loucks, University of Waterloo; Kartik Mohanram, Rice University; Jane Morehead, Mississippi State University; Chris Myers, University of Utah; Vojin Oklobdzija, University of California (Davis); James Palmer, Rochester Institute of Technology; Gandhi Puvvada, University of Southern California; Teodoro Robles, Milwaukee School of Engineering; Tatyana Roziner, Boston University; Rob Rutenbar, Carnegie Mellon University; Eric Schwartz, University of Florida; Wen-Tsong Shiue, Oregon State University; Peter Simko, Miami University; Scott Smith, University of Missouri (Rolla); Arun Somani, Iowa State University; Bernard Svihel, University of Texas (Arlington); and Zeljko Zilic, McGill University provided constructive criticism and made numerous suggestions for improvements. The support of McGraw-Hill people has been exemplary. We truly appreciate the help of Raghu Srinivasan, Vincent Bradshaw, Darlene Schueller, Curt Reynolds, and Michael Lange. We are also grateful for the excellent support in the typesetting of the book that has been provided by Techsetters, Inc. Stephen Brown and Zvonko Vranesic ## **CONTENTS** | Chapter 1 Introduction 1 | 第1章 绪论 1 | |------------------------------------------------|--------------------| | 1.1 Digital Hardware 2 | 1.1 数字硬件 2 | | 1.1.1 Standard Chips 4 | 1.1.1 标准芯片 4 | | 1.1.2 Programmable Logic Devices 5 | 1.1.2 可编程逻辑器件 5 | | 1.1.3 Custom-Designed Chips 5 | 1.1.3 定制芯片 5 | | 1.2 The Design Process 6 | 1.2 设计过程 6 | | 1.3 Structure of a Computer 8 | 1.3 计算机结构 8 | | 1.4 Logic Circuit Design in This Book 8 | 1.4 本书中的逻辑电路设计 8 | | 1.5 Digital Representation of Information 11 | 1.5 信息的数字表示 11 | | 1.5.1 Binary Numbers 12 | 1.5.1 二进制数 12 | | 1.5.2 Conversion between Decimal and | 1.5.2 十进制和二进制系统之间的 | | Binary Systems 13 | 转换 13 | | 1.5.3 ASCII Character Code 14 | 1.5.3 ASCII 字符码 14 | | 1.5.4 Digital and Analog Information 16 | 1.5.4 数字和模拟信息 16 | | 1.6 Theory and Practice 16 | 1.6 理论和实践 16 | | Problems 18 | 习题 18 | | References 19 | 参考文献 19 | | Chapter 2 Introduction to Logic<br>Circuits 21 | 第2章 逻辑电路导论 21 | | 2.1 Variables and Functions 22 | 2.1 变量和函数 22 | | 2.2 Inversion 25 | 2.2 反相 25 | | 2.3 Truth Tables 26 | 2.3 真值表 26 | | 2.4 Logic Gates and Networks 27 | 2.4 逻辑门和网络 27 | | 2.4.1 Analysis of a Logic Network 29 | 2.4.1 逻辑网络的分析 29 | | 2.5 Boolean Algebra 33 | 2.5 布尔代数 33 | | 2.5.1 The Venn Diagram 37 | 2.5.1 维恩图 37 | | 2.5.2 Notation and Terminology 42 | 2.5.2 符号和术语 42 | | 2.5.3 Precedence of Operations 43 | 2.5.3 操作的优先级 43 | | 2.6 Synthesis Using AND, OR, and NOT | 2.6 用与、或和非门进行综合 43 | |-----------------------------------------------|---------------------------| | Gates 43 | | | 2. 6. 1 Sum-of-Products and Product-of- | 2.6.1 与或和或与形式 48 | | Sums Forms 48 | | | 2.7 NAND and NOR Logic Networks 54 | 2.7 与非和或非逻辑网络 54 | | 2.8 Design Examples 59 | 2.8 设计实例 59 | | 2.8.1 Three-Way Light Control 59 | 2.8.1 三路灯光控制 59 | | 2.8.2 Multiplexer Circuit 60 | 2.8.2 多路选择器电路 60 | | 2.8.3 Number Display 63 | 2.8.3 数字显示 63 | | 2.9 Introduction to CAD Tools 64 | 2.9 CAD 工具简介 64 | | 2.9.1 Design Entry 64 | 2.9.1 设计输入 64 | | 2.9.2 Logic Synthesis 66 | 2.9.2 逻辑综合 66 | | 2.9.3 Functional Simulation 67 | 2.9.3 功能仿真 67 | | 2.9.4 Physical Design 67 | 2.9.4 物理设计 67 | | 2.9.5 Timing Simulation 67 | 2.9.5 时序仿真 67 | | 2.9.6 Circuit Implementation 68 | 2.9.6 电路实现 68 | | 2.9.7 Complete Design Flow 68 | 2.9.7 完整的设计流程 68 | | 2.10 Introduction to Verilog 68 | 2.10 Verilog 简介 68 | | 2. 10. 1 Structural Specification of Logic | 2.10.1 逻辑电路的结构描述 70 | | Circuits 70 | | | 2.10.2 Behavioral Specification of Logic | 2.10.2 逻辑电路的行为描述 72 | | Circuits 72 | | | 2. 10. 3 Hierarchical Verilog Code 76 | 2.10.3 层次化 Verilog 代码 76 | | 2.10.4 How NOT to Write Verilog Code 78 | 2.10.4 如何不写 Verilog 代码 78 | | 2.11 Minimization and Karnaugh Maps 78 | 2.11 化简和卡诺图 78 | | 2.12 Strategy for Minimization 87 | 2.12 化简策略 87 | | 2.12.1 Terminology 87 | 2.12.1 术语 87 | | 2.12.2 Minimization Procedure 89 | 2.12.2 化简过程 89 | | 2.13 Minimization of Product-of-Sums Forms 91 | 2.13 或与形式的最简 91 | | 2.14 Incompletely Specified Functions 94 | 2.14 不完全确定函数 94 | | 2.15 Multiple-Output Circuits 96 | 2.15 多输出电路 96 | | 2.16 Concluding Remarks 101 | 2.16 小结 101 | | 2.17 Examples of Solved Problems 101 | 2.17 问题求解案例 101 | | Problems 111 | 习题 111 | | References 120 | 参考文献 120 | | | | 第3章 数的表示和算术电路 121 | Chapter 3 | Number | Representat | ion and | |-----------|----------|--------------|---------| | | Arithmet | tic Circuits | 121 | | 3.1 Positional Number Representation 122 | 3.1 数位表示法 122 | |---------------------------------------------|----------------------------| | 3.1.1 Unsigned Integers 122 | 3.1.1 无符号整数 122 | | 3.1.2 Octal and Hexadecimal | 3.1.2 八进制数和十六进制数的 | | Representations 123 | 表示 123 | | 3.2 Addition of Unsigned Numbers 125 | 3.2 无符号数的加法 125 | | 3.2.1 Decomposed Full-Adder 129 | 3.2.1 全加器的分解 129 | | 3.2.2 Ripple-Carry Adder 129 | 3.2.2 行波进位加法器 129 | | 3.2.3 Design Example 130 | 3.2.3 设计实例 130 | | 3.3 Signed Numbers 132 | 3.3 有符号数 132 | | 3.3.1 Negative Numbers 133 | 3.3.1 负数 133 | | 3.3.2 Addition and Subtraction 135 | 3.3.2 加法和减法 135 | | 3.3.3 Adder and Subtractor Unit 138 | 3.3.3 加法器和减法器单元 138 | | 3.3.4 Radix-Complement Schemes 139 | 3.3.4 基数补码方案 139 | | 3.3.5 Arithmetic Overflow 143 | 3.3.5 算术溢出 143 | | 3.3.6 Performance Issues 145 | 3.3.6 性能问题 145 | | 3.4 Fast Adders 145 | 3.4 快速加法器 145 | | 3.4.1 Carry-Lookahead Adder 146 | 3.4.1 超前进位加法器 146 | | 3.5 Design of Arithmetic Circuits Using CAD | 3.5 用 CAD 工具设计算术电路 151 | | Tools 151 | | | 3.5.1 Design of Arithmetic Circuits Using | 3.5.1 用原理图编辑工具设计算术 | | Schematic Capture 151 | 电路 151 | | 3.5.2 Design of Arithmetic Circuits Using | 3.5.2 用 Verilog 设计算术电路 152 | | Verilog 152 | | | 3.5.3 Using Vectored Signals 155 | 3.5.3 用向量信号 155 | | 3.5.4 Using a Generic Specification 156 | 3.5.4 用自动生成语句 156 | | 3.5.5 Nets and Variables in Verilog 158 | 3.5.5 Verilog 中的线网和变量 158 | | 3.5.6 Arithmetic Assignment | 3.5.6 算术赋值语句 159 | | Statements 159 | | | 3.5.7 Module Hierarchy in Verilog | 3.5.7 Verilog 中的模块层次化 163 | | Code 163 | | | 3.5.8 Representation of Numbers in Verilog | 3.5.8 Verilog 中数的表示 166 | | Code 166 | | 4.6.7 Tasks and Functions 229 | 3.6 Mul | tiplication 167 | 3.6 乘法 167 | |-----------|---------------------------------------|--------------------------| | 3.6.1 | Array Multiplier for Unsigned | 3.6.1 无符号数的阵列乘法 167 | | | Numbers 167 | | | 3.6.2 | Multiplication of Signed | 3.6.2 有符号数的乘法 169 | | | Numbers 169 | | | 3.7 Oth | er Number Representations 170 | 3.7 其他数的表示 170 | | 3.7.1 | Fixed-Point Numbers 170 | 3.7.1 定点数 170 | | 3.7.2 | Floating-Point Numbers 172 | 3.7.2 浮点数 172 | | 3.7.3 | Binary-Coded-Decimal | 3.7.3 二进制编码的十进制数 | | | Representation 174 | 表示 174 | | 3.8 Exa | mples of Solved Problems 178 | 3.8 问题求解案例 178 | | Problems | 184 | 习题 184 | | Reference | s 188 | 参考文献 188 | | Chapter 4 | Combinational-Circuit Building | 第4章 组合电路构件块 189 | | | Blocks 189 | | | 4.1 Mul | tiplexers 190 | 4.1 多路选择器 190 | | 4.1.1 | Synthesis of Logic Functions Using | 4.1.1 用多路选择器进行逻辑函数 | | | Multiplexers 193 | 综合 193 | | 4.1.2 | Multiplexer Synthesis Using Shannon's | 4.1.2 用香农展开进行多路选择器 | | | Expansion 196 | 综合 196 | | 4.2 Dec | oders 201 | 4.2 译码器 201 | | 4.2.1 | Demultiplexers 203 | 4.2.1 多路分解器 203 | | 4.3 Enc | oders 205 | 4.3 编码器 205 | | 4.3.1 | Binary Encoders 205 | 4.3.1 二进制编码器 205 | | 4.3.2 | Priority Encoders 205 | 4.3.2 优先编码器 205 | | 4.4 Cod | e Converters 208 | 4.4 码制转换器 208 | | 4.5 Arit | hmetic Comparison Circuits 208 | 4.5 算术比较电路 208 | | 4.6 Ver | ilog for Combinational Circuits 210 | 4.6 用 Verilog 表示组合电路 210 | | 4.6.1 | The Conditional Operator 210 | 4.6.1 条件操作符 210 | | 4.6.2 | The If-Else Statement 212 | 4.6.2 if-else 语句 212 | | 4.6.3 | The Case Statement 215 | 4.6.3 case 语句 215 | | 4.6.4 | The For Loop 221 | 4.6.4 for 循环语句 221 | | 4.6.5 | Verilog Operators 223 | 4.6.5 Verilog 操作符 223 | | 4.6.6 | The Generate Construct 228 | 4.6.6 生成结构 228 | 4.6.7 任务和函数 229 | 4.7 Concluding Remarks 232 | 4.7 小结 232 | |------------------------------------------|----------------------------| | 4.8 Examples of Solved Problems 233 | 4.8 问题求解案例 233 | | Problems 243 | 习题 243 | | References 246 | 参考文献 246 | | Chapter 5 Flip-Flops, Registers, and | 第5章 触发器、寄存器和计数器 247 | | Counters 247 | | | 5.1 Basic Latch 249 | 5.1 基本锁存器 249 | | 5.2 Gated SR Latch 251 | 5.2 门控 SR 锁存器 251 | | 5.2.1 Gated SR Latch with NAND | 5.2.1 用与非门实现的门控 SR | | Gates 253 | 锁存器 253 | | 5.3 Gated D Latch 253 | 5.3 门控 D 锁存器 253 | | 5.3.1 Effects of Propagation Delays 255 | 5.3.1 传输延时的影响 255 | | 5.4 Edge-Triggered D Flip-Flops 256 | 5.4 边沿触发的 D 触发器 256 | | 5.4.1 Master-Slave D Flip-Flop 256 | 5.4.1 主从 D 触发器 256 | | 5.4.2 Other Types of Edge-Triggered | 5.4.2 其他类型的边沿触发的 | | D Flip-Flops 258 | D 触发器 258 | | 5.4.3 D Flip-Flops with Clear and | 5.4.3 带清零和置位的 D 触发器 260 | | Preset 260 | | | 5.4.4 Flip-Flop Timing Parameters 263 | 5.4.4 触发器的时间参数 263 | | 5.5 T Flip-Flop 263 | 5.5 T触发器 263 | | 5.6 JK Flip-Flop 264 | 5.6 JK 触发器 264 | | 5.7 Summary of Terminology 266 | 5.7 术语小结 266 | | 5.8 Registers 267 | 5.8 寄存器 267 | | 5.8.1 Shift Register 267 | 5.8.1 移位寄存器 267 | | 5.8.2 Parallel-Access Shift Register 267 | 5.8.2 并行存取的移位寄存器 267 | | 5.9 Counters 269 | 5.9 计数器 269 | | 5.9.1 Asynchronous Counters 269 | 5.9.1 异步计数器 269 | | 5.9.2 Synchronous Counters 272 | 5.9.2 同步计数器 272 | | 5.9.3 Counters with Parallel Load 276 | 5.9.3 可并行置数的计数器 276 | | 5.10 Reset Synchronization 278 | 5.10 同步复位 278 | | 5.11 Other Types of Counters 280 | 5.11 其他类型的计数器 280 | | 5. 11. 1 BCD Counter 280 | 5.11.1 BCD 计数器 280 | | 5.11.2 Ring Counter 280 | 5.11.2 环形计数器 280 | | 5.11.3 Johnson Counter 283 | 5.11.3 约翰森(Johnson)计数器 283 | | 5.11.4 Remarks on Counter Design 283 | 5.11.4 计数器设计小结 283 | |---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5.12 Using Storage Elements with CAD | 5.12 CAD 工具中存储单元的使用 284 | | Tools 284 | | | 5.12.1 Including Storage Elements in | 5.12.1 在原理图中加入存储 | | Schematics 284 | 单元 284 | | 5.12.2 Using Verilog Constructs for Storage | 5.12.2 用 Verilog 代码实现存储 | | Elements 285 | 单元 285 | | 5.12.3 Blocking and Non-Blocking | 5.12.3 阻塞和非阻塞赋值 288 | | Assignments 288 | | | 5.12.4 Non-Blocking Assignments for | 5.12.4 组合电路的非阻塞赋值 293 | | Combinational Circuits 293 | | | 5. 12. 5 Flip-Flops with Clear | 5.12.5 具有清零功能的触发器 293 | | Capability 293 | | | 5.13 Using Verilog Constructs for Registers | 5.13 用 Verilog 代码实现寄存器和 | | and Counters 295 | 计数器 295 | | 5.13.1 Flip-Flops and Registers with | 5.13.1 具有使能输入的触发器和 | | Enable Inputs 300 | 寄存器 300 | | 5.13.2 Shift Registers with Enable | 5.13.2 具有使能输入的移位 | | Inputs 302 | 寄存器 302 | | 5.14 Design Example 302 | 5.14 设计案例 302 | | 5. 14. 1 Reaction Timer 302 | 5.14.1 反应计时器 302 | | 5. 14. 2 Register Transfer Level (RTL) | 5.14.2 寄存器传输级(RTL) | | Code 309 | 代码 309 | | 5.15 Timing Analysis of Flip-flop | 5.15 触发器电路的时序分析 310 | | Circuits 310 | | | 5. 15. 1 Timing Analysis with Clock | 5.15.1 有时钟漂移的时序分析 312 | | Skew 312 | S 0 194 | | 5.16 Concluding Remarks 314 | 5.16 小结 314 | | 5. 17 Examples of Solved Problems 315 | 5.17 问题求解案例 315 | | Problems 321 | 习题 321 | | References 329 | 参考文献 329 | | Chapter 6 Synchronous Sequential | 第6章 同步时序电路 331 | | Circuits 331 | and the second s | | 6.1 Basic Design Steps 333 | 6.1 基本设计 | 6.1.1 状态图 333 6.1.1 State Diagram 333