**SUMAN LATA TRIPATHI . SOBHIT SAXENA SANJEET K. SINHA · GOVIND S. PATEL** 

# **DIGITAL VLSI DESIGN AND SIMULATION WITH VERILOG**



**Digital VLSI Design and Simulation with Verilog**

## **Digital VLSI Design and Simulation with Verilog**

*Dr. Suman Lata Tripathi Lovely Professional University, Phagwara, Punjab, India*

*Dr. Sobhit Saxena Lovely Professional University, Phagwara, Punjab, India*

*Dr. Sanjeet Kumar Sinha Lovely Professional University, Phagwara, Punjab, India*

*Dr. Govind Singh Patel IIMT College of Engineering, Greater Noida, UP, India*

# WILEY

This edition first published 2022 © 2022 John Wiley & Sons Ltd.

All rights reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording or otherwise, except as permitted by law. Advice on how to obtain permission to reuse material from this title is available at<http://www.wiley.com/go/permissions>.

The right of Suman Lata Tripathi, Sobhit Saxena, Sanjeet Kumar Sinha, and Govind Singh Patel to be identified as the authors of this work has been asserted in accordance with law.

*Registered Office* John Wiley & Sons, Inc., 111 River Street, Hoboken, NJ 07030, USA

*Editorial Office* 9600 Garsington Road, Oxford, OX4 2DQ, UK

For details of our global editorial offices, customer services, and more information about Wiley products visit us at <www.wiley.com>.

Wiley also publishes its books in a variety of electronic formats and by print-on-demand. Some content that appears in standard print versions of this book may not be available in other formats.

#### *Limit of Liability/Disclaimer of Warranty*

While the publisher and authors have used their best efforts in preparing this work, they make no representations or warranties with respect to the accuracy or completeness of the contents of this work and specifically disclaim all warranties, including without limitation any implied warranties of merchantability or fitness for a particular purpose. No warranty may be created or extended by sales representatives, written sales materials or promotional statements for this work. The fact that an organization, website, or product is referred to in this work as a citation and/or potential source of further information does not mean that the publisher and authors endorse the information or services the organization, website, or product may provide or recommendations it may make. This work is sold with the understanding that the publisher is not engaged in rendering professional services. The advice and strategies contained herein may not be suitable for your situation. You should consult with a specialist where appropriate. Further, readers should be aware that websites listed in this work may have changed or disappeared between when this work was written and when it is read. Neither the publisher nor authors shall be liable for any loss of profit or any other commercial damages, including but not limited to special, incidental, consequential, or other damages.

#### *Library of Congress Cataloging-in-Publication Data*

Names: Tripathi, Suman Lata, author. | Saxena, Sobhit, author. | Sinha, Sanjeet Kumar, author. | Patel, Govind Singh, author.

Title: Digital VLSI design and simulation with Verilog / Suman Lata Tripathi, Sobhit Saxena, Sanjeet Kumar Sinha, Govind Singh Patel.

Description: Hoboken, NJ : John Wiley & Sons, 2022. | Includes bibliographical references and index.

Identifiers: LCCN 2021020790 (print) | LCCN 2021020791 (ebook) | ISBN 9781119778042 (hardback) | ISBN 9781119778066 (pdf) | ISBN 9781119778080 (epub) | ISBN 9781119778097 (ebook)

Subjects: LCSH: Integrated circuits--Very large scale integration--Design and construction. | Verilog (Computer hardware description language) Classification: LCC TK7874.75 .T75 2022 (print) | LCC TK7874.75 (ebook) |

DDC 621.39/5028553--dc23

LC record available at<https://lccn.loc.gov/2021020790>

LC ebook record available at <https://lccn.loc.gov/2021020791>

Cover image: © Raigvi/Shutterstock Cover design by Wiley

Set in 9.5/12.5 STIXTwoText by Integra Software Services Pvt. Ltd, Pondicherry, India

10 9 8 7 6 5 4 3 2 1

## **Contents**

#### **[Preface](#page-11-0)** *xi* **[About the Authors](#page-13-0)** *xiii*

- **1 [Combinational Circuit Design](#page-15-0)** *1*
- 1.1 [Logic Gates](#page-15-0) *1*
- 1.1.1 [Universal Gate Operation](#page-17-0) *3*
- 1.1.2 [Combinational Logic Circuits](#page-19-0) *5*
- 1.2 [Combinational Logic Circuits Using MSI](#page-20-0) *6*
- 1.2.1 [Adders](#page-20-0) *6*
- 1.2.2 [Multiplexers](#page--1-0) *12*
- 1.2.3 [De-multiplexer](#page--1-0) *14*
- 1.2.4 [Decoders](#page--1-0) *15*
- 1.2.5 [Multiplier](#page--1-0) *17*
- 1.2.6 [Comparators](#page--1-0) *18*
- 1.2.7 [Code Converters](#page--1-0) *19*
- 1.2.8 [Decimal to BCD Encoder](#page--1-0) *20* [Review Questions](#page--1-0) *21* [Multiple Choice Questions](#page--1-0) *22* [Reference](#page--1-0) *23*

#### **2 [Sequential Circuit Design](#page--1-0)** *25*

- 2.1 [Flip-flops \(F/F\)](#page--1-0) *25*
- 2.1.1 [S-R F/F](#page--1-0) *25*
- 2.1.2 [D F/F](#page--1-0) *26*
- 2.1.3 [J-K F/F](#page--1-0) *26*
- 2.1.4 [T F/F](#page--1-0) *28*
- 2.1.5 [F/F Excitation Table](#page--1-0) *29*
- 2.1.6 [F/F Characteristic Table](#page--1-0) *29*
- **vi** *Contents*
	- 2.2 [Registers](#page--1-0) *31*
	- 2.2.1 [Serial I/P and Serial O/P \(SISO\)](#page--1-0) *31*
	- 2.2.2 [Serial Input and Parallel Output \(SIPO\)](#page--1-0) *31*
	- 2.2.3 [Parallel Input and Parallel Output \(PIPO\)](#page--1-0) *32*
	- 2.2.4 [Parallel Input and Serial Output \(PISO\)](#page--1-0) *32*
	- 2.3 [Counters](#page--1-0) *33*
	- 2.3.1 [Synchronous Counter](#page--1-0) *33*
	- 2.3.2 [Asynchronous Counter](#page--1-0) *33*
	- 2.3.3 [Design of a 3-Bit Synchronous Up-counter](#page--1-0) *34*
	- 2.3.4 [Ring Counter](#page--1-0) *36*
	- 2.3.5 [Johnson Counter](#page--1-0) *37*
	- 2.4 [Finite State Machine \(FSM\)](#page--1-0) *37*
	- 2.4.1 [Mealy and Moore Machine](#page--1-0) *38*
	- 2.4.2 [Pattern or Sequence Detector](#page--1-0) *38* [Review Questions](#page--1-0) *41* [Multiple Choice Questions](#page--1-0) *41* [Reference](#page--1-0) *42*
	- **3 [Introduction to Verilog HDL](#page--1-0)** *43*
	- 3.1 [Basics of Verilog HDL](#page--1-0) *43*
	- 3.1.1 [Introduction to VLSI](#page--1-0) *43*
	- 3.1.2 [Analog and Digital VLSI](#page--1-0) *43*
	- 3.1.3 [Machine Language and HDLs](#page--1-0) *44*
	- 3.1.4 [Design Methodologies](#page--1-0) *44*
	- 3.1.5 [Design Flow](#page--1-0) *45*
	- 3.2 [Level of Abstractions and Modeling Concepts](#page--1-0) *45*
	- 3.2.1 [Gate Level](#page--1-0) *45*
	- 3.2.2 [Dataflow Level](#page--1-0) *47*
	- 3.2.3 [Behavioral Level](#page--1-0) *47*
	- 3.2.4 [Switch Level](#page--1-0) *47*
	- 3.3 [Basics \(Lexical\) Conventions](#page--1-0) *47*
	- 3.3.1 [Comments](#page--1-0) *47*
	- 3.3.2 [Whitespace](#page--1-0) *48*
	- 3.3.3 [Identifiers](#page--1-0) *48*
	- 3.3.4 [Escaped Identifiers](#page--1-0) *48*
	- 3.3.5 [Keywords](#page--1-0) *48*
	- 3.3.6 [Strings](#page--1-0) *49*
	- 3.3.7 [Operators](#page--1-0) *49*
	- 3.3.8 [Numbers](#page--1-0) *49*
	- 3.4 [Data Types](#page--1-0) *50*
	- 3.4.1 [Values](#page--1-0) *50*
- [3.4.2 Nets](#page--1-0) *50* 3.4.3 [Registers](#page--1-0) *51* 3.4.4 [Vectors](#page--1-0) *51* 3.4.5 [Integer Data Type](#page--1-0) *51* 3.4.6 [Real Data Type](#page--1-0) *51* 3.4.7 [Time Data Type](#page--1-0) *52* 3.4.8 [Arrays](#page--1-0) *52* 3.4.9 [Memories](#page--1-0) *52* 3.5 [Testbench Concept](#page--1-0) *53* [Multiple Choice Questions](#page--1-0) *53* [References](#page--1-0) *54* **4 [Programming Techniques in Verilog I](#page--1-0)** *55* 4.1 [Programming Techniques in Verilog I](#page--1-0) *55* 4.2 [Gate-Level Model of Circuits](#page--1-0) *55* 4.3 [Combinational Circuits](#page--1-0) *57* 4.3.1 [Adder and Subtractor](#page--1-0) *57* 4.3.2 [Multiplexer and De-multiplexer](#page--1-0) *66* 4.3.3 [Decoder and Encoder](#page--1-0) *71* 4.3.4 [Comparator](#page--1-0) *75* [Review Questions](#page--1-0) *77* [Multiple Choice Questions](#page--1-0) *77* [References](#page--1-0) *78* **5 [Programming Techniques in Verilog II](#page--1-0)** *79* 5.1 [Programming Techniques in Verilog II](#page--1-0) *79* 5.2 [Dataflow Model of Circuits](#page--1-0) *79* 5.3 [Dataflow Model of Combinational Circuits](#page--1-0) *80*
- 5.3.1 [Adder and Subtractor](#page--1-0) *80*
- 5.3.2 [Multiplexer](#page--1-0) *82*
- 5.3.3 [Decoder](#page--1-0) *85*
- 5.3.4 [Comparator](#page--1-0) *86*
- 5.4 [Testbench](#page--1-0) *87*
- 5.4.1 [Dataflow Model of the Half Adder and Testbench](#page--1-0) *88*
- 5.4.2 [Dataflow Model of the Half Subtractor and Testbench](#page--1-0) *89*
- 5.4.3 Dataflow Model of 2 × [1 Mux and Testbench](#page--1-0) *90*
- 5.4.4 Dataflow Model of 4 × [1 Mux and Testbench](#page--1-0) *91*
- 5.4.5 [Dataflow Model of 2-to-4 Decoder and Testbench](#page--1-0) *92* [Review Questions](#page--1-0) *93* [Multiple Choice Questions](#page--1-0) *94* [References](#page--1-0) *95*

#### **viii** *Contents*

#### **6 [Programming Techniques in Verilog II](#page--1-0)** *97*

- 6.1 [Programming Techniques in Verilog II](#page--1-0) *97*
- 6.2 [Behavioral Model of Combinational Circuits](#page--1-0) *98*
- 6.2.1 [Behavioral Code of a Half Adder Using If-else](#page--1-0) *98*
- 6.2.2 [Behavioral Code of a Full Adder Using Half Adders](#page--1-0) *99*
- 6.2.3 [Behavioral Code of a 4-bit Full Adder \(FA\)](#page--1-0) *100*
- 6.2.4 [Behavioral Model of Multiplexer Circuits](#page--1-0) *101*
- 6.2.5 [Behavioral Model of a 2-to-4 Decoder](#page--1-0) *104*
- 6.2.6 [Behavioral Model of a 4-to-2 Encoder](#page--1-0) *106*
- 6.3 [Behavioral Model of Sequential Circuits](#page--1-0) *108*
- 6.3.1 [Behavioral Modeling of the D-Latch](#page--1-0) *108*
- 6.3.2 [Behavioral Modeling of the D-F/F](#page--1-0) *109*
- 6.3.3 [Behavioral Modeling of the J-K F/F](#page--1-0) *110*
- 6.3.4 [Behavioral Modeling of the D-F/F Using J-K F/F](#page--1-0) *112*
- 6.3.5 [Behavioral Modeling of the T-F/F Using J-K F/F](#page--1-0) *113*
- 6.3.6 [Behavior Modeling of an S-R F/F Using J-K F/F](#page--1-0) *114* [Review Questions](#page--1-0) *115* [Multiple Choice Questions](#page--1-0) *115* [References](#page--1-0) *116*

#### **7 [Digital Design Using Switches](#page--1-0)** *117*

- 7.1 [Switch-Level Model](#page--1-0) *117*
- 7.2 [Digital Design Using CMOS Technology](#page--1-0) *118*
- 7.3 [CMOS Inverter](#page--1-0) *119*
- [7.4 Design and Implementation of the Combinational Circuit Using](#page--1-0)  Switches *120*
- 7.4.1 [Types of Switches](#page--1-0) *120*
- 7.4.2 [CMOS Switches](#page--1-0) *121*
- 7.4.3 [Resistive Switches](#page--1-0) *121*
- 7.4.4 [Bidirectional Switches](#page--1-0) *122*
- 7.4.5 [Supply and Ground Requirements](#page--1-0) *122*
- 7.5 [Logic Implementation Using Switches](#page--1-0) *123*
- 7.5.1 [Digital Design with a Transmission Gate](#page--1-0) *127*
- 7.6 [Implementation with Bidirectional Switches](#page--1-0) *127*
- 7.6.1 [Multiplexer Using Switches](#page--1-0) *127*
- 7.7 [Verilog Switch-Level Description with Structural-Level](#page--1-0)  Modeling *131*
- 7.8 [Delay Model with Switches](#page--1-0) *131* [Review Questions](#page--1-0) *132* [Multiple Choice Questions](#page--1-0) *133* [References](#page--1-0) *134*

*Contents* **ix**

- **8 [Advance Verilog Topics](#page--1-0)** *135*
- 8.1 [Delay Modeling and Programming](#page--1-0) *135*
- 8.1.1 [Delay Modeling](#page--1-0) *135*
- 8.1.2 [Distributed-Delay Model](#page--1-0) *135*
- 8.1.3 [Lumped-Delay Model](#page--1-0) *136*
- 8.1.4 [Pin-to-Pin-Delay Model](#page--1-0) *137*
- 8.2 [User-Defined Primitive \(UDP\)](#page--1-0) *138*
- 8.2.1 [Combinational UDPs](#page--1-0) *139*
- 8.2.2 [Sequential UDPs](#page--1-0) *142*
- 8.2.3 [Shorthands in UDP](#page--1-0) *144*
- 8.3 [Task and Function](#page--1-0) *144*
- 8.3.1 [Difference between Task and Function](#page--1-0) *144*
- 8.3.2 [Syntax of Task and Function Declaration](#page--1-0) *145*
- 8.3.3 [Invoking Task and Function](#page--1-0) *147*
- 8.3.4 [Examples of Task Declaration and Invocation](#page--1-0) *147*
- 8.3.5 [Examples of Function Declaration and Invocation](#page--1-0) *148* [Review Questions](#page--1-0) *148* [Multiple Choice Questions](#page--1-0) *149* [References](#page--1-0) *149*

**9 [Programmable and Reconfigurable Devices](#page--1-0)** *151*

- 9.1 [Logic Synthesis](#page--1-0) *151*
- 9.1.1 [Technology Mapping](#page--1-0) *151*
- 9.1.2 [Technology Libraries](#page--1-0) *152*
- 9.2 [Introduction of a Programmable Logic Device](#page--1-0) *152*
- 9.2.1 [PROM, PAL and PLA](#page--1-0) *153*
- 9.2.2 [SPLD and CPLD](#page--1-0) *154*
- 9.3 [Field-Programmable Gate Array](#page--1-0) *156*
- 9.3.1 [FPGA Architecture](#page--1-0) *158*
- 9.4 [Shannon's Expansion and Look-up Table](#page--1-0) *158*
- 9.4.1 [2-Input LUT](#page--1-0) *159*
- 9.4.2 [3-Input LUT](#page--1-0) *160*
- 9.5 [FPGA Families](#page--1-0) *161*
- 9.6 [Programming with FPGA](#page--1-0) *161*
- 9.6.1 [Introduction to Xilinx Vivado Design Suite for FPGA-Based](#page--1-0)  Implementations *163*
- 9.7 [ASIC and Its Applications](#page--1-0) *163* [Review Questions](#page--1-0) *164* [Multiple Choice Questions](#page--1-0) *164* [References](#page--1-0) *167*

**x** *Contents*

#### **10 [Project Based on Verilog HDLs](#page--1-0)** *169*

- 10.1 [Project Based on Combinational Circuit Design Using Verilog](#page--1-0)  HDL *171*
- 10.1.1 [Full Adder Using Switches at Structural Level Model](#page--1-0) *171*
- 10.1.2 [Ripple-Carry Full Adder \(RCFA\)](#page--1-0) *174*
- 10.1.3 [4-bit Carry Look-ahead Adder \(CLA\)](#page--1-0) *174*
- 10.1.4 [Design of a 4-bit Carry Save Adder \(CSA\)](#page--1-0) *176*
- 10.1.5 [2-bit Array Multiplier](#page--1-0) *177*
- 10.1.6 2 × [2 Bit Division Circuit Design](#page--1-0) *178*
- 10.1.7 [2-bit Comparator](#page--1-0) *179*
- 10.1.8 [16-bit Arithmetic Logic Unit](#page--1-0) *180*
- 10.1.9 Design and Implementation of  $4 \times 16$  Decoder Using  $2 \times 4$ Decoder *181*
- 10.2 [Project Based on Sequential Circuit Design Using Verilog HDL](#page--1-0) *182*
- 10.2.1 [Design of 4-bit Up/down Counter](#page--1-0) *182*
- 10.2.2 [LFSR Based 8-bit Test Pattern Generator](#page--1-0) *183*
- 10.3 [Counter Design](#page--1-0) *185*
- 10.3.1 [Random Counter that Counts Sequence like 2,4,6,8,2,8…and](#page--1-0)  so On *185*
- 10.3.2 [Use of Task at the Behavioral-Level Model](#page--1-0) *187*
- 10.3.3 [Traffic Signal Light Controller](#page--1-0) *188*
- 10.3.4 [Hamming Code\(h,k\) Encoder/Decoder](#page--1-0) *189* [Review Questions](#page--1-0) *192* [Multiple Choice Questions](#page--1-0) *192* [References](#page--1-0) *193*

#### **11 [SystemVerilog](#page--1-0)** *195*

- 11.1 [Introduction](#page--1-0) *195*
- 11.2 [Distinct Features of SystemVerilog](#page--1-0) *195*
- 11.2.1 [Data Types](#page--1-0) *196*
- 11.2.2 [Arrays](#page--1-0) *197*
- 11.2.3 [Typedef](#page--1-0) *199*
- 11.2.4 [Enum](#page--1-0) *200*
- 11.3 [Always\\_type](#page--1-0) *201*
- 11.4 [\\$log2c\(\) Function](#page--1-0) *202*
- 11.5 [System-Verilog as a Verification Language](#page--1-0) *203* [Review Questions](#page--1-0) *203* [Multiple Choice Questions](#page--1-0) *204* [Reference](#page--1-0) *204*

**[Index](#page--1-0)** *205*

## <span id="page-11-0"></span>**Preface**

Integrated circuits are now growing in importance in every electronic system that needs an efficient VLSI architecture design with low-power consumption, a compress chip area, speed, and operating frequency. The challenge for VLSI system designers is to optimize hardware-software integration for lowering the total cost of product acquisition. So, there is a demand for better technological solutions for advanced VLSI architectures that can be done through hardware description language (HDL). Verilog HDL is one of the programming languages that can provide better solutions in this new era of the VLSI industry. The prefabrication design and analysis of such advanced VLSI architecture can easily be implemented with Verilog HDL using available software tools such as Xilinx and Cadence.

This book mainly deals with the fundamental concepts of digital design along with their design verification with Verilog HDL. It will be a common source of knowledge for beginners as well as research-seeking students working in the area of VLSI design, covering fundamentals of digital design from switch level to FPGA-based implementation using hardware description language (HDL).

The book is summarized in 10 chapters. Chapters 1 and 2 describe the fundamental concepts behind digital circuit design including combinational and sequential circuit design. Chapters 3 to 8 focus on sequential and combinational circuit design using Verilog HDL at different levels of abstraction in Verilog coding. Chapter 9 includes implementation of any logic function using a programmable logic device such as PLD, CPLD, FPGA, etc. Chapter 10 covers a few real-time examples of digital circuit design using Verilog. Chapter 11 focuses on System Verilog, distinct features, computing Verilog and System Verilog with design example.

## <span id="page-13-0"></span>**About the Authors**

**Dr. Suman Lata Tripathi** completed her PhD in the area of microelectronics and VLSI from Motilal Nehru National Institute of Technology, Allahabad. She obtained her M.Tech in Electronics Engineering from Uttar Pradesh Technical University, Lucknow and B.Tech in Electrical Engineering from Purvanchal University, Jaunpur. She is associated with Lovely Professional University as a Professor with more than 17 years of experience in academics. She has published more than 55 research papers in refereed IEEE, Springer, and IOP science journals and conferences. She has organized several workshops, summer internships, and expert lectures for students. She has worked as a session chair, conference steering committee member, editorial board member, and reviewer in international/national IEEE/Springer Journal and conferences. She received the "Research Excellence Award" in 2019 at Lovely Professional University. She received the best paper at IEEE ICICS-2018. She has edited more than 12 books/1 book series in different areas of electronics and electrical engineering. She is associated with editing work for top publishers including Elsevier, CRC, Taylor and Francis, Wiley-IEEE, SP Wiley, Nova Science, and Apple Academic Press. She also works as series editor for, "Smart Engineering Systems" CRC Press, Taylor and Francis. She is associated as a senior member IEEE, Fellow IETE and Life member of ISC and is continuously involved in different professional activities along with her academic work. Her area of expertise includes microelectronics device modeling and characterization, low-power VLSI circuit design, VLSI design of testing, and advance FET design for IoT, Embedded System Design and biomedical applications etc.

**Dr. Sobhit Saxena** completed his PhD at "IIT Roorkee" from the Metallurgical & Materials Engineering Department. He has designed a new hybrid system of Li-ion battery and supercapacitor for energy storage applications. He worked as SEM (Scanning Electron Microscopy) operator for 4 years under the MHRD fellowship. He obtained his M.Tech in VLSI from Shobhit University, Meerut

#### **xiv** *About the Authors*

and B.E. from MIT Moradabad in Electronics and Communication Engineering. He has vast teaching experience of more than 10 years in various colleges and universities. Currently, he is working as Associate Professor in the School of Electronics and Electrical Engineering, Lovely Professional University. He has been awarded the "Perfect Award" four times consecutively (2007–2010) for achieving 100% results. He has published around 12 research papers in SCIindexed journals and reputed international conferences held at different IITs. His area of expertise includes nanomaterial synthesis and characterization, electrochemical analysis and modeling and simulation of CNT based interconnects for VLSI circuits.

**Dr. Sanjeet Kumar Sinha** completed a doctoral program in the Department of Electrical Engineering of the National Institute of Technology (NIT) Silchar. He obtained his M.Tech in Microelectronics and VLSI Design from NIT Silchar**.** He is associated with Lovely Professional University as an Associate Professor with more than 10 years of experience in academia. Over the years, he has developed an innovative approach to teaching and conducting research with undergraduates through creating and presenting course materials in both laboratory and classroom settings. He has published around 35 research papers in refereed journals/conferences including Elsevier, IEEE transaction, etc. He has published book chapters in Elsevier, Taylor & Francis, etc. His area of expertise includes microelectronics device modeling and characterization, low-power VLSI circuit design, VLSI design of testing, fabrication & characterization of CNT FET, etc.

**Dr. Govind Singh Patel** received his Masters degree in Instrumentation & Control Engineering from MD University, Rohtak, India. He has studied and been awarded a PhD in Electronics and Communication Engineering from Thapar University, Patiala, India. He is working as Professor in the Department of Electronics and Communication Engineering, IIMT Engineering College, Greater Noida, UP, India. He has published more than 62 papers in National and International Journals. He has also filed four Indian patents. His area of expertise includes VLSI signal processing, communication systems, low-power VLSI circuit design, VLSI design &testing and advance electronics, design for IoT, and agriculture applications. His one book titled "Smart Agriculture: Deep Learning, Machine Learning and IoT" is in the process of publication with CRC Taylor and Francis.

## <span id="page-15-0"></span>**1 Combinational Circuit Design**

This chapter describes the combinational logic circuits design and their implementation with logic gates, multiplexers, decoders, etc. Combinational circuits are the major block of any digital design or function [1]. So, a detailed overview before the design and analysis of digital circuit with Verilog modules, plays a significant role in hardware optimization to achieve the desired outcomes.

#### **1.1 Logic Gates**

Logic gates are very useful when performing a few basic operations in any digital computer system. These logic gates perform many operations in complex circuits and other control systems, e.g., basic operations like AND, OR, and NOT. The functionality of each basic gate as well as the extended version are discussed in this chapter.

#### **AND operation:**

It performs the AND operation. The circuit diagram of the N input AND operation is shown in Figure 1.1.



Figure 1.1 Symbol of an AND gate.

*Digital VLSI Design and Simulation with Verilog,* First Edition. Suman Lata Tripathi, Sobhit Saxena, Sanjeet Kumar Sinha, and Govind Singh Patel. © 2022 John Wiley & Sons Ltd. Published 2022 by John Wiley & Sons Ltd.

#### **2** *1 Combinational Circuit Design*

The AND gate may have N number of inputs and one output. If the number of inputs are N then  $N \ge 2$  conditions must be applied for input operation. Digital inputs are applied in terms of A, B, C……N, and the output is Y.

The mathematic equation is given below:

$$
Y = A AND B AND C AND D........AND N
$$
  
= A.B.C.D........N  
= ABCD........N

The truth table for an AND gate is provided in Table 1.1

| I/P            |                | O/P            |
|----------------|----------------|----------------|
| A              | В              | γ              |
| $\overline{0}$ | $\overline{0}$ | $\overline{0}$ |
| $\mathbf{0}$   | $\mathbf{1}$   | $\mathbf{0}$   |
| 1              | $\overline{0}$ | $\overline{0}$ |
| 1              | 1              | 1              |

**Table 1.1** T. Table of AND gate.

#### **OR operation:**

It performs OR operation. The symbol for an OR operation is shown in Figure 1.2.



Figure 1.2 Symbol for an OR gate.

The OR gate may have N number of inputs and one output. If the number of inputs are N then  $N \geq 2$  conditions must be applied for input operation. Digital inputs are applied in terms of A, B, C……N, and the output is Y.

The mathematic equation is given below:

Y = A OR B OR C OR D OR N = A+B+C+D + N ……… …… .

The truth table for an OR gate is provided in Table 1.2.

| I/P            |                | O/P            |  |
|----------------|----------------|----------------|--|
| A              | B              | γ              |  |
| $\overline{0}$ | $\overline{0}$ | $\overline{0}$ |  |
| $\overline{0}$ | 1              | 1              |  |
| 1              | $\overline{0}$ | $\mathbf{1}$   |  |
| 1              | 1              | 1              |  |

<span id="page-17-0"></span>**Table 1.2** Truth table of an OR gate.

#### **NOT operation:**

This is also called an inverter. The symbol for the NOT gate is shown in Figure 1.3. It has a single input device and it generates an inverted output. Table 1.3 describes the truth table of a NOT gate. The mathematical equation is written as:

$$
Y = NOT A
$$

$$
= \overline{A}
$$



Figure 1.3 Symbol for a NOT gate.





#### **1.1.1 Universal Gate Operation**

Universal gates are those in which any logical expression can be realized. The NAND and NOR gates are very popular and are widely used for realization of logical expressions. Therefore, these two NAND and NOR gates are used to implement other gates so these are called universal gates.

#### **4** *1 Combinational Circuit Design*

#### **NAND operation**

This is a universal gate. The operation NOT-AND is known as a NAND operation. It has N number of inputs and one output like other basic gates. However, two inputs and one output NAND gate are shown in Figure 1.4. Table 1.4 provides output values of a NAND gate in terms of inputs. The Boolean equation is given below:





Figure 1.4 Symbol for a NAND gate.

**Table 1.4** Truth table of a NAND gate.

| I/P          |                | O/P      |  |
|--------------|----------------|----------|--|
| A            | В              | γ        |  |
| $\mathbf{0}$ | $\overline{0}$ | 1        |  |
| $\mathbf{0}$ | 1              | 1        |  |
| 1            | $\overline{0}$ | 1        |  |
| 1            | 1              | $\Omega$ |  |

#### **NOR operation**

This is a universal gate. The operation NOT-OR is known as a NOR operation. It has N number of inputs and one output similar to basic gates. The symbol diagram of two inputs and one output is shown in Figure 1.5. Table 1.5 gives output values of a NOR gate in terms of inputs. The Boolean equation is given below:



**Figure 1.5** Symbol for a NOR gate.

| $I/P$          |                | O/P            |  |
|----------------|----------------|----------------|--|
| A              | В              | Υ              |  |
| $\overline{0}$ | $\theta$       | 1              |  |
| $\overline{0}$ | 1              | $\overline{0}$ |  |
| 1              | $\overline{0}$ | $\overline{0}$ |  |
| 1              | 1              | $\mathbf{0}$   |  |

<span id="page-19-0"></span>**Table 1.5** Truth table of a NOR gate.

#### **EX-OR Operation**

The operation EX-OR is used in many applications. It has N number of inputs and one output like other basic gates. The symbol diagram of two I/P and one O/P is shown in Figure 1.6. Table 1.6 provides the output values of an EX-OR gate in terms of inputs. Its mathematic equation is given below:

 $Y = A \oplus B$ 



**Figure 1.6** Symbol for a NAND gate.





#### **1.1.2 Combinational Logic Circuits**

This type of circuit depends upon the I/Ps in that particular instant of time. A memory element is not available. A combinational circuit may have a number of sub-systems as shown in Figure 1.7.

<span id="page-20-0"></span>

**Figure 1.7** Diagram of a combinational logic circuit.

There are many ways to design these combinational logic circuits. These include:

- 1. Boolean expression
- 2. Set of statement
- 3. Truth table

These designs are used to design combinational logic circuits. However, a number of methods are also available to simplify Boolean function. These include:

- a) Algebraic method
- b) K-map method
- c) Variable entered method
- d) Tabulation method

#### **Standard representation for logical functions**

Any logical functions can be represented in terms of their logical variables. Logical variables and their functions are in binary form. There are two standard forms generally being used in circuit designing.

- 1. Sum of product (SOP)
- 2. Product of sum (POS)

Apart from the form above, other forms are also available to design circuits. However, these forms are conveniently suitable for the design process. This is discussed in more detail in the next subsection.

### **1.2 Combinational Logic Circuits Using MSI**

This subsection describes the simplification and realization of the combinational logic circuits using gates. These methods are used to integrate complex functions in the form of IC. There are many devices are available such as adders, multiplexers, de-multiplexers, decoders, and multipliers.

#### **1.2.1 Adders**

An adder is a combinational logic circuit that performs arithmetic sums of binary numbers and produces corresponding outputs.

#### **Half Adder**

This is a basic adder that performs arithmetic sums of two inputs and gives the corresponding output in terms of sum and carry. The diagram of a H. adder is shown in Figure 1.8.



**Figure 1.8** Block diagram of a H. adder.

A and B are I/Ps and O/Ps and are the sum and carry of the H. adder. The truth table is given in Table 1.7.

**Table 1.7** Truth table of a half adder.

| A              | В        | <b>SUM</b> | <b>CARRY</b> |
|----------------|----------|------------|--------------|
| $\overline{0}$ | $\theta$ | $\Omega$   | 0            |
| $\mathbf{0}$   | 1        | 1          | $\theta$     |
| 1              | $\theta$ | 1          | $\theta$     |
| 1              | 1        | $\Omega$   |              |

Mathematical expressions for the H. adder are:

$$
Sum = \overline{AB} + \overline{AB}
$$

$$
= A \oplus B
$$

$$
Carry = \overline{AB}
$$

The circuit diagram of the H. adder is shown in Figure 1.9.



**Figure 1.9** Circuit diagram of a half adder.

#### **8** *1 Combinational Circuit Design*

#### **Full Adder**

This performs the arithmetic sum of three inputs and gives the corresponding two outputs in terms of sum and carry. A block diagram of the full adder is shown in Figure 1.10. Table 1.8 provides the truth table of a full adder circuit where output variables (Sum, Cout) are expressed in terms of input values.



**Figure 1.10** Block diagram of a full adder.

| A            | В              | Cin            | Sum            | Cout           |
|--------------|----------------|----------------|----------------|----------------|
| $\mathbf{0}$ | 0              | 0              | 0              | 0              |
| $\mathbf{0}$ | $\mathbf{0}$   | 1              | 1              | $\overline{0}$ |
| $\mathbf{0}$ | 1              | $\overline{0}$ | $\mathbf{1}$   | $\overline{0}$ |
| $\mathbf{0}$ | 1              | 1              | $\mathbf{0}$   | $\mathbf{1}$   |
| $\mathbf{1}$ | $\overline{0}$ | $\overline{0}$ | 1              | $\overline{0}$ |
| $\mathbf{1}$ | $\overline{0}$ | $\mathbf{1}$   | $\overline{0}$ | $\mathbf{1}$   |
| $\mathbf{1}$ | 1              | $\overline{0}$ | $\overline{0}$ | 1              |
| $\mathbf{1}$ | 1              | 1              | 1              | 1              |

**Table 1.8** Truth table of a full adder.

Boolean expressions for the F. adder are: K-Map for Sum:



 $Sum = A \oplus B \oplus Cin$ 

K-Map for Cout:



 $Cout = AB + BCin + Cin A$